Skip to content

Latest commit

 

History

History
55 lines (41 loc) · 1.16 KB

readme.md

File metadata and controls

55 lines (41 loc) · 1.16 KB

Github webhook php

composer install

Sample of usages

use Illuminate\Http\Request;

$webhook = (new \WebhookHanlder\GithubWebhook(new Request))
  ->setCredentials(['secret_key' => 'my-secret-key'])
  ->handle()
  ->getResponse();

What is happen behind request during webhook? Lets simulate using fake payload transport via curl on localhost:8080.

php -S localhost:8080 

Generate mock secret key and payload

php -r "echo hash_hmac('sha1','{"data": "sample_response"}','testing');"

set credentials by using testing in this case.

use Illuminate\Http\Request;

$webhook = (new \WebhookHanlder\GithubWebhook(new Request))
  ->setCredentials(['secret_key' => 'my-secret-key'])
  ->handle()
  ->getResponse();

Get signature validation

$webhook = (new GithubWebhook(new Request))
    ->setCredentials(['secret_key' => 'testing'])
    ->handle()
    ->passes();

Request via curl by sending fake header and payload.

 curl -X POST localhost:8080 \ 
 -H 'X-Hub-Signature: sha1=40cf35581833746c71a4c3c53886fe2a2e207577' \
 -H 'Content-type: application/json' -d '{"data": "sample_response"}'