Firebase Admin SDK یک API برای مدیریت کاربران Firebase Authentication با امتیازات بالا ارائه میکند. API مدیریت کاربر ادمین به شما این امکان را می دهد که به صورت برنامه ریزی شده وظایف زیر را از یک محیط سرور امن انجام دهید:
- کاربران جدید را بدون هیچ گونه محدودیت یا محدودیت نرخ ایجاد کنید.
- کاربران را با معیارهای مختلفی مانند uid، ایمیل یا شماره تلفن جستجو کنید.
- تمام کاربران یک پروژه مشخص شده را به صورت دسته ای لیست کنید.
- به ابرداده های کاربر از جمله تاریخ ایجاد حساب و آخرین تاریخ ورود به سیستم دسترسی داشته باشید.
- کاربران را بدون نیاز به رمز عبور موجود حذف کنید.
- ویژگی های کاربر - از جمله رمز عبور آنها - را بدون نیاز به ورود به عنوان کاربر به روز کنید.
- ایمیلها را بدون نیاز به گذر از جریانهای کنش خارج از باند برای تأیید ایمیلها تأیید کنید.
- ایمیل کاربر را بدون ارسال لینک ایمیل تغییر دهید تا این تغییرات لغو شود.
- بدون نیاز به گذر از جریان تأیید پیامک، یک کاربر جدید با شماره تلفن ایجاد کنید.
- شماره تلفن کاربر را بدون نیاز به عبور از جریان تأیید پیامک تغییر دهید.
- کاربران ارائه آفلاین در حالت غیرفعال هستند و بعداً زمان فعال کردن آنها را کنترل کنید.
- کنسول های کاربر سفارشی بسازید که برای سیستم مدیریت کاربر یک برنامه خاص طراحی شده است.
قبل از شروع
برای استفاده از API مدیریت کاربر ارائه شده توسط Firebase Admin SDK، باید یک حساب سرویس داشته باشید. دستورالعملهای راهاندازی را برای اطلاعات بیشتر در مورد نحوه اولیهسازی Admin SDK دنبال کنید.
بازیابی اطلاعات کاربر
راه اصلی برای شناسایی یک کاربر توسط uid
آنها است که یک شناسه منحصر به فرد برای آن کاربر است. Admin SDK روشی را ارائه می دهد که امکان واکشی اطلاعات نمایه کاربران را توسط 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);
});
جاوا
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());
پایتون
from firebase_admin import auth
user = auth.get_user(uid)
print('Successfully fetched user data: {0}'.format(user.uid))
برو
// 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)
سی شارپ
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}");
این متد یک شی UserRecord
برای کاربر مربوط به uid
ارائه شده به متد برمی گرداند.
اگر uid
ارائه شده متعلق به یک کاربر موجود نباشد یا به هر دلیل دیگری کاربر نتواند واکشی شود، روش بالا خطا میکند. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Auth Admin مراجعه کنید.
در برخی موارد به جای uid
کاربر، ایمیل کاربر را خواهید داشت. Firebase Admin SDK از جستجوی اطلاعات کاربر با یک ایمیل پشتیبانی می کند:
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);
});
جاوا
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());
پایتون
from firebase_admin import auth
user = auth.get_user_by_email(email)
print('Successfully fetched user data: {0}'.format(user.uid))
برو
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)
سی شارپ
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}");
این روش یک شی UserRecord
برای کاربر مربوط به ایمیل ارائه شده برمی گرداند.
اگر ایمیل ارائه شده متعلق به یک کاربر موجود نباشد یا کاربر به هر دلیل دیگری قابل واکشی نباشد، Admin SDK با خطا مواجه می شود. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
در موارد دیگر، به جای uid
کاربر، شماره تلفن کاربر را خواهید داشت. Firebase Admin SDK از جستجوی اطلاعات کاربر با یک شماره تلفن پشتیبانی می کند:
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);
});
جاوا
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());
پایتون
from firebase_admin import auth
user = auth.get_user_by_phone_number(phone)
print('Successfully fetched user data: {0}'.format(user.uid))
برو
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)
سی شارپ
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}");
این روش یک شی UserRecord
برای کاربر مربوط به شماره تلفن ارائه شده برمی گرداند.
اگر شماره تلفن ارائه شده متعلق به یک کاربر موجود نباشد یا کاربر به هر دلیل دیگری قابل واکشی نباشد، Admin SDK با خطا مواجه می شود. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
بازیابی انبوه داده های کاربر
Firebase Admin SDK همچنین امکان بازیابی لیستی از کاربران را بر اساس شناسههایی که ارائه میکنید، میدهد. می توانید کاربران را با شناسه کاربری، ایمیل یا شماره تلفن آنها شناسایی کنید. حداکثر 100 شناسه را می توان در یک تماس ارائه کرد. شناسه ها می توانند ترکیبی از انواع باشند:
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);
});
جاوا
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);
}
پایتون
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)
برو
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)
}
سی شارپ
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}");
}
این روش فهرستی را به اندازه فهرست ورودی برمیگرداند، با هر ورودی حاوی UserRecord
مربوطه یا خطایی که نشان میدهد چرا نمیتوان آن شناسه را جستجو کرد. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
یک کاربر ایجاد کنید
Admin SDK روشی را ارائه می دهد که به شما امکان می دهد یک کاربر جدید Firebase Authentication ایجاد کنید. این روش یک شی حاوی اطلاعات نمایه را می پذیرد تا در حساب کاربری جدید ایجاد شده درج شود:
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);
});
جاوا
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());
پایتون
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))
برو
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)
سی شارپ
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}");
به طور پیش فرض، Firebase Authentication یک uid
تصادفی برای کاربر جدید ایجاد می کند. اگر در عوض میخواهید uid
خود را برای کاربر جدید مشخص کنید، میتوانید آن را به عنوان آرگومان ارسال شده به روش ایجاد کاربر اضافه کنید:
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);
});
جاوا
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());
پایتون
user = auth.create_user(
uid='some-uid', email='user@example.com', phone_number='+15555550100')
print('Sucessfully created new user: {0}'.format(user.uid))
برو
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)
سی شارپ
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}");
هر ترکیبی از ویژگی های زیر را می توان ارائه داد:
جدول 1. ویژگی های پشتیبانی شده توسط عملیات ایجاد کاربر
اموال | تایپ کنید | توضیحات |
---|---|---|
uid | رشته | uid برای اختصاص دادن به کاربر تازه ایجاد شده. باید رشته ای بین 1 تا 128 کاراکتر باشد که شامل آن می شود. اگر ارائه نشود، یک uid تصادفی به طور خودکار ایجاد می شود. uid کوتاهتر عملکرد بهتری را ارائه می دهند. |
email | رشته | ایمیل اصلی کاربر باید یک آدرس ایمیل معتبر باشد. |
emailVerified | بولی | آیا ایمیل اصلی کاربر تأیید شده است یا خیر. اگر ارائه نشده باشد، پیش فرض false است. |
phoneNumber | رشته | شماره تلفن اصلی کاربر. باید یک شماره تلفن معتبر مطابق با مشخصات E.164 باشد. |
password | رشته | رمز عبور خام و هش نشده کاربر. باید حداقل شش کاراکتر باشد. |
displayName | رشته | نام نمایشی کاربران |
photoURL | رشته | آدرس عکس کاربر. |
disabled | بولی | این که آیا کاربر غیرفعال است یا خیر. برای معلولین true . false برای فعال. اگر ارائه نشده باشد، پیش فرض false است. |
روش ایجاد کاربر یک شی UserRecord
برای کاربر تازه ایجاد شده برمی گرداند.
اگر uid
، ایمیل یا شماره تلفن ارائه شده قبلاً توسط یک کاربر موجود استفاده می شود یا کاربر به دلیل دیگری نمی تواند ایجاد شود، روش فوق با خطا انجام نمی شود. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
یک کاربر را به روز کنید
Firebase Admin SDK تغییر دادههای کاربر موجود را تسهیل میکند. برای به روز رسانی برای آن کاربر باید یک uid
به همراه ویژگی ها مشخص کنید:
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);
});
جاوا
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());
پایتون
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))
برو
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)
سی شارپ
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}");
هر ترکیبی از ویژگی های زیر را می توان ارائه داد:
جدول 2. ویژگی های پشتیبانی شده توسط عملیات کاربر به روز رسانی
اموال | تایپ کنید | توضیحات |
---|---|---|
email | رشته | ایمیل اصلی جدید کاربر. باید یک آدرس ایمیل معتبر باشد. |
emailVerified | بولی | آیا ایمیل اصلی کاربر تأیید شده است یا خیر. اگر ارائه نشده باشد، پیش فرض false است. |
phoneNumber | رشته | شماره تلفن اصلی جدید کاربر. باید یک شماره تلفن معتبر مطابق با مشخصات E.164 باشد. برای پاک کردن شماره تلفن موجود کاربر، روی null تنظیم کنید. |
password | رشته | رمز عبور خام و هش نشده جدید کاربر. باید حداقل شش کاراکتر باشد. |
displayName | رشته | null | نام نمایشی جدید کاربران برای پاک کردن نام نمایشی موجود کاربر، روی null تنظیم کنید. |
photoURL | رشته | null | آدرس عکس جدید کاربران. برای پاک کردن URL عکس موجود کاربر، روی null تنظیم کنید. اگر null نباشد، باید یک URL معتبر باشد. |
disabled | بولی | این که آیا کاربر غیرفعال است یا خیر. برای افراد ناتوان true . false برای فعال. |
روش کاربر بهروزرسانی، یک شی UserRecord
بهروزرسانی شده را پس از تکمیل موفقیتآمیز بهروزرسانی، برمیگرداند.
اگر uid
ارائه شده با یک کاربر موجود مطابقت نداشته باشد، ایمیل یا شماره تلفن ارائه شده قبلاً توسط یک کاربر موجود استفاده می شود، یا کاربر به هر دلیل دیگری نمی تواند به روز شود، روش فوق با خطا انجام نمی شود. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
حذف یک کاربر
Firebase Admin SDK اجازه می دهد تا کاربران موجود را با استفاده از uid
حذف کنید:
Node.js
getAuth()
.deleteUser(uid)
.then(() => {
console.log('Successfully deleted user');
})
.catch((error) => {
console.log('Error deleting user:', error);
});
جاوا
FirebaseAuth.getInstance().deleteUser(uid);
System.out.println("Successfully deleted user.");
پایتون
auth.delete_user(uid)
print('Successfully deleted user')
برو
err := client.DeleteUser(ctx, uid)
if err != nil {
log.Fatalf("error deleting user: %v\n", err)
}
log.Printf("Successfully deleted user: %s\n", uid)
سی شارپ
await FirebaseAuth.DefaultInstance.DeleteUserAsync(uid);
Console.WriteLine("Successfully deleted user.");
هنگامی که حذف با موفقیت کامل شد، روش حذف کاربر یک نتیجه خالی برمی گرداند.
اگر uid
ارائه شده با یک کاربر موجود مطابقت نداشته باشد یا کاربر به هر دلیل دیگری قابل حذف نباشد، روش حذف کاربر خطا می دهد. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
حذف چند کاربر
Firebase Admin SDK همچنین می تواند چندین کاربر را همزمان حذف کند. با این حال، توجه داشته باشید که استفاده از روشهایی مانند deleteUsers(uids)
برای حذف چند کاربر به طور همزمان، کنترلکننده رویداد onDelete()
برای Cloud Functions for Firebase فعال نمیکند. این به این دلیل است که حذف دسته ای رویداد حذف کاربر را در هر کاربر ایجاد نمی کند. اگر می خواهید رویدادهای حذف کاربر برای هر کاربر حذف شده فعال شود، کاربران را یکی یکی حذف کنید.
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);
});
جاوا
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());
}
پایتون
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))
برو
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)
}
سی شارپ
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}");
}
روش حذف کاربران لیستی از خرابیها را برای کاربرانی که حذف نشدند برمیگرداند. برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
لیست همه کاربران
Firebase Admin SDK اجازه می دهد تا کل لیست کاربران را به صورت دسته ای بازیابی کنید:
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();
جاوا
// 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());
}
پایتون
# 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)
برو
// 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
}
}
سی شارپ
// 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}");
}
هر دسته از نتایج حاوی لیستی از کاربران و نشانه صفحه بعدی است که برای لیست کردن دسته بعدی از کاربران استفاده می شود. هنگامی که همه کاربران قبلاً لیست شده اند، هیچ pageToken
برگردانده نمی شود.
اگر فیلد maxResults
مشخص نشده باشد، از 1000 کاربر پیشفرض در هر دسته استفاده میشود. این همچنین حداکثر تعداد کاربرانی است که در هر زمان مجاز به لیست شدن هستند. هر مقدار بزرگتر از حداکثر یک خطای آرگومان ایجاد می کند. اگر pageToken
مشخص نشده باشد، عملیات فهرستی از کاربران را از ابتدا به ترتیب توسط uid
انجام می دهد.
برای فهرست کامل کدهای خطا، از جمله توضیحات و مراحل حل، به خطاهای API Authentication مدیر مراجعه کنید.
هش رمز عبور کاربران لیست شده
در صورتی که حساب کاربری/سرویس مورد استفاده برای ایجاد درخواست توکن دسترسی OAuth دارای مجوز firebaseauth.configs.getHashConfig
باشد، این API نیز passwordSalt
و passwordHash
هش شده توسط باطن Firebase Auth را برای کاربران رمز عبور برمی گرداند. در غیر این صورت passwordHash
و passwordSalt
تنظیم نمی شوند.
به دلیل ماهیت حساس هش رمز عبور، حساب سرویس Firebase Admin SDK به طور پیش فرض مجوز firebaseauth.configs.getHashConfig
را ندارد. نمیتوانید مجوزی را مستقیماً به حساب کاربری/سرویس اضافه کنید، اما میتوانید این کار را بهطور غیرمستقیم با ایجاد یک نقش IAM سفارشی انجام دهید.
برای ایجاد نقش سفارشی IAM:
- به صفحه نقشها در IAM و پنل مدیریت در کنسول Google Cloud بروید.
- پروژه خود را از منوی کشویی بالای صفحه انتخاب کنید.
- روی CREATE ROLE کلیک کنید
- روی ADD PERMISSIONs کلیک کنید
- مجوز
firebaseauth.configs.getHashConfig
را جستجو کنید و آن کادر را انتخاب کنید. - روی ADD کلیک کنید
- روی CREATE کلیک کنید تا ایجاد نقش جدید به پایان برسد.
نقش سفارشی ایجاد شده را به حساب کاربر/سرویس در صفحه IAM اضافه کنید:
- در پنل IAM & admin ، IAM را انتخاب کنید
- سرویس یا حساب کاربری را از لیست اعضا برای ویرایش انتخاب کنید.
- روی ADD ANOTHER ROLE کلیک کنید.
- نقش سفارشی جدیدی که قبلا ایجاد شده را جستجو کنید.
- روی ذخیره کلیک کنید.