Управление пользователями в Firebase

Создать пользователя

Для создания нового пользователя у вас есть следующие варианты:

  • В вашем приложении : создайте нового пользователя в вашем проекте Firebase, вызвав метод CreateUserWithEmailAndPassword или выполнив первую авторизацию пользователя с помощью федеративного поставщика идентификации, такого как Google Sign-In или Facebook Login .

  • В консоли Firebase : создайте нового пользователя, аутентифицированного по паролю, на вкладке «Безопасность» > «Аутентификация» > «Пользователи» .

Получите текущего авторизованного пользователя.

Рекомендуемый способ получения информации о текущем пользователе — это установка обработчика событий на объекте Auth:

class MyAuthStateListener : public firebase::auth::AuthStateListener {
 public:
  void OnAuthStateChanged(firebase::auth::Auth* auth) override {
    firebase::auth::User user = auth->current_user();
    if (user.is_valid()) {
      // User is signed in
      printf("OnAuthStateChanged: signed_in %s\n", user.uid().c_str());
    } else {
      // User is signed out
      printf("OnAuthStateChanged: signed_out\n");
    }
    // ...
  }
};
// ... initialization code
// Test notification on registration.
MyAuthStateListener state_change_listener;
auth->AddAuthStateListener(&state_change_listener);

Использование слушателя гарантирует, что объект Auth не будет находиться в промежуточном состоянии — например, на этапе инициализации — когда вы получаете текущего пользователя.

Также можно получить текущего авторизованного пользователя, вызвав current_user . Если пользователь не авторизован, метод is_valid вернет значение false.

Сохранение учетных данных пользователя

После входа пользователя в систему его учетные данные будут сохранены в локальном хранилище ключей. Локальный кэш учетных данных пользователя можно удалить, выйдя из системы. Хранилище ключей зависит от платформы:

Получить профиль пользователя

Чтобы получить информацию о профиле пользователя, используйте методы доступа экземпляра firebase::auth::User . Например:

firebase::auth::User user = auth->current_user();
if (user.is_valid()) {
  std::string name = user.display_name();
  std::string email = user.email();
  std::string photo_url = user.photo_url();
  // The user's ID, unique to the Firebase project.
  // Do NOT use this value to authenticate with your backend server,
  // if you have one. Use firebase::auth::User::Token() instead.
  std::string uid = user.uid();
}

Получите информацию о профиле пользователя, относящуюся к конкретному поставщику услуг.

Для получения информации профиля, полученной от поставщиков авторизации, связанных с пользователем, используйте метод ProviderData . Например:

firebase::auth::User user = auth->current_user();
if (user.is_valid()) {
  for (auto it = user.provider_data().begin();
       it != user.provider_data().end(); ++it) {
    firebase::auth::UserInfoInterface profile = *it;
    // Id of the provider (ex: google.com)
    std::string providerId = profile.provider_id();

    // UID specific to the provider
    std::string uid = profile.uid();

    // Name, email address, and profile photo Url
    std::string name = profile.display_name();
    std::string email = profile.email();
    std::string photoUrl = profile.photo_url();
  }
}

Обновить профиль пользователя

С помощью метода UpdateUserProfile можно обновить основную информацию профиля пользователя — отображаемое имя и URL-адрес фотографии профиля. Например:

firebase::auth::User user = auth->current_user();
if (user.is_valid()) {
  firebase::auth::User::UserProfile profile;
  profile.display_name = "Jane Q. User";
  profile.photo_url = "https://example.com/jane-q-user/profile.jpg";
  user.UpdateUserProfile(profile).OnCompletion(
      [](const firebase::Future<void>& completed_future, void* user_data) {
        // We are probably in a different thread right now.
        if (completed_future.error() == 0) {
          printf("User profile updated.");
        }
      },
      nullptr);  // pass user_data here.
}

Укажите адрес электронной почты пользователя

С помощью метода UpdateEmail можно задать адрес электронной почты пользователя. Например:

firebase::auth::User user = auth->current_user();
if (user.is_valid()) {
  user.UpdateEmail("user@example.com")
      .OnCompletion(
          [](const firebase::Future<void>& completed_future,
             void* user_data) {
            // We are probably in a different thread right now.
            if (completed_future.error() == 0) {
              printf("User email address updated.");
            }
          },
          nullptr);
}

Отправить пользователю письмо с подтверждением

Вы можете отправить пользователю письмо с подтверждением адреса электронной почты, используя метод SendEmailVerification . Например:

firebase::auth::User user = auth->current_user();
if (user.is_valid()) {
  user.SendEmailVerification().OnCompletion(
      [](const firebase::Future<void>& completed_future, void* user_data) {
        // We are probably in a different thread right now.
        if (completed_future.error() == 0) {
          printf("Email sent.");
        }
      },
      nullptr);
}

Вы можете настроить шаблон электронного письма, используемый в разделе «Аутентификация» консоли Firebase , на странице «Шаблоны электронных писем». См. раздел «Шаблоны электронных писем» в Справочном центре Firebase.

Установить пароль пользователя

С помощью метода UpdatePassword можно установить пароль пользователя. Например:

firebase::auth::User user = auth->current_user();
std::string newPassword = "SOME-SECURE-PASSWORD";

if (user.is_valid()) {
  user.UpdatePassword(newPassword.c_str())
      .OnCompletion(
          [](const firebase::Future<void>& completed_future,
             void* user_data) {
            // We are probably in a different thread right now.
            if (completed_future.error() == 0) {
              printf("password updated.");
            }
          },
          nullptr);
}

Отправить письмо для сброса пароля

Вы можете отправить пользователю письмо для сброса пароля с помощью метода SendPasswordResetEmail . Например:

std::string emailAddress = "user@example.com";

auth->SendPasswordResetEmail(emailAddress.c_str())
    .OnCompletion(
        [](const firebase::Future<void>& completed_future,
           void* user_data) {
          // We are probably in a different thread right now.
          if (completed_future.error() == 0) {
            // Email sent.
          } else {
            // An error happened.
            printf("Error %d: %s", completed_future.error(),
                   completed_future.error_message());
          }
        },
        nullptr);

Вы можете настроить используемый шаблон электронного письма на вкладке «Безопасность > Аутентификация > Шаблоны» в консоли Firebase . См. раздел «Шаблоны электронных писем» в Справочном центре Firebase.

Вы также можете отправлять электронные письма для сброса пароля из консоли Firebase .

Удалить пользователя

Удалить учетную запись пользователя можно с помощью метода Delete . Например:

firebase::auth::User user = auth->current_user();
if (user.is_valid()) {
  user.Delete().OnCompletion(
      [](const firebase::Future<void>& completed_future, void* user_data) {
        if (completed_future.error() == 0) {
          // User deleted.
        } else {
          // An error happened.
          printf("Error %d: %s", completed_future.error(),
                 completed_future.error_message());
        }
      },
      nullptr);
}

Также вы можете удалить пользователей в консоли Firebase на вкладке «Безопасность > Аутентификация > Пользователи» .

Повторная аутентификация пользователя

Некоторые действия, требующие повышенного внимания к безопасности, такие как удаление учетной записи , установка основного адреса электронной почты и изменение пароля, предполагают, что пользователь недавно вошел в систему. Если вы выполните одно из этих действий, а пользователь вошел в систему слишком давно, действие не удастся.

В этом случае выполните повторную аутентификацию пользователя, получив от него новые учетные данные для входа и передав их в функцию Reauthenticate . Например:

firebase::auth::User user = auth->current_user();

// Get auth credentials from the user for re-authentication. The example
// below shows email and password credentials but there are multiple
// possible providers, such as GoogleAuthProvider or FacebookAuthProvider.
firebase::auth::Credential credential =
    firebase::auth::EmailAuthProvider::GetCredential("user@example.com",
                                                     "password1234");

if (user.is_valid()) {
  user.Reauthenticate(credential)
      .OnCompletion(
          [](const firebase::Future<void>& completed_future,
             void* user_data) {
            if (completed_future.error() == 0) {
              printf("User re-authenticated.");
            }
          },
          nullptr);
}

Импорт учетных записей пользователей

Вы можете импортировать учетные записи пользователей из файла в свой проект Firebase, используя команду auth:import в Firebase CLI. Например:

firebase auth:import users.json --hash-algo=scrypt --rounds=8 --mem-cost=14