protected function parseAccessTokenResponse($responseBody) { if (version_compare($this->apiVersion, 'v2.2', '>') === true) { $data = json_decode($responseBody, true); } else { parse_str($responseBody, $data); } if (null === $data || !is_array($data)) { throw new TokenResponseException('Unable to parse response.'); } elseif (isset($data['error'])) { if (is_array($data['error']) === true) { $errorMessage = $data['error']['message']; } else { $errorMessage = $data['error']; } throw new TokenResponseException('Error in retrieving token: "' . $errorMessage . '"'); } $token = new StdOAuth2Token(); $token->setAccessToken($data['access_token']); if (isset($data['expires'])) { $token->setLifeTime($data['expires']); } if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); unset($data['expires']); $token->setExtraParams($data); return $token; }
/** * @param string $responseBody * @return \OAuth\Common\Token\TokenInterface|\OAuth\OAuth2\Token\StdOAuth2Token * @throws \OAuth\Common\Http\Exception\TokenResponseException */ protected function parseAccessTokenResponse($responseBody) { $data = json_decode($responseBody, true); if (null === $data || !is_array($data)) { throw new TokenResponseException('Unable to parse response.'); } elseif (isset($data['error'])) { throw new TokenResponseException('Error in retrieving token: "' . $data['error'] . '"'); } $token = new StdOAuth2Token(); $token->setAccessToken($data['access_token']); $token->setLifeTime($data['expires_in']); if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); unset($data['expires_in']); $token->setExtraParams($data); return $token; }
/** * {@inheritdoc} */ protected function parseAccessTokenResponse($responseBody) { // Facebook gives us a query string ... Oh wait. JSON is too simple, understand ? parse_str($responseBody, $data); if (null === $data || !is_array($data)) { throw new TokenResponseException('Unable to parse response.'); } elseif (isset($data['error'])) { throw new TokenResponseException('Error in retrieving token: "' . $data['error'] . '"'); } $token = new StdOAuth2Token(); $token->setAccessToken($data['access_token']); $token->setLifeTime($data['expires']); if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); unset($data['expires']); $token->setExtraParams($data); return $token; }
/** * @param string $responseBody * @return StdOAuth2Token * @throws TokenResponseException */ protected function parseAccessTokenResponse($responseBody) { $data = $this->service->parseAccessTokenResponse($responseBody); if (!isset($data) || !is_array($data)) { throw new TokenResponseException('Unable to parse response.'); } $error = $this->service->getAccessTokenResponseError($data); if (isset($error)) { throw new TokenResponseException('Error in retrieving token: "' . $error . '"'); } $token = new StdOAuth2Token(); $names = $this->service->getAccessTokenArgumentNames(); $token->setAccessToken($data[$names['access_token']]); unset($data[$names['access_token']]); if (isset($data[$names['expires_in']])) { $token->setLifeTime($data[$names['expires_in']]); unset($data[$names['expires_in']]); } else { $token->setLifetime($this->service->getTokenDefaultLifetime()); } if (isset($data[$names['refresh_token']])) { $token->setRefreshToken($data[$names['refresh_token']]); unset($data[$names['refresh_token']]); } $token->setExtraParams($data); return $token; }
/** * {@inheritdoc} */ protected function parseAccessTokenResponse($responseBody) { // Facebook gives us a query string on old api versions if (0 !== strpos($responseBody, '{')) { parse_str($responseBody, $data); } else { $data = json_decode($responseBody, true); } if (null === $data || !is_array($data)) { throw new TokenResponseException('Unable to parse response.'); } elseif (isset($data['error'])) { throw new TokenResponseException('Error in retrieving token: "' . $data['error'] . '"'); } elseif (empty($data['access_token'])) { throw new TokenResponseException('Error in retrieving token: Access token is empty!'); } $token = new StdOAuth2Token(); $token->setAccessToken($data['access_token']); if (isset($data['expires'])) { $token->setLifeTime($data['expires']); } if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); unset($data['expires']); $token->setExtraParams($data); return $token; }
/** * {@inheritdoc} */ protected function parseAccessTokenResponse($responseBody) { parse_str($responseBody, $data); if (null === $data || !is_array($data) || empty($data)) { throw new TokenResponseException('Unable to parse response.'); } elseif (isset($data['error'])) { throw new TokenResponseException('Error in retrieving token: "' . $data['error'] . '"'); } elseif (isset($data['error_reason'])) { throw new TokenResponseException('Error in retrieving token: "' . $data['error_reason'] . '"'); } $token = new StdOAuth2Token(); $token->setAccessToken($data['access_token']); $token->setLifeTime($data['expires']); // I hope one day Deezer add a refresh token :) if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); unset($data['expires']); $token->setExtraParams($data); return $token; }