. */ namespace SP\Core\Crypt; use SP\Core\Bootstrap\BootstrapBase; use SP\Http\Request; use SP\Http\RequestInterface; /** * Class Cookie * * @package SP\Core\Crypt */ abstract class Cookie { protected Request $request; private string $cookieName; /** * Cookie constructor. * * @param string $cookieName * @param RequestInterface $request */ protected function __construct(string $cookieName, RequestInterface $request) { $this->cookieName = $cookieName; $this->request = $request; } /** * Firmar la cookie para autentificación */ final public function sign(string $data, string $cypher): string { $data = base64_encode($data); return Hash::signMessage($data, $cypher) . ';' . $data; } /** * Comprobar la firma de la cookie y devolver los datos * * @return bool|string */ final public function getCookieData(string $data, string $cypher) { if (strpos($data, ';') === false) { return false; } [$signature, $data] = explode(';', $data, 2); return Hash::checkMessage($data, $cypher, $signature) ? base64_decode($data) : false; } /** * Returns cookie raw data * * @return bool|string */ protected function getCookie() { return $this->request ->getRequest() ->cookies() ->get($this->cookieName, false); } /** * Sets cookie data */ protected function setCookie(string $data): bool { // Do not try to set cookies when testing if (IS_TESTING) { return true; } if (headers_sent()) { logger('Headers already sent', 'ERROR'); return false; } return setcookie($this->cookieName, $data, 0, BootstrapBase::$WEBROOT); } }