olsgreen / oauth2-sage-business-cloud
为 PHP League OAuth2-Client 提供的 Sage Business Cloud OAuth 2.0 客户端提供者
1.0
2021-08-09 12:18 UTC
Requires
- php: ^7.3 || ^8.0
- league/oauth2-client: ^2.0
Requires (Dev)
- mockery/mockery: ^1.3
- phpunit/phpunit: ^7.5.20 || ^9.3
This package is auto-updated.
Last update: 2024-09-09 19:00:56 UTC
README
此包为 PHP League 的 OAuth 2.0 客户端 提供Sage Business Cloud OAuth 2.0 支持。
此包需要 PHP >= 7.4。
安装
要安装,请使用 composer
composer require olsgreen/oauth2-sage-business-cloud
用法
用法与 The League 的 OAuth 客户端相同,使用 \Olsgreen\OAuth2\Client\Provider\SageBusinessCloud
作为提供者。
授权码流
$provider = new Olsgreen\OAuth2\Client\Provider\SageBusinessCloud([ 'clientId' => '{sage-client-id}', 'clientSecret' => '{sage-client-secret}', 'redirectUri' => 'https://example.com/callback-url', 'locale' => 'en-GB', // Optional 'country' => 'gb', // Optional ]); if (!isset($_GET['code'])) { // If we don't have an authorization code then get one $authUrl = $provider->getAuthorizationUrl(); $_SESSION['oauth2state'] = $provider->getState(); header('Location: '.$authUrl); exit; // Check given state against previously stored one to mitigate CSRF attack } elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) { unset($_SESSION['oauth2state']); exit('Invalid state'); } else { // Try to get an access token (using the authorization code grant) $token = $provider->getAccessToken('authorization_code', [ 'code' => $_GET['code'] ]); // Use this to interact with an API on the users behalf echo $token->getToken(); }
国家 & 地区
有关当前支持的国家和地区的列表,请参阅 https://developer.sage.com/accounting/guides/authenticating/authentication/。
测试
$ ./vendor/bin/phpunit
许可协议
MIT 许可协议(MIT)。有关更多信息,请参阅 许可文件。