Buka konsol

Menautkan Beberapa Penyedia Autentikasi ke Akun di Unity

Anda dapat mengizinkan pengguna untuk login ke aplikasi Anda menggunakan beberapa penyedia autentikasi, dengan menautkan kredensial penyedia autentikasi ke akun pengguna yang ada. Pengguna bisa diidentifikasi dengan ID pengguna Firebase yang sama, apa pun penyedia autentikasi yang mereka gunakan untuk login. Misalnya, pengguna yang login dengan sandi bisa menautkan akun Google dan login dengan salah satu metode tersebut di lain waktu. Atau, seorang pengguna anonim bisa menautkan akun Facebook, kemudian login dengan Facebook untuk melanjutkan penggunaan aplikasi Anda.

Sebelum Anda memulai

Tambahkan dukungan untuk 2 penyedia autentikasi atau lebih (mungkin dengan menyertakan autentikasi anonim) ke aplikasi Anda.

Kelas FirebaseAuth adalah gateway untuk semua panggilan API. Class ini dapat diakses melalui FirebaseAuth.DefaultInstance.
Firebase.Auth.FirebaseAuth auth = Firebase.Auth.FirebaseAuth.DefaultInstance;

Menautkan kredensial penyedia autentikasi ke akun pengguna

Untuk menautkan kredensial penyedia autentikasi ke akun pengguna yang ada:

  1. Login sebagai pengguna menggunakan penyedia atau metode autentikasi apa pun.
  2. Selesaikan alur login untuk penyedia autentikasi baru hingga, tetapi tidak termasuk, tahap pemanggilan salah satu metode Firebase.Auth.FirebaseAuth.SignInWithCredentialAsync. Misalnya, dapatkan token ID Google, token akses Facebook, atau email dan sandi pengguna.
  3. Dapatkan Firebase.Auth.Credential untuk penyedia autentikasi baru:

    Login dengan Google
    Firebase.Auth.Credential credential =
        Firebase.Auth.GoogleAuthProvider.GetCredential(googleIdToken, googleAccessToken);
    
    Login dengan Facebook
    Firebase.Auth.Credential credential =
        Firebase.Auth.FacebookAuthProvider.GetCredential(accessToken);
    
    Login dengan email-sandi
    Firebase.Auth.Credential credential =
        Firebase.Auth.EmailAuthProvider.GetCredential(email, password);
    
  4. Teruskan objek Firebase.Auth.Credential ke metode LinkWithCredentialAsync milik pengguna yang login:

    auth.CurrentUser.LinkWithCredentialAsync(credential).ContinueWith(task => {
      if (task.IsCanceled) {
        Debug.LogError("LinkWithCredentialAsync was canceled.");
        return;
      }
      if (task.IsFaulted) {
        Debug.LogError("LinkWithCredentialAsync encountered an error: " + task.Exception);
        return;
      }
    
      Firebase.Auth.FirebaseUser newUser = task.Result;
      Debug.LogFormat("Credentials successfully linked to Firebase user: {0} ({1})",
          newUser.DisplayName, newUser.UserId);
    });
    

    Panggilan ke LinkWithCredentialAsync akan gagal jika kredensial sudah dihubungkan ke akun pengguna lain. Dalam situasi ini, Anda harus menangani penggabungan akun dan data terkait secara tepat untuk aplikasi Anda:

    // Gather data for the currently signed in User.
    string currentUserId = auth.CurrentUser.UserId;
    string currentEmail = auth.CurrentUser.Email;
    string currentDisplayName = auth.CurrentUser.DisplayName;
    System.Uri currentPhotoUrl = auth.CurrentUser.PhotoUrl;
    
    // Sign in with the new credentials.
    auth.SignInWithCredentialAsync(credential).ContinueWith(task => {
      if (task.IsCanceled) {
        Debug.LogError("SignInWithCredentialAsync was canceled.");
        return;
      }
      if (task.IsFaulted) {
        Debug.LogError("SignInWithCredentialAsync encountered an error: " + task.Exception);
        return;
      }
    
      Firebase.Auth.FirebaseUser newUser = task.Result;
      Debug.LogFormat("User signed in successfully: {0} ({1})",
          newUser.DisplayName, newUser.UserId);
    
      // TODO: Merge app specific details using the newUser and values from the
      // previous user, saved above.
    });
    

Jika panggilan ke LinkWithCredentialAsync berhasil, pengguna dapat masuk menggunakan penyedia autentikasi yang ditautkan dan mengakses data Firebase yang sama.

Membatalkan tautan penyedia autentikasi dari akun pengguna

Anda dapat membatalkan tautan penyedia autentikasi dari akun, sehingga pengguna tidak dapat login lagi dengan penyedia tersebut.

Untuk membatalkan tautan penyedia autentikasi dari akun pengguna, teruskan ID penyedia ke metode UnlinkAsync. Anda dapat memperoleh ID penyedia milik penyedia autentikasi yang terhubung ke pengguna dengan memanggil ProviderData.

// Unlink the sign-in provider from the currently active user.
// providerIdString is a string identifying a provider,
// retrieved via FirebaseAuth.FetchProvidersForEmail().
auth.CurrentUser.UnlinkAsync(providerIdString).ContinueWith(task => {
  if (task.IsCanceled) {
    Debug.LogError("UnlinkAsync was canceled.");
    return;
  }
  if (task.IsFaulted) {
    Debug.LogError("UnlinkAsync encountered an error: " + task.Exception);
    return;
  }

  // The user has been unlinked from the provider.
  Firebase.Auth.FirebaseUser newUser = task.Result;
  Debug.LogFormat("Credentials successfully unlinked from user: {0} ({1})",
      newUser.DisplayName, newUser.UserId);
});