Vous pouvez autoriser les utilisateurs à se connecter à votre application à l'aide de plusieurs fournisseurs d'authentification en associant les informations d'identification du fournisseur d'authentification à un compte utilisateur existant. Les utilisateurs sont identifiables par le même identifiant utilisateur Firebase, quel que soit le fournisseur d'authentification utilisé pour se connecter. Par exemple, un utilisateur qui s'est connecté avec un mot de passe peut associer un compte Google et se connecter avec l'une ou l'autre méthode à l'avenir. Ou bien, un utilisateur anonyme peut associer un compte Facebook puis, plus tard, se connecter avec Facebook pour continuer à utiliser votre application.
Avant que tu commences
Ajoutez la prise en charge de deux fournisseurs d'authentification ou plus (y compris éventuellement l'authentification anonyme) à votre application.
Associer les informations d'identification du fournisseur d'authentification à un compte utilisateur
Pour lier les informations d'identification du fournisseur d'authentification à un compte utilisateur existant :
Connectez l’utilisateur à l’aide de n’importe quel fournisseur ou méthode d’authentification.
Complétez le flux de connexion pour le nouveau fournisseur d'authentification jusqu'à, mais non compris, l'appel de l'une des méthodes
signInWith
-. Par exemple, obtenez le jeton d'identification Google de l'utilisateur, le jeton d'accès Facebook ou l'adresse e-mail et le mot de passe.Obtenez un objet
Credential
pour le nouveau fournisseur d'authentification :// Google Sign-in final credential = GoogleAuthProvider.credential(idToken: idToken); // Email and password sign-in final credential = EmailAuthProvider.credential(email: emailAddress, password: password); // Etc.
Transmettez l'objet
Credential
à la méthodelinkWithCredential()
de l'utilisateur connecté :try { final userCredential = await FirebaseAuth.instance.currentUser ?.linkWithCredential(credential); } on FirebaseAuthException catch (e) { switch (e.code) { case "provider-already-linked": print("The provider has already been linked to the user."); break; case "invalid-credential": print("The provider's credential is not valid."); break; case "credential-already-in-use": print("The account corresponding to the credential already exists, " "or is already linked to a Firebase User."); break; // See the API reference for the full list of error codes. default: print("Unknown error."); } ```
Si l'appel à linkWithCredential()
réussit, l'utilisateur peut désormais se connecter à l'aide de n'importe quel fournisseur d'authentification lié et accéder aux mêmes données Firebase.
Dissocier un fournisseur d'authentification d'un compte utilisateur
Vous pouvez dissocier un fournisseur d'authentification d'un compte, afin que l'utilisateur ne puisse plus se connecter avec ce fournisseur.
Pour dissocier un fournisseur d'authentification d'un compte utilisateur, transmettez l'ID du fournisseur à la méthode unlink()
. Vous pouvez obtenir les ID des fournisseurs d'authentification liés à un utilisateur à partir de la propriété providerData
de l'objet User
.
try {
await FirebaseAuth.instance.currentUser?.unlink(providerId);
} on FirebaseAuthException catch (e) {
switch (e.code) {
case "no-such-provider":
print("The user isn't linked to the provider or the provider "
"doesn't exist.");
break;
default:
print("Unknown error.");
}
}