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:----XpWWxj44yqQsc6j2tFAG4VCliQjqgN5lQ29SCE60hO1+LcCwRSyQ/KLF5h9tpagfI4HstV84UUaPePVS1yobFSpPppB9nrAmalUASRpL2tq9gPyXqK9Yrqju4UayqsJOFqyuz93S5XzylssVMX+zL7UagxX1NXIFJBWXw7XJ9LbSMqwXbvPpo32aWPoKmAd2Ob4EiC1H1CKWhDLiU4hGm4xZJ5W4KONZaC2IWTW50qWLTqZfteUuQUl5acMID/H5dIv7NAc3h3HOOdlsfhwdjqRVMKVhyIOWeKfXsGDQf/SX9hp2Bl5rrGTCsrxRD25foroXO/mc+jD0Bt3u1vjm3MapqmR25RlnueogyUjB98Tn/5a1KN1DKhypo99oaz4ay8ektiQXDpUAOslpDcTTYXKhO7+W1chJf+weQj47GoxQO/nyJeXNDhvcU1JGPLjNRW20GPVQDMy8p1EMkn+jrcaaLA2rSmEs5Ep71OsI836OK72oJbL7WhTKKahAgaFQubs09+XESTmGn6dLYWxYAngjPxmjHZdLWiRc7UAQhY46Qb0PjAiRhvcyQtTo8IVLFtblSmpF1pr1yrwhCKJZ0lnM2OVs5BKJH6GnqvZpr1lVIsRxKZn1PDWE8Ax5sEQfZCMzRHfzoss0rKR9JR4i3RwISm3qfbPvNme6b+8fydQ=----ATTACHMENT:----MjcxMjc4MDM5NTgwMDYxMiAxNDcxMjg4NTYyOTQ5MTYxIDI4MzI1Mjc0MDU3ODc1NzU=