. */ namespace SP\Core\Crypt; use SP\Bootstrap; use SP\Http\Request; /** * Class Cookie * * @package SP\Core\Crypt */ abstract class Cookie { /** * @var Request */ protected $request; /** * @var string */ private $cookieName; /** * Cookie constructor. * * @param string $cookieName * @param Request $request */ protected function __construct(string $cookieName, Request $request) { $this->cookieName = $cookieName; $this->request = $request; } /** * Firmar la cookie para autentificación * * @param string $data * @param string $cypher * * @return string */ public final 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 */ public final function getCookieData(string $data, string $cypher) { if (strpos($data, ';') === false) { return false; } list($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 * * @param string $data * * @return bool */ protected function setCookie(string $data): bool { // Do not try to set cookies when testing if (APP_MODULE === 'tests') { return true; } if (headers_sent()) { logger('Headers already sent', 'ERROR'); return false; } return setcookie($this->cookieName, $data, 0, Bootstrap::$WEBROOT); } }