config('2fauth.config.outgoingProxy'), ], $guzzle); parent::__construct($request, $clientId, $clientSecret, $redirectUrl, $guzzle); } /** * {@inheritdoc} */ public static function additionalConfigKeys() { return ['token_url', 'authorize_url', 'userinfo_url']; } /** * {@inheritdoc} */ protected function getAuthUrl($state) { return $this->buildAuthUrlFromBase($this->getConfig('authorize_url'), $state); } /** * {@inheritdoc} */ protected function getTokenUrl() { return $this->getConfig('token_url'); } /** * {@inheritdoc} */ protected function getUserByToken($token) { $response = $this->getHttpClient()->get($this->getConfig('userinfo_url'), [ RequestOptions::HEADERS => [ 'Authorization' => 'Bearer ' . $token, ], ]); return json_decode((string) $response->getBody(), true); } /** * {@inheritdoc} */ protected function mapUserToObject(array $user) { return (new User)->setRaw($user)->map([ 'email' => $user['email'] ?? null, 'email_verified' => $user['email_verified'] ?? null, 'name' => $user['name'] ?? null, 'given_name' => $user['given_name'] ?? null, 'family_name' => $user['family_name'] ?? null, 'preferred_username' => $user['preferred_username'] ?? null, 'nickname' => $user['nickname'] ?? null, 'groups' => $user['groups'] ?? null, 'id' => $user['sub'], ]); } }