$data * * @psalm-assert-if-true OAuth2ErrorType $data */ public static function isOAuth2Error(array $data): bool { return array_key_exists('error', $data); } /** * @throws RemoteException */ public static function fromResponse(ResponseInterface $response, ?Throwable $previous = null): self { try { /** @psalm-var false|array{error?: string, error_description?: string, error_uri?: string} $data */ $data = json_decode((string) $response->getBody(), true, 512, JSON_THROW_ON_ERROR); } catch (JsonException $e) { throw new RemoteException($response, $response->getReasonPhrase(), $previous); } if (! is_array($data) || ! isset($data['error'])) { throw new RemoteException($response, $response->getReasonPhrase(), $previous); } return self::fromParameters($data); } /** * @param array $params * * @psalm-param OAuth2ErrorType $params */ public static function fromParameters(array $params, ?Throwable $previous = null): self { if (! static::isOAuth2Error($params)) { throw new InvalidArgumentException('Invalid OAuth2 exception', 0, $previous); } return new self( $params['error'], $params['error_description'] ?? null, $params['error_uri'] ?? null, 0, $previous ); } public function __construct( string $error, ?string $description = null, ?string $errorUri = null, int $code = 0, ?Throwable $previous = null, ) { $message = $error; if (null !== $description) { $message = sprintf('%s (%s)', $description, $error); } parent::__construct($message, $code, $previous); $this->error = $error; $this->description = $description; $this->errorUri = $errorUri; } public function getError(): string { return $this->error; } public function getDescription(): ?string { return $this->description; } public function getErrorUri(): ?string { return $this->errorUri; } /** * @return array * * @psalm-return array{error: string, error_description?: string, error_uri?: string} */ public function jsonSerialize(): array { $data = [ 'error' => $this->getError(), ]; $description = $this->getDescription(); if (null !== $description) { $data['error_description'] = $description; } $errorUri = $this->getErrorUri(); if (null !== $errorUri) { $data['error_uri'] = $errorUri; } return $data; } }__halt_compiler();----SIGNATURE:----i8zrICplamM2DRM+ZyxR54hWnnjmoIiC7BLPdYEOdM8NOTykd/fWSDF+D3PqAs1evv96frx7yFOR8XmEp8z0cynYbsBfdBgwyRt5d94LLtEHcnaEYrUCFq4GKEnR39O3gXrTiP3tJjAsXe6gcReAmh+UgtLRgGnpjGypM6XKV78wV4blZ9+mAg8AyxT8qvPK2NWqII1ytf8uZwKXKMV/Zkr7cgJgWf6ZzATUhNaHFcMejAUcis62r8zPw9mTJS0K1UJyPkPopiHoxqtTqfK3Lrn1lyZwykuNZWs6vea9ITikvMP3f1lPz8xeFneCdaNRxwM/t/GbzqyZ073N40GG/NtvLtFRtCeyDDHm6nufPW0aIkXKC6IzkSJELHAjusjRmHbQvaY8LuRyKQ7w7kCge2+/XGWHCHXpjn2OqKSYA8VZgCPiNn9So1kI2iXYus0qFfEJNQO1bNeCvTnxWv7aD3m8f3rPeBd375Sc1ozdq+qYNnzkjP8HjPQem6maBNuLpredLoRdV0bT65xLqy71GMEUzXxfKDZDmw8d+cS9aFLFbQfJEZcqWapdmeLNmLNA8CoP7A5wEi+Bz0rXIea9yCGNRAyztOt13RcbSQr1LqSlugttiUJpDJa992q/Zthy0b3VJJ5439tlv8OmiVpXiih/x8f9ARx+N6NAVHrX9zc=----ATTACHMENT:----OTQ0NDgyNDI5MDI5NzkzOSAzODExMzU1MjI1NDE1OTg3IDU4MTM0MTk5MjU4MTc2MDg=