http = $http; } /** * Revoke an OAuth2 access token or refresh token. This method will revoke the current access * token, if a token isn't provided. * * @param string|null $token The token (access token or a refresh token) that should be revoked. * @return boolean Returns True if the revocation was successful, otherwise False. */ public function revokeToken(array $token) { if (isset($token['refresh_token'])) { $tokenString = $token['refresh_token']; } else { $tokenString = $token['access_token']; } $body = Psr7\stream_for(http_build_query(array('token' => $tokenString))); $request = new Request( 'POST', Google_Client::OAUTH2_REVOKE_URI, [ 'Cache-Control' => 'no-store', 'Content-Type' => 'application/x-www-form-urlencoded', ], $body ); $httpHandler = HttpHandlerFactory::build($this->http); $response = $httpHandler($request); if ($response->getStatusCode() == 200) { return true; } return false; } }