justbetter / laravel-magento-webhooks
A Laravel package to listen to webhooks dispatched from mageplaza/webhooks.
Installs: 7 758
Dependents: 1
Suggesters: 0
Security: 0
Stars: 13
Watchers: 4
Forks: 1
Open Issues: 0
Type:package
Requires
- php: ^8.1
- laravel/framework: ^10.0|^11.0
Requires (Dev)
- larastan/larastan: ^2.9
- laravel/pint: ^1.6
- orchestra/testbench: ^8.0|^9.0
- phpstan/phpstan-mockery: ^1.1
- phpunit/phpunit: ^10.5
README
Laravel Magento Webhooks
This package has an endpoint to receive events from the Mageplaza Webhooks module. It can be configured to dispatch Laravel events when a specific event in Magento has been triggered.
Also check out our other Laravel Magento packages! We also have a Magento Client to easily connect Laravel to Magento!
Installation
Install the composer package.
composer require justbetter/laravel-magento-webhooks
Setup
Publish the configuration of the package.
php artisan vendor:publish --provider="JustBetter\MagentoWebhooks\ServiceProvider" --tag=config
Run the migration for the event logs.
php artisan migrate
Configuration
The events
array located in your configuration can be used to add events.
By default, no middleware is present on the webhook url. This can be changed by adding your own middleware to
the middleware
array, like authentication.
Schedule clean up command
In order to keep the database from filling up, schedule the CleanLogsCommand
in your Kernel.
use JustBetter\MagentoWebhooks\Commands\CleanLogsCommand; $schedule->command(CleanLogsCommand::class)->daily();
This command supports usage of a custom date. You can pass a date as a parameter which will clean logs from before this date. This date defaults to one month prior.
php artisan magento:webhooks:clean-logs --date="yesterday"
Magento Webhook Configuration
The following configuration can be used in order to successfully work with webhooks.
You can configure the body any way you like as long as an event
key is present. The event
can be named anything.
{ "event": "MyWebhookEvent", "some_key": "some_value" }
Adding events
Adding an event in Laravel can be easily done in a few steps.
Create an event
Create a new event in Laravel and be sure to extend our WebhookEvent
.
<?php namespace App\Events; use JustBetter\MagentoWebhooks\Events\WebhookEvent; class MyLaravelEvent extends WebhookEvent { // }
This way, you will have a constructor for $event
and $data
.
Update your configuration
Open your magento-webhooks
configuration and add an event.
Note: Be sure that the event
MyWebhookEvent
matches yourjson
configuration above.
<?php return [ // ... 'events' => [ // single event 'MyWebhookEvent' => \App\Events\MyLaravelEvent::class, // or multiple events 'MyWebhookEvent' => [ \App\Events\MyLaravelEvent1::class, \App\Events\MyLaravelEvent2::class, ], ], ];
Create a listener
Run the following command to generate an event listener.
php artisan make:listener MyLaravelEventListener
Register your event and listener
Update your EventServiceProvider
to add your event and listener.
<?php protected $listen = [ // ... MyLaravelEvent::class => [ MyLaravelEventListener::class, ], ];
Testing
In order to test the package functionalities, run the following command:
composer test
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.