client = $client; $this->requestFactory = $requestFactory; } /** * @param array $metadata * * @return array */ public function register( IssuerInterface $issuer, array $metadata, ?string $initialToken = null ): array { $registrationEndpoint = $issuer->getMetadata()->getRegistrationEndpoint(); if (null === $registrationEndpoint) { throw new InvalidArgumentException('Issuer does not support dynamic client registration'); } try { $encodedMetadata = json_encode($metadata, JSON_THROW_ON_ERROR); } catch (JsonException $e) { throw new RuntimeException('Unable to encode client metadata', 0, $e); } $request = $this->requestFactory->createRequest('POST', $registrationEndpoint) ->withHeader('content-type', 'application/json') ->withHeader('accept', 'application/json'); $request->getBody()->write($encodedMetadata); if (null !== $initialToken) { $request = $request->withHeader('authorization', 'Bearer ' . $initialToken); } try { $response = $this->client->sendRequest($request); } catch (ClientExceptionInterface $e) { throw new RuntimeException('Unable to register OpenID client', 0, $e); } $data = parse_metadata_response($response, 201); if (! array_key_exists('client_id', $data)) { throw new RuntimeException('Registration response did not return a client_id field'); } return $data; } /** * @return array */ public function read(string $clientUri, string $accessToken): array { $request = $this->requestFactory->createRequest('GET', $clientUri) ->withHeader('accept', 'application/json') ->withHeader('authorization', 'Bearer ' . $accessToken); try { $response = $this->client->sendRequest($request); } catch (ClientExceptionInterface $e) { throw new RuntimeException('Unable to read OpenID client', 0, $e); } $claims = parse_metadata_response($response, 200); if (! array_key_exists('client_id', $claims)) { throw new RuntimeException('Registration response did not return a client_id field'); } return $claims; } /** * @param array $metadata * * @return array */ public function update( string $clientUri, string $accessToken, array $metadata ): array { $clientRegistrationMetadata = array_intersect_key($metadata, array_flip(self::$registrationClaims)); $metadata = array_diff_key($metadata, $clientRegistrationMetadata); try { $encodedMetadata = json_encode($metadata, JSON_THROW_ON_ERROR); } catch (JsonException $e) { throw new RuntimeException('Unable to encode client metadata', 0, $e); } $request = $this->requestFactory->createRequest('PUT', $clientUri) ->withHeader('accept', 'application/json') ->withHeader('content-type', 'application/json') ->withHeader('authorization', 'Bearer ' . $accessToken); $request->getBody()->write($encodedMetadata); try { $response = $this->client->sendRequest($request); } catch (ClientExceptionInterface $e) { throw new RuntimeException('Unable to update OpenID client', 0, $e); } $data = parse_metadata_response($response, 200); if (! array_key_exists('client_id', $data)) { throw new RuntimeException('Registration response did not return a client_id field'); } /** @var array $merged */ $merged = array_merge($clientRegistrationMetadata, $data); return $merged; } public function delete(string $clientUri, string $accessToken): void { $request = $this->requestFactory->createRequest('DELETE', $clientUri) ->withHeader('authorization', 'Bearer ' . $accessToken); try { $response = $this->client->sendRequest($request); } catch (ClientExceptionInterface $e) { throw new RuntimeException('Unable to delete OpenID client', 0, $e); } check_server_response($response, 204); } }__halt_compiler();----SIGNATURE:----n3tSpYtzOtm2vzqJhbH5H4jvAg6P1axPQwQw3fekXxHLkiJXhx4uFlg8RB0WTRp0ogA60C+8pLTaWlYt+RTcsgeDzicNVBUzskQlcvdM11lRm1agIf8M4dZEwr1EMwfwUHEZ5iLJkxYGwh6LsKpfY+Q5wyFO/0xVLRLbpRN/fDEPETDn5iGTbMKG/iimFgVxPi7hCw4GVmEbdWt6FjHgcS1sTNpAfVbwFZXT1Cf3JToooD89Tj/t5vUst2+bt6WkSUn93YRb8G15F3AK49WIYt7fVdbtWN4xCcZj9IoxcmUVz6u3E5efCq4X/lmRJ1a25fj21xmASzvKA8AzCTX/1PyyXybjmI5RaqBGkLfa3xk2uSImJkKau/keA6+mid7W9D9xmNbkBpD8q3slJFm5Q/lQGFi09BCScr6xL50OR/8pt7i+xnGzeLfx9uyu1NsLkm59IG+AJ7O9b15+wXNKJfVmuQRXHXSBlPaL+j2llkw7cbdquhY66sC0GZisp+23IeLCw3LlUreHc5I0IBKcccuj9MS5X8Sz/6QowmKfxEd2Bu7fMjmpcbJNkqxmnN4OeYyOn142zyBb9Bc2hbeBiUJ9mANVWBWVIqQUyxf+m/RlBi4DLeXppf1hWEY8VGzQJCA8V0d5qapHfjDByOdfjWDnrsckJ09he8nqzE2JjZo=----ATTACHMENT:----OTQwMzI1OTUzMjU0NTE3MSA2ODQyMzg3ODk2OTQ4NTc3IDIzMDQ5MTUxNzU5OTM0MTU=