obrignoni / webhooks
This Laravel package helps you organize, secure and map webhooks to events.
This package's canonical repository appears to be gone and the package has been frozen as a result. Email us for help if needed.
Installs: 616
Dependents: 0
Suggesters: 0
Security: 0
Stars: 13
Watchers: 1
Forks: 4
Open Issues: 2
pkg:composer/obrignoni/webhooks
Requires
- laravel/framework: ^5.3
Requires (Dev)
- mockery/mockery: ^0.9.5
- phpunit/phpunit: ~5.4
This package is not auto-updated.
Last update: 2020-02-27 21:17:11 UTC
README
This Laravel package helps you organize, secure and map webhooks to events.
Installation
To get started, install Laravel Webhooks via the Composer package manager:
composer require obrignoni/webhooks
Next, register the Webhooks service provider in the providers array of your config/app.php configuration file:
Obrignoni\Webhooks\WebhooksServiceProvider::class,
Why a webhooks package?
I want to...
- integrate my applications with webhooks from multiple services.
- keep the webhooks organized and secure.
- map webhook events to Laravel events.
Usage
Lets take Github Webhooks for example.
A Github webhook payload looks like this...
POST /payload HTTP/1.1
Host: localhost:4567
X-Github-Delivery: 72d3162e-cc78-11e3-81ab-4c9367dc0958
User-Agent: GitHub-Hookshot/044aadd
Content-Type: application/json
Content-Length: 6615
X-GitHub-Event: issues
{
  "action": "opened",
  "issue": {
    "url": "https://api.github.com/repos/octocat/Hello-World/issues/1347",
    "number": 1347,
    ...
  },
  "repository" : {
    "id": 1296269,
    "full_name": "octocat/Hello-World",
    "owner": {
      "login": "octocat",
      "id": 1,
      ...
    },
    ...
  },
  "sender": {
    "login": "octocat",
    "id": 1,
    ...
  }
}
Notice the X-GitHub-Event header contains issues, one of Github Events.
We can use an artisan command to setup a webhook for github.
php artisan make:webhook github
This will create the App\Http\Webhooks\Github class.
The webhook class extends a WebhookRequest which also extends a FormRequest and adds a couple of extra configuration options.
Lets take a look at the generated class.
<?php namespace App\Http\Webhooks; use Obrignoni\Webhooks\Http\WebhookRequest; class Github extends WebhookRequest { protected $eventField = ''; protected $events = []; protected $authorization = null; public function authorize() { // Authorize the webhook the same way you would with a FormRequest. return false; } public function rules() { return [ ]; } }
We can setup our Github webhook like this...
<?php namespace App\Http\Webhooks; use Obrignoni\Webhooks\Authorization\GithubAuthorization; use Obrignoni\Webhooks\Http\WebhookRequest; class Github extends WebhookRequest { protected $eventField = 'X-GitHub-Event'; protected $authorization = GithubAuthorization::class; }
Event Field
The event field is the request parameter or header that contains the event value.
Authorization Handler
The authorization handler can contain the logic to authorize the request. It should return a boolean value.
The $authorization is set to the GithubAuthorization handler that is included with this package.
Using an authorization handler is optional and it can be used in lieu of the authorize.
Mapped Events
You use the $events array to map each webhook event to an event class. If left empty, event names will be automatically
transformed to studly cased classes. For a Github webhook, the pull_request event will be transformed to
App\Events\GithubPullRequest.
Here as an example of how to set up custom events.
<?php namespace App\Http\Webhooks; use Obrignoni\Webhooks\Authorization\GithubAuthorization; use Obrignoni\Webhooks\Http\WebhookRequest; class Github extends WebhookRequest { protected $field = 'X-GitHub-Event'; protected $authorization = GithubAuthorization::class; protected $events = [ 'issue_comment' => 'App\Events\SomebodyMadeACommentOnGithub', 'pull_request' => 'App\Events\SomebodySubmittedAPullRequest', ]; }
Webhook Requests Extend Form Requests
You have the option of using the authorize and rules methods just like Form Requests.