From b2b0894b6db78ce33be5523fade6e78b22661bdf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Simon=20Pr=C3=A9vost?= Date: Fri, 4 Oct 2024 15:34:18 -0400 Subject: [PATCH 1/3] Add CA dcDomain Zoho provider --- src/clients/zoho/provider/Zoho.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/clients/zoho/provider/Zoho.php b/src/clients/zoho/provider/Zoho.php index 9984601..e5d9c3a 100644 --- a/src/clients/zoho/provider/Zoho.php +++ b/src/clients/zoho/provider/Zoho.php @@ -26,6 +26,7 @@ class Zoho extends AbstractProvider 'IN' => 'https://accounts.zoho.in', 'CN' => 'https://accounts.zoho.com.cn', 'JP' => 'https://accounts.zoho.jp', + 'CA' => 'https://accounts.zohocloud.ca', ]; /** From 769fec6df7f6a7c476117a01feb48cbfe6fc3184 Mon Sep 17 00:00:00 2001 From: Josh Crawford Date: Sun, 13 Oct 2024 12:59:58 +1100 Subject: [PATCH 2/3] Add Xero provider --- src/clients/xero/provider/Xero.php | 180 ++++++++++++++++++ src/clients/xero/provider/XeroPkce.php | 21 ++ .../xero/provider/XeroResourceOwner.php | 56 ++++++ src/clients/xero/provider/XeroTenant.php | 61 ++++++ .../exception/XeroProviderException.php | 20 ++ src/helpers/Provider.php | 3 + src/providers/Xero.php | 22 +++ 7 files changed, 363 insertions(+) create mode 100644 src/clients/xero/provider/Xero.php create mode 100644 src/clients/xero/provider/XeroPkce.php create mode 100644 src/clients/xero/provider/XeroResourceOwner.php create mode 100644 src/clients/xero/provider/XeroTenant.php create mode 100644 src/clients/xero/provider/exception/XeroProviderException.php create mode 100644 src/providers/Xero.php diff --git a/src/clients/xero/provider/Xero.php b/src/clients/xero/provider/Xero.php new file mode 100644 index 0000000..8397741 --- /dev/null +++ b/src/clients/xero/provider/Xero.php @@ -0,0 +1,180 @@ +getAuthenticatedRequest( + self::METHOD_GET, + $this->getTenantsUrl($params), + $token + ); + + $response = $this->getParsedResponse($request); + $tenants = []; + + foreach ($response as $tenantData) { + $tenants[] = XeroTenant::fromArray($tenantData); + } + + return $tenants; + } + + /** + * @param AccessTokenInterface $token + * @param $connectionId + * @return mixed + * @throws \League\OAuth2\Client\Provider\Exception\IdentityProviderException + */ + public function disconnect(AccessTokenInterface $token, $connectionId) + { + $url = sprintf('%s/%s', $this->getTenantsUrl(), $connectionId); + + $request = $this->getAuthenticatedRequest(self::METHOD_DELETE, $url, $token); + + $response = $this->getParsedResponse($request); + return $response; + } + + + /** + * Returns the URL for requesting the resource owner's details. + * + * @param AccessToken $token + * + * @return string + */ + public function getResourceOwnerDetailsUrl(AccessToken $token) + { + //This does not exist as it comes down in the JWT + return ''; + } + + /** + * @param AccessToken $token + * @return XeroResourceOwner + */ + public function getResourceOwner(AccessToken $token) + { + return XeroResourceOwner::fromJWT($token->getValues()['id_token']); + } + + + /** + * Checks a provider response for errors. + * + * @param ResponseInterface $response + * @param array|string $data Parsed response data + * + * @throws \Calcinai\OAuth2\Client\Provider\Exception\XeroProviderException + */ + protected function checkResponse(ResponseInterface $response, $data) + { + if ($response->getStatusCode() >= 400) { + throw new XeroProviderException( + isset($data['error']) ? $data['error'] : $response->getReasonPhrase(), + $response->getStatusCode(), + $response + ); + } + } + + /** + * @return array + */ + protected function getDefaultScopes() + { + return ['openid email profile']; + } + + /** + * Returns the string that should be used to separate scopes when building + * the URL for requesting an access token. + * + * @return string Scope separator, defaults to ' ' + */ + protected function getScopeSeparator() + { + return ' '; + } + + /** + * Generates a resource owner object from a successful resource owner + * details request. + * + * @param array $response + * @param AccessToken $token + * @return void|ResourceOwnerInterface + */ + protected function createResourceOwner(array $response, AccessToken $token) + { + // This does nothing as we get the resource owner from the token itself, don't need to make a request to get it. + } + + /** + * @param mixed|null $token + * @return array + */ + protected function getAuthorizationHeaders($token = null) + { + return [ + 'Authorization' => 'Bearer ' . $token->getToken() + ]; + } +} diff --git a/src/clients/xero/provider/XeroPkce.php b/src/clients/xero/provider/XeroPkce.php new file mode 100644 index 0000000..646c267 --- /dev/null +++ b/src/clients/xero/provider/XeroPkce.php @@ -0,0 +1,21 @@ +xero_userid = $decoded->xero_userid; + $self->preferred_username = $decoded->preferred_username; + $self->email = $decoded->email; + $self->given_name = $decoded->given_name; + $self->family_name = $decoded->family_name; + + return $self; + } +} diff --git a/src/clients/xero/provider/XeroTenant.php b/src/clients/xero/provider/XeroTenant.php new file mode 100644 index 0000000..7d48aea --- /dev/null +++ b/src/clients/xero/provider/XeroTenant.php @@ -0,0 +1,61 @@ +id = $data['id']; + $self->authEventId = $data['authEventId']; + $self->tenantId = $data['tenantId']; + $self->tenantType = $data['tenantType']; + $self->tenantName = $data['tenantName']; + $self->createdDateUtc = new \DateTime($data['createdDateUtc']); + $self->updatedDateUtc = isset($data['updatedDateUtc']) ? new \DateTime($data['updatedDateUtc']) : null; + + return $self; + } +} diff --git a/src/clients/xero/provider/exception/XeroProviderException.php b/src/clients/xero/provider/exception/XeroProviderException.php new file mode 100644 index 0000000..7ef2136 --- /dev/null +++ b/src/clients/xero/provider/exception/XeroProviderException.php @@ -0,0 +1,20 @@ +getStatusCode(), (string)$response->getBody()); + } +} diff --git a/src/helpers/Provider.php b/src/helpers/Provider.php index 0154d19..696c160 100644 --- a/src/helpers/Provider.php +++ b/src/helpers/Provider.php @@ -155,6 +155,7 @@ public static function getPrimaryColor(string $handle): ?string 'wikipedia' => '#000000', 'wordpress' => '#21759B', 'x' => '#0f141a', + 'xero' => '#02b7e3', 'xing' => '#046466', 'yahoo' => '#6001D2', 'yammer' => '#106EBE', @@ -458,6 +459,8 @@ public static function getIcon(string $handle): ?string 'x' => '', + 'xero' => '', + 'xing' => '', 'yahoo' => '', diff --git a/src/providers/Xero.php b/src/providers/Xero.php new file mode 100644 index 0000000..784ffb7 --- /dev/null +++ b/src/providers/Xero.php @@ -0,0 +1,22 @@ + Date: Sun, 20 Oct 2024 12:31:28 +1100 Subject: [PATCH 3/3] version 1.0.35 --- CHANGELOG.md | 6 ++++++ composer.json | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 178cec9..023eb17 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # Changelog +## 1.0.35 - 2024-10-20 + +### Added +- Add Xero provider. +- Add CA domain to Zoho provider. + ## 1.0.34 - 2024-09-13 ### Fixed diff --git a/composer.json b/composer.json index 8cf296c..cbaf369 100644 --- a/composer.json +++ b/composer.json @@ -1,7 +1,7 @@ { "name": "verbb/auth", "description": "A Craft CMS module to make working with authentication for third-parties a breeze.", - "version": "1.0.34", + "version": "1.0.35", "support": { "email": "support@verbb.io", "issues": "https://github.com/verbb/auth/issues?state=open",