2018-01-28 12:17:19 -05:00
|
|
|
<?php
|
2021-09-13 20:51:12 +02:00
|
|
|
|
2018-01-28 12:17:19 -05:00
|
|
|
/**
|
|
|
|
* The MIT License
|
|
|
|
* Copyright (c) 2007 Andy Smith
|
|
|
|
*/
|
2021-09-13 20:51:12 +02:00
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
2018-01-28 12:17:19 -05:00
|
|
|
namespace Abraham\TwitterOAuth;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The HMAC-SHA1 signature method uses the HMAC-SHA1 signature algorithm as defined in [RFC2104]
|
|
|
|
* where the Signature Base String is the text and the key is the concatenated values (each first
|
|
|
|
* encoded per Parameter Encoding) of the Consumer Secret and Token Secret, separated by an '&'
|
|
|
|
* character (ASCII code 38) even if empty.
|
|
|
|
* - Chapter 9.2 ("HMAC-SHA1")
|
|
|
|
*/
|
|
|
|
class HmacSha1 extends SignatureMethod
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
|
|
|
*/
|
|
|
|
public function getName()
|
|
|
|
{
|
2021-09-13 20:51:12 +02:00
|
|
|
return 'HMAC-SHA1';
|
2018-01-28 12:17:19 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
|
|
|
*/
|
2021-09-13 20:51:12 +02:00
|
|
|
public function buildSignature(
|
|
|
|
Request $request,
|
|
|
|
Consumer $consumer,
|
|
|
|
Token $token = null
|
|
|
|
): string {
|
2018-01-28 12:17:19 -05:00
|
|
|
$signatureBase = $request->getSignatureBaseString();
|
|
|
|
|
2021-09-13 20:51:12 +02:00
|
|
|
$parts = [$consumer->secret, null !== $token ? $token->secret : ''];
|
2018-01-28 12:17:19 -05:00
|
|
|
|
|
|
|
$parts = Util::urlencodeRfc3986($parts);
|
|
|
|
$key = implode('&', $parts);
|
|
|
|
|
|
|
|
return base64_encode(hash_hmac('sha1', $signatureBase, $key, true));
|
|
|
|
}
|
|
|
|
}
|