Firebase एडमिन SDK, खास सुविधाओं वाले Firebase Authentication उपयोगकर्ता. एडमिन यूज़र मैनेजमेंट एपीआई प्रोग्राम बनाकर नीचे दिए गए टास्क पूरे किए जा सकते हैं. इसके लिए सुरक्षित सर्वर एनवायरमेंट:
- किसी भी थ्रॉटलिंग या दर सीमित किए बिना नए उपयोगकर्ता बनाएं.
- उपयोगकर्ताओं को अलग-अलग शर्तों, जैसे कि uid, ईमेल या फ़ोन नंबर के आधार पर खोजें.
- किसी खास प्रोजेक्ट के सभी उपयोगकर्ताओं की सूची बैच में दें.
- खाता बनाने की तारीख और पिछली बार साइन इन करने की तारीख के साथ उपयोगकर्ता का मेटाडेटा ऐक्सेस करें.
- उपयोगकर्ताओं के मौजूदा पासवर्ड की ज़रूरत के बिना उन्हें हटाना.
- साइन इन किए बिना, उपयोगकर्ता प्रॉपर्टी का पासवर्ड अपडेट करें उपयोगकर्ता किस तरह का है.
- इन कामों के लिए आउट-ऑफ़-बैंड कार्रवाई फ़्लो के बिना ईमेल की पुष्टि करें ईमेल सत्यापित करें.
- इन बदलावों को निरस्त करने के लिए, ईमेल लिंक भेजे बिना उपयोगकर्ता के ईमेल को बदलें.
- मैसेज (एसएमएस) किए बिना फ़ोन नंबर के साथ नया उपयोगकर्ता बनाएं पुष्टि करने की प्रोसेस.
- मैसेज (एसएमएस) की मदद से पुष्टि किए बिना उपयोगकर्ता का फ़ोन नंबर बदलना फ़्लो.
- उपयोगकर्ता एक बंद स्थिति में ऑफ़लाइन प्रावधान करते हैं और फिर बाद में यह नियंत्रित करते हैं कि कब उन्हें चालू करें.
- ऐसे कस्टम उपयोगकर्ता कंसोल बनाएं जो किसी खास ऐप्लिकेशन के उपयोगकर्ता के हिसाब से हों मैनेजमेंट सिस्टम.
शुरू करने से पहले
Firebase एडमिन SDK से मिले यूज़र मैनेजमेंट एपीआई का इस्तेमाल करने के लिए, सेवा खाता होना चाहिए. सेटअप से जुड़े निर्देशों का पालन करें .
उपयोगकर्ता का डेटा वापस पाना
किसी उपयोगकर्ता की पहचान करने का मुख्य तरीका, उसका uid
है. यह इसके लिए यूनीक आइडेंटिफ़ायर होता है
उस उपयोगकर्ता के बारे में बात करते हैं. एडमिन 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);
});
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))
शुरू करें
// 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}");
यह तरीका UserRecord
दिखाता है
ऑब्जेक्ट, जो तरीके के लिए दिए गए uid
से जुड़े उपयोगकर्ता के लिए है.
अगर दिया गया uid
किसी मौजूदा उपयोगकर्ता का नहीं है या उपयोगकर्ता
किसी दूसरी वजह से फ़ेच करने पर, ऊपर दिए गए तरीके में गड़बड़ी होती है.
गड़बड़ी के कोड की पूरी सूची देखने के लिए,
ठीक करने के तरीके के बारे में ज़्यादा जानने के लिए, Admin Auth API से जुड़ी गड़बड़ियां देखें.
कुछ मामलों में आपके पास उपयोगकर्ता के uid
के बजाय उसका ईमेल होगा. Firebase
एडमिन 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);
});
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))
शुरू करें
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}");
यह तरीका इसके लिए UserRecord
ऑब्जेक्ट लौटाता है
दिए गए ईमेल पते से जुड़ा कोई उपयोगकर्ता खाता है.
अगर दिया गया ईमेल किसी मौजूदा उपयोगकर्ता का नहीं है या उपयोगकर्ता किसी दूसरी वजह से फ़ेच किए जाने पर, एडमिन SDK टूल में गड़बड़ी मिलती है. गड़बड़ी के कोड की पूरी सूची देखने के लिए, जिसमें गड़बड़ी का ब्यौरा भी शामिल है और उन्हें ठीक करने के तरीके के बारे में ज़्यादा जानने के लिए, एडमिन Authentication एपीआई से जुड़ी गड़बड़ियां देखें.
अन्य मामलों में, आपके पास उपयोगकर्ता के uid
के बजाय उसका फ़ोन नंबर होगा. कॉन्टेंट बनाने
Firebase एडमिन 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);
});
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))
शुरू करें
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}");
यह तरीका इसके लिए UserRecord
ऑब्जेक्ट लौटाता है
दिए गए फ़ोन नंबर से संबंधित उपयोगकर्ता.
अगर दिया गया फ़ोन नंबर किसी मौजूदा उपयोगकर्ता या उपयोगकर्ता का नहीं है किसी दूसरी वजह से फ़ेच नहीं किया जा सकता, तो एडमिन SDK टूल में गड़बड़ी मिलती है. गड़बड़ी के कोड की पूरी सूची देखने के लिए, जिसमें गड़बड़ी का ब्यौरा भी शामिल है और उन्हें ठीक करने के तरीके के बारे में ज़्यादा जानने के लिए, एडमिन Authentication एपीआई से जुड़ी गड़बड़ियां देखें.
उपयोगकर्ता का डेटा एक साथ वापस पाएं
Firebase एडमिन 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);
});
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)
शुरू करें
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}");
}
इस तरीके से, हर एंट्री के साथ सूची का साइज़, इनपुट सूची के साइज़ के बराबर हो जाता है
या तो संबंधित UserRecord
शामिल है या फिर गड़बड़ी की वजह बताने वाली गड़बड़ी है
आइडेंटिफ़ायर नहीं खोजा जा सका. गड़बड़ी कोड की पूरी सूची देखने के लिए,
जानकारी और इसे हल करने के चरणों के साथ-साथ, Admin Authentication API देखें
गड़बड़ियां.
उपयोगकर्ता बनाएं
एडमिन 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);
});
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))
शुरू करें
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}");
डिफ़ॉल्ट रूप से, 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);
});
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))
शुरू करें
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}");
नीचे दी गई प्रॉपर्टी का कोई भी कॉम्बिनेशन दिया जा सकता है:
टेबल 1. 'उपयोगकर्ता बनाएं' कार्रवाई के साथ काम करने वाली प्रॉपर्टी
प्रॉपर्टी | टाइप | ब्यौरा |
---|---|---|
uid |
स्ट्रिंग |
नए उपयोगकर्ता को असाइन करने के लिए uid .
1 से 128 वर्णों की स्ट्रिंग. अगर यह पैरामीटर उपलब्ध नहीं कराया जाता है, तो
रैंडम uid अपने-आप जनरेट हो जाएगा. छोटा
uid से बेहतर परफ़ॉर्मेंस मिलती है.
|
email |
स्ट्रिंग | उपयोगकर्ता का मुख्य ईमेल पता. एक मान्य ईमेल पता होना चाहिए. |
emailVerified |
बूलियन |
उपयोगकर्ता के मुख्य ईमेल पते की पुष्टि की गई है या नहीं. अगर यह पैरामीटर उपलब्ध नहीं कराया जाता, तो
डिफ़ॉल्ट वैल्यू false है.
|
phoneNumber |
स्ट्रिंग | उपयोगकर्ता का मुख्य फ़ोन नंबर. यह E.164 स्पेसिफ़िकेशन का पालन करने वाला होना चाहिए फ़ोन नंबर. |
password |
स्ट्रिंग | उपयोगकर्ता का बिना हैश किया गया पासवर्ड. कम से कम छह वर्ण होने चाहिए. |
displayName |
स्ट्रिंग | उपयोगकर्ता की डिसप्ले नेम. |
photoURL |
स्ट्रिंग | उपयोगकर्ता की फ़ोटो का यूआरएल. |
disabled |
बूलियन |
उपयोगकर्ता बंद है या नहीं. बंद के लिए true ;
false को चालू किया गया. अगर यह पैरामीटर उपलब्ध नहीं कराया गया है, तो डिफ़ॉल्ट वैल्यू यह होती है
false .
|
उपयोगकर्ता बनाने का तरीका, प्रॉपर्टी के लिए UserRecord
ऑब्जेक्ट दिखाता है
नया उपयोगकर्ता बनाया गया.
अगर आपने uid
का इस्तेमाल किया है, तो ईमेल या फ़ोन नंबर का इस्तेमाल पहले से ही कोई मौजूदा कंपनी कर रहा है
किसी अन्य वजह से उपयोगकर्ता या उपयोगकर्ता नहीं बनाया जा सकता, तो ऊपर दिया गया तरीका काम नहीं करता
पर सेट करें. गड़बड़ी के कोड की पूरी सूची देखने के लिए, इसमें ये शामिल हैं
जानकारी और उसे हल करने के तरीके के लिए, Admin Authentication API देखें
गड़बड़ियां.
उपयोगकर्ता को अपडेट करना
Firebase एडमिन 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);
});
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))
शुरू करें
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}");
नीचे दी गई प्रॉपर्टी का कोई भी कॉम्बिनेशन दिया जा सकता है:
टेबल 2. 'उपयोगकर्ता को अपडेट करें' कार्रवाई के साथ काम करने वाली प्रॉपर्टी
प्रॉपर्टी | टाइप | ब्यौरा |
---|---|---|
email |
स्ट्रिंग | उपयोगकर्ता का नया प्राइमरी ईमेल पता. एक मान्य ईमेल पता होना चाहिए. |
emailVerified |
बूलियन |
उपयोगकर्ता के मुख्य ईमेल पते की पुष्टि की गई है या नहीं. अगर यह पैरामीटर उपलब्ध नहीं कराया जाता, तो
डिफ़ॉल्ट वैल्यू false है.
|
phoneNumber |
स्ट्रिंग |
उपयोगकर्ता का नया मुख्य फ़ोन नंबर. यह E.164 स्पेसिफ़िकेशन का पालन करने वाला होना चाहिए
फ़ोन नंबर. उपयोगकर्ता के मौजूदा रिकॉर्ड हटाने के लिए, null पर सेट करें
फ़ोन नंबर.
|
password |
स्ट्रिंग | उपयोगकर्ता का बिना हैश किया गया नया पासवर्ड. कम से कम छह वर्ण होने चाहिए. |
displayName |
स्ट्रिंग | null |
उपयोगकर्ता की नया डिसप्ले नेम. उपयोगकर्ता की अनुमतियां हटाने के लिए, null पर सेट करें
मौजूदा डिसप्ले नेम.
|
photoURL |
स्ट्रिंग | null |
उपयोगकर्ता की नई फ़ोटो का यूआरएल डालें. उपयोगकर्ता की अनुमतियां हटाने के लिए, null पर सेट करें
मौजूदा फ़ोटो का यूआरएल. अगर null एट्रिब्यूट नहीं है, तो मान्य यूआरएल डालें.
|
disabled |
बूलियन |
उपयोगकर्ता बंद है या नहीं. बंद के लिए true ;
false को चालू किया गया.
|
उपयोगकर्ता का अपडेट करने का तरीका, अपडेट किया गया UserRecord
ऑब्जेक्ट दिखाता है. ऐसा तब होता है, जब
अपडेट सफलतापूर्वक पूरा होता है.
अगर दिया गया uid
किसी मौजूदा उपयोगकर्ता से मेल नहीं खाता है, तो
कोई मौजूदा उपयोगकर्ता इस ईमेल या फ़ोन नंबर का इस्तेमाल पहले से ही कर रहा हो या उपयोगकर्ता ये काम नहीं कर सकता
किसी अन्य कारण से अपडेट नहीं किया जाता, तो ऊपर दिया गया तरीका
गड़बड़ी. गड़बड़ी के कोड की पूरी सूची देखने के लिए, जिसमें गड़बड़ी का ब्यौरा और उसका समाधान भी शामिल होता है
एडमिन Authentication एपीआई से जुड़ी गड़बड़ियां देखें.
उपयोगकर्ता को हटाना
Firebase एडमिन SDK टूल की मदद से, मौजूदा उपयोगकर्ताओं को उनके 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')
शुरू करें
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.");
'उपयोगकर्ता का डेटा मिटाएं' तरीका, डेटा मिटाए जाने पर खाली नतीजा दिखाता है का इस्तेमाल किया जा सकता है.
अगर दिया गया uid
किसी मौजूदा उपयोगकर्ता से मेल नहीं खाता है या उपयोगकर्ता ऐसा नहीं कर सकता है
किसी दूसरी वजह से मिटाए जाने पर, उपयोगकर्ता को मिटाने के तरीके में गड़बड़ी होती है.
गड़बड़ी के कोड की पूरी सूची देखने के लिए, जिसमें गड़बड़ी का ब्यौरा भी शामिल है
और उन्हें ठीक करने के तरीके के बारे में ज़्यादा जानने के लिए, एडमिन Authentication एपीआई से जुड़ी गड़बड़ियां देखें.
एक से ज़्यादा उपयोगकर्ताओं को मिटाएं
Firebase एडमिन SDK टूल, एक साथ कई उपयोगकर्ताओं को मिटा सकता है. हालांकि,
ध्यान दें कि deleteUsers(uids)
जैसी विधियों का उपयोग करके,
एक बार Cloud Functions for Firebase के लिए onDelete()
इवेंट हैंडलर को ट्रिगर नहीं करेगा.
ऐसा इसलिए होता है, क्योंकि बैच मिटाने की सुविधा, उपयोगकर्ता को मिटाने का इवेंट कभी भी ट्रिगर नहीं करती
एक उपयोगकर्ता के तौर पर उपलब्ध है. यहां से एक उपयोगकर्ता को हटाएं
तय करें.
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))
शुरू करें
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}");
}
उपयोगकर्ताओं को हटाने का तरीका उन उपयोगकर्ताओं की विफलताओं की सूची दिखाता है जिन्हें मिटाया नहीं जा सकता. गड़बड़ी के कोड की पूरी सूची देखने के लिए, जिसमें गड़बड़ी का ब्यौरा भी शामिल है और उन्हें ठीक करने के तरीके के बारे में ज़्यादा जानने के लिए, एडमिन Authentication एपीआई से जुड़ी गड़बड़ियां देखें.
सभी उपयोगकर्ताओं की सूची बनाएं
Firebase एडमिन 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();
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)
शुरू करें
// 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}");
}
नतीजों के हर बैच में उपयोगकर्ताओं की सूची होती है. साथ ही, अगले पेज टोकन का इस्तेमाल इन कामों के लिए किया जाता है
उपयोगकर्ताओं के अगले बैच की सूची बनाना. अगर सभी उपयोगकर्ताओं को पहले से ही सूची में शामिल कर लिया गया है, तो कोई
pageToken
लौटाया गया.
अगर कोई maxResults
फ़ील्ड तय नहीं किया गया है, तो हर बैच के लिए डिफ़ॉल्ट रूप से 1,000 उपयोगकर्ता इस्तेमाल किए जाते हैं.
यह एक बार में, सूची में शामिल किए जाने वाले उपयोगकर्ताओं की ज़्यादा से ज़्यादा संख्या भी होती है. कोई भी
सबसे बड़ी संख्या से ज़्यादा मान होने पर तर्क में गड़बड़ी होगी.
अगर कोई pageToken
तय नहीं किया गया है, तो कार्रवाई
शुरुआत में, uid
के हिसाब से.
गड़बड़ी के कोड की पूरी सूची देखने के लिए, जिसमें गड़बड़ी का ब्यौरा भी शामिल है और उन्हें ठीक करने के तरीके के बारे में ज़्यादा जानने के लिए, एडमिन Authentication एपीआई से जुड़ी गड़बड़ियां देखें.
सूची में शामिल उपयोगकर्ताओं के पासवर्ड हैश
यह एपीआई,passwordSalt
passwordHash
पासवर्ड उपयोगकर्ताओं के लिए Firebase पुष्टि बैकएंड अगर उपयोगकर्ता/सेवा खाते का इस्तेमाल किया जाता है
अनुरोध करने के लिए OAuth ऐक्सेस टोकन को जनरेट करने में
firebaseauth.configs.getHashConfig
की अनुमति. अगर ऐसा नहीं है, तो passwordHash
और passwordSalt
को सेट नहीं किया जाएगा.
पासवर्ड हैश की संवेदनशील प्रकृति की वजह से, Firebase एडमिन SDK सेवा
खाते के पास इसके द्वारा firebaseauth.configs.getHashConfig
की अनुमति नहीं है
डिफ़ॉल्ट. किसी उपयोगकर्ता/सेवा खाते में सीधे तौर पर अनुमति नहीं जोड़ी जा सकती, लेकिन
दूसरे तरीके से सीधे तौर पर ऐसा नहीं किया जा सकता.
कस्टम IAM भूमिका बनाना.
कस्टम आईएएम भूमिका बनाने के लिए:
- IAM और भूमिकाओं पर जाएं एडमिन पैनल में Google Cloud कंसोल.
- पेज पर सबसे ऊपर मौजूद ड्रॉप-डाउन से अपना प्रोजेक्ट चुनें.
- भूमिका बनाएं पर क्लिक करें
- अनुमतियां जोड़ें पर क्लिक करें
firebaseauth.configs.getHashConfig
अनुमति खोजें और उसे चुनें चेकबॉक्स.- जोड़ें पर क्लिक करें
- नई भूमिका बनाने के लिए, बनाएं पर क्लिक करें.
आईएएम पेज में, उपयोगकर्ता/सेवा खाते में बनाई गई कस्टम भूमिका जोड़ें:
- IAM और एडमिन पैनल, आईएएम चुनें
- बदलाव करने के लिए सदस्यों की सूची से सेवा या उपयोगकर्ता खाता चुनें.
- कोई अन्य भूमिका जोड़ें पर क्लिक करें.
- पहले से बनाई गई नई कस्टम भूमिका खोजें.
- सेव करें पर क्लिक करें.