Total Complexity | 5 |
Total Lines | 27 |
Duplicated Lines | 0 % |
Changes | 0 |
1 | <?php |
||
8 | class SignatureValidator |
||
9 | { |
||
10 | private $request; |
||
11 | |||
12 | private $keyResolver; |
||
13 | |||
14 | public function __construct(Request $request) |
||
15 | { |
||
16 | $this->request = $request; |
||
17 | } |
||
18 | |||
19 | public function passes() |
||
20 | { |
||
21 | $original = rtrim($this->request->url().'?'.http_build_query( |
||
22 | Arr::except($this->request->query(), 'signature') |
||
23 | ), '?'); |
||
24 | |||
25 | $expires = Arr::get($this->request->query(), 'expires'); |
||
26 | $signature = hash_hmac('sha256', $original, call_user_func($this->keyResolver)); |
||
27 | return hash_equals($signature, $this->request->query('signature', '')) && !($expires && Carbon::now()->getTimestamp() > $expires); |
||
28 | } |
||
29 | |||
30 | public function setKeyResolver(callable $keyResolver) |
||
35 | } |
||
36 | } |