Pakiet SDK Firebase Admin udostępnia interfejs API do zarządzania Firebase Authentication użytkowników z podwyższonymi uprawnieniami. Interfejs Admin User Management API pozwala programowo wykonywać następujące zadania bezpieczne środowisko serwera:
- Tworzenie nowych użytkowników bez ograniczania przepustowości.
- Możesz wyszukiwać użytkowników według różnych kryteriów, takich jak UID, adres e-mail czy numer telefonu.
- Wyświetlenie listy wszystkich użytkowników z określonego projektu partiami.
- Dostęp do metadanych użytkowników, w tym daty utworzenia konta i ostatniego logowania.
- Usuń użytkowników bez konieczności podawania hasła.
- Aktualizowanie właściwości użytkownika (w tym hasła) bez konieczności logowania się jako użytkownik.
- Weryfikuj e-maile bez konieczności przechodzenia przez procedurę pozapasmową w przypadku weryfikacji e-maili.
- Aby cofnąć te zmiany, zmień adres e-mail użytkownika bez wysyłania linków.
- Tworzenie nowego użytkownika z numerem telefonu bez wysyłania SMS-ów proces weryfikacji.
- Zmiana numeru telefonu użytkownika bez weryfikacji za pomocą wiadomości SMS przepływu danych.
- Udostępnianie offline użytkownikom w stanie wyłączonym, a następnie kontrolowanie, kiedy mają włączyć je.
- Tworzenie niestandardowych konsol użytkowników dostosowanych do użytkownika określonej aplikacji systemu zarządzania.
Zanim zaczniesz
Aby korzystać z interfejsu API do zarządzania użytkownikami dostępnego w pakiecie SDK Firebase Admin, musisz: musi mieć konto usługi. Postępuj zgodnie z instrukcjami konfiguracji. , aby dowiedzieć się więcej o inicjowaniu pakietu Admin SDK.
Pobieranie danych użytkownika
Podstawowym sposobem identyfikacji użytkownika jest uid
, unikalny identyfikator
tego użytkownika. Pakiet Admin SDK udostępnia metodę, która umożliwia pobranie profilu
informacje o użytkownikach według ich uid
:
Node.js
getAuth()
.getUser(uid)
.then((userRecord) => {
// See the UserRecord reference doc for the contents of userRecord.
console.log(`Successfully fetched user data: ${userRecord.toJSON()}`);
})
.catch((error) => {
console.log('Error fetching user data:', error);
});
Java
UserRecord userRecord = FirebaseAuth.getInstance().getUser(uid);
// See the UserRecord reference doc for the contents of userRecord.
System.out.println("Successfully fetched user data: " + userRecord.getUid());
Python
from firebase_admin import auth
user = auth.get_user(uid)
print('Successfully fetched user data: {0}'.format(user.uid))
Go
// Get an auth client from the firebase.App
client, err := app.Auth(ctx)
if err != nil {
log.Fatalf("error getting Auth client: %v\n", err)
}
u, err := client.GetUser(ctx, uid)
if err != nil {
log.Fatalf("error getting user %s: %v\n", uid, err)
}
log.Printf("Successfully fetched user data: %v\n", u)
C#
UserRecord userRecord = await FirebaseAuth.DefaultInstance.GetUserAsync(uid);
// See the UserRecord reference doc for the contents of userRecord.
Console.WriteLine($"Successfully fetched user data: {userRecord.Uid}");
Ta metoda zwraca UserRecord
dla użytkownika odpowiadającego funkcji uid
dostarczonej metodowi.
Jeśli podany uid
nie należy do istniejącego użytkownika lub użytkownik nie może
pobrane z dowolnego innego powodu, powyższa metoda zwraca błąd.
Pełną listę kodów błędów, w tym ich opisy i
procedury rozwiązywania problemów zawiera artykuł Błędy interfejsu Admin Auth API.
W niektórych przypadkach zamiast uid
będziesz mieć adres e-mail użytkownika. Firebase
Pakiet Admin SDK obsługuje wyszukiwanie informacji o użytkownikach za pomocą adresu e-mail:
Node.js
getAuth()
.getUserByEmail(email)
.then((userRecord) => {
// See the UserRecord reference doc for the contents of userRecord.
console.log(`Successfully fetched user data: ${userRecord.toJSON()}`);
})
.catch((error) => {
console.log('Error fetching user data:', error);
});
Java
UserRecord userRecord = FirebaseAuth.getInstance().getUserByEmail(email);
// See the UserRecord reference doc for the contents of userRecord.
System.out.println("Successfully fetched user data: " + userRecord.getEmail());
Python
from firebase_admin import auth
user = auth.get_user_by_email(email)
print('Successfully fetched user data: {0}'.format(user.uid))
Go
u, err := client.GetUserByEmail(ctx, email)
if err != nil {
log.Fatalf("error getting user by email %s: %v\n", email, err)
}
log.Printf("Successfully fetched user data: %v\n", u)
C#
UserRecord userRecord = await FirebaseAuth.DefaultInstance.GetUserByEmailAsync(email);
// See the UserRecord reference doc for the contents of userRecord.
Console.WriteLine($"Successfully fetched user data: {userRecord.Uid}");
Ta metoda zwraca obiekt UserRecord
dla argumentu
użytkownika odpowiadającego podanemu adresowi e-mail.
Jeśli podany adres e-mail nie należy do istniejącego użytkownika lub użytkownik nie może pobrane z jakiegokolwiek innego powodu, pakiet Admin SDK zwraca błąd. Pełną listę kodów błędów wraz z opisami i sposoby ich rozwiązywania znajdziesz w artykule Błędy interfejsu API Authentication administratora.
W innych przypadkach zamiast uid
będziesz mieć numer telefonu użytkownika.
Pakiet SDK Firebase Admin obsługuje wyszukiwanie informacji o użytkownikach za pomocą numeru telefonu:
Node.js
getAuth()
.getUserByPhoneNumber(phoneNumber)
.then((userRecord) => {
// See the UserRecord reference doc for the contents of userRecord.
console.log(`Successfully fetched user data: ${userRecord.toJSON()}`);
})
.catch((error) => {
console.log('Error fetching user data:', error);
});
Java
UserRecord userRecord = FirebaseAuth.getInstance().getUserByPhoneNumber(phoneNumber);
// See the UserRecord reference doc for the contents of userRecord.
System.out.println("Successfully fetched user data: " + userRecord.getPhoneNumber());
Python
from firebase_admin import auth
user = auth.get_user_by_phone_number(phone)
print('Successfully fetched user data: {0}'.format(user.uid))
Go
u, err := client.GetUserByPhoneNumber(ctx, phone)
if err != nil {
log.Fatalf("error getting user by phone %s: %v\n", phone, err)
}
log.Printf("Successfully fetched user data: %v\n", u)
C#
UserRecord userRecord = await FirebaseAuth.DefaultInstance.GetUserByPhoneNumberAsync(phoneNumber);
// See the UserRecord reference doc for the contents of userRecord.
Console.WriteLine($"Successfully fetched user data: {userRecord.Uid}");
Ta metoda zwraca obiekt UserRecord
dla argumentu
odpowiadający podanemu numerowi telefonu.
Jeśli podany numer telefonu nie należy do obecnego użytkownika nie może zostać pobrana z żadnego innego powodu, pakiet Admin SDK zgłosi błąd. Pełną listę kodów błędów wraz z opisami i sposoby ich rozwiązywania znajdziesz w artykule Błędy interfejsu API Authentication administratora.
Zbiorcze pobieranie danych użytkowników
Pakiet Firebase Admin SDK umożliwia też pobieranie listy użytkowników na podstawie przez użytkowników. Możesz identyfikować użytkowników po ich identyfikatorze, adresie e-mail lub numeru telefonu. W jednym wywołaniu można podać maksymalnie 100 identyfikatorów. Mogą one obejmować różne typy identyfikatorów:
Node.js
getAuth()
.getUsers([
{ uid: 'uid1' },
{ email: 'user2@example.com' },
{ phoneNumber: '+15555550003' },
{ providerId: 'google.com', providerUid: 'google_uid4' },
])
.then((getUsersResult) => {
console.log('Successfully fetched user data:');
getUsersResult.users.forEach((userRecord) => {
console.log(userRecord);
});
console.log('Unable to find users corresponding to these identifiers:');
getUsersResult.notFound.forEach((userIdentifier) => {
console.log(userIdentifier);
});
})
.catch((error) => {
console.log('Error fetching user data:', error);
});
Java
GetUsersResult result = FirebaseAuth.getInstance().getUsersAsync(Arrays.asList(
new UidIdentifier("uid1"),
new EmailIdentifier("user2@example.com"),
new PhoneIdentifier("+15555550003"),
new ProviderIdentifier("google.com", "google_uid4"))).get();
System.out.println("Successfully fetched user data:");
for (UserRecord user : result.getUsers()) {
System.out.println(user.getUid());
}
System.out.println("Unable to find users corresponding to these identifiers:");
for (UserIdentifier uid : result.getNotFound()) {
System.out.println(uid);
}
Python
from firebase_admin import auth
result = auth.get_users([
auth.UidIdentifier('uid1'),
auth.EmailIdentifier('user2@example.com'),
auth.PhoneIdentifier(+15555550003),
auth.ProviderIdentifier('google.com', 'google_uid4')
])
print('Successfully fetched user data:')
for user in result.users:
print(user.uid)
print('Unable to find users corresponding to these identifiers:')
for uid in result.not_found:
print(uid)
Go
getUsersResult, err := client.GetUsers(ctx, []auth.UserIdentifier{
auth.UIDIdentifier{UID: "uid1"},
auth.EmailIdentifier{Email: "user@example.com"},
auth.PhoneIdentifier{PhoneNumber: "+15555551234"},
auth.ProviderIdentifier{ProviderID: "google.com", ProviderUID: "google_uid1"},
})
if err != nil {
log.Fatalf("error retriving multiple users: %v\n", err)
}
log.Printf("Successfully fetched user data:")
for _, u := range getUsersResult.Users {
log.Printf("%v", u)
}
log.Printf("Unable to find users corresponding to these identifiers:")
for _, id := range getUsersResult.NotFound {
log.Printf("%v", id)
}
C#
GetUsersResult result = await FirebaseAuth.DefaultInstance.GetUsersAsync(
new List<UserIdentifier>
{
new UidIdentifier("uid1"),
new EmailIdentifier("user2@example.com"),
new PhoneIdentifier("+15555550003"),
new ProviderIdentifier("google.com", "google_uid4"),
});
Console.WriteLine("Successfully fetched user data:");
foreach (UserRecord user in result.Users)
{
Console.WriteLine($"User: {user.Uid}");
}
Console.WriteLine("Unable to find users corresponding to these identifiers:");
foreach (UserIdentifier uid in result.NotFound)
{
Console.WriteLine($"{uid}");
}
Ta metoda zwraca listę o takim samym rozmiarze jak lista danych wejściowych, przy czym każdy wpis
zawierające odpowiedni element UserRecord
lub błąd wskazujący przyczynę
nie udało się znaleźć tego identyfikatora. Pełną listę kodów błędów znajdziesz
w tym opisy i sposoby rozwiązania problemu, zapoznaj się z informacjami o interfejsie Admin Authentication API
Błędy.
Tworzenie konta użytkownika
Pakiet Admin SDK udostępnia metodę, która pozwala umożliwia utworzenie nowego użytkownika Firebase Authentication. Ta metoda akceptuje obiekt zawierający informacje o profilu, które mają zostać uwzględnione w nowo utworzonym konto użytkownika:
Node.js
getAuth()
.createUser({
email: 'user@example.com',
emailVerified: false,
phoneNumber: '+11234567890',
password: 'secretPassword',
displayName: 'John Doe',
photoURL: 'http://www.example.com/12345678/photo.png',
disabled: false,
})
.then((userRecord) => {
// See the UserRecord reference doc for the contents of userRecord.
console.log('Successfully created new user:', userRecord.uid);
})
.catch((error) => {
console.log('Error creating new user:', error);
});
Java
CreateRequest request = new CreateRequest()
.setEmail("user@example.com")
.setEmailVerified(false)
.setPassword("secretPassword")
.setPhoneNumber("+11234567890")
.setDisplayName("John Doe")
.setPhotoUrl("http://www.example.com/12345678/photo.png")
.setDisabled(false);
UserRecord userRecord = FirebaseAuth.getInstance().createUser(request);
System.out.println("Successfully created new user: " + userRecord.getUid());
Python
user = auth.create_user(
email='user@example.com',
email_verified=False,
phone_number='+15555550100',
password='secretPassword',
display_name='John Doe',
photo_url='http://www.example.com/12345678/photo.png',
disabled=False)
print('Sucessfully created new user: {0}'.format(user.uid))
Go
params := (&auth.UserToCreate{}).
Email("user@example.com").
EmailVerified(false).
PhoneNumber("+15555550100").
Password("secretPassword").
DisplayName("John Doe").
PhotoURL("http://www.example.com/12345678/photo.png").
Disabled(false)
u, err := client.CreateUser(ctx, params)
if err != nil {
log.Fatalf("error creating user: %v\n", err)
}
log.Printf("Successfully created user: %v\n", u)
C#
UserRecordArgs args = new UserRecordArgs()
{
Email = "user@example.com",
EmailVerified = false,
PhoneNumber = "+11234567890",
Password = "secretPassword",
DisplayName = "John Doe",
PhotoUrl = "http://www.example.com/12345678/photo.png",
Disabled = false,
};
UserRecord userRecord = await FirebaseAuth.DefaultInstance.CreateUserAsync(args);
// See the UserRecord reference doc for the contents of userRecord.
Console.WriteLine($"Successfully created new user: {userRecord.Uid}");
Domyślnie Firebase Authentication generuje losowy tag uid
dla nowego użytkownika. Jeśli
zamiast tego chcesz dla nowego użytkownika określić własny uid
, możesz go uwzględnić
jako argument przekazywany do metody tworzenia użytkownika:
Node.js
getAuth()
.createUser({
uid: 'some-uid',
email: 'user@example.com',
phoneNumber: '+11234567890',
})
.then((userRecord) => {
// See the UserRecord reference doc for the contents of userRecord.
console.log('Successfully created new user:', userRecord.uid);
})
.catch((error) => {
console.log('Error creating new user:', error);
});
Java
CreateRequest request = new CreateRequest()
.setUid("some-uid")
.setEmail("user@example.com")
.setPhoneNumber("+11234567890");
UserRecord userRecord = FirebaseAuth.getInstance().createUser(request);
System.out.println("Successfully created new user: " + userRecord.getUid());
Python
user = auth.create_user(
uid='some-uid', email='user@example.com', phone_number='+15555550100')
print('Sucessfully created new user: {0}'.format(user.uid))
Go
params := (&auth.UserToCreate{}).
UID(uid).
Email("user@example.com").
PhoneNumber("+15555550100")
u, err := client.CreateUser(ctx, params)
if err != nil {
log.Fatalf("error creating user: %v\n", err)
}
log.Printf("Successfully created user: %v\n", u)
C#
UserRecordArgs args = new UserRecordArgs()
{
Uid = "some-uid",
Email = "user@example.com",
PhoneNumber = "+11234567890",
};
UserRecord userRecord = await FirebaseAuth.DefaultInstance.CreateUserAsync(args);
// See the UserRecord reference doc for the contents of userRecord.
Console.WriteLine($"Successfully created new user: {userRecord.Uid}");
Możesz podać dowolną kombinację tych właściwości:
Tabela 1. Właściwości obsługiwane przez operację tworzenia użytkownika
Właściwość | Typ | Opis |
---|---|---|
uid |
ciąg znaków |
uid , który ma zostać przypisany do nowo utworzonego użytkownika. Musi to być
ciąg o długości od 1 do 128 znaków włącznie. Jeśli nie zostanie podana, parametr
zostanie automatycznie wygenerowana losowa wartość uid . Krótsza
Komponenty typu uid zapewniają większą skuteczność.
|
email |
ciąg znaków | Główny adres e-mail użytkownika. Wymagany jest prawidłowy adres e-mail. |
emailVerified |
wartość logiczna |
Wskazuje, czy podstawowy adres e-mail użytkownika został zweryfikowany. Jeśli nie zostanie podany, parametr
domyślna wartość to false .
|
phoneNumber |
ciąg znaków | Podstawowy numer telefonu użytkownika. Musi być prawidłową specyfikacją E.164 numeru telefonu. |
password |
ciąg znaków | Nieprzetworzone, niezaszyfrowane hasło użytkownika. Musi składać się z co najmniej 6 znaków. |
displayName |
ciąg znaków | Dane użytkowników wyświetlaną nazwę. |
photoURL |
ciąg znaków | Adres URL zdjęcia użytkownika. |
disabled |
wartość logiczna |
Wskazuje, czy użytkownik jest wyłączony. true – wyłączono;
false dla włączonego. Jeśli nie zostanie podana, domyślną wartością będzie
false
|
Metoda tworzenia użytkownika zwraca obiekt UserRecord
dla funkcji
konto użytkownika.
Jeśli podany uid
, adres e-mail lub numer telefonu jest już używany przez istniejącą
użytkownika lub użytkownika nie można utworzyć z żadnego innego powodu, powyższa metoda nie powiedzie się
z błędem. Pełną listę kodów błędów, w tym
opisy i sposoby rozwiązania tego problemu znajdziesz w artykule Admin Authentication API
Błędy.
Aktualizowanie konta użytkownika
Pakiet SDK Firebase Admin umożliwia modyfikowanie danych obecnego użytkownika. Potrzebujesz
, aby określić właściwość uid
wraz z właściwościami do zaktualizowania dla danego użytkownika:
Node.js
getAuth()
.updateUser(uid, {
email: 'modifiedUser@example.com',
phoneNumber: '+11234567890',
emailVerified: true,
password: 'newPassword',
displayName: 'Jane Doe',
photoURL: 'http://www.example.com/12345678/photo.png',
disabled: true,
})
.then((userRecord) => {
// See the UserRecord reference doc for the contents of userRecord.
console.log('Successfully updated user', userRecord.toJSON());
})
.catch((error) => {
console.log('Error updating user:', error);
});
Java
UpdateRequest request = new UpdateRequest(uid)
.setEmail("user@example.com")
.setPhoneNumber("+11234567890")
.setEmailVerified(true)
.setPassword("newPassword")
.setDisplayName("Jane Doe")
.setPhotoUrl("http://www.example.com/12345678/photo.png")
.setDisabled(true);
UserRecord userRecord = FirebaseAuth.getInstance().updateUser(request);
System.out.println("Successfully updated user: " + userRecord.getUid());
Python
user = auth.update_user(
uid,
email='user@example.com',
phone_number='+15555550100',
email_verified=True,
password='newPassword',
display_name='John Doe',
photo_url='http://www.example.com/12345678/photo.png',
disabled=True)
print('Sucessfully updated user: {0}'.format(user.uid))
Go
params := (&auth.UserToUpdate{}).
Email("user@example.com").
EmailVerified(true).
PhoneNumber("+15555550100").
Password("newPassword").
DisplayName("John Doe").
PhotoURL("http://www.example.com/12345678/photo.png").
Disabled(true)
u, err := client.UpdateUser(ctx, uid, params)
if err != nil {
log.Fatalf("error updating user: %v\n", err)
}
log.Printf("Successfully updated user: %v\n", u)
C#
UserRecordArgs args = new UserRecordArgs()
{
Uid = uid,
Email = "modifiedUser@example.com",
PhoneNumber = "+11234567890",
EmailVerified = true,
Password = "newPassword",
DisplayName = "Jane Doe",
PhotoUrl = "http://www.example.com/12345678/photo.png",
Disabled = true,
};
UserRecord userRecord = await FirebaseAuth.DefaultInstance.UpdateUserAsync(args);
// See the UserRecord reference doc for the contents of userRecord.
Console.WriteLine($"Successfully updated user: {userRecord.Uid}");
Możesz podać dowolną kombinację tych właściwości:
Tabela 2. Właściwości obsługiwane przez operację aktualizacji użytkownika
Właściwość | Typ | Opis |
---|---|---|
email |
ciąg znaków | Nowy główny adres e-mail użytkownika. Wymagany jest prawidłowy adres e-mail. |
emailVerified |
wartość logiczna |
Wskazuje, czy podstawowy adres e-mail użytkownika został zweryfikowany. Jeśli nie zostanie podany, parametr
domyślna wartość to false .
|
phoneNumber |
ciąg znaków |
Nowy podstawowy numer telefonu użytkownika. Musi być prawidłową specyfikacją E.164
numeru telefonu. Ustaw jako null , aby wyczyścić istniejące dane użytkownika
numeru telefonu.
|
password |
ciąg znaków | Nowe surowe, niezaszyfrowane hasło użytkownika. Musi składać się z co najmniej 6 znaków. |
displayName |
ciąg znaków | null |
Dane użytkowników nową wyświetlaną nazwę. Ustaw jako null , aby wyczyścić dane użytkownika
istniejącą wyświetlaną nazwę.
|
photoURL |
ciąg znaków | null |
Dane użytkowników nowy adres URL zdjęcia. Ustaw jako null , aby wyczyścić dane użytkownika
istniejącego adresu URL zdjęcia. Jeśli wartość jest inna niż null , musisz podać prawidłowy adres URL.
|
disabled |
wartość logiczna |
Wskazuje, czy użytkownik jest wyłączony. true – wyłączono;
false dla włączonego.
|
Metoda aktualizacji użytkownika zwraca zaktualizowany obiekt UserRecord
, gdy
zakończono aktualizację.
Jeśli podana wartość uid
nie odpowiada istniejącemu użytkownikowi, zostanie podana wartość
adres e-mail lub numer telefonu jest już używany przez istniejącego użytkownika albo
aktualizacji z jakiegokolwiek innego powodu, powyższa metoda zakończy się niepowodzeniem i
. Pełną listę kodów błędów wraz z opisami i rozwiązaniami
czynności znajdziesz w artykule Błędy interfejsu API administratora Authentication.
Usuwanie konta użytkownika
Pakiet Firebase Admin SDK umożliwia usuwanie dotychczasowych użytkowników za pomocą uid
:
Node.js
getAuth()
.deleteUser(uid)
.then(() => {
console.log('Successfully deleted user');
})
.catch((error) => {
console.log('Error deleting user:', error);
});
Java
FirebaseAuth.getInstance().deleteUser(uid);
System.out.println("Successfully deleted user.");
Python
auth.delete_user(uid)
print('Successfully deleted user')
Go
err := client.DeleteUser(ctx, uid)
if err != nil {
log.Fatalf("error deleting user: %v\n", err)
}
log.Printf("Successfully deleted user: %s\n", uid)
C#
await FirebaseAuth.DefaultInstance.DeleteUserAsync(uid);
Console.WriteLine("Successfully deleted user.");
Metoda usuwania użytkownika zwraca pusty wynik po zakończeniu usuwania. .
Jeśli podany uid
nie odpowiada istniejącemu użytkownikowi lub użytkownik nie może
zostaną usunięte z jakiegokolwiek innego powodu, metoda delete spowoduje błąd.
Pełną listę kodów błędów wraz z opisami
i sposoby ich rozwiązywania znajdziesz w artykule Błędy interfejsu API Authentication administratora.
Usuń wielu użytkowników
Za pomocą pakietu Firebase Admin SDK możesz usunąć wielu użytkowników naraz. Pamiętaj jednak:
pamiętaj, że usuwanie wielu użytkowników w organizacji za pomocą takich metod jak deleteUsers(uids)
nie spowoduje uruchomienia modułu obsługi zdarzeń onDelete()
dla funkcji Cloud Functions for Firebase.
Dzieje się tak, ponieważ usuwanie zbiorcze nie wywołuje zdarzenia usunięcia użytkownika
każdego użytkownika. Usuń jednego użytkownika w
w określonym czasie, jeśli chcesz, aby zdarzenia usunięcia użytkownika były uruchamiane w przypadku każdego usuniętego konta użytkownika.
Node.js
getAuth()
.deleteUsers([uid1, uid2, uid3])
.then((deleteUsersResult) => {
console.log(`Successfully deleted ${deleteUsersResult.successCount} users`);
console.log(`Failed to delete ${deleteUsersResult.failureCount} users`);
deleteUsersResult.errors.forEach((err) => {
console.log(err.error.toJSON());
});
})
.catch((error) => {
console.log('Error deleting users:', error);
});
Java
DeleteUsersResult result = FirebaseAuth.getInstance().deleteUsersAsync(
Arrays.asList("uid1", "uid2", "uid3")).get();
System.out.println("Successfully deleted " + result.getSuccessCount() + " users");
System.out.println("Failed to delete " + result.getFailureCount() + " users");
for (ErrorInfo error : result.getErrors()) {
System.out.println("error #" + error.getIndex() + ", reason: " + error.getReason());
}
Python
from firebase_admin import auth
result = auth.delete_users(["uid1", "uid2", "uid3"])
print('Successfully deleted {0} users'.format(result.success_count))
print('Failed to delete {0} users'.format(result.failure_count))
for err in result.errors:
print('error #{0}, reason: {1}'.format(result.index, result.reason))
Go
deleteUsersResult, err := client.DeleteUsers(ctx, []string{"uid1", "uid2", "uid3"})
if err != nil {
log.Fatalf("error deleting users: %v\n", err)
}
log.Printf("Successfully deleted %d users", deleteUsersResult.SuccessCount)
log.Printf("Failed to delete %d users", deleteUsersResult.FailureCount)
for _, err := range deleteUsersResult.Errors {
log.Printf("%v", err)
}
C#
DeleteUsersResult result = await FirebaseAuth.DefaultInstance.DeleteUsersAsync(new List<string>
{
"uid1",
"uid2",
"uid3",
});
Console.WriteLine($"Successfully deleted {result.SuccessCount} users.");
Console.WriteLine($"Failed to delete {result.FailureCount} users.");
foreach (ErrorInfo err in result.Errors)
{
Console.WriteLine($"Error #{err.Index}, reason: {err.Reason}");
}
Metoda usuwania użytkowników zwraca listę błędów dotyczących kont użytkowników, nie można usunąć. Pełną listę kodów błędów wraz z opisami i sposoby ich rozwiązywania znajdziesz w artykule Błędy interfejsu API Authentication administratora.
Wyświetl wszystkich użytkowników
Pakiet Firebase Admin SDK umożliwia zbiorcze pobieranie całej listy użytkowników:
Node.js
const listAllUsers = (nextPageToken) => {
// List batch of users, 1000 at a time.
getAuth()
.listUsers(1000, nextPageToken)
.then((listUsersResult) => {
listUsersResult.users.forEach((userRecord) => {
console.log('user', userRecord.toJSON());
});
if (listUsersResult.pageToken) {
// List next batch of users.
listAllUsers(listUsersResult.pageToken);
}
})
.catch((error) => {
console.log('Error listing users:', error);
});
};
// Start listing users from the beginning, 1000 at a time.
listAllUsers();
Java
// Start listing users from the beginning, 1000 at a time.
ListUsersPage page = FirebaseAuth.getInstance().listUsers(null);
while (page != null) {
for (ExportedUserRecord user : page.getValues()) {
System.out.println("User: " + user.getUid());
}
page = page.getNextPage();
}
// Iterate through all users. This will still retrieve users in batches,
// buffering no more than 1000 users in memory at a time.
page = FirebaseAuth.getInstance().listUsers(null);
for (ExportedUserRecord user : page.iterateAll()) {
System.out.println("User: " + user.getUid());
}
Python
# Start listing users from the beginning, 1000 at a time.
page = auth.list_users()
while page:
for user in page.users:
print('User: ' + user.uid)
# Get next batch of users.
page = page.get_next_page()
# Iterate through all users. This will still retrieve users in batches,
# buffering no more than 1000 users in memory at a time.
for user in auth.list_users().iterate_all():
print('User: ' + user.uid)
Go
// Note, behind the scenes, the Users() iterator will retrive 1000 Users at a time through the API
iter := client.Users(ctx, "")
for {
user, err := iter.Next()
if err == iterator.Done {
break
}
if err != nil {
log.Fatalf("error listing users: %s\n", err)
}
log.Printf("read user user: %v\n", user)
}
// Iterating by pages 100 users at a time.
// Note that using both the Next() function on an iterator and the NextPage()
// on a Pager wrapping that same iterator will result in an error.
pager := iterator.NewPager(client.Users(ctx, ""), 100, "")
for {
var users []*auth.ExportedUserRecord
nextPageToken, err := pager.NextPage(&users)
if err != nil {
log.Fatalf("paging error %v\n", err)
}
for _, u := range users {
log.Printf("read user user: %v\n", u)
}
if nextPageToken == "" {
break
}
}
C#
// Start listing users from the beginning, 1000 at a time.
var pagedEnumerable = FirebaseAuth.DefaultInstance.ListUsersAsync(null);
var responses = pagedEnumerable.AsRawResponses().GetAsyncEnumerator();
while (await responses.MoveNextAsync())
{
ExportedUserRecords response = responses.Current;
foreach (ExportedUserRecord user in response.Users)
{
Console.WriteLine($"User: {user.Uid}");
}
}
// Iterate through all users. This will still retrieve users in batches,
// buffering no more than 1000 users in memory at a time.
var enumerator = FirebaseAuth.DefaultInstance.ListUsersAsync(null).GetAsyncEnumerator();
while (await enumerator.MoveNextAsync())
{
ExportedUserRecord user = enumerator.Current;
Console.WriteLine($"User: {user.Uid}");
}
Każda grupa wyników zawiera listę użytkowników i kolejny token strony używany do
wyświetlić kolejną grupę użytkowników. Jeśli wszyscy użytkownicy są już na liście, nie będzie
Zwracana jest wartość pageToken
.
Jeśli nie podasz żadnego pola maxResults
, zostanie użyte domyślne 1000 użytkowników na grupę.
Jest to także maksymalna dozwolona liczba użytkowników na liście jednocześnie. Dowolne
większa wartość niż maksymalna spowoduje zgłoszenie błędu argumentu.
Jeśli nie określisz elementu pageToken
, operacja spowoduje wyświetlenie listy użytkowników z
na początku w kolejności według: uid
.
Pełną listę kodów błędów wraz z opisami i sposoby ich rozwiązywania znajdziesz w artykule Błędy interfejsu API Authentication administratora.
Hashe haseł na liście użytkowników
Ten interfejs API zwraca również wartości passwordSalt
i passwordHash
zahaszowane przez
Backend uwierzytelniania Firebase dla użytkowników haseł, jeśli konto użytkownika/usługi wcześniej
musi wygenerować token dostępu OAuth żądania
Uprawnienia: firebaseauth.configs.getHashConfig
. W przeciwnym razie passwordHash
i passwordSalt
nie zostaną ustawione.
Ze względu na poufny charakter haszy haseł usługa Firebase Admin SDK
konto nie ma uprawnienia firebaseauth.configs.getHashConfig
przez
wartość domyślną. Nie możesz dodać uprawnień bezpośrednio do konta użytkownika/usługi, ale
może to robić pośrednio przez
utworzyć niestandardową rolę uprawnień.
Aby utworzyć niestandardową rolę uprawnień:
- Otwórz stronę Role w sekcji Administracja w panelu administracyjnym w konsoli Google Cloud.
- Wybierz projekt w menu u góry strony.
- Kliknij UTWÓRZ ROLĘ.
- Kliknij DODAJ UPRAWNIENIA.
- Wyszukaj uprawnienie
firebaseauth.configs.getHashConfig
i wybierz je . - Kliknij DODAJ
- Aby zakończyć tworzenie nowej roli, kliknij UTWÓRZ.
Na stronie uprawnień dodaj utworzoną rolę niestandardową do konta użytkownika lub usługi:
- W sekcji Administracja panelu administratora, wybierz Uprawnienia.
- Wybierz usługę lub konto użytkownika z listy użytkowników do edycji.
- Kliknij DODAJ KOLEJNĄ ROLĘ.
- Wyszukaj nowo utworzoną nową rolę niestandardową.
- Kliknij ZAPISZ.