. */ namespace SP\Core\Crypt; use SP\Core\Bootstrap\BootstrapBase; use SP\Domain\Http\RequestInterface; use function SP\logger; /** * Class Cookie * * @package SP\Core\Crypt */ abstract class Cookie { /** * Cookie constructor. * * @param string $cookieName * @param RequestInterface $request */ protected function __construct(private readonly string $cookieName, protected readonly RequestInterface $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 * * @param string $data * @param string $cypher * * @return bool|string */ final public function getCookieData(string $data, string $cypher): bool|string { if (!str_contains($data, ';')) { 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(): bool|string { 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); } }