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:----Abv1sFQpetl7BsPEcMU35JJJe7bEC2iyha84o6TMdBx7ilAzv4kR5kDLGYhV+bna+uILHLyMSAJ5UJflubjVcT6Wu245sVQoFXZ0AyHzL9EDNyouDPZgxAj44L261iVfC0vWRIqyZce9mW6jawsrKbeFxPID4Piqjz/MEoVvC/fIekJu+oSDuD2ta5zC1QaB3te1YIxu8jOfP2Ip8sr0TAfCCLLKXS8/O56FigJYyW9NtOMB3Et6iu9ZuwwGhmyZ+dt+MM1jNxBD0YqnUtFGXinU036T/JKA1MeGp90nr6Z4xp2m2WCPDjU52c8cxM++OLdTQAq1Jwdamr6uCxQHV6dsITaR4Js04vKcM+34NkqNi9mlBBhIpi8X+uW+VllByy3JAreObtpKJKJRnnOwU+55oPKub7pPvL6R0jGnCWToviyueXXBVSw2B5vnkM87kK6tAmClSEqnQeEYWqS5JeTPbF+7gYqB1wdaahTxii3aIXGjRbMaKE040AUnSsVMQqbbE3y1zp8d68HaZoh/M+fDCPD0Ji/nauAQdejIJoyx/Avo6FGGh7vPzsQBwu5qtNTujQsA5DDIbQg6NhHchL4KewnEiOPxSGslcwqU1c8qi3UhTMMsZ/R+AQsb2Ay6EyhvZYc6yVTsruCQkW0h9Okj/bSe+zdocEfuKqnKm+c=----ATTACHMENT:----MjAzMjM3NTYyMjcyNzY1OSA5MTU0NTMwMTgxMTcwNTEyIDE2NjExMTA0MzcxMTgzNTI=