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!
Install the composer package.
composer require justbetter/laravel-magento-webhooksPublish the configuration of the package.
php artisan vendor:publish --provider="JustBetter\MagentoWebhooks\ServiceProvider" --tag=configRun the migration for the event logs.
php artisan migrateThe 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.
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"The following configuration can be used in order to successfully work with webhooks.
| Key | Value |
|---|---|
| Payload URL | http://localhost/magento/webhook |
| Method | POST |
| Content Type | application/json |
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 an event in Laravel can be easily done in a few steps.
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.
Open your magento-webhooks configuration and add an event.
Note: Be sure that the event
MyWebhookEventmatches yourjsonconfiguration above.
<?php
return [
// ...
'events' => [
// single event
'MyWebhookEvent' => \App\Events\MyLaravelEvent::class,
// or multiple events
'MyWebhookEvent' => [
\App\Events\MyLaravelEvent1::class,
\App\Events\MyLaravelEvent2::class,
],
],
];Run the following command to generate an event listener.
php artisan make:listener MyLaravelEventListenerUpdate your EventServiceProvider to add your event and listener.
<?php
protected $listen = [
// ...
MyLaravelEvent::class => [
MyLaravelEventListener::class,
],
];In order to test the package functionalities, run the following command:
composer testPlease see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.