Configuration d’un backend personnalisé

Configurez un écran de connexion personnalisé pour les visiteurs de votre documentation

circle-exclamation

Ce guide vous explique comment configurer un écran de connexion protégé pour votre site de documentation GitBook à l’aide de votre propre personnalisé backend d’authentification.

circle-info

Si vous utilisez l’un des fournisseurs d’authentification que nous prenons en charge ou si vous avez un backend compatible OpenID Connectarrow-up-right (OIDC), consultez nos guides d’intégration pour une configuration plus fluide : Auth0 | Azure AD | Okta | AWS Cognito | OIDC

Aperçu

Pour configurer un système d’authentification personnalisé pour votre site GitBook, suivez ces étapes clés :

1

Créer un backend personnalisé pour authentifier vos utilisateurs

Implémentez un backend qui invite les utilisateurs à se connecter et les authentifie.

2

Signer et transmettre un jeton JWT à GitBook

Créez un jeton JWT et signez-le avec la clé privée de votre site.

3

Configurer une URL de repli

Configurez une URL à utiliser lorsqu’un visiteur non authentifié accède à votre site.

4

Configurer un accès authentifié multi-locataire (facultatif)

Configurez votre backend pour gérer l’authentification sur plusieurs sites GitBook.

5

Configurer votre backend pour le contenu adaptatif (facultatif)

Configurez votre backend pour fonctionner avec le contenu adaptatif dans GitBook.

1. Créer un backend personnalisé pour authentifier vos utilisateurs

Afin de commencer à authentifier les utilisateurs avant qu’ils puissent consulter votre documentation, vous devrez mettre en place un serveur capable de gérer la connexion et l’authentification des utilisateurs.

Votre backend doit :

  • Inviter les utilisateurs à se connecter à l’aide de votre méthode d’authentification préférée.

  • Valider les identifiants des utilisateurs et les authentifier.

  • Générer et signer un jeton Web JSON (JWT) lors de l’authentification réussie.

  • Rediriger les utilisateurs vers GitBook avec le JWT inclus dans l’URL.

2. Signer et transmettre un jeton JWT à GitBook

Une fois que votre backend authentifie un utilisateur, il doit générer un JWT et le transmettre à GitBook lors de la redirection vers votre site. Le jeton doit être signé à l’aide de la clé privée fournie dans les paramètres d’audience de votre site après l’activation de l’accès authentifié.

L’exemple suivant devrait montrer à quoi pourrait ressembler un gestionnaire de requête de connexion dans votre backend personnalisé :

3. Configurer une URL de repli

L’URL de repli est utilisée lorsqu’un visiteur non authentifié tente d’accéder à votre site protégé. GitBook le redirigera alors vers cette URL.

Cette URL doit pointer vers un gestionnaire dans votre backend personnalisé, où vous pouvez lui demander de se connecter, l’authentifier, puis le rediriger vers votre site avec le JWT inclus dans l’URL.

Par exemple, si votre écran de connexion se trouve à https://example.com/login, vous devez inclure cette valeur comme URL de repli.

Vous pouvez configurer cette URL de repli dans les paramètres d’audience de votre site, sous l’onglet « Accès authentifié ».

A GitBook screenshot showing where to configure a fallback URL
Configurer une URL de repli

Lors de la redirection vers l’URL de repli, GitBook inclut un location paramètre de requête à l’URL de repli que vous pouvez utiliser dans votre gestionnaire pour rediriger l’utilisateur vers l’emplacement d’origine de l’utilisateur :

circle-exclamation

4. Configurer un accès authentifié multi-locataire (facultatif)

Si vous utilisez GitBook comme plateforme pour fournir du contenu à vos différents clients, vous devez probablement configurer un accès authentifié multi-locataire. Votre backend d’authentification doit être responsable de la gestion de l’authentification sur plusieurs sites différents. Cela est possible dans GitBook avec quelques petits ajustements dans le code de votre backend d’authentification personnalisé.

Ajouter tous les locataires à votre serveur d’authentification

Votre backend d’authentification devra connaître les clés de signature JWT et les URL de tous les sites GitBook qu’il est censé gérer. Si vous avez deux sites dans votre organisation pour le client A et le client B, vous pouvez imaginer votre code d’authentification stockant un tel mappage :

Donner un contexte supplémentaire à votre serveur d’authentification

Lorsqu’il est impossible à GitBook d’authentifier la requête d’un utilisateur, il le redirige vers l’URL de repli. Cette URL pointe vers votre backend d’authentification, qui est chargé d’authentifier l’utilisateur et de le rediriger vers le contenu demandé.

Pour prendre en charge plusieurs locataires, votre backend d’authentification doit savoir à quel site GitBook l’utilisateur est censé accéder. Cette information peut être transmise dans l’URL de repli.

Ainsi, par exemple, vous pourriez configurer les URL de repli de chaque site comme suit :

Site GitBook
URL de repli

Site du client A

https://auth-backend.acme.org/login?site=customer-a

Site du client B

https://auth-backend.acme.org/login?site=customer-b

Votre backend d’authentification peut ensuite vérifier ces informations et gérer la redirection vers le bon site en conséquence :

5. Configurer votre backend pour le contenu adaptatif (facultatif)

Pour tirer parti de la fonctionnalité de contenu adaptatif dans votre configuration d’accès authentifié, vous pouvez inclure des attributs utilisateur supplémentaires (revendications) dans la charge utile du JWT que votre backend personnalisé génère et inclure dans l’URL lors de la redirection de l’utilisateur vers le site.

Ces revendications, lorsqu’elles sont incluses dans le JWT, sont utilisées par GitBook pour adapter le contenu dynamiquement pour les visiteurs de votre site.

Pour tout mettre ensemble, l’exemple de code suivant montre comment vous pourriez inclure ces revendications dans le JWT, qui peuvent ensuite être utilisées par GitBook pour adapter le contenu à vos visiteurs :

Après avoir configuré et défini les bonnes revendications à envoyer à GitBook, rendez-vous dans «Adapter votre contenu» pour continuer la configuration de votre site.

Mis à jour

Ce contenu vous a-t-il été utile ?