getRecipient($recipientIndex); $data = [ 'ciphertext' => Base64Url::encode($jwe->getCiphertext()), 'iv' => Base64Url::encode($jwe->getIV()), 'tag' => Base64Url::encode($jwe->getTag()), ]; if (null !== $jwe->getAAD()) { $data['aad'] = Base64Url::encode($jwe->getAAD()); } if (0 !== count($jwe->getSharedProtectedHeader())) { $data['protected'] = $jwe->getEncodedSharedProtectedHeader(); } if (0 !== count($jwe->getSharedHeader())) { $data['unprotected'] = $jwe->getSharedHeader(); } if (0 !== count($recipient->getHeader())) { $data['header'] = $recipient->getHeader(); } if (null !== $recipient->getEncryptedKey()) { $data['encrypted_key'] = Base64Url::encode($recipient->getEncryptedKey()); } return JsonConverter::encode($data); } public function unserialize(string $input): JWE { $data = JsonConverter::decode($input); $this->checkData($data); $ciphertext = Base64Url::decode($data['ciphertext']); $iv = Base64Url::decode($data['iv']); $tag = Base64Url::decode($data['tag']); $aad = array_key_exists('aad', $data) ? Base64Url::decode($data['aad']) : null; [$encodedSharedProtectedHeader, $sharedProtectedHeader, $sharedHeader] = $this->processHeaders($data); $encryptedKey = array_key_exists('encrypted_key', $data) ? Base64Url::decode($data['encrypted_key']) : null; $header = array_key_exists('header', $data) ? $data['header'] : []; return new JWE( $ciphertext, $iv, $tag, $aad, $sharedHeader, $sharedProtectedHeader, $encodedSharedProtectedHeader, [new Recipient($header, $encryptedKey)] ); } /** * @throws InvalidArgumentException if the payload cannot be encoded */ private function checkData(?array $data): void { if (null === $data || !isset($data['ciphertext']) || isset($data['recipients'])) { throw new InvalidArgumentException('Unsupported input.'); } } private function processHeaders(array $data): array { $encodedSharedProtectedHeader = array_key_exists('protected', $data) ? $data['protected'] : null; $sharedProtectedHeader = $encodedSharedProtectedHeader ? JsonConverter::decode(Base64Url::decode($encodedSharedProtectedHeader)) : []; $sharedHeader = $data['unprotected'] ?? []; return [$encodedSharedProtectedHeader, $sharedProtectedHeader, $sharedHeader]; } }