Logto est une alternative à Auth0 conçue pour les applications modernes et les produits SaaS. Il offre des services à la fois Cloud et Open-source pour vous aider à lancer rapidement votre système de gestion des identités et des accès (IAM). Profitez de l'authentification, de l'autorisation et de la gestion multi-locataires tout-en-un.
Nous recommandons de commencer avec un locataire de développement gratuit sur Logto Cloud. Cela vous permet d'explorer facilement toutes les fonctionnalités.
Dans cet article, nous allons parcourir les étapes pour construire rapidement l'expérience de connexion SendGrid (authentification utilisateur) avec Android (Kotlin / Java) et Logto.
Prérequis
- Une instance Logto en cours d'exécution. Consultez la page d'introduction pour commencer.
- Connaissance de base de Android (Kotlin / Java).
- Un compte SendGrid utilisable.
Créer une application dans Logto
Logto est basé sur l'authentification OpenID Connect (OIDC) et l'autorisation OAuth 2.0. Il prend en charge la gestion des identités fédérées à travers plusieurs applications, communément appelée authentification unique (SSO).
Pour créer votre application Native app, suivez simplement ces étapes :
- Ouvrez la Logto Console. Dans la section "Get started", cliquez sur le lien "View all" pour ouvrir la liste des frameworks d'application. Alternativement, vous pouvez naviguer vers Logto Console > Applications, et cliquer sur le bouton "Create application".
- Dans la fenêtre modale qui s'ouvre, cliquez sur la section "Native app" ou filtrez tous les frameworks "Native app" disponibles en utilisant les cases à cocher de filtre rapide à gauche. Cliquez sur la carte du framework "Android" pour commencer à créer votre application.
- Entrez le nom de l'application, par exemple, "Bookstore", et cliquez sur "Create application".
🎉 Ta-da ! Vous venez de créer votre première application dans Logto. Vous verrez une page de félicitations qui inclut un guide d'intégration détaillé. Suivez le guide pour voir quelle sera l'expérience dans votre application.
Intégrer Logto SDK
- L'exemple est basé sur le système View et le modèle View, mais les concepts sont les mêmes lors de l'utilisation de Jetpack Compose.
- L'exemple est écrit en Kotlin, mais les concepts sont les mêmes pour Java.
- Les projets d'exemple en Kotlin et en Java sont disponibles sur notre répertoire SDK.
- La vidéo tutorielle est disponible sur notre chaîne YouTube.
Installation
Le niveau API Android minimal pris en charge par Logto Android SDK est le niveau 24.
Avant d'installer Logto Android SDK, assurez-vous que mavenCentral() est ajouté à votre configuration de dépôt dans le fichier de construction du projet Gradle :
dependencyResolutionManagement {
repositories {
mavenCentral()
}
}
Ajoutez Logto Android SDK à vos dépendances :
- Kotlin
- Groovy
dependencies {
implementation("io.logto.sdk:android:1.1.3")
}
dependencies {
implementation 'io.logto.sdk:android:1.1.3'
}
Étant donné que le SDK nécessite un accès à Internet, vous devez ajouter la permission suivante à votre fichier AndroidManifest.xml :
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<!-- ajouter la permission internet -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- autres configurations... -->
</manifest>
Init LogtoClient
Créez un LogtoViewModel.kt et initialisez LogtoClient dans ce modèle de vue :
//...avec d'autres imports
import io.logto.sdk.android.LogtoClient
import io.logto.sdk.android.type.LogtoConfig
class LogtoViewModel(application: Application) : AndroidViewModel(application) {
private val logtoConfig = LogtoConfig(
endpoint = "<votre-point-de-terminaison-logto>",
appId = "<votre-id-app>",
scopes = null,
resources = null,
usingPersistStorage = true,
)
private val logtoClient = LogtoClient(logtoConfig, application)
companion object {
val Factory: ViewModelProvider.Factory = object : ViewModelProvider.Factory {
@Suppress("UNCHECKED_CAST")
override fun <T : ViewModel> create(
modelClass: Class<T>,
extras: CreationExtras
): T {
// Obtenez l'objet Application à partir des extras
val application = checkNotNull(extras[APPLICATION_KEY])
return LogtoViewModel(application) as T
}
}
}
}
ensuite, créez un LogtoViewModel pour votre MainActivity.kt :
//...avec d'autres imports
class MainActivity : AppCompatActivity() {
private val logtoViewModel: LogtoViewModel by viewModels { LogtoViewModel.Factory }
//...autres codes
}
Configurer l'URI de redirection
Passons à la page des détails de l'application de Logto Console. Ajoutez une URI de redirection io.logto.android://io.logto.sample/callback et cliquez sur "Enregistrer les modifications".
Implémenter la connexion et la déconnexion
Avant d'appeler logtoClient.signIn, assurez-vous d'avoir correctement configuré l'URI de redirection dans la console d'administration.
Vous pouvez utiliser logtoClient.signIn pour connecter l'utilisateur et logtoClient.signOut pour déconnecter l'utilisateur.
Par exemple, dans une application Android :
//...avec d'autres imports
class LogtoViewModel(application: Application) : AndroidViewModel(application) {
// ...autres codes
// Ajouter une donnée en direct pour observer le statut d'authentification
private val _authenticated = MutableLiveData(logtoClient.isAuthenticated)
val authenticated: LiveData<Boolean>
get() = _authenticated
fun signIn(context: Activity) {
logtoClient.signIn(context, "io.logto.android://io.logto.sample/callback") { logtoException ->
logtoException?.let { println(it) }
// Mettre à jour la donnée en direct
_authenticated.postValue(logtoClient.isAuthenticated)
}
}
fun signOut() {
logtoClient.signOut { logtoException ->
logtoException?.let { println(it) }
// Mettre à jour la donnée en direct
_authenticated.postValue(logtoClient.isAuthenticated)
}
}
}
Ensuite, appelez les méthodes signIn et signOut dans votre activité :
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
//...autres codes
// Supposons que vous ayez un bouton avec l'identifiant "sign_in_button" dans votre mise en page
val signInButton = findViewById<Button>(R.id.sign_in_button)
signInButton.setOnClickListener {
logtoViewModel.signIn(this)
}
// Supposons que vous ayez un bouton avec l'identifiant "sign_out_button" dans votre mise en page
val signOutButton = findViewById<Button>(R.id.sign_out_button)
signOutButton.setOnClickListener {
if (logtoViewModel.authenticated) { // Vérifiez si l'utilisateur est authentifié
logtoViewModel.signOut()
}
}
// Observez le statut d'authentification pour mettre à jour l'interface utilisateur
logtoViewModel.authenticated.observe(this) { authenticated ->
if (authenticated) {
// L'utilisateur est authentifié
signInButton.visibility = View.GONE
signOutButton.visibility = View.VISIBLE
} else {
// L'utilisateur n'est pas authentifié
signInButton.visibility = View.VISIBLE
signOutButton.visibility = View.GONE
}
}
}
}
Point de contrôle : Testez votre application
Maintenant, vous pouvez tester votre application :
- Exécutez votre application, vous verrez le bouton de connexion.
- Cliquez sur le bouton de connexion, le SDK initiera le processus de connexion et vous redirigera vers la page de connexion Logto.
- Après vous être connecté, vous serez redirigé vers votre application et verrez le bouton de déconnexion.
- Cliquez sur le bouton de déconnexion pour effacer le stockage des jetons et vous déconnecter.
Ajouter le connecteur SendGrid
Le connecteur Email est une méthode utilisée pour envoyer des mots de passe à usage unique (OTP) pour l'authentification. Il permet la vérification de Adresse e-mail pour prendre en charge l'authentification sans mot de passe, y compris l'inscription, la connexion, l'authentification à deux facteurs (2FA) et la récupération de compte basées sur Email. Vous pouvez facilement connecter SendGrid en tant que fournisseur Email. Avec le connecteur Email de Logto, vous pouvez configurer cela en quelques minutes seulement.
Pour ajouter un connecteur Email, suivez simplement ces étapes :
- Accédez à Console > Connector > Email and SMS connectors.
- Pour ajouter un nouveau connecteur Email, cliquez sur le bouton "Configurer" et sélectionnez "SendGrid".
- Consultez la documentation README pour le fournisseur sélectionné.
- Complétez les champs de configuration dans la section "Configuration des paramètres".
- Personnalisez le modèle Email à l'aide de l'éditeur JSON.
- Testez votre configuration en envoyant un code de vérification à votre Adresse e-mail.
Si vous suivez le guide du connecteur sur place, vous pouvez passer à la section suivante.
Configurer Connecteur d'e-mail SendGrid
Enregistrer un compte SendGrid
Créez un nouveau compte sur le site web de SendGrid. Vous pouvez ignorer cette étape si vous possédez déjà un compte.
Vérifier les expéditeurs
Rendez-vous sur la page de console SendGrid et connectez-vous avec votre compte SendGrid.
Les expéditeurs indiquent les adresses à partir desquelles notre e-mail de code de vérification sera envoyé. Afin d'envoyer des e-mails via le serveur de messagerie SendGrid, vous devez vérifier au moins un expéditeur.
Depuis la page de console SendGrid, allez dans "Settings" -> "Sender Authentication" depuis la barre latérale.
L'authentification de domaine est recommandée mais non obligatoire. Vous pouvez cliquer sur "Get started" dans la carte "Authenticate Your Domain" et suivre le guide pour lier et vérifier un expéditeur à SendGrid.
En cliquant sur le bouton "Verify a Single Sender" dans le panneau, vous accédez à un formulaire nécessitant des informations essentielles pour créer un expéditeur. Suivez le guide, remplissez tous les champs et cliquez sur le bouton "Create".
Après la création de l'expéditeur unique, un e-mail contenant un lien de vérification sera envoyé à l'adresse e-mail de votre expéditeur. Rendez-vous dans votre boîte de réception, trouvez l'e-mail de vérification et terminez la vérification de l'expéditeur unique en cliquant sur le lien fourni dans l'e-mail. Vous pouvez maintenant envoyer des e-mails via le connecteur SendGrid en utilisant l'expéditeur que vous venez de vérifier.
Créer des clés API
Commençons depuis la page de console SendGrid, allez dans "Settings" -> "API Keys" depuis la barre latérale.
Cliquez sur "Create API Key" dans le coin supérieur droit de la page des clés API. Saisissez le nom de la clé API et personnalisez les "API Key Permission" selon votre cas d'utilisation. Un accès global Full Access ou Restricted Access avec un accès complet à Mail Send est requis avant d'envoyer des e-mails avec cette clé API.
La clé API vous est présentée à l'écran dès que vous avez terminé le processus Create API Key. Vous devez sauvegarder cette clé API dans un endroit sûr car c'est la seule occasion où vous pourrez la voir.
Configurer votre connecteur
Renseignez le champ apiKey avec la clé API créée dans la section "Créer des clés API".
Renseignez les champs fromEmail et fromName avec l’adresse d’expéditeur et le surnom de l’expéditeur. Vous pouvez trouver les détails de l’expéditeur sur la page "Sender Management". fromName est OPTIONNEL, vous pouvez donc le laisser vide.
Vous pouvez ajouter plusieurs modèles de connecteur de messagerie SendGrid pour différents cas. Voici un exemple d’ajout d’un seul modèle :
- Renseignez le champ
subject, qui sert de titre aux e-mails. - Renseignez le champ
contentavec un contenu de type chaîne de caractères arbitraire. N'oubliez pas de laisser l’espace réservé{{code}}pour le code de vérification aléatoire. - Renseignez le champ
usageTypeavecRegister,SignIn,ForgotPassword,Genericselon les différents cas d’utilisation. - Renseignez le champ
typeavectext/plainoutext/htmlselon le type de contenu.
Pour activer tous les parcours utilisateur, les modèles avec usageType Register, SignIn, ForgotPassword et Generic sont requis.
Voici un exemple de JSON de modèle de connecteur SendGrid.
[
{
"subject": "<register-template-subject>",
"content": "<Logto: Votre code de vérification est {{code}}. (modèle d'inscription)>",
"usageType": "Register",
"type": "text/plain",
},
{
"subject": "<sign-in-template-subject>",
"content": "<Logto: Votre code de vérification est {{code}}. (modèle de connexion)>",
"usageType": "SignIn",
"type": "text/plain",
},
{
"subject": "<forgot-password-template-subject>",
"content": "<Logto: Votre code de vérification est {{code}}. (modèle mot de passe oublié)>",
"usageType": "ForgotPassword",
"type": "text/plain",
},
{
"subject": "<generic-template-subject>",
"content": "<Logto: Votre code de vérification est {{code}}. (modèle générique)>",
"usageType": "Generic",
"type": "text/plain",
},
]
Tester le connecteur e-mail SendGrid
Vous pouvez saisir une adresse e-mail et cliquer sur "Send" pour vérifier si les paramètres fonctionnent avant de cliquer sur "Save and Done".
C’est tout. N’oubliez pas de Activer le connecteur pour l’inscription et la connexion.
Types de configuration
| Nom | Type |
|---|---|
| apiKey | string |
| fromEmail | string |
| fromName | string (OPTIONNEL) |
| templates | Template[] |
| Propriétés du modèle | Type | Valeurs Enum |
|---|---|---|
| subject | string | N/A |
| content | string | N/A |
| usageType | enum string | 'Register' / 'SignIn' / 'ForgotPassword' / 'Generic' |
| type | enum string | 'text/plain' / 'text/html' |
Enregistrer votre configuration
Vérifiez que vous avez rempli les valeurs nécessaires dans la zone de configuration du connecteur Logto. Cliquez sur "Enregistrer et terminer" (ou "Enregistrer les modifications") et le connecteur SendGrid devrait être disponible maintenant.
Activer le connecteur SendGrid dans l'expérience de connexion
Une fois que vous avez créé un connecteur avec succès, vous pouvez activer la connexion et l'inscription sans mot de passe basées sur le numéro de téléphone.
- Accédez à Console > Expérience de connexion > Inscription et connexion.
- Configurez les méthodes d'inscription (Optionnel) :
- Sélectionnez "Adresse e-mail" ou "Email ou numéro de téléphone" comme identifiant d'inscription.
- "Vérifier à l'inscription" est forcé d'être activé. Vous pouvez également activer "Créer un mot de passe" lors de l'inscription.
- Configurez les méthodes de connexion :
- Sélectionnez Adresse e-mail comme l'un des identifiants de connexion. Vous pouvez fournir plusieurs identifiants disponibles (email, numéro de téléphone et nom d'utilisateur).
- Sélectionnez "Code de vérification" et / ou "Mot de passe" comme facteur d'authentification.
- Cliquez sur "Enregistrer les modifications" et testez-le dans "Aperçu en direct".
En plus de l'inscription et de la connexion via les OTP , vous pouvez également activer la récupération de mot de passe et la vérification de sécurité basée sur , ainsi que lier Adresse e-mail au profil. Voir Flux des utilisateurs finaux pour plus de détails.
Test et validation
Retournez à votre application Android (Kotlin / Java). Vous devriez maintenant pouvoir vous connecter avec SendGrid. Profitez-en !
Lectures complémentaires
Flux des utilisateurs finaux : Logto fournit des flux d'authentification prêts à l'emploi, y compris l'authentification multi-facteurs (MFA) et le SSO d’entreprise, ainsi que des API puissantes pour une mise en œuvre flexible des paramètres de compte, de la vérification de sécurité et de l'expérience multi-locataire.
Autorisation : L'autorisation définit les actions qu'un utilisateur peut effectuer ou les ressources auxquelles il peut accéder après avoir été authentifié. Découvrez comment protéger votre API pour les applications natives et monopages et mettre en œuvre le contrôle d’accès basé sur les rôles (RBAC).
Organisations : Particulièrement efficace dans les applications SaaS multi-locataires et B2B, la fonctionnalité d'organisation permet la création de locataires, la gestion des membres, le RBAC au niveau de l'organisation et l'approvisionnement juste-à-temps.
Série IAM client : Nos articles de blog en série sur la gestion des identités et des accès des clients (ou consommateurs), des sujets de base aux sujets avancés et au-delà.