C++ を使用してアカウントに複数の認証プロバイダをリンクする

既存のユーザー アカウントに認証プロバイダの認証情報をリンクすることで、ユーザーが複数の認証プロバイダを使用してアプリにログインできるようになります。ログインに使用した認証プロバイダに関係なく、同じ Firebase ユーザー ID でユーザーを識別できます。たとえば、パスワードを使用してログインしたユーザーが認証情報を Google アカウントにリンクすれば、それ以降はどちらの方法でもログインできるようになります。また、匿名ユーザーが認証情報を Facebook アカウントにリンクすると、それ以降は Facebook にログインしてアプリを使用できるようになります。

準備

アプリに複数の認証プロバイダ(匿名認証も含む)のサポートを追加します。

ユーザー アカウントに認証プロバイダの認証情報をリンクする

既存のユーザー アカウントに認証プロバイダの認証情報をリンクするには:

  1. 任意の認証プロバイダや認証方法を使用してユーザーのログインを行います。
  2. 新しい認証プロバイダのサインインフローを行います(ただし、いずれかの firebase::auth::Auth::SignInWithCredential メソッドを呼び出す手前まで)。たとえば、ユーザーの Google ID トークン、Facebook アクセス トークン、またはメールとパスワードを取得します。
  3. 新しい認証プロバイダの firebase::auth::Credential を取得します。

    Google ログイン
    firebase::auth::Credential credential =
        firebase::auth::GoogleAuthProvider::GetCredential(google_id_token,
                                                          nullptr);
    
    Facebook ログイン
    firebase::auth::Credential credential =
        firebase::auth::FacebookAuthProvider::GetCredential(access_token);
    
    メールとパスワードによるログイン
    firebase::auth::Credential credential =
        firebase::auth::EmailAuthProvider::GetCredential(email, password);
    
  4. ログインしたユーザーの LinkWithCredential メソッドに firebase::auth::Credential オブジェクトを渡します。

    // Link the new credential to the currently active user.
    firebase::auth::User* current_user = auth->CurrentUser();
    firebase::Future<firebase::auth::User*> result =
        current_user->LinkWithCredential(credential);
    

    認証情報が別のユーザー アカウントに既にリンクされている場合は、LinkWithCredential の呼び出しが失敗します。この場合は、アプリに適した方法でアカウントと関連データの統合を行う必要があります。

    // Gather data for the currently signed in User.
    firebase::auth::User* current_user = auth->CurrentUser();
    std::string current_email = current_user->Email();
    std::string current_provider_id = current_user->ProviderId();
    std::string current_display_name = current_user->DisplayName();
    std::string current_photo_url = current_user->PhotoUrl();
    
    // Sign in with the new credentials.
    firebase::Future<firebase::auth::User*> result =
        auth->SignInWithCredential(credential);
    
    // To keep example simple, wait on the current thread until call completes.
    while (result.Status() == firebase::kFutureStatusPending) {
      Wait(100);
    }
    
    // The new User is now active.
    if (result.Error() == firebase::auth::kAuthErrorNone) {
      firebase::auth::User* new_user = *result.Result();
    
      // Merge new_user with the user in details.
      // ...
      (void)new_user;
    }
    

LinkWithCredential の呼び出しが成功したら、ユーザーはリンクされた認証プロバイダを使用してログインし、同じ Firebase データにアクセスできるようになります。

ユーザー アカウントから認証プロバイダのリンクを解除する

アカウントから認証プロバイダのリンクを解除することで、ユーザーがそのプロバイダを使用してログインできなくなります。

ユーザー アカウントから認証プロバイダのリンクを解除するには、プロバイダ ID を Unlink メソッドに渡します。 ProviderData を呼び出すことで、ユーザーにリンクされた認証プロバイダの ID を取得できます。

// Unlink the sign-in provider from the currently active user.
firebase::auth::User* current_user = auth->CurrentUser();
firebase::Future<firebase::auth::User*> result =
    current_user->Unlink(providerId);

フィードバックを送信...