Join us for Firebase Summit on November 10, 2021. Tune in to learn how Firebase can help you accelerate app development, release with confidence, and scale with ease. Register

ব্যবহারকারীদের ম্যানেজ করুন

ফায়ারবেস অ্যাডমিন এসডিকে আপনার ফায়ারবেস প্রমাণীকরণ ব্যবহারকারীদের উন্নত সুযোগ -সুবিধা সহ পরিচালনার জন্য একটি API প্রদান করে। অ্যাডমিন ইউজার ম্যানেজমেন্ট এপিআই আপনাকে একটি নিরাপদ সার্ভার পরিবেশ থেকে নিম্নলিখিত কাজগুলি প্রোগ্রামগতভাবে সম্পন্ন করার ক্ষমতা দেয়:

  • কোনো থ্রোটলিং বা রেট সীমাবদ্ধ না করে নতুন ব্যবহারকারী তৈরি করুন।
  • ইউআইডি, ইমেইল বা ফোন নম্বরের মতো ব্যবহারকারীদের বিভিন্ন মানদণ্ড অনুসারে সন্ধান করুন।
  • একটি নির্দিষ্ট প্রকল্পের সমস্ত ব্যবহারকারীদের ব্যাচে তালিকাভুক্ত করুন।
  • অ্যাকাউন্ট তৈরির তারিখ এবং শেষ সাইন-ইন তারিখ সহ ব্যবহারকারীর মেটাডেটা অ্যাক্সেস করুন।
  • ব্যবহারকারীদের তাদের বিদ্যমান পাসওয়ার্ডের প্রয়োজন ছাড়াই মুছুন।
  • ব্যবহারকারীর বৈশিষ্ট্যগুলি আপডেট করুন - তাদের পাসওয়ার্ড সহ - ব্যবহারকারী হিসাবে সাইন ইন না করে।
  • ইমেল যাচাই করার জন্য আউট-অফ-ব্যান্ড অ্যাকশন প্রবাহের মধ্য দিয়ে না গিয়ে ইমেলগুলি যাচাই করুন।
  • এই পরিবর্তনগুলি প্রত্যাহার করতে ইমেল লিঙ্ক না পাঠিয়ে ব্যবহারকারীর ইমেল পরিবর্তন করুন।
  • এসএমএস যাচাই প্রবাহে না গিয়ে একটি ফোন নম্বর সহ একটি নতুন ব্যবহারকারী তৈরি করুন।
  • এসএমএস যাচাই প্রবাহে না গিয়ে ব্যবহারকারীর ফোন নম্বর পরিবর্তন করুন।
  • অক্ষম অবস্থায় অফলাইন বিধান ব্যবহারকারীরা এবং পরে কবে তাদের সক্ষম করবেন তা নিয়ন্ত্রণ করুন।
  • কাস্টম ইউজার কনসোল তৈরি করুন যা একটি নির্দিষ্ট অ্যাপ্লিকেশনের ইউজার ম্যানেজমেন্ট সিস্টেমের উপযোগী।

তুমি শুরু করার আগে

ফায়ারবেস অ্যাডমিন এসডিকে প্রদত্ত ইউজার ম্যানেজমেন্ট এপিআই ব্যবহার করতে, আপনার অবশ্যই একটি পরিষেবা অ্যাকাউন্ট থাকতে হবে। অনুসরণ সেটআপ নির্দেশমালা কিভাবে এডমিন 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);
  });

জাভা

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 একটি বিদ্যমান ব্যবহারকারী অন্তর্গত নয় অথবা ব্যবহারকারীর অন্য কোন কারণে সংগৃহীত হতে পারে না, উপরে পদ্ধতি একটি ত্রুটি ছোঁড়ার। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

কিছু কিছু ক্ষেত্রে আপনি একটি ব্যবহারকারীর ইমেল পরিবর্তে তাদের থাকবে uid । ফায়ারবেস অ্যাডমিন এসডিকে একটি ইমেলের মাধ্যমে ব্যবহারকারীর তথ্য খোঁজা সমর্থন করে:

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 ব্যবহারকারী প্রদত্ত ইমেল সংশ্লিষ্ট জন্য বস্তু।

যদি প্রদত্ত ইমেলটি বিদ্যমান ব্যবহারকারীর অন্তর্গত না হয় বা অন্য কোনো কারণে ব্যবহারকারীকে আনা যায় না, তাহলে প্রশাসক SDK একটি ত্রুটি ছুঁড়ে দেয়। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

অন্যান্য ক্ষেত্রে, আপনি একটি ব্যবহারকারীর ফোন পরিবর্তে সংখ্যা তাদের থাকবে 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);
  });

জাভা

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 ব্যবহারকারী যে ফোন নম্বরটি দিয়েছিলেন সংশ্লিষ্ট জন্য বস্তু।

যদি প্রদত্ত ফোন নম্বরটি বিদ্যমান ব্যবহারকারীর অন্তর্গত না হয় বা অন্য কোনো কারণে ব্যবহারকারীকে আনা যায় না, তাহলে প্রশাসক 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 বা ইঙ্গিত কেন যে আইডেন্টিফায়ার তাকিয়ে করা পারল না একটি ত্রুটি। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

একটি ব্যবহারকারী তৈরি করুন

অ্যাডমিন এসডিকে একটি পদ্ধতি প্রদান করে যা আপনাকে একটি নতুন ফায়ারবেস প্রমাণীকরণ ব্যবহারকারী তৈরি করতে দেয়। এই পদ্ধতিটি নতুন তৈরি ব্যবহারকারীর অ্যাকাউন্টে অন্তর্ভুক্ত করার জন্য প্রোফাইল তথ্য সম্বলিত একটি বস্তু গ্রহণ করে:

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 প্রমাণীকরণ একটি র্যান্ডম উত্পন্ন করবে 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 স্বয়ংক্রিয়ভাবে উত্পন্ন করা হবে না।
email স্ট্রিং ব্যবহারকারীর প্রাথমিক ইমেইল। একটি বৈধ ইমেইল ঠিকানা আবশ্যক.
emailVerified বুলিয়ান ব্যবহারকারীর প্রাথমিক ইমেইল যাচাই করা হয়েছে কি না। না হলে, ডিফল্ট false
phoneNumber স্ট্রিং ব্যবহারকারীর প্রাথমিক ফোন নম্বর। একটি বৈধ E.164 স্পেক সঙ্গতিপূর্ণ ফোন নম্বর হতে হবে।
password স্ট্রিং ব্যবহারকারীর কাঁচা, অপ্রয়োজনীয় পাসওয়ার্ড। কমপক্ষে ছয় অক্ষর দীর্ঘ হতে হবে।
displayName স্ট্রিং ব্যবহারকারীদের প্রদর্শনের নাম।
photoURL স্ট্রিং ব্যবহারকারীর ছবির URL।
disabled বুলিয়ান ব্যবহারকারী নিষ্ক্রিয় কিনা। true প্রতিবন্ধী জন্য; false জন্য সক্ষম। না হলে, ডিফল্ট false

ব্যবহারকারী তৈরি পদ্ধতি ফেরৎ UserRecord নব নির্মিত ব্যবহারকারীর জন্য বস্তু।

যদি প্রদত্ত uid , ইমেল বা ফোন নম্বর একটি বিদ্যমান ব্যবহারকারী দ্বারা ইতিমধ্যে ব্যবহারে রয়েছে অথবা ব্যবহারকারীর অন্য কোন কারণে তৈরি করা যাবে না, উপরোক্ত পদ্ধতি একটি ত্রুটি সহ ব্যর্থ। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

একজন ব্যবহারকারীকে আপডেট করুন

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

জাভা

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 ব্যবহারকারীর বিদ্যমান ফটো URL পরিষ্কার। অ- যদি null , একটি কার্যকর URL হওয়া আবশ্যক।
disabled বুলিয়ান ব্যবহারকারী নিষ্ক্রিয় কিনা। true প্রতিবন্ধী জন্য; false জন্য সক্ষম।

ব্যবহারকারী আপডেট পদ্ধতি একটি আপডেট ফেরৎ UserRecord বস্তুর আপডেট সফলভাবে সমাপ্ত হবে।

প্রদত্ত তাহলে uid একটি বিদ্যমান ব্যবহারকারী সঙ্গে সঙ্গতিপূর্ণ নয়, প্রদান করা ইমেল বা ফোন নম্বর একটি বিদ্যমান ব্যবহারকারী দ্বারা ইতিমধ্যে ব্যবহারে রয়েছে, অথবা ব্যবহারকারীর অন্য কোন কারণে আপডেট করা যাবে না, উপরোক্ত পদ্ধতি একটি ত্রুটি সহ ব্যর্থ। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

একটি ব্যবহারকারী মুছে দিন

Firebase এডমিন 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 একটি বিদ্যমান ব্যবহারকারী সঙ্গে সঙ্গতিপূর্ণ নয় অথবা ব্যবহারকারীর অন্য কোন কারণে মুছে ফেলা যাবে না, তাহলে ডিলিট ব্যবহারকারী পদ্ধতি একটি ত্রুটি ছোঁড়ার। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

একাধিক ব্যবহারকারী মুছুন

Firebase অ্যাডমিন SDK একই সাথে একাধিক ব্যবহারকারীকে মুছে দিতে পারে। যাইহোক, নোট যে ভালো পদ্ধতি ব্যবহার করে deleteUsers(uids) একযোগে একাধিক জন ব্যবহারকারীকে মুছে ফেলার আরম্ভ করা হবে না onDelete() 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}");
}

ব্যবহারকারীদের মুছে ফেলার পদ্ধতিটি ব্যবহারকারীদের ব্যর্থতার একটি তালিকা প্রদান করে যা মুছে ফেলা যায় নি। বিবরণ এবং রেজল্যুশন পদক্ষেপ সহ ত্রুটি কোড, একটি পূর্ণ তালিকার জন্য, দেখুন এডমিন প্রমাণীকরণ এপিআই ত্রুটি

সমস্ত ব্যবহারকারীর তালিকা করুন

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

জাভা

// 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 এছাড়াও ফেরৎ passwordSalt এবং passwordHash ব্যবহারকারী / পরিষেবা অ্যাকাউন্ট অনুরোধ OAuth অ্যাক্সেস টোকেন হয়েছে জেনারেট করতে ব্যবহৃত যদি পাসওয়ার্ড ব্যবহারকারীদের জন্য Firebase প্রমাণীকরণ ব্যাকএন্ড দ্বারা কুচি-কুচি করিয়া কাটা বস্তু firebaseauth.configs.getHashConfig অনুমতি নেই। তা না হলে passwordHash এবং passwordSalt সেট করা হবে না।

পাসওয়ার্ড হ্যাশ সংবেদনশীল প্রকৃতি কারণে Firebase এডমিন SDK এর সেবা অ্যাকাউন্ট নেই firebaseauth.configs.getHashConfig ডিফল্টরূপে অনুমতি নেই। আপনি একটি অনুমতির সরাসরি একটি ব্যবহারকারী / পরিষেবা অ্যাকাউন্ট যোগ করতে পারবেন না, কিন্তু আপনি দ্বারা তা পরোক্ষভাবে কি করতে পারেন একটি কাস্টম IAM ভূমিকা তৈরি

কাস্টম আইএএম ভূমিকা তৈরি করতে:

  1. IAM & অ্যাডমিন প্যানেলে ভূমিকা পৃষ্ঠা Google মেঘ কনসোলে এ যান।
  2. পৃষ্ঠার শীর্ষে ড্রপ-ডাউন থেকে আপনার প্রকল্প নির্বাচন করুন।
  3. ভূমিকা তৈরি করুন ক্লিক করুন
  4. এডিডি অনুমতিগুলি ক্লিক করুন
  5. জন্য অনুসন্ধান করুন firebaseauth.configs.getHashConfig অনুমতি এবং যে চেকবক্স নির্বাচন করুন।
  6. জুড়ুন এ ক্লিক করুন
  7. নতুন ভূমিকা তৈরি করা শেষ করতে ক্লিক করুন।

আইএএম পৃষ্ঠায় ব্যবহারকারী/পরিষেবা অ্যাকাউন্টে তৈরি কাস্টম ভূমিকা যোগ করুন:

  1. IAM & অ্যাডমিন প্যানেলে IAM নির্বাচন
  2. সম্পাদনার জন্য সদস্যদের তালিকা থেকে পরিষেবা বা ব্যবহারকারীর অ্যাকাউন্ট নির্বাচন করুন।
  3. অন্য একটি ভূমিকা যোগ করুন।
  4. পূর্বে তৈরি নতুন কাস্টম ভূমিকা অনুসন্ধান করুন।
  5. সংরক্ষণ ক্লিক করুন।