Aller au contenu principal

Déboguer et tester votre interface utilisateur personnalisée localement

Pour les utilisateurs de Logto Cloud, nous avons simplifié l'intégration de votre propre interface utilisateur à Logto. Les utilisateurs Cloud peuvent désormais télécharger un fichier zip contenant les ressources de l'interface utilisateur personnalisée dans Console > Expérience de connexion > Branding > Apportez votre UI (Consultez la page Apportez votre UI pour plus de détails.)

Cependant, lors du développement de telles pages d'interface utilisateur personnalisées, les utilisateurs souhaitent tester et déboguer le code localement avant de le télécharger sur Logto Cloud. Cette commande CLI vous aide à configurer un tunnel local et à connecter ensemble les 3 entités suivantes : votre point de terminaison d'authentification Logto Cloud, votre application et votre interface utilisateur de connexion personnalisée.

Pourquoi en ai-je besoin ?

Par défaut, lorsque vous cliquez sur le bouton "connexion" dans votre application, vous serez redirigé vers la page de connexion configurée au point de terminaison Logto. Un flux de connexion réussi peut être illustré comme suit :

Mais maintenant que vous développez votre propre interface utilisateur de connexion personnalisée, vous avez besoin d'un moyen de naviguer vers les pages de votre interface utilisateur de connexion personnalisée exécutées sur votre machine locale à la place. Cela nécessite un service de tunnel local pour intercepter les requêtes sortantes de votre application et les rediriger vers vos pages d'interface utilisateur de connexion personnalisées.

De plus, vous devez interagir avec Logto's Experience API pour authentifier les utilisateurs et gérer les sessions. Ce service aidera également à transférer ces requêtes Experience API vers Logto Cloud afin d'éviter les problèmes de CORS.

Le diagramme de séquence ci-dessous illustre comment un flux de "connexion" réussi fonctionne avec votre interface utilisateur personnalisée et le service de tunnel en place :

Avec le service de tunnel en place, vous pouvez désormais développer et tester votre interface utilisateur de connexion personnalisée localement, sans avoir besoin de télécharger les ressources sur Logto Cloud à chaque modification.

Instructions

Étape 1 : Exécutez la commande

En supposant que votre ID de locataire Cloud soit foobar, et que vous ayez une page de connexion personnalisée exécutée sur votre serveur de développement local à http://localhost:4000, vous pouvez exécuter la commande de cette manière :

logto-tunnel -p 9000 --experience-uri http://localhost:4000/ --endpoint https://foobar.logto.app/

Cela fonctionne également si vous avez configuré un domaine personnalisé dans Logto :

logto-tunnel -p 9000 --experience-uri http://localhost:4000/ --endpoint https://your.custom.domain/

Alternativement, la commande prend également en charge les ressources HTML statiques sans avoir besoin de les exécuter d'abord sur un serveur de développement. Assurez-vous simplement qu'il y a un index.html dans le chemin que vous avez spécifié.

logto-tunnel -p 9000 --experience-path /path/to/your/static/files --endpoint https://foobar.logto.app/

Étape 2 : Mettez à jour l'URI du point de terminaison dans votre application

Enfin, exécutez votre application et définissez son point de terminaison Logto sur l'adresse du service de tunnel http://localhost:9000/ à la place.

Prenons une application React comme exemple :

import { LogtoProvider, LogtoConfig } from '@logto/react';

const config: LogtoConfig = {
// endpoint: 'https://foobar.logto.app/', // point de terminaison Logto Cloud original
endpoint: 'http://localhost:9000/', // adresse du service de tunnel
appId: '<your-application-id>',
};

const App = () => (
<LogtoProvider config={config}>
<YourAppContent />
</LogtoProvider>
);

Si vous utilisez la connexion sociale, vous devez également mettre à jour l'URI de redirection dans les paramètres de votre fournisseur social vers l'adresse du service de tunnel.

http://localhost:9000/callback/<connector-id>

Si tout est correctement configuré, lorsque vous cliquez sur le bouton "connexion" dans votre application, vous devriez être redirigé vers votre page de connexion personnalisée au lieu de l'interface utilisateur intégrée de Logto, avec une session valide (cookies) qui vous permet d'interagir davantage avec Logto Experience API.

Bon codage !

Automatisez le déploiement de votre interface utilisateur de connexion personnalisée avec le workflow GitHub Actions