getSignature($signatureIndex); $data = []; $values = [ 'payload' => $jws->getEncodedPayload(), 'protected' => $signature->getEncodedProtectedHeader(), 'header' => $signature->getHeader(), ]; $encodedPayload = $jws->getEncodedPayload(); if (null !== $encodedPayload && '' !== $encodedPayload) { $data['payload'] = $encodedPayload; } $encodedProtectedHeader = $signature->getEncodedProtectedHeader(); if (null !== $encodedProtectedHeader && '' !== $encodedProtectedHeader) { $data['protected'] = $encodedProtectedHeader; } $header = $signature->getHeader(); if (0 !== count($header)) { $data['header'] = $header; } $data['signature'] = Base64Url::encode($signature->getSignature()); return JsonConverter::encode($data); } /** * @throws InvalidArgumentException if the input is not supported * @throws InvalidArgumentException if the JWS header is invalid */ public function unserialize(string $input): JWS { $data = JsonConverter::decode($input); if (!is_array($data)) { throw new InvalidArgumentException('Unsupported input.'); } if (!isset($data['signature'])) { throw new InvalidArgumentException('Unsupported input.'); } $signature = Base64Url::decode($data['signature']); if (isset($data['protected'])) { $encodedProtectedHeader = $data['protected']; $protectedHeader = JsonConverter::decode(Base64Url::decode($data['protected'])); } else { $encodedProtectedHeader = null; $protectedHeader = []; } if (isset($data['header'])) { if (!is_array($data['header'])) { throw new InvalidArgumentException('Bad header.'); } $header = $data['header']; } else { $header = []; } if (isset($data['payload'])) { $encodedPayload = $data['payload']; $payload = $this->isPayloadEncoded($protectedHeader) ? Base64Url::decode($encodedPayload) : $encodedPayload; } else { $payload = null; $encodedPayload = null; } $jws = new JWS($payload, $encodedPayload, null === $encodedPayload); return $jws->addSignature($signature, $protectedHeader, $encodedProtectedHeader, $header); } }