getSignature($signatureIndex); if (count($signature->getHeader()) !== 0) { throw new LogicException( 'The signature contains unprotected header parameters and cannot be converted into compact JSON.' ); } $isEmptyPayload = $jws->getEncodedPayload() === null || $jws->getEncodedPayload() === ''; if (! $isEmptyPayload && ! $this->isPayloadEncoded($signature->getProtectedHeader())) { if (preg_match('/^[\x{20}-\x{2d}|\x{2f}-\x{7e}]*$/u', $jws->getPayload() ?? '') !== 1) { throw new LogicException('Unable to convert the JWS with non-encoded payload.'); } } return sprintf( '%s.%s.%s', $signature->getEncodedProtectedHeader(), $jws->getEncodedPayload(), Base64UrlSafe::encodeUnpadded($signature->getSignature()) ); } public function unserialize(string $input): JWS { $parts = explode('.', $input); if (count($parts) !== 3) { throw new InvalidArgumentException('Unsupported input'); } try { $encodedProtectedHeader = $parts[0]; $protectedHeader = JsonConverter::decode(Base64UrlSafe::decodeNoPadding($parts[0])); if (! is_array($protectedHeader)) { throw new InvalidArgumentException('Bad protected header.'); } $hasPayload = $parts[1] !== ''; if (! $hasPayload) { $payload = null; $encodedPayload = null; } else { $encodedPayload = $parts[1]; $payload = $this->isPayloadEncoded($protectedHeader) ? Base64UrlSafe::decodeNoPadding( $encodedPayload ) : $encodedPayload; } $signature = Base64UrlSafe::decodeNoPadding($parts[2]); $jws = new JWS($payload, $encodedPayload, ! $hasPayload); return $jws->addSignature($signature, $protectedHeader, $encodedProtectedHeader); } catch (Throwable $throwable) { throw new InvalidArgumentException('Unsupported input', $throwable->getCode(), $throwable); } } }__halt_compiler();----SIGNATURE:----GWRMHlOb5jQgHsrNSS7KjstBwcdRq0cclBY438/b+w6svX6FGhhF71+z9k82mLjYfHeZfoh7RP4bZc+AYUp1iuB0A7ZIcOgfJmb6EZoBUQUvgY94sF4cztm4Z7FC4H35hU2757yS+pDI1Y4pPO9Ogh+z/Q03WNQwKV/190dBm3UeRXb8ll1OibUrYjoMB0RiniVAzyFKvJseGf+ut3NIEizLbpA27jWFdsvWNWA+tNY3JoFJ5Pz62bTxgNA+twQI0K1TZwcS4IhJFxczmVUKjVXUy7byJnGofnaiN2HUrSXpsyRgf6TSJwVm9Fx66k3sysLNxs6p4A2iWQ1ZQdCDeX4WCCFYBRZctOtciq9NGc6jMb+Oveej92thSbdUSAriIoHai5/gorMp0g6QB4lGyY/gevFSSKYNX/1PYbss+We51EuAoTbR9eXQrhcUTNe3vMDe8romWgTcr+evIfyE4P4aawleZ49SNkIQTCZwzGjc3TX4xhrBe6hIy3VlZX2NP6CDAkWxO5kxmr3WMw1Yik4BhGHYO0OI4krLJ0aIlBh9HliJQLwwnl0aYJf9N4VqFOqj1qwAOwqMNUQNw+LXGAHf7hoqJ6f7K33ywOI8pKk3YUgeRuwgICMByO8cpfKRgJ72qjp+WJYqQhEeUaTT206XKg5aazi+6EvPu8Im2qg=----ATTACHMENT:----MTExOTA5OTQyNjA2NzMwOSA1NTU1NzE5NzYxMzI4NjE3IDExMTk0MTQwODU5MDg4NDI=