]> git.mxchange.org Git - friendica.git/blob - tests/Util/StaticCookie.php
Reduce the usage of the "proxifyUrl" function
[friendica.git] / tests / Util / StaticCookie.php
1 <?php
2 /**
3  * @copyright Copyright (C) 2010-2021, the Friendica project
4  *
5  * @license GNU AGPL version 3 or any later version
6  *
7  * This program is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU Affero General Public License as
9  * published by the Free Software Foundation, either version 3 of the
10  * License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU Affero General Public License for more details.
16  *
17  * You should have received a copy of the GNU Affero General Public License
18  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
19  *
20  */
21
22 namespace Friendica\Test\Util;
23
24 use Friendica\Model\User\Cookie;
25
26 /**
27  * Overrides the Cookie class so all cookie information will be saved to a static public variable
28  */
29 class StaticCookie extends Cookie
30 {
31         /** @var array static Cookie array mock */
32         public static $_COOKIE = [];
33         /** @var int The last expire time set */
34         public static $_EXPIRE;
35
36         /**
37          * Send a cookie - protected, internal function for test-mocking possibility
38          *
39          * @param string $value  [optional]
40          * @param int    $expire [optional]
41          * @param bool   $secure [optional]
42          * @return bool
43          *
44          * @noinspection PhpMissingParentCallCommonInspection
45          *
46          * @link         https://php.net/manual/en/function.setcookie.php
47          *
48          * @see          Cookie::setCookie()
49          */
50         protected function setCookie(string $value = null, int $expire = null, bool $secure = null): bool
51         {
52                 self::$_COOKIE[self::NAME] = $value;
53                 self::$_EXPIRE = $expire;
54
55                 return true;
56         }
57
58         public static function clearStatic()
59         {
60                 self::$_EXPIRE = null;
61                 self::$_COOKIE = [];
62         }
63 }