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; }
/** * Parses the access token response and returns a TokenInterface. * * * @param string $responseBody * * @return TokenInterface * * @throws TokenResponseException */ protected function parseAccessTokenResponse($responseBody) { $request = \Request::getInstance(); if ($request->get('error')) { $reason = $request->get('error_description'); throw new TokenResponseException($reason); } $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']); $data['state'] = $request->get('state'); $token->setExtraParams($data); return $token; }
/** * {@inheritdoc} */ 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']); if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } unset($data['access_token']); $token->setExtraParams($data); return $token; }
/** * {@inheritdoc} */ 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']); // Salesforce tokens evidently never expire... $token->setEndOfLife(StdOAuth2Token::EOL_NEVER_EXPIRES); unset($data['access_token']); if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); unset($data['refresh_token']); } $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; }
/** * {@inheritdoc} */ protected function parseAccessTokenResponse($responseBody) { $JSON = new \JSON(JSON_LOOSE_TYPE); $data = $JSON->decode($responseBody); 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']); 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; }
public function refreshAccessToken() { $access_token = $this->access_token; $service = Facades\Social::service($this->provider); if (2 === Facades\Social::oauthSpec($this->provider)) { $token = new StdOAuth2Token(); $token->setAccessToken(array_get($access_token, 'token')); $token->setRefreshToken(array_get($access_token, 'refresh_token')); } else { $token = new StdOAuth1Token(); $token->setAccessToken(array_get($access_token, 'token')); $token->setAccessTokenSecret(array_get($access_token, 'secret')); $token->setRefreshToken(array_get($access_token, 'refresh_token')); } $service->getStorage()->storeAccessToken(ucfirst($this->provider), $token); try { $new_token = $service->refreshAccessToken($token); } catch (\Exception $e) { return false; } if (!$new_token->getAccessToken()) { return false; } $access_token['token'] = $new_token->getAccessToken(); if ($new_token->getEndOfLife()) { $access_token['end_of_life'] = $new_token->getEndOfLife(); } if ($new_token->getExtraParams()) { $access_token['extra_params'] = $new_token->getExtraParams(); } if (2 !== Facades\Social::oauthSpec($this->provider) && $new_token->getAccessTokenSecret()) { $access_token['secret'] = $new_token->getAccessTokenSecret(); } $this->access_token = $access_token; $this->save(); return true; }
/** * @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) { $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']); // Salesforce access tokens depend on the session timeout settings. // The session timeout for an access token can be configured in Salesforce from Setup by clicking Security Controls | Session Settings. $token->setEndOfLife(StdOAuth2Token::EOL_UNKNOWN); unset($data['access_token']); if (isset($data['refresh_token'])) { $token->setRefreshToken($data['refresh_token']); // Save Refresh Token persistently until it is cleared manually update_option('gf_salesforce_refreshtoken', $data['refresh_token']); unset($data['refresh_token']); } else { $refresh_token = get_option('gf_salesforce_refreshtoken'); if (!empty($refresh_token)) { $token->setRefreshToken($refresh_token); } } $token->setExtraParams($data); return $token; }
/** * {@inheritdoc} */ protected function parseAccessTokenResponse($responseBody) { $data = @json_decode($responseBody, true); // Facebook gives us a query string on old api (v2.0) if (!$data) { 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']); 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; }