Aller au contenu principal

Configurer la connexion sociale avec OpenID Connect (OIDC)

Le connecteur officiel Logto pour le protocole OpenID Connect (OIDC).

astuce:

Dans ce guide, nous supposons que vous avez des connaissances de base sur les Connecteurs Logto. Si ce n'est pas le cas, consultez le guide Configurer les connecteurs pour commencer.

Commencer

Le connecteur OIDC permet la connexion de Logto à un fournisseur d'identité sociale arbitraire qui prend en charge le protocole OIDC.

ℹ️ Remarque

Le connecteur OIDC est un type spécial de connecteur dans Logto, vous pouvez ajouter quelques connecteurs basés sur OIDC.

Créez votre application OIDC

Lorsque vous ouvrez cette page, nous croyons que vous savez déjà à quel fournisseur d'identité sociale vous souhaitez vous connecter. La première chose à faire est de confirmer que le fournisseur d'identité prend en charge le protocole OIDC, ce qui est une condition préalable pour configurer un connecteur valide. Ensuite, suivez les instructions du fournisseur d'identité pour enregistrer et créer l'application pertinente pour l'Autorisation OIDC.

Configurez votre connecteur

Nous ne prenons en charge que le type de subvention "Authorization Code" pour des raisons de sécurité et il peut parfaitement s'adapter au scénario de Logto.

clientId et clientSecret peuvent être trouvés sur la page des détails de vos applications OIDC.

clientId : L'ID client est un identifiant unique qui identifie l'application cliente lors de l'enregistrement auprès du serveur d'autorisation. Cet ID est utilisé par le serveur d'autorisation pour vérifier l'identité de l'application cliente et pour associer tous les jetons d’accès autorisés à cette application cliente spécifique.

clientSecret : Le secret client est une clé confidentielle qui est délivrée à l'application cliente par le serveur d'autorisation lors de l'enregistrement. L'application cliente utilise cette clé secrète pour s'authentifier auprès du serveur d'autorisation lors de la demande de jetons d’accès. Le secret client est considéré comme une information confidentielle et doit être gardé en sécurité à tout moment.

tokenEndpointAuthMethod : La méthode d'authentification du point de terminaison de jeton est utilisée par l'application cliente pour s'authentifier auprès du serveur d'autorisation lors de la demande de jetons d’accès. Pour découvrir les méthodes prises en charge, consultez le champ token_endpoint_auth_methods_supported disponible au point de terminaison de découverte OpenID Connect du fournisseur de service OAuth 2.0, ou référez-vous à la documentation pertinente fournie par le fournisseur de service OAuth 2.0.

clientSecretJwtSigningAlgorithm (Optionnel) : Requis uniquement lorsque tokenEndpointAuthMethod est client_secret_jwt. L'algorithme de signature JWT du secret client est utilisé par l'application cliente pour signer le JWT qui est envoyé au serveur d'autorisation lors de la requête de jeton.

scope : Le paramètre de portée est utilisé pour spécifier l'ensemble des ressources et des permissions auxquelles l'application cliente demande l'accès. Le paramètre de portée est généralement défini comme une liste de valeurs séparées par des espaces qui représentent des permissions spécifiques. Par exemple, une valeur de portée de "read write" pourrait indiquer que l'application cliente demande un accès en lecture et écriture aux données d'un utilisateur.

Vous êtes censé trouver authorizationEndpoint, tokenEndpoint, jwksUri et issuer comme informations de configuration du fournisseur OpenID. Ils devraient être disponibles dans la documentation du fournisseur social.

authenticationEndpoint : Ce point de terminaison est utilisé pour initier le processus d'authentification. Le processus d'authentification implique généralement que l'utilisateur se connecte et accorde l'autorisation à l'application cliente d'accéder à ses ressources.

tokenEndpoint : Ce point de terminaison est utilisé par l'application cliente pour obtenir un jeton d’identifiant qui peut être utilisé pour accéder aux ressources demandées. L'application cliente envoie généralement une requête au point de terminaison de jeton avec un type de subvention et un code d'autorisation pour recevoir un jeton d’identifiant.

jwksUri : Il s'agit de l'URL du point de terminaison où l'ensemble de clés Web JSON (JWKS) du fournisseur d'identité sociale (IdP en abrégé) peut être obtenu. Le JWKS est un ensemble de clés cryptographiques que l'IdP utilise pour signer et vérifier les JSON Web Tokens (JWT) qui sont émis lors du processus d'authentification. Le jwksUri est utilisé par la partie de confiance (RP) pour obtenir les clés publiques utilisées par l'IdP pour signer les JWT, afin que la RP puisse vérifier l'authenticité et l'intégrité des JWT reçus de l'IdP.

issuer : Il s'agit de l'identifiant unique de l'IdP qui est utilisé par la RP pour vérifier les JWT reçus de l'IdP. Il est inclus dans les JWT en tant que revendication iss (le jeton d’identifiant est toujours un JWT). La valeur de l'émetteur doit correspondre à l'URL du serveur d'autorisation de l'IdP, et elle doit être une URI que la RP considère comme fiable. Lorsque la RP reçoit un JWT, elle vérifie la revendication iss pour s'assurer qu'il a été émis par un IdP de confiance, et que le JWT est destiné à être utilisé avec la RP.

Ensemble, jwksUri et issuer fournissent un mécanisme sécurisé pour la RP pour vérifier l'identité de l'utilisateur final lors du processus d'authentification. En utilisant les clés publiques obtenues à partir du jwksUri, la RP peut vérifier l'authenticité et l'intégrité des JWT émis par l'IdP. La valeur de l'émetteur garantit que la RP n'accepte que les JWT qui ont été émis par un IdP de confiance, et que les JWT sont destinés à être utilisés avec la RP.

Étant donné qu'une requête d’authentification est toujours requise, un authRequestOptionalConfig est fourni pour regrouper toutes les configurations optionnelles, vous pouvez trouver des détails sur OIDC Authentication Request. Vous pouvez également constater que nonce est manquant dans cette configuration. Étant donné que nonce doit être identique pour chaque requête, nous avons placé la génération de nonce dans l'implémentation du code. Alors ne vous inquiétez pas ! Le jwksUri et l'issuer mentionnés précédemment sont également inclus dans idTokenVerificationConfig.

Vous vous demandez peut-être pourquoi un protocole OIDC standard prend en charge à la fois les flux implicites et hybrides, alors que le connecteur Logto ne prend en charge que le flux d'autorisation. Il a été déterminé que les flux implicites et hybrides sont moins sécurisés que le flux d'autorisation. En raison de l'accent mis par Logto sur la sécurité, il ne prend en charge que le flux d'autorisation pour le plus haut niveau de sécurité pour ses utilisateurs, malgré sa nature légèrement moins pratique.

responseType et grantType ne peuvent être que des valeurs FIXES avec le flux "Authorization Code", nous les rendons donc optionnels et les valeurs par défaut seront automatiquement remplies.

ℹ️ Remarque

Pour tous les types de flux, nous avons fourni une clé customConfig OPTIONNELLE pour placer vos paramètres personnalisés. Chaque fournisseur d'identité sociale pourrait avoir sa propre variante sur le protocole standard OIDC. Si votre fournisseur d'identité sociale souhaité respecte strictement le protocole standard OIDC, alors vous n'avez pas besoin de vous soucier de customConfig.

Types de configuration

NomTypeRequis
scopestringVrai
clientIdstringVrai
clientSecretstringVrai
authorizationEndpointstringVrai
tokenEndpointstringVrai
idTokenVerificationConfigIdTokenVerificationConfigVrai
authRequestOptionalConfigAuthRequestOptionalConfigFaux
customConfigRecord<string, string>Faux
Propriétés AuthRequestOptionalConfigTypeRequis
responseTypestringFaux
tokenEndpointstringFaux
responseModestringFaux
displaystringFaux
promptstringFaux
maxAgestringFaux
uiLocalesstringFaux
idTokenHintstringFaux
loginHintstringFaux
acrValuesstringFaux
Propriétés IdTokenVerificationConfigTypeRequis
jwksUristringVrai
issuerstring | string[]Faux
audiencestring | string[]Faux
algorithmsstring[]Faux
clockTolerancestring | numberFaux
critRecord<string, string | boolean>Faux
currentDateDateFaux
maxTokenAgestring | numberFaux
subjectstringFaux
typstringFaux

Voir ici pour plus de détails sur IdTokenVerificationConfig.