Conditions | 5 |
Paths | 2 |
Total Lines | 15 |
Lines | 0 |
Ratio | 0 % |
Tests | 7 |
CRAP Score | 5 |
Changes | 0 |
1 | <?php |
||
22 | 3 | public static function verify( |
|
23 | $payload, |
||
24 | $header, |
||
25 | $secret, |
||
26 | $tolerance = self::DEFAULT_TOLERANCE |
||
27 | ) { |
||
28 | 3 | list($timestamp, $signature) = explode(':', trim($header), 2); |
|
29 | |||
30 | 3 | if (!is_numeric($timestamp) || empty($signature) || |
|
31 | 3 | (($tolerance > 0) && (abs(time() - $timestamp) > $tolerance))) { |
|
32 | 2 | return false; |
|
33 | } |
||
34 | 1 | $expected = hash_hmac('sha256', "{$timestamp}:{$payload}", $secret); |
|
35 | 1 | return hash_equals($expected, $signature); |
|
36 | } |
||
37 | } |
||
38 |