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

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

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

শুরু করার আগে

Firebase Admin SDK দ্বারা প্রদত্ত ইউজার ম্যানেজমেন্ট API ব্যবহার করার জন্য, আপনার একটি সার্ভিস অ্যাকাউন্ট থাকতে হবে। Admin SDK কীভাবে ইনিশিয়ালাইজ করতে হয় সে সম্পর্কে আরও তথ্যের জন্য সেটআপ নির্দেশাবলী অনুসরণ করুন।

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

একজন ব্যবহারকারীকে শনাক্ত করার প্রধান উপায় হলো তার uid , যা সেই ব্যবহারকারীর একটি অনন্য শনাক্তকারী। অ্যাডমিন এসডিকে (Admin SDK) এমন একটি পদ্ধতি প্রদান করে যার মাধ্যমে ব্যবহারকারীদের uid ব্যবহার করে তাদের প্রোফাইলের তথ্য সংগ্রহ করা যায়:

নোড.জেএস

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(f'Successfully fetched user data: {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}");

এই মেথডটি প্রদত্ত uid এর সাথে সম্পর্কিত ব্যবহারকারীর জন্য একটি UserRecord অবজেক্ট রিটার্ন করে।

প্রদত্ত uid যদি কোনো বিদ্যমান ব্যবহারকারীর না হয় অথবা অন্য কোনো কারণে ব্যবহারকারীকে খুঁজে পাওয়া না যায়, তাহলে উপরের পদ্ধতিটি একটি ত্রুটি দেখায়। ত্রুটি কোডগুলির সম্পূর্ণ তালিকা, বিবরণ এবং সমাধানের ধাপগুলির জন্য, অ্যাডমিন অথেন্টিকেশন এপিআই ত্রুটি (Admin Auth API Errors ) দেখুন।

কিছু ক্ষেত্রে আপনার কাছে ব্যবহারকারীর uid পরিবর্তে তার ইমেল থাকবে। Firebase Admin SDK ইমেলের মাধ্যমে ব্যবহারকারীর তথ্য খোঁজা সমর্থন করে:

নোড.জেএস

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(f'Successfully fetched user data: {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 একটি ত্রুটি দেখায়। বিবরণ এবং সমাধানের ধাপসহ ত্রুটি কোডগুলোর সম্পূর্ণ তালিকার জন্য, অ্যাডমিন অথেনটিকেশন এপিআই ত্রুটিসমূহ (Admin Authentication API Errors ) দেখুন।

অন্যান্য ক্ষেত্রে, আপনার কাছে ব্যবহারকারীর uid এর পরিবর্তে তার ফোন নম্বর থাকবে। Firebase Admin SDK ফোন নম্বর দিয়ে ব্যবহারকারীর তথ্য খোঁজা সমর্থন করে:

নোড.জেএস

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(f'Successfully fetched user data: {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 Errors ) দেখুন।

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

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

নোড.জেএস

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 Errors ) দেখুন।

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

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

নোড.জেএস

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(f'Sucessfully created new user: {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 নির্দিষ্ট করতে চান, তাহলে ব্যবহারকারী তৈরির মেথডে একটি আর্গুমেন্ট হিসেবে তা অন্তর্ভুক্ত করতে পারেন:

নোড.জেএস

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(f'Sucessfully created new user: {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}");

নিম্নলিখিত বৈশিষ্ট্যগুলির যেকোনো সংমিশ্রণ প্রদান করা যেতে পারে:

সারণি ১. ব্যবহারকারী তৈরি অপারেশন দ্বারা সমর্থিত বৈশিষ্ট্যসমূহ

সম্পত্তি প্রকার বর্ণনা
uid স্ট্রিং নতুন তৈরি করা ব্যবহারকারীকে বরাদ্দ করার জন্য uid । এটি অবশ্যই ১ থেকে ১২৮ অক্ষরের মধ্যে একটি স্ট্রিং হতে হবে। যদি এটি প্রদান করা না হয়, তবে স্বয়ংক্রিয়ভাবে একটি র‍্যান্ডম uid তৈরি করা হবে। ছোট uid ভালো পারফরম্যান্স প্রদান করে।
email স্ট্রিং ব্যবহারকারীর প্রাথমিক ইমেল। এটি অবশ্যই একটি বৈধ ইমেল ঠিকানা হতে হবে।
emailVerified বুলিয়ান ব্যবহারকারীর প্রাথমিক ইমেল যাচাই করা হয়েছে কি না। যদি তা প্রদান করা না হয়, তবে ডিফল্ট মান false থাকে।
phoneNumber স্ট্রিং ব্যবহারকারীর প্রাথমিক ফোন নম্বর। অবশ্যই একটি বৈধ এবং E.164 স্পেক-সম্মত ফোন নম্বর হতে হবে।
password স্ট্রিং ব্যবহারকারীর মূল, হ্যাশবিহীন পাসওয়ার্ড। অবশ্যই কমপক্ষে ছয় অক্ষরের হতে হবে।
displayName স্ট্রিং ব্যবহারকারীর প্রদর্শিত নাম।
photoURL স্ট্রিং ব্যবহারকারীর ছবির ইউআরএল।
disabled বুলিয়ান ব্যবহারকারী নিষ্ক্রিয় কিনা। নিষ্ক্রিয় হলে true ; সক্রিয় হলে false । প্রদান করা না হলে, ডিফল্ট মান false '।

ব্যবহারকারী তৈরির পদ্ধতিটি নতুন তৈরি করা ব্যবহারকারীর জন্য একটি UserRecord অবজেক্ট রিটার্ন করে।

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

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

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

নোড.জেএস

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(f'Sucessfully updated user: {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}");

নিম্নলিখিত বৈশিষ্ট্যগুলির যেকোনো সংমিশ্রণ প্রদান করা যেতে পারে:

সারণি ২. ব্যবহারকারী আপডেট অপারেশন দ্বারা সমর্থিত বৈশিষ্ট্যসমূহ

সম্পত্তি প্রকার বর্ণনা
email স্ট্রিং ব্যবহারকারীর নতুন প্রাথমিক ইমেল। এটি অবশ্যই একটি বৈধ ইমেল ঠিকানা হতে হবে।
emailVerified বুলিয়ান ব্যবহারকারীর প্রাথমিক ইমেল যাচাই করা হয়েছে কি না। যদি তা প্রদান করা না হয়, তবে ডিফল্ট মান false থাকে।
phoneNumber স্ট্রিং | null ব্যবহারকারীর নতুন প্রাথমিক ফোন নম্বর। এটি অবশ্যই একটি বৈধ এবং E.164 স্পেক-সম্মত ফোন নম্বর হতে হবে। ব্যবহারকারীর বিদ্যমান ফোন নম্বরটি মুছে ফেলার জন্য এটিকে ' null সেট করুন।
password স্ট্রিং ব্যবহারকারীর নতুন র', আনহ্যাশড পাসওয়ার্ড। অবশ্যই কমপক্ষে ছয় অক্ষরের হতে হবে।
displayName স্ট্রিং | null ব্যবহারকারীর নতুন প্রদর্শিত নাম। ব্যবহারকারীর বিদ্যমান প্রদর্শিত নাম মুছে ফেলতে এটিকে null এ সেট করুন।
photoURL স্ট্রিং | null ব্যবহারকারীর নতুন ফটো ইউআরএল। ব্যবহারকারীর বিদ্যমান ফটো ইউআরএল মুছে ফেলতে এটিকে null সেট করুন। যদি null না হয়, তবে এটি অবশ্যই একটি বৈধ ইউআরএল হতে হবে।
disabled বুলিয়ান ব্যবহারকারী অক্ষম কিনা। অক্ষম হলে true ; সক্ষম হলে false

আপডেট সফলভাবে সম্পন্ন হলে, `update user` মেথডটি একটি আপডেট করা UserRecord অবজেক্ট রিটার্ন করে।

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

একজন ব্যবহারকারীকে মুছে ফেলুন

Firebase অ্যাডমিন SDK ব্যবহার করে বিদ্যমান ব্যবহারকারীদের তাদের uid দিয়ে মুছে ফেলা যায়:

নোড.জেএস

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

ব্যবহারকারী মুছে ফেলার প্রক্রিয়াটি সফলভাবে সম্পন্ন হলে `delete user` মেথডটি একটি খালি ফলাফল রিটার্ন করে।

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

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

Firebase Admin SDK ব্যবহার করে একসাথে একাধিক ব্যবহারকারীকে ডিলিট করা যায়। তবে, মনে রাখবেন যে, একসাথে একাধিক ব্যবহারকারীকে ডিলিট করার জন্য deleteUsers(uids) এর মতো মেথড ব্যবহার করলে Cloud Functions for Firebase onDelete() ইভেন্ট হ্যান্ডলার ট্রিগার হবে না। এর কারণ হলো, ব্যাচ ডিলিট প্রতিটি ব্যবহারকারীর জন্য আলাদাভাবে ইউজার ডিলিশন ইভেন্ট ট্রিগার করে না। যদি আপনি চান যে ডিলিট করা প্রতিটি ব্যবহারকারীর জন্য ইউজার ডিলিশন ইভেন্ট ট্রিগার হোক, তাহলে ব্যবহারকারীদের এক এক করে ডিলিট করুন।

নোড.জেএস

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(f'Successfully deleted {result.success_count} users')
print(f'Failed to delete {result.failure_count} users')
for err in result.errors:
    print(f'error #{result.index}, reason: {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 এপিআই ত্রুটিসমূহ দেখুন।

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

ফায়ারবেস অ্যাডমিন এসডিকে-এর মাধ্যমে ব্যবহারকারীদের সম্পূর্ণ তালিকা ব্যাচ আকারে পাওয়া যায়:

নোড.জেএস

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 ফিল্ড নির্দিষ্ট করা না থাকে, তাহলে প্রতি ব্যাচে ডিফল্ট ১০০০ জন ব্যবহারকারী ব্যবহৃত হয়। একবারে তালিকাভুক্ত করার জন্য এটিই অনুমোদিত ব্যবহারকারীর সর্বোচ্চ সংখ্যা। সর্বোচ্চ সংখ্যার চেয়ে বেশি যেকোনো মান একটি আর্গুমেন্ট ত্রুটি (argument error) দেখাবে। যদি কোনো pageToken নির্দিষ্ট করা না থাকে, তাহলে অপারেশনটি ব্যবহারকারীদের শুরু থেকে uid অনুসারে সাজিয়ে তালিকাভুক্ত করবে।

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

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

এই API-টি পাসওয়ার্ড ব্যবহারকারীদের জন্য Firebase Auth ব্যাকএন্ড দ্বারা হ্যাশ করা passwordSalt এবং passwordHash ফেরত দেয়, যদি অনুরোধের OAuth অ্যাক্সেস টোকেন তৈরি করতে ব্যবহৃত ব্যবহারকারী/পরিষেবা অ্যাকাউন্টের firebaseauth.configs.getHashConfig পারমিশন থাকে। অন্যথায় passwordHash এবং passwordSalt সেট করা হবে না।

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

কাস্টম IAM রোল তৈরি করতে:

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

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

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