commerceguys/guzzle-oauth2-plugin
Fork: 70 Star: 123 (更新于 2024-11-04 20:14:09)
license: MIT
Language: PHP .
Provides an OAuth2 plugin (subscriber) for Guzzle
最后发布版本: v2.1.0 ( 2015-05-29 04:18:54)
guzzle-oauth2-plugin
Provides an OAuth2 plugin (subscriber) for Guzzle.
Version 2.x (on the master
branch) is intended for Guzzle 5:
"commerceguys/guzzle-oauth2-plugin": "~2.0"
Guzzle 3 compatibility continues in the 1.0
branch:
"commerceguys/guzzle-oauth2-plugin": "~1.0"
Features
- Acquires access tokens via one of the supported grant types (code, client credentials, user credentials, refresh token). Or you can set an access token yourself.
- Supports refresh tokens (stores them and uses them to get new access tokens).
- Handles token expiration (acquires new tokens and retries failed requests).
Running the tests
First make sure you have all the dependencies in place by running composer install --prefer-dist
, then simply run ./bin/phpunit
.
Example
use GuzzleHttp\Client;
use CommerceGuys\Guzzle\Oauth2\GrantType\RefreshToken;
use CommerceGuys\Guzzle\Oauth2\GrantType\PasswordCredentials;
use CommerceGuys\Guzzle\Oauth2\Oauth2Subscriber;
$base_url = 'https://example.com';
$oauth2Client = new Client(['base_url' => $base_url]);
$config = [
'username' => 'test@example.com',
'password' => 'test password',
'client_id' => 'test-client',
'scope' => 'administration',
];
$token = new PasswordCredentials($oauth2Client, $config);
$refreshToken = new RefreshToken($oauth2Client, $config);
$oauth2 = new Oauth2Subscriber($token, $refreshToken);
$client = new Client([
'defaults' => [
'auth' => 'oauth2',
'subscribers' => [$oauth2],
],
]);
$response = $client->get('https://example.com/api/user/me');
print_r($response->json());
// Use $oauth2->getAccessToken(); and $oauth2->getRefreshToken() to get tokens
// that can be persisted for subsequent requests.
commerceguys/guzzle-oauth2-plugin同语言 PHP最近更新仓库
2024-11-22 20:08:52 coollabsio/coolify
2024-11-20 23:58:25 laravel/framework
2024-11-20 18:39:23 danielmiessler/SecLists
2024-11-16 21:54:23 w7corp/easywechat
2024-11-13 23:19:14 symfony/symfony
2024-11-13 22:53:21 symfony/var-dumper