Associer plusieurs fournisseurs d'authentification à un compte

Vous pouvez autoriser les utilisateurs à se connecter à votre application à l'aide de plusieurs fournisseurs d'authentification en associant les identifiants du fournisseur d'authentification à un compte utilisateur existant. Les utilisateurs sont identifiables par le même ID utilisateur Firebase, quel que soit le fournisseur d'authentification qu'ils ont utilisé pour se connecter. Par exemple, un utilisateur qui s'est connecté avec un mot de passe, vous pouvez associer un compte Google et vous connecter via l'une ou l'autre des méthodes à venir. Un utilisateur anonyme peut également associer un compte Facebook, puis se connecter avec Facebook pour continuer à utiliser votre application.

Avant de commencer

Ajouter la prise en charge de deux fournisseurs d'authentification ou plus (y compris authentification anonyme) à votre application.

Pour associer les identifiants du fournisseur d'authentification à un compte utilisateur existant :

  1. Connectez l'utilisateur à l'aide de n'importe quel fournisseur ou méthode d'authentification.

  2. Terminez le flux de connexion du nouveau fournisseur d'authentification jusqu'à l'appel de l'une des méthodes signInWith, sans l'inclure. Par exemple, obtenez le jeton d'ID Google, le jeton d'accès Facebook ou l'adresse e-mail et le mot de passe de l'utilisateur.

  3. 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.
    
  4. Transmettez l'objet Credential à la méthode linkWithCredential() 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() aboutit, l'utilisateur peut désormais se connecter avec n'importe quel fournisseur d'authentification associé et accéder aux mêmes données Firebase.

Vous pouvez dissocier un fournisseur d'authentification d'un compte afin que l'utilisateur ne puisse plus une connexion plus longue auprès de 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 de fournisseur des fournisseurs d'authentification associé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.");
  }
}