asad / oauth2-zoho
The PHP League OAuth2-Client 的 Zoho OAuth 2.0 客户端提供程序
1.1.0
2021-03-07 01:55 UTC
Requires
- league/oauth2-client: ^2.0
Requires (Dev)
- eloquent/phony-phpunit: ^2.0
- jakub-onderka/php-parallel-lint: ^0.9.2
- mockery/mockery: ~0.9
- php-coveralls/php-coveralls: ^2.1
- phpunit/phpunit: ^6.0
- squizlabs/php_codesniffer: ^2.0
This package is auto-updated.
Last update: 2024-09-22 03:52:00 UTC
README
此软件包为 PHP League 的 ZOHO OAuth 2.0 提供支持,用于 OAuth 2.0 客户端。
要使用此软件包,需要 ZOHO 客户端 ID 和客户端密钥。这些在文档中分别称为 {zoho-client-id}
和 {zoho-client-secret}
。
请按照 ZOHO 指示 创建所需的凭证。
安装
您可以通过 composer 安装此软件包
composer require asad/oauth2-zoho
用法
授权码流程
use Asad\OAuth2\Client\Provider\Zoho; $provider = new Zoho([ 'clientId' => '{zoho-client-id}', 'clientSecret' => '{zoho-client-secret}', 'redirectUri' => 'http://localhost:8000/zoho/oauth2', 'dc' => 'AU' //It will be optional if your ZOHO are in US location ]); if (!isset($_GET['code'])) { // If we don't have an authorization code then get one $authUrl = $provider->getAuthorizationUrl([ 'scope' => [ 'ZohoCRM.modules.ALL', //Important: Define your data accessability scope here 'ZohoCRM.settings.ALL', ], 'access_type' => 'offline', //Important: If you want to generate the refresh token, set this value as offline 'prompt' => 'consent' //Important: Will not return a refresh token if this is not also set ]); $_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) try { $token = $provider->getAccessToken('authorization_code', [ 'code' => $_GET['code'] ]); //$user = $provider->getResourceOwner($token); echo $access_token = $token->getToken(); echo $refresh_token = $token->getRefreshToken(); //Save this refresh token to somewehre echo $token->getExpires(); } catch (\Exception $e) { //handle you exception } }
刷新令牌
刷新令牌仅提供给请求离线访问的应用程序。您可以通过在 getAuthorizationUrl() 请求中传递 access_type 选项来指定离线访问。
use Asad\OAuth2\Client\Provider\Zoho; use League\OAuth2\Client\Grant\RefreshToken; $provider = new Zoho([ 'clientId' => '{zoho-client-id}', 'clientSecret' => '{zoho-client-secret}', 'dc' => 'AU' //It will be optional if your ZOHO are in US location ]); $refreshToken = 'FromYourStoredData'; $grant = new RefreshToken(); $token = $provider->getAccessToken($grant, ['refresh_token' => $refreshToken]);
测试
composer test
贡献
有关详细信息,请参阅 CONTRIBUTING。
安全
如果您发现任何安全相关的问题,请通过电子邮件 asadku34@gamil.com 而不是使用问题跟踪器。
致谢
许可证
MIT 许可证 (MIT)。请参阅 许可证文件 了解更多信息。