ayodvr/laravel-webhook-manager
最新稳定版本:v1.2.0
Composer 安装命令:
composer require ayodvr/laravel-webhook-manager
包简介
A reusable package for Laravel that allows developers to receive, process, and manage incoming webhooks reliably.
README 文档
README
A reusable Laravel package for receiving, processing, and managing incoming webhooks reliably. It handles webhooks from multiple providers, prevents duplicates, and ensures high reliability for critical backend systems.
Features
- Signature Verification: Ensures incoming requests are authentic using HMAC-SHA256.
- Automatic Duplicate Prevention: Uses unique provider IDs (Stripe ID, GitHub Delivery ID, etc.) or signatures to prevent duplicate processing.
- Reliable Processing: Queue-based asynchronous processing with automatic status tracking and retries.
- Event Dispatching: Fires Laravel events (
WebhookReceived) for easy integration. - Configurable: Customizable route prefix, retry intervals, queue names, and signature secrets.
- Multiple Providers: Built-in support for Paystack, Stripe, PayPal, GitHub, and more.
- Interactive Demo: Includes a built-in dashboard to simulate and monitor webhooks.
Installation
Requirements
- PHP: ^8.2
- Laravel: ^10.0 || ^11.0 || ^12.0
Via Composer
composer require ayodvr/laravel-webhook-manager
Publish Configuration
Publish the configuration file:
php artisan vendor:publish --tag=webhook-config
Publish Migration
Run the migration to create the webhook events table:
php artisan migrate
Set your webhook signature secret in your .env file:
WEBHOOK_SIGNATURE_SECRET=your-secret-key-here
Interactive Demo
The package comes with a built-in demo dashboard to help you test and visualize the webhook flow.
- Start the server:
php artisan serve
- Access the dashboard:
Navigate to
http://127.0.0.1:8000/demoin your browser. - Simulate Webhooks: Click the "Simulate Paystack Payment" button to trigger a mock signed webhook and watch it process in real-time.
Usage
Receiving Webhooks
Webhooks are automatically handled at the /webhooks/{provider} route (configurable via route_prefix). For example:
- Paystack:
POST /webhooks/paystack - Stripe:
POST /webhooks/stripe - PayPal:
POST /webhooks/paypal
Listening to Webhooks
Listen to the WebhookReceived event in your EventServiceProvider or using a Listener:
<?php namespace App\Listeners; use Cybrox\WebhookManager\Events\WebhookReceived; class ProcessWebhook { public function handle(WebhookReceived $event): void { $webhookEvent = $event->webhookEvent; // Process based on provider if ($webhookEvent->provider === 'paystack') { $payload = json_decode($webhookEvent->payload, true); // Your logic here... } } }
Configuration Options
Edit config/webhook-manager.php to customize behavior:
return [ 'route_prefix' => env('WEBHOOK_ROUTE_PREFIX', 'webhooks'), 'signature_secret' => env('WEBHOOK_SIGNATURE_SECRET'), 'max_attempts' => env('WEBHOOK_MAX_ATTEMPTS', 3), 'queue' => env('WEBHOOK_QUEUE', 'webhooks'), 'providers' => ['stripe', 'paypal', 'github', 'paystack'], ];
Testing
Run the test suite:
php artisan test
Contributing
Contributions are welcome! Please see the contributing guide for more details.
License
This package is open-sourced software licensed under the MIT license.
统计信息
- 总下载量: 4
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-11-16