diff --git a/packages/core/src/sso/AzureAdSsoConnector/index.ts b/packages/core/src/sso/AzureAdSsoConnector/index.ts index db3435d70..bd8587de9 100644 --- a/packages/core/src/sso/AzureAdSsoConnector/index.ts +++ b/packages/core/src/sso/AzureAdSsoConnector/index.ts @@ -31,7 +31,7 @@ export const azureAdSsoConnectorFactory: SingleSignOnFactory { + const oidcConfig = await this.getOidcConfig(); + const { nonce, redirectUri } = connectorSession; + + // Fetch token from the OIDC provider using authorization code + const { idToken, accessToken } = await fetchToken(oidcConfig, data, redirectUri); + + assertThat( + accessToken, + new SsoConnectorError(SsoConnectorErrorCodes.AuthorizationFailed, { + message: 'The access token is missing from the response.', + }) + ); + + // Verify the id token and get the user id + const { sub: id } = await getIdTokenClaims(idToken, oidcConfig, nonce); + + // Fetch user info from the userinfo endpoint + const { sub, name, picture, email, email_verified, phone, phone_verified, ...rest } = + await getUserInfo(accessToken, oidcConfig.userinfoEndpoint); + + return { + id, + ...conditional(name && { name }), + ...conditional(picture && { avatar: picture }), + ...conditional(email && email_verified && { email }), + ...conditional(phone && phone_verified && { phone }), + ...camelcaseKeys(rest), + ...conditional(email && !email_verified && { unverifiedEmail: email }), + ...conditional(phone && !phone_verified && { unverifiedPhone: phone }), + }; + } +} + +export const azureOidcSsoConnectorFactory: SingleSignOnFactory = { + providerName: SsoProviderName.AZURE_AD_OIDC, + logo: '', + logoDark: + '', + description: { + en: 'OpenID Connect on the Microsoft identity platform. Formerly known as Azure AD OIDC.', + de: 'OpenID Connect auf der Microsoft-Identitätsplattform. Früher bekannt als Azure AD OIDC.', + es: 'OpenID Connect en la plataforma de identidad de Microsoft. Anteriormente conocido como Azure AD OIDC.', + fr: 'OpenID Connect sur la plateforme d’identité Microsoft. Anciennement connu sous le nom de Azure AD OIDC.', + it: 'OpenID Connect sulla piattaforma di identità Microsoft. Precedentemente noto come Azure AD OIDC.', + ja: 'Microsoft アイデンティティ プラットフォーム上の OpenID Connect. 以前は Azure AD OIDC として知られていました。', + ko: 'Microsoft Identity 플랫폼에서 OpenID Connect. 이전에는 Azure AD OIDC로 알려져 있었습니다.', + 'pl-PL': 'OpenID Connect na platformie tożsamości Microsoft. Dawniej znany jako Azure AD OIDC.', + 'pt-BR': + 'OpenID Connect na plataforma de identidade da Microsoft. Anteriormente conhecido como Azure AD OIDC.', + 'pt-PT': + 'OpenID Connect na plataforma de identidade da Microsoft. Anteriormente conhecido como Azure AD OIDC.', + ru: 'OpenID Connect на платформе идентификации Microsoft. Ранее известный как Azure AD OIDC.', + 'tr-TR': + 'Microsoft kimlik platformunda OpenID Connect. Eskiden Azure AD OIDC olarak bilinirdi.', + 'zh-CN': 'Microsoft 身份平台上的 OpenID Connect. 以前称为 Azure AD OIDC。', + 'zh-HK': 'Microsoft 身份平台上的 OpenID Connect. 以前稱為 Azure AD OIDC。', + 'zh-TW': 'Microsoft 身份平台上的 OpenID Connect. 以前稱為 Azure AD OIDC。', + }, + + name: { + en: 'Microsoft OpenID Connect', + }, + configGuard: basicOidcConnectorConfigGuard, + constructor: AzureOidcSsoConnector, +}; diff --git a/packages/core/src/sso/OidcConnector/index.ts b/packages/core/src/sso/OidcConnector/index.ts index 32e7205dc..480318ed2 100644 --- a/packages/core/src/sso/OidcConnector/index.ts +++ b/packages/core/src/sso/OidcConnector/index.ts @@ -95,7 +95,6 @@ class OidcConnector { * @param data unknown oidc authorization response * @param connectorSession The connector session data from the oidc provider session storage * @returns The user info from the OIDC provider - */ async getUserInfo( connectorSession: SingleSignOnConnectorSession, diff --git a/packages/core/src/sso/index.ts b/packages/core/src/sso/index.ts index 28864642b..9f1547d99 100644 --- a/packages/core/src/sso/index.ts +++ b/packages/core/src/sso/index.ts @@ -5,6 +5,10 @@ import { type AzureAdSsoConnector, azureAdSsoConnectorFactory, } from './AzureAdSsoConnector/index.js'; +import { + type AzureOidcSsoConnector, + azureOidcSsoConnectorFactory, +} from './AzureOidcSsoConnector/index.js'; import { type GoogleWorkspaceSsoConnector, googleWorkSpaceSsoConnectorFactory, @@ -12,7 +16,7 @@ import { } from './GoogleWorkspaceSsoConnector/index.js'; import { oidcSsoConnectorFactory, type OidcSsoConnector } from './OidcSsoConnector/index.js'; import { oktaSsoConnectorFactory, type OktaSsoConnector } from './OktaSsoConnector/index.js'; -import { type SamlSsoConnector, samlSsoConnectorFactory } from './SamlSsoConnector/index.js'; +import { samlSsoConnectorFactory, type SamlSsoConnector } from './SamlSsoConnector/index.js'; import { type basicOidcConnectorConfigGuard } from './types/oidc.js'; import { type samlConnectorConfigGuard } from './types/saml.js'; @@ -22,6 +26,7 @@ type SingleSignOnConstructor = { [SsoProviderName.AZURE_AD]: typeof AzureAdSsoConnector; [SsoProviderName.GOOGLE_WORKSPACE]: typeof GoogleWorkspaceSsoConnector; [SsoProviderName.OKTA]: typeof OktaSsoConnector; + [SsoProviderName.AZURE_AD_OIDC]: typeof AzureOidcSsoConnector; }; export type SingleSignOnConnectorConfig = { @@ -30,6 +35,7 @@ export type SingleSignOnConnectorConfig = { [SsoProviderName.AZURE_AD]: typeof samlConnectorConfigGuard; [SsoProviderName.GOOGLE_WORKSPACE]: typeof googleWorkspaceSsoConnectorConfigGuard; [SsoProviderName.OKTA]: typeof basicOidcConnectorConfigGuard; + [SsoProviderName.AZURE_AD_OIDC]: typeof basicOidcConnectorConfigGuard; }; export type SingleSignOnFactory = { @@ -50,6 +56,7 @@ export const ssoConnectorFactories: { [SsoProviderName.AZURE_AD]: azureAdSsoConnectorFactory, [SsoProviderName.GOOGLE_WORKSPACE]: googleWorkSpaceSsoConnectorFactory, [SsoProviderName.OKTA]: oktaSsoConnectorFactory, + [SsoProviderName.AZURE_AD_OIDC]: azureOidcSsoConnectorFactory, }; export const standardSsoConnectorProviders = Object.freeze([ diff --git a/packages/schemas/src/types/sso-connector.ts b/packages/schemas/src/types/sso-connector.ts index 6e1b273ee..145393922 100644 --- a/packages/schemas/src/types/sso-connector.ts +++ b/packages/schemas/src/types/sso-connector.ts @@ -20,6 +20,7 @@ export enum SsoProviderName { AZURE_AD = 'AzureAD', GOOGLE_WORKSPACE = 'GoogleWorkspace', OKTA = 'Okta', + AZURE_AD_OIDC = 'AzureAdOidc', } export const singleSignOnDomainBlackList = Object.freeze([