Google is committed to advancing racial equity for Black communities. See how.
Bu sayfa, Cloud Translation API ile çevrilmiştir.
Switch to English

Kullanıcıları Yönet

Firebase Yönetici SDK'sı, Firebase Kimlik Doğrulaması kullanıcılarınızı yüksek ayrıcalıklarla yönetmek için bir API sağlar. Yönetici kullanıcı yönetimi API'si, güvenli bir sunucu ortamından aşağıdaki görevleri programlı olarak tamamlamanıza olanak tanır:

  • Kısma veya hız sınırlaması olmadan yeni kullanıcılar oluşturun.
  • Kullanıcıları uid, email veya telefon numarası gibi farklı ölçütlere göre arayın.
  • Belirli bir projenin tüm kullanıcılarını toplu olarak listeleyin.
  • Hesap oluşturma tarihi ve son oturum açma tarihi dahil olmak üzere kullanıcı meta verilerine erişin.
  • Varolan parolalarını gerektirmeden kullanıcıları silin.
  • Kullanıcı olarak oturum açmak zorunda kalmadan kullanıcı özelliklerini - parolaları dahil - güncelleyin.
  • E-postaları doğrulamak için bant dışı eylem akışlarından geçmek zorunda kalmadan e-postaları doğrulayın.
  • Bu değişiklikleri iptal etmek için e-posta bağlantıları göndermeden bir kullanıcının e-postasını değiştirin.
  • SMS doğrulama akışından geçmek zorunda kalmadan telefon numarasıyla yeni bir kullanıcı oluşturun.
  • SMS doğrulama akışından geçmek zorunda kalmadan bir kullanıcının telefon numarasını değiştirin.
  • Çevrimdışı sağlama kullanıcıları devre dışı bırakılır ve daha sonra ne zaman etkinleştirilecekleri denetlenir.
  • Belirli bir uygulamanın kullanıcı yönetim sistemine göre uyarlanmış özel kullanıcı konsolları oluşturun.

Sen başlamadan önce

Firebase Yönetici SDK'sı tarafından sağlanan kullanıcı yönetimi API'sını kullanmak için bir hizmet hesabınızın olması gerekir. Yönetici SDK'sını başlatma hakkında daha fazla bilgi için kurulum talimatlarını uygulayın.

Kullanıcı verilerini alma

Bir kullanıcıyı tanımlamanın birincil yolu, kullanıcı için benzersiz bir tanımlayıcı olan uid . Yönetici SDK'sı, kullanıcıların profil bilgilerini kullanıcı kimliklerine göre uid olanak tanıyan bir yöntem sağlar:

node.js

 admin.auth().getUser(uid)
  .then(function(userRecord) {
    // See the UserRecord reference doc for the contents of userRecord.
    console.log('Successfully fetched user data:', userRecord.toJSON());
  })
  .catch(function(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());
 

piton

 from firebase_admin import auth

user = auth.get_user(uid)
print('Successfully fetched user data: {0}'.format(user.uid))
 

Git

 // 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}");
 

Bu yöntem, bir döner UserRecord tekabül eden bir kullanıcı için bir nesne uid yöntemine sağladı.

Sağlanan uid mevcut bir kullanıcıya ait değilse veya kullanıcı başka bir nedenle getirilemezse, yukarıdaki yöntem bir hata atar. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Yetkilendirme API Hataları'na bakın .

Bazı durumlarda kullanıcı uid yerine kullanıcının e-postası olur. Firebase Yönetici SDK'sı, kullanıcı bilgilerinin e-posta ile aranmasını destekler:

node.js

 admin.auth().getUserByEmail(email)
  .then(function(userRecord) {
    // See the UserRecord reference doc for the contents of userRecord.
    console.log('Successfully fetched user data:', userRecord.toJSON());
  })
  .catch(function(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());
 

piton

 from firebase_admin import auth

user = auth.get_user_by_email(email)
print('Successfully fetched user data: {0}'.format(user.uid))
 

Git

 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}");
 

Bu yöntem, sağlanan e-postaya karşılık gelen kullanıcı için bir UserRecord nesnesi döndürür.

Sağlanan e-posta mevcut bir kullanıcıya ait değilse veya kullanıcı başka bir nedenle getirilemezse, Yönetici SDK'sı bir hata atar. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Diğer durumlarda, kullanıcı uid yerine bir kullanıcının telefon numarasına sahip olursunuz. Firebase Yönetici SDK'sı, telefon numarasıyla kullanıcı bilgilerinin aranmasını destekler:

node.js

 admin.auth().getUserByPhoneNumber(phoneNumber)
  .then(function(userRecord) {
    // See the UserRecord reference doc for the contents of userRecord.
    console.log('Successfully fetched user data:', userRecord.toJSON());
  })
  .catch(function(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());
 

piton

 from firebase_admin import auth

user = auth.get_user_by_phone_number(phone)
print('Successfully fetched user data: {0}'.format(user.uid))
 

Git

 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}");
 

Bu yöntem, sağlanan telefon numarasına karşılık gelen kullanıcı için bir UserRecord nesnesi döndürür.

Sağlanan telefon numarası mevcut bir kullanıcıya ait değilse veya kullanıcı başka bir nedenle getirilemezse, Yönetici SDK'sı bir hata atar. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Kullanıcı verilerini toplu olarak alma

Firebase Yönetici SDK'sı, sağladığınız tanımlayıcılara göre bir kullanıcı listesi almanıza da olanak tanır. Kullanıcıları kullanıcı kimliklerine, e-postalarına veya telefon numaralarına göre tanımlayabilirsiniz. Tek bir aramada en fazla 100 tanımlayıcı sağlanabilir. Tanımlayıcılar bir tür karışım içerebilir:

node.js

 admin.auth().getUsers([
    { uid: 'uid1' },
    { email: 'user2@example.com' },
    { phoneNumber: '+15555550003' },
    { providerId: 'google.com', providerUid: 'google_uid4' },
  ])
  .then(function(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(function(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);
}
 

piton

 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)
 

Git

 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}");
}

 

Bu yöntem, giriş listesiyle aynı boyutta bir liste döndürür; her giriş, karşılık gelen UserRecord veya bu tanımlayıcının neden UserRecord belirten bir hata içerir. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Bir kullanıcı oluşturun

Yönetici SDK'sı, yeni bir Firebase Kimlik Doğrulama kullanıcısı oluşturmanıza olanak tanıyan bir yöntem sağlar. Bu yöntem, yeni oluşturulan kullanıcı hesabına eklenecek profil bilgilerini içeren bir nesneyi kabul eder:

node.js

 admin.auth().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(function(userRecord) {
    // See the UserRecord reference doc for the contents of userRecord.
    console.log('Successfully created new user:', userRecord.uid);
  })
  .catch(function(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());
 

piton

 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))
 

Git

 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}");
 

Varsayılan olarak, Firebase Kimlik Doğrulaması yeni kullanıcı için rastgele bir uid kimliği oluşturur. Bunun yerine yeni kullanıcı için kendi uid belirtmek istiyorsanız, kullanıcı oluşturma yöntemine iletilen bağımsız değişkeni ekleyebilirsiniz:

node.js

 admin.auth().createUser({
  uid: 'some-uid',
  email: 'user@example.com',
  phoneNumber: '+11234567890'
})
  .then(function(userRecord) {
    // See the UserRecord reference doc for the contents of userRecord.
    console.log('Successfully created new user:', userRecord.uid);
  })
  .catch(function(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());
 

piton

 user = auth.create_user(
    uid='some-uid', email='user@example.com', phone_number='+15555550100')
print('Sucessfully created new user: {0}'.format(user.uid))
 

Git

 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}");
 

Aşağıdaki özelliklerin herhangi bir kombinasyonu sağlanabilir:

Çizelge 1. Kullanıcı oluşturma işlemi tarafından desteklenen özellikler

Emlak tip Açıklama
uid sicim Yeni oluşturulan kullanıcıya atanacak uid . 1 - 128 karakter uzunluğunda (dahil) bir dize olmalıdır. uid , otomatik olarak rastgele bir uid oluşturulur.
email sicim Kullanıcının birincil e-postası. Geçerli bir e-posta adresi olmalı.
emailVerified boole Kullanıcının birincil e-postasının doğrulanıp doğrulanmadığı. Sağlanmazsa, varsayılan değer false .
phoneNumber sicim Kullanıcının birincil telefon numarası. Geçerli bir E.164 spesifikasyonlu telefon numarası olmalıdır.
password sicim Kullanıcının ham, unhashed şifresi. En az altı karakter uzunluğunda olmalı.
displayName sicim Kullanıcıların görünen adı.
photoURL sicim Kullanıcının fotoğraf URL'si.
disabled boole Kullanıcının devre dışı bırakılıp bırakılmadığı. engelliler için true ; etkin için false . Sağlanmazsa, varsayılan değer false .

Kullanıcı oluşturma yöntemi, yeni oluşturulan kullanıcı için bir UserRecord nesnesi döndürür.

Sağlanan uid , e-posta veya telefon numarası mevcut bir kullanıcı tarafından zaten kullanılıyorsa veya kullanıcı başka bir nedenle oluşturulamıyorsa, yukarıdaki yöntem bir hatayla başarısız olur. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Bir kullanıcıyı güncelleme

Firebase Yönetici SDK'sı, mevcut bir kullanıcının verilerini değiştirmeyi kolaylaştırır. Söz konusu kullanıcı için güncellenecek özelliklerle birlikte bir uid belirtmeniz gerekir:

node.js

 admin.auth().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(function(userRecord) {
    // See the UserRecord reference doc for the contents of userRecord.
    console.log('Successfully updated user', userRecord.toJSON());
  })
  .catch(function(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());
 

piton

 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))
 

Git

 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}");
 

Aşağıdaki özelliklerin herhangi bir kombinasyonu sağlanabilir:

Çizelge 2. Güncelleme kullanıcı işlemi tarafından desteklenen özellikler

Emlak tip Açıklama
email sicim Kullanıcının yeni birincil e-postası. Geçerli bir e-posta adresi olmalı.
emailVerified boole Kullanıcının birincil e-postasının doğrulanıp doğrulanmadığı. Sağlanmazsa, varsayılan değer false .
phoneNumber sicim Kullanıcının yeni birincil telefon numarası. Geçerli bir E.164 spesifikasyonlu telefon numarası olmalıdır. Kullanıcının mevcut telefon numarasını silmek için null olarak ayarlayın.
password sicim Kullanıcının yeni ham, unhashed şifresi. En az altı karakter uzunluğunda olmalı.
displayName dize | null Kullanıcıların yeni görünen adı. Kullanıcının mevcut görünen adını silmek için null olarak ayarlayın.
photoURL dize | null Kullanıcıların yeni fotoğraf URL'si. Kullanıcının mevcut fotoğraf URL'sini temizlemek için null olarak ayarlayın. null değilse, geçerli bir URL olmalıdır.
disabled boole Kullanıcının devre dışı bırakılıp bırakılmadığı. engelliler için true ; etkin için false .

Güncelleme başarıyla tamamlandığında güncelleme kullanıcı yöntemi, güncellenmiş bir UserRecord nesnesi döndürür.

Sağlanan uid mevcut bir kullanıcıya karşılık gelmiyorsa, sağlanan e-posta veya telefon numarası mevcut bir kullanıcı tarafından zaten kullanılıyorsa veya kullanıcı başka bir nedenle güncellenemiyorsa, yukarıdaki yöntem bir hatayla başarısız olur. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Bir kullanıcıyı silme

Firebase Yönetici SDK, tarafından mevcut kullanıcıları silme sağlar uid :

node.js

 admin.auth().deleteUser(uid)
  .then(function() {
    console.log('Successfully deleted user');
  })
  .catch(function(error) {
    console.log('Error deleting user:', error);
  });
 

Java

 FirebaseAuth.getInstance().deleteUser(uid);
System.out.println("Successfully deleted user.");
 

piton

 auth.delete_user(uid)
print('Successfully deleted user')
 

Git

 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.");
 

Silme işlemi başarıyla tamamlandığında kullanıcı silme yöntemi boş bir sonuç döndürür.

Sağlanan uid mevcut bir kullanıcıya karşılık gelmiyorsa veya kullanıcı başka bir nedenle silinemezse, kullanıcı silme yöntemi bir hata atar. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Birden Çok Kullanıcıyı Sil

Firebase Yönetici SDK'sı aynı anda birden fazla kullanıcıyı silebilir:

node.js

 admin.auth().deleteUsers([uid1, uid2, uid3])
  .then(function(deleteUsersResult) {
    console.log('Successfully deleted ' + deleteUsersResult.successCount + ' users');
    console.log('Failed to delete ' +  deleteUsersResult.failureCount + ' users');
    deleteUsersResult.errors.forEach(function(err) {
      console.log(err.error.toJSON());
    });
  })
  .catch(function(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());
}
 

piton

 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))
 

Git

 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}");
}

 

Kullanıcıları sil yöntemi, silinemeyen kullanıcılar için bir hata listesi döndürür. Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Tüm kullanıcıları listele

Firebase Yönetici SDK'sı, kullanıcı listesinin tamamını toplu olarak almayı sağlar:

node.js

 function listAllUsers(nextPageToken) {
  // List batch of users, 1000 at a time.
  admin.auth().listUsers(1000, nextPageToken)
    .then(function(listUsersResult) {
      listUsersResult.users.forEach(function(userRecord) {
        console.log('user', userRecord.toJSON());
      });
      if (listUsersResult.pageToken) {
        // List next batch of users.
        listAllUsers(listUsersResult.pageToken);
      }
    })
    .catch(function(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());
}
 

piton

 # 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)
 

Git

 // 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().GetEnumerator();
while (await responses.MoveNext())
{
    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).GetEnumerator();
while (await enumerator.MoveNext())
{
    ExportedUserRecord user = enumerator.Current;
    Console.WriteLine($"User: {user.Uid}");
}

 

Her sonuç grubu, bir kullanıcı listesi ve bir sonraki kullanıcı grubunu listelemek için kullanılan bir sonraki sayfa jetonunu içerir. Tüm kullanıcılar zaten listelendiyse, hiçbir pageToken döndürülmez.

maxResults alanı belirtilmezse, toplu iş başına varsayılan 1000 kullanıcı kullanılır. Bu aynı zamanda bir anda listelenmesine izin verilen maksimum kullanıcı sayısıdır. Maksimumdan büyük herhangi bir değer bir argüman hatası verir. Herhangi bir pageToken belirtilmezse, işlem en başından uid tarafından sıralanmış kullanıcıları listeler.

Açıklamalar ve çözüm adımları da dahil olmak üzere hata kodlarının tam listesi için Yönetici Kimlik Doğrulama API Hataları'na bakın .

Listelenen kullanıcıların şifre karmaları

Bu API döndüren passwordSalt ve passwordHash kullanıcı / hizmet hesabı vardır belirteç isteği OAuth erişimini oluşturmak için kullanılan eğer şifre kullanıcıları için Firebase Auth arka uç tarafından karma firebaseauth.configs.getHashConfig izni. Aksi takdirde passwordHash ve passwordSalt ayarlanmaz.

Parola karmasının hassas yapısı nedeniyle, firebaseauth.configs.getHashConfig Yöneticisi SDK hizmeti hesabının varsayılan olarak firebaseauth.configs.getHashConfig izni yoktur. Bir kullanıcı / hizmet hesabına doğrudan izin ekleyemezsiniz, ancak bunu özel bir IAM rolü oluşturarak dolaylı olarak yapabilirsiniz.

Özel IAM rolünü oluşturmak için:

  1. GCP Konsolu'ndaki IAM ve yönetici panelindeki Roller sayfasına gidin.
  2. Sayfanın üst kısmındaki açılır menüden projenizi seçin.
  3. ROL OLUŞTUR'u tıklayın
  4. İZİNLERİ EKLE'yi tıklayın
  5. firebaseauth.configs.getHashConfig iznini arayın ve bu onay kutusunu seçin.
  6. EKLE'yi tıklayın
  7. Yeni rolü oluşturmayı tamamlamak için OLUŞTUR'u tıklayın.

Oluşturulan özel rolü IAM sayfasındaki kullanıcı / hizmet hesabına ekleyin:

  1. IAM ve yönetici panelinde IAM'yi seçin
  2. Düzenlenecek üye listesinden hizmeti veya kullanıcı hesabını seçin.
  3. BAŞKA BİR ROL EKLE'yi tıklayın.
  4. Daha önce oluşturulan yeni özel rolü arayın.
  5. KAYDET 'i tıklayın.