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

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

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

শুরু করার আগে

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

ব্যবহারকারীর তথ্য পুনরুদ্ধার করুন

ব্যবহারকারীকে শনাক্ত করার প্রাথমিক উপায় হল তাদের uid , যা সেই ব্যবহারকারীর জন্য একটি অনন্য শনাক্তকারী। অ্যাডমিন 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 ত্রুটি দেখুন।

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

অন্যান্য ক্ষেত্রে, আপনার কাছে ব্যবহারকারীর 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 ত্রুটি দেখুন।

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

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

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

অ্যাডমিন SDK একটি পদ্ধতি প্রদান করে যা আপনাকে একটি নতুন 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 স্ট্রিং ব্যবহারকারীর ছবির URL।
disabled বুলিয়ান ব্যবহারকারী নিষ্ক্রিয় কিনা। নিষ্ক্রিয় হলে true ; সক্রিয় হলে false । যদি না থাকে, তাহলে ডিফল্ট হল false

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

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

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

Firebase Admin SDK একজন বিদ্যমান ব্যবহারকারীর ডেটা পরিবর্তন করতে সাহায্য করে। আপনাকে সেই ব্যবহারকারীর জন্য আপডেট করার জন্য বৈশিষ্ট্যগুলির সাথে একটি 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}");

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

সারণী 2। আপডেট ব্যবহারকারীর ক্রিয়াকলাপ দ্বারা সমর্থিত বৈশিষ্ট্য

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

আপডেট সফলভাবে সম্পন্ন হলে আপডেট ব্যবহারকারী পদ্ধতি একটি আপডেট করা UserRecord অবজেক্ট ফেরত পাঠায়।

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

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

Firebase Admin 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 কোনও বিদ্যমান ব্যবহারকারীর সাথে সামঞ্জস্যপূর্ণ না হয় অথবা অন্য কোনও কারণে ব্যবহারকারীকে মুছে ফেলা না যায়, তাহলে ব্যবহারকারী মুছে ফেলার পদ্ধতিটি একটি ত্রুটি ঠেলে দেয়। ত্রুটি কোডগুলির সম্পূর্ণ তালিকার জন্য, বর্ণনা এবং সমাধানের ধাপগুলি সহ, Admin Authentication API Errors দেখুন।

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

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

নোড.জেএস

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 API ত্রুটিগুলি দেখুন।

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

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

নোড.জেএস

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

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

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

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

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

কাস্টম IAM ভূমিকা তৈরি করতে:

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

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

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