*/ class FirebaseJwt implements EncryptionInterface { public function __construct() { if (!class_exists(JWT::class)) { throw new \ErrorException('firebase/php-jwt must be installed to use this feature. You can do this by running "composer require firebase/php-jwt"'); } } public function encode($payload, $key, $alg = 'HS256', $keyId = null) { return JWT::encode($payload, $key, $alg, $keyId); } public function decode($jwt, $key = null, $allowedAlgorithms = null) { try { //Maintain BC: Do not verify if no algorithms are passed in. if (!$allowedAlgorithms) { $tks = \explode('.', $jwt); if (\count($tks) === 3) { [$headb64] = $tks; $headerRaw = JWT::urlsafeB64Decode($headb64); if (($header = JWT::jsonDecode($headerRaw))) { $key = new Key($key, $header->alg); } } } elseif(is_array($allowedAlgorithms)) { $key = new Key($key, $allowedAlgorithms[0]); } else { $key = new Key($key, $allowedAlgorithms); } return (array) JWT::decode($jwt, $key); } catch (\Exception $e) { return false; } } public function urlSafeB64Encode($data) { return JWT::urlsafeB64Encode($data); } public function urlSafeB64Decode($b64) { return JWT::urlsafeB64Decode($b64); } }