weblabnl / laravel-webhook-call
:package_description
Installs: 2 822
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 3
Requires
- php: ^8.0
- illuminate/contracts: ^9.0|^10.0
- spatie/laravel-package-tools: ^1.13.0
- spatie/laravel-webhook-server: ^3.4
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^6.0
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^7.0
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.1
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5
- dev-main
- 0.3.1
- 0.3.0
- v0.2.2
- v0.2.1
- v0.2.0
- v0.1.0
- dev-feature/WEB-10144
- dev-dependabot/github_actions/stefanzweifel/git-auto-commit-action-5
- dev-dependabot/github_actions/actions/checkout-4
- dev-dependabot/github_actions/aglipanci/laravel-pint-action-2.3.0
- dev-laravel_10_support
- dev-feature/WEB-8611
- dev-feature/listener_fix
This package is not auto-updated.
Last update: 2024-12-27 21:52:11 UTC
README
A webhook is a way for an app to provide other applications with real-time information. When an event occurs in the app, a notification is sent in the form of an HTTP request to registered webhooks.
This package allows you to easily store webhook endpoints and events in a database, while the results of the webhook calls are logged in the database. It is built on top of the excellent spatie/laravel-webhook-server package, that provides among things functionality to sign calls and to retry failed calls. This package makes it easier and adds functionality for managing and tracking webhooks and their associated data.
With this package, you can easily manage and track your webhooks, making it possible to build interfaces for managing webhooks on top of this.
Installation
You can install the package via composer:
composer require weblabnl/laravel-webhook-call
You can publish the config file with:
php artisan vendor:publish --provider="Weblab\WebhookCall\WebhookCallServiceProvider"
This is the contents of the file that will be published at config/webhook-call.php
. You can change the default values
to your needs and bring your own top model objects.
return [ // the model to use for the webhook calls 'models' => [ // The model that should be used to store the webhook endpoint data. 'webhook' => \Weblab\WebhookCall\Models\Webhook::class, // The model that should be used to store the webhook event data. 'webhook_event' => \Weblab\WebhookCall\Models\WebhookEvent::class, // The model that should be used to store the webhook log data. 'webhook_log' => \Weblab\WebhookCall\Models\WebhookLog::class, ], ];
After installing the package, you can run the migrations using:
php artisan migrate
Usage
Calling a webhook is as simple as:
// fetch a webhook from the database $webhook = Webhook::find(1); // call the webhook WebhookCall::create() ->wehbook($webhook) ->dispatch();
Webhook logging
In addition to storing webhook endpoints and events in the database, this package also provides detailed logs of webhook call results. Both successful and failed results are stored in the database and include information such as the endpoint response code, response, and the original payload. This makes it easy to track and troubleshoot any issues with your webhooks.
Providing the webhook event for the log
When you call a webhook, you can provide an event that will be stored in the log.
// fetch a webhook from the database $webhook = Webhook::find(1); $webhookEvent = $webhook->webhookEvents() ->where('name', 'order.created') ->first(); // call the webhook WebhookCall::create() ->wehbook($webhook) ->webhookEvent($webhookEvent) ->dispatch();
After this, the webhook event is available in any log entries related to this webhook call as well
Entities related to the webhook data
When you call a webhook, you can provide an entity that will be stored in the log.
// fetch a webhook from the database $webhook = Webhook::find(1); // fetch an entity from the database $entity = Order::find(1); // call the webhook WebhookCall::create() ->wehbook($webhook) ->entity($entity) ->dispatch();
After this, the entity is available in any log entries related to this webhook call as well
More options
More available options for testing and the WebhookCall class can be found on the spatie/laravel-webhook-server github page
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Security
If you discover any security-related issues, please email development@weblab.nl instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.