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

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

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

আপনি শুরু করার আগে

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

ব্যবহারকারীর ডেটা পুনরুদ্ধার করুন

কোনও ব্যবহারকারীকে সনাক্ত করার প্রাথমিক উপায় হ'ল তাদের uid , সেই ব্যবহারকারীর জন্য একটি অনন্য পরিচয়। অ্যাডমিন এসডিকে এমন একটি পদ্ধতি সরবরাহ করে যা ব্যবহারকারীদের 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 এর পরিবর্তে ব্যবহারকারীর ইমেল থাকবে। 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);
  });

জাভা

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 অবজেক্ট প্রদান করে।

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

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

প্রচুর ব্যবহারকারীর ডেটা পুনরুদ্ধার করুন

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

জাভা

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

জাভা

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 , ইমেল বা ফোন নম্বরটি ইতিমধ্যেই একটি বিদ্যমান ব্যবহারকারীর দ্বারা ব্যবহার করা হয় বা অন্য কোনো কারণে ব্যবহারকারী তৈরি করা না যায়, উপরের পদ্ধতিটি একটি ত্রুটির সাথে ব্যর্থ হয়৷ বিবরণ এবং রেজোলিউশন পদক্ষেপ সহ ত্রুটি কোডগুলির একটি সম্পূর্ণ তালিকার জন্য, অ্যাডমিন 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);
  });

জাভা

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

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

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

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

ফায়ারবেস অ্যাডমিন এসডিকে একবারে একাধিক ব্যবহারকারী মুছে ফেলতে পারে। যাইহোক, মনে রাখবেন যে এক সাথে একাধিক ব্যবহারকারীকে মুছে ফেলার জন্য 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);
  });

জাভা

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

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

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

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 দ্বারা অর্ডার করা হবে।

বিবরণ এবং রেজোলিউশন পদক্ষেপ সহ ত্রুটি কোডগুলির একটি সম্পূর্ণ তালিকার জন্য, অ্যাডমিন Authentication API ত্রুটিগুলি দেখুন।

তালিকাভুক্ত ব্যবহারকারীদের পাসওয়ার্ড হ্যাশ

This API also returns the passwordSalt and passwordHash hashed by the Firebase Auth backend for password users if the user/service account used to generate the request OAuth access token has the firebaseauth.configs.getHashConfig permission. অন্যথায় passwordHash এবং passwordSalt সেট করা হবে না।

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

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

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

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

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