-
Notifications
You must be signed in to change notification settings - Fork 3.4k
/
CookieEncryptedEquals.php
95 lines (83 loc) · 2.24 KB
/
CookieEncryptedEquals.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<?php
declare(strict_types=1);
/**
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
*
* Licensed under The MIT License
* For full copyright and license information, please see the LICENSE.txt
* Redistributions of files must retain the above copyright notice
*
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
* @since 3.7.0
* @license https://www.opensource.org/licenses/mit-license.php MIT License
*/
namespace Cake\TestSuite\Constraint\Response;
use Cake\Http\Response;
use Cake\Utility\CookieCryptTrait;
use Psr\Http\Message\ResponseInterface;
/**
* CookieEncryptedEquals
*
* @internal
*/
class CookieEncryptedEquals extends CookieEquals
{
use CookieCryptTrait;
/**
* @var \Cake\Http\Response
*/
protected ResponseInterface $response;
/**
* @var string
*/
protected string $key;
/**
* @var string
*/
protected string $mode;
/**
* Constructor.
*
* @param \Cake\Http\Response|null $response A response instance.
* @param string $cookieName Cookie name
* @param string $mode Mode
* @param string $key Key
*/
public function __construct(?Response $response, string $cookieName, string $mode, string $key)
{
parent::__construct($response, $cookieName);
$this->key = $key;
$this->mode = $mode;
}
/**
* Checks assertion
*
* @param mixed $other Expected content
* @return bool
* @phpcsSuppress SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint
*/
public function matches($other): bool
{
$cookie = $this->response->getCookie($this->cookieName);
return $cookie !== null && $this->_decrypt($cookie['value'], $this->mode) === $other;
}
/**
* Assertion message
*
* @return string
*/
public function toString(): string
{
return sprintf('is encrypted in cookie \'%s\'', $this->cookieName);
}
/**
* Returns the encryption key
*
* @return string
*/
protected function _getCookieEncryptionKey(): string
{
return $this->key;
}
}