HMAC not static
This commit is contained in:
@ -5,13 +5,19 @@ use Incoviba\Common\Ideal;
|
||||
|
||||
class HMAC extends Ideal\Service
|
||||
{
|
||||
public static function validate(string $timestamp, string $requestSignature, string $requestId, string $secret): bool
|
||||
public function validate(string $timestamp, string $requestSignature, string $requestId, string $secret): bool
|
||||
{
|
||||
$message = "{$timestamp}.{$requestId}";
|
||||
$encodedSecret = mb_convert_encoding($secret, 'UTF-8');
|
||||
$encodedMessage = mb_convert_encoding($message, 'UTF-8');
|
||||
$hmacObject = hash_hmac('sha256', $encodedMessage, $encodedSecret);
|
||||
$computedSignature = base64_encode($hmacObject);
|
||||
$this->logger->info('Validating HMAC', [
|
||||
'requestSignature' => $requestSignature,
|
||||
'computedSignature' => $hmacObject,
|
||||
'compare1' => hash_equals($hmacObject, $requestSignature),
|
||||
'compare2' => hash_equals($computedSignature, $requestSignature),
|
||||
]);
|
||||
return hash_equals($computedSignature, $requestSignature);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user