Download the PHP package muscobytes/laravel-cdek-webhook without Composer
On this page you can find all versions of the php package muscobytes/laravel-cdek-webhook. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download muscobytes/laravel-cdek-webhook
More information about muscobytes/laravel-cdek-webhook
Files in muscobytes/laravel-cdek-webhook
Package laravel-cdek-webhook
Short Description Create endpoint in your Laravel application for CDEK with zero effort.
License MIT
Homepage https://github.com/muscobytes/laravel-cdek-webhook
Informations about the package laravel-cdek-webhook
CDEK webhook handler for Laravel
Установка
Настройка
Настройка пакета заключается в определении URL для обработки запросов от CDEK. Это можно сделать двумя способами: установка переменной через файл .env
или определение переменной в файле config/cdek.php
.
.env
В файл .env
необходимо добавить следующую строку:
config/cdek.php
Для определения URL посредством файла конфигурации необходимо опубликовать файл конфигурации:
В файле config/cdek.php
необходимо определить значение для ключа webhook_url
:
Использование
При выполнении запроса на URL, определенный в настройках, будет инициирован вызов одного из событий:
DownloadPhotoEvent::class
OrderStatusEvent::class
PrealertEvent::class
PrintFormEvent::class
Для каждого из вышеперечисленных событий вы можете создать собственный обработчик события.
Например, для события DownloadPhotoEvent::class
:
В созданном файле app/Listeners/DownloadPhotoListener.php
необходимо определить метод handle
:
В свойстве $message
объекта DownloadPhotoEvent
находится DTO с данными запроса от СДЭК.
- для
DownloadPhotoEvent
это Muscobytes\CdekWebhook\Messages\DownloadPhotoMessage - для
OrderStatusEvent
это Muscobytes\CdekWebhook\Messages\OrderStatusMessage - для
PrealertEvent
это Muscobytes\CdekWebhook\Messages\PrealertClosedMessage - для
PrintFormEvent
это Muscobytes\CdekWebhook\Messages\PrintFormMessage
Набор свойств DTO соответствует набору полей, описанных в документации СДЭК.
Для того чтобы зарегистрировать обработчик события, необходимо добавить в массив $listen
класс события и присвоить ему класс обработчика события в файле app/Providers/EventServiceProvider.php
: