Gerenciar usuários no Firebase

Crie um usuário

Você cria um novo usuário no seu projeto do Firebase chamando o método CreateUserWithEmailAndPassword ou fazendo login em um usuário pela primeira vez usando um provedor de identidade federado, como Google Sign-In ou Facebook Login .

Você também pode criar novos usuários autenticados por senha na seção Autenticação do console do Firebase , na página Usuários.

Obtenha o usuário atualmente conectado

A maneira recomendada de obter o usuário atual é definindo um ouvinte no objeto Auth:

Firebase.Auth.FirebaseAuth auth;
Firebase.Auth.FirebaseUser user;

// Handle initialization of the necessary firebase modules:
void InitializeFirebase() {
 
Debug.Log("Setting up Firebase Auth");
  auth
= Firebase.Auth.FirebaseAuth.DefaultInstance;
  auth
.StateChanged += AuthStateChanged;
 
AuthStateChanged(this, null);
}

// Track state changes of the auth object.
void AuthStateChanged(object sender, System.EventArgs eventArgs) {
 
if (auth.CurrentUser != user) {
   
bool signedIn = user != auth.CurrentUser && auth.CurrentUser != null;
   
if (!signedIn && user != null) {
     
Debug.Log("Signed out " + user.UserId);
   
}
    user
= auth.CurrentUser;
   
if (signedIn) {
     
Debug.Log("Signed in " + user.UserId);
   
}
 
}
}

// Handle removing subscription and reference to the Auth instance.
// Automatically called by a Monobehaviour after Destroy is called on it.
void OnDestroy() {
  auth
.StateChanged -= AuthStateChanged;
  auth
= null;
}

Ao usar um ouvinte, você garante que o objeto Auth não esteja em um estado intermediário — como inicialização — ao obter o usuário atual.

Você também pode obter o usuário conectado no momento chamando CurrentUser . Se um usuário não estiver conectado, CurrentUser retornará nulo. Se um usuário estiver desconectado, IsValid() do usuário retornará falso.

Persistir a credencial de um usuário

As credenciais do usuário serão armazenadas no keystore local após o login do usuário. O cache local de credenciais do usuário pode ser excluído desconectando o usuário. O keystore é específico da plataforma:

Obtenha o perfil de um usuário

Para obter informações de perfil de um usuário, use os métodos acessadores de uma instância de Firebase.Auth.FirebaseUser . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
if (user != null) {
 
string name = user.DisplayName;
 
string email = user.Email;
 
System.Uri photo_url = user.PhotoUrl;
 
// 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 User.TokenAsync() instead.
 
string uid = user.UserId;
}

Obtenha informações de perfil específicas do provedor de um usuário

Para obter as informações de perfil recuperadas dos provedores de login vinculados a um usuário, use o método ProviderData . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
if (user != null) {
 
foreach (var profile in user.ProviderData) {
   
// Id of the provider (ex: google.com)
   
string providerId = profile.ProviderId;

   
// UID specific to the provider
   
string uid = profile.UserId;

   
// Name, email address, and profile photo Url
   
string name = profile.DisplayName;
   
string email = profile.Email;
   
System.Uri photoUrl = profile.PhotoUrl;
 
}
}

Atualizar o perfil de um usuário

Você pode atualizar as informações básicas do perfil de um usuário (o nome de exibição do usuário e o URL da foto do perfil) com o método UpdateUserProfile . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
if (user != null) {
 
Firebase.Auth.UserProfile profile = new Firebase.Auth.UserProfile {
   
DisplayName = "Jane Q. User",
   
PhotoUrl = new System.Uri("https://example.com/jane-q-user/profile.jpg"),
 
};
  user
.UpdateUserProfileAsync(profile).ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("UpdateUserProfileAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("UpdateUserProfileAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("User profile updated successfully.");
 
});
}

Definir o endereço de e-mail de um usuário

Você pode definir o endereço de e-mail de um usuário com o método UpdateEmail . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
if (user != null) {
  user
.UpdateEmailAsync("user@example.com").ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("UpdateEmailAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("UpdateEmailAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("User email updated successfully.");
 
});
}

Enviar um e-mail de verificação a um usuário

Você pode enviar um email de verificação de endereço para um usuário com o método SendEmailVerification . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
if (user != null) {
  user
.SendEmailVerificationAsync().ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("SendEmailVerificationAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("SendEmailVerificationAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("Email sent successfully.");
 
});
}

Você pode personalizar o modelo de e-mail usado na seção Autenticação do console do Firebase , na página Modelos de e-mail. Consulte Modelos de e-mail na Central de Ajuda do Firebase.

Definir uma senha de usuário

Você pode definir uma senha de usuário com o método UpdatePassword . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
string newPassword = "SOME-SECURE-PASSWORD";
if (user != null) {
  user
.UpdatePasswordAsync(newPassword).ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("UpdatePasswordAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("UpdatePasswordAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("Password updated successfully.");
 
});
}

Envie um e-mail de redefinição de senha

Você pode enviar um email de redefinição de senha para um usuário com o método SendPasswordResetEmail . Por exemplo:

string emailAddress = "user@example.com";
if (user != null) {
  auth
.SendPasswordResetEmailAsync(emailAddress).ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("SendPasswordResetEmailAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("SendPasswordResetEmailAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("Password reset email sent successfully.");
 
});
}

Você pode personalizar o modelo de e-mail usado na seção Autenticação do console do Firebase , na página Modelos de e-mail. Consulte Modelos de e-mail na Central de Ajuda do Firebase.

Você também pode enviar e-mails de redefinição de senha do console do Firebase.

Excluir um usuário

Você pode excluir uma conta de usuário com o método Delete . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;
if (user != null) {
  user
.DeleteAsync().ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("DeleteAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("DeleteAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("User deleted successfully.");
 
});
}

Você também pode excluir usuários da seção Autenticação do console do Firebase , na página Usuários.

Reautenticar um usuário

Algumas ações sensíveis à segurança, como excluir uma conta , definir um endereço de e-mail principal e alterar uma senha , exigem que o usuário tenha feito login recentemente. Se você realizar uma dessas ações e o usuário tiver feito login há muito tempo, o a ação falha.

Quando isso acontecer, autentique novamente o usuário obtendo novas credenciais de login do usuário e passando-as para Reauthenticate . Por exemplo:

Firebase.Auth.FirebaseUser user = auth.CurrentUser;

// 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 != null) {
  user
.ReauthenticateAsync(credential).ContinueWith(task => {
   
if (task.IsCanceled) {
     
Debug.LogError("ReauthenticateAsync was canceled.");
     
return;
   
}
   
if (task.IsFaulted) {
     
Debug.LogError("ReauthenticateAsync encountered an error: " + task.Exception);
     
return;
   
}

   
Debug.Log("User reauthenticated successfully.");
 
});
}

Importar contas de usuário

Você pode importar contas de usuário de um arquivo para seu projeto do Firebase usando o comando auth:import da CLI do Firebase. Por exemplo:

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