2017 © Pedro Peláez
 

library http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

image

acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  • Tuesday, July 10, 2018
  • by matthewmorley
  • Repository
  • 14 Watchers
  • 24 Stars
  • 239,413 Installations
  • PHP
  • 10 Dependents
  • 1 Suggesters
  • 22 Forks
  • 0 Open issues
  • 28 Versions
  • 17 % Grown

The README.md

HTTP HMAC Signer for PHP

Build Status Total Downloads Latest Stable Version License, (*1)

This library implements version 2.0 of the HTTP HMAC Spec to sign and verify RESTful Web API requests. It integrates with popular frameworks and libraries, like Symfony and Guzzle, and can be used on both the server and client., (*2)

Installation

Use Composer and add it as a dependency to your project's composer.json file:, (*3)

{
    "require": {
        "acquia/http-hmac-php": "^5.0"
    }
}

Please refer to Composer's documentation for more detailed installation and usage instructions., (*4)

Usage

Sign an API request sent via Guzzle


require_once 'vendor/autoload.php'; use Acquia\Hmac\Guzzle\HmacAuthMiddleware; use Acquia\Hmac\Key; use GuzzleHttp\Client; use GuzzleHttp\HandlerStack; // Create the HTTP HMAC key. // A key consists of and ID and a Base64-encoded shared secret. // Note: the API provider may have already encoded the secret. In this case, it should not be re-encoded. $key_id = 'e7fe97fa-a0c8-4a42-ab8e-2c26d52df059'; $key_secret = base64_encode('secret'); $key = new Key($key_id, $key_secret); // Optionally, you can provide additional headers when generating the signature. // The header keys need to be provided to the middleware below. $headers = [ 'X-Custom-1' => 'value1', 'X-Custom-2' => 'value2', ]; // Specify the API's realm. // Consult the API documentation for this value. $realm = 'Acquia'; // Create a Guzzle middleware to handle authentication during all requests. // Provide your key, realm and the names of any additional custom headers. $middleware = new HmacAuthMiddleware($key, $realm, array_keys($headers)); // Register the middleware. $stack = HandlerStack::create(); $stack->push($middleware); // Create a client. $client = new Client([ 'handler' => $stack, ]); // Request. try { $result = $client->get('https://service.acquia.io/api/v1/widget', [ 'headers' => $headers, ]); } catch (ClientException $e) { print $e->getMessage(); $response = $e->getResponse(); } print $response->getBody();

Authenticate the request using PSR-7-compatible requests

use Acquia\Hmac\RequestAuthenticator;
use Acquia\Hmac\ResponseSigner;

// $keyLoader implements \Acquia\Hmac\KeyLoaderInterface
$authenticator = new RequestAuthenticator($keyLoader);

// $request implements PSR-7's \Psr\Http\Message\RequestInterface
// An exception will be thrown if it cannot authenticate.
$key = $authenticator->authenticate($request);

$signer = new ResponseSigner($key, $request);
$signedResponse = $signer->signResponse($response);

Authenticate using Symfony's Security component

In order to use the provided Symfony integration, you will need to include the following optional libraries in your project's composer.json, (*5)

{
    "require": {
        "symfony/psr-http-message-bridge": "~0.1",
        "symfony/security": "~3.0",
        "zendframework/zend-diactoros": "~1.3.5"
    }
}

Sample implementation:, (*6)

# app/config/parameters.yml
parameters:
   hmac_keys: {"key": "secret"}

# app/config/services.yml
services:
    hmac.keyloader:
        class: Acquia\Hmac\KeyLoader
        arguments:
            $keys: '%hmac_keys%'

    hmac.request.authenticator:
        class: Acquia\Hmac\RequestAuthenticator
        arguments:
         - '@hmac.keyloader'
        public: false

    hmac.response.signer:
        class: Acquia\Hmac\Symfony\HmacResponseListener
        tags:
          - { name: kernel.event_listener, event: kernel.response, method: onKernelResponse }

    hmac.entry-point:
        class: Acquia\Hmac\Symfony\HmacAuthenticationEntryPoint

    hmac.security.authentication.provider:
        class: Acquia\Hmac\Symfony\HmacAuthenticationProvider
        arguments:
            - '@hmac.request.authenticator'
        public: false

    hmac.security.authentication.listener:
        class: Acquia\Hmac\Symfony\HmacAuthenticationListener
        arguments: ['@security.token_storage', '@security.authentication.manager', '@hmac.entry-point']
        public: false

# app/config/security.yml
security:
    # ...

    firewalls:
        hmac_auth:
            pattern:   ^/api/
            stateless: true
            hmac_auth: true
// src/AppBundle/AppBundle.php
namespace AppBundle;

use Acquia\Hmac\Symfony\HmacFactory;
use Symfony\Component\HttpKernel\Bundle\Bundle;
use Symfony\Component\DependencyInjection\ContainerBuilder;

class AppBundle extends Bundle
{
    public function build(ContainerBuilder $container)
    {
        parent::build($container);
        $extension = $container->getExtension('security');
        $extension->addSecurityListenerFactory(new HmacFactory());
    }
}

PHPUnit testing a controller using HMAC HTTP authentication in Symfony:, (*7)

  1. Add the service declaration:
# app/config/parameters_test.yml

services:
    test.client.hmac:
        class: Acquia\Hmac\Test\Mocks\Symfony\HmacClient
        arguments: ['@kernel', '%test.client.parameters%', '@test.client.history', '@test.client.cookiejar']

// src/AppBundle/Tests/HmacTestCase.php

namespace MyApp\Bundle\AppBundle\Tests;

use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Bundle\FrameworkBundle\Client;
use Acquia\Hmac\Key;

class HmacTestCase extends WebTestCase
{
    /**
     * @var Client
     */
    private $client;

    protected static function createClient(array $options = array(), array $server = array())
    {
        $kernel = static::bootKernel($options);

        $client = $kernel->getContainer()->get('test.client.hmac');
        $client->setServerParameters($server);

        return $client;
    }

    protected function setUp()
    {
        $this->client = static::createClient();

        $this->client->setKey(new Key('my-key', 'my-not-really-secret'));
    }

Contributing and Development

GNU Make and Composer are used to manage development dependencies and testing:, (*8)

# Install depdendencies
make install

# Run test suite
make test

All code should adhere to the following standards:, (*9)

Submit changes using GitHub's standard pull request workflow., (*10)

The Versions

24/06 2016

dev-request-response-objects-in-exceptions

dev-request-response-objects-in-exceptions https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

 

The Development Requires

02/05 2016
18/04 2016

3.0.0-beta2

3.0.0.0-beta2 https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

 

The Development Requires

14/04 2016

3.0.0-beta1

3.0.0.0-beta1 https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

 

The Development Requires

12/04 2016

dev-3.0.0-beta

dev-3.0.0-beta https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

 

The Development Requires

08/04 2016

dev-3.0.0+poc

dev-3.0.0+poc https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

  • php >=5.5.0

 

The Development Requires

28/01 2016

2.1.0

2.1.0.0 https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

  • php >=5.5.0

 

The Development Requires

23/11 2015
23/11 2015

2.0.1

2.0.1.0 https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

  • php >=5.5.0

 

The Development Requires

11/11 2015

2.0.0

2.0.0.0 https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

  • php >=5.5.0

 

The Development Requires

20/02 2015

1.0.x-dev

1.0.9999999.9999999-dev https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

  • php >=5.4.0

 

The Development Requires

20/02 2015
15/02 2015

0.7.0

0.7.0.0 https://github.com/acquia/http-hmac-php

An implementation of the HTTP HMAC Spec in PHP that integrates with popular libraries such as Symfony and Guzzle.

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires