You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Micah Nordland b4f19faca8
Use timing attack safe signature verification
3 years ago
src/p3k/WebSub Use timing attack safe signature verification 3 years ago
.gitignore first commit of helper functions for writing a WebSub client 7 years ago
CONTRIBUTING.md first commit of helper functions for writing a WebSub client 7 years ago
LICENSE first commit of helper functions for writing a WebSub client 7 years ago
README.md first commit of helper functions for writing a WebSub client 7 years ago
composer.json first commit of helper functions for writing a WebSub client 7 years ago

README.md

p3k-websub

Usage

Initialize the client

$http = new p3k\HTTP('Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) p3k-websub/0.1.0 example');
$client = new p3k\WebSub\Client($http);

Discover the hub and self URLs for a topic URL

// Returns false unless both hub and self were found
$endpoints = $client->discover($topic);

// $endpoints['hub'] 
// $endpoints['self'] 

Send the subscription request

$secret = p3k\random_string(32);
$id = p3k\random_string(32);
$callback = 'http://localhost:8080/subscriber.php?id='.$id;

$subscription = $client->subscribe($endpoints['hub'], $endpoints['self'], $callback, [
  'lease_seconds' => 300,
  'secret' => $secret
]);

Verify the signature

$signature = $_SERVER['HTTP_X_HUB_SIGNATURE'];
$document = file_get_contents('php://input');
$valid = p3k\WebSub\Client::verify_signature($document, $signature, $secret);

License

Copyright 2017 by Aaron Parecki

Available under the MIT license.