Google 致力于为黑人社区推动种族平等。查看具体举措

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

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

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

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

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

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

কোনও ব্যবহারকারীকে সনাক্ত করার প্রাথমিক উপায় হ'ল তাদের uid , সেই ব্যবহারকারীর জন্য একটি অনন্য শনাক্তকারী। অ্যাডমিন এসডিকে একটি পদ্ধতি সরবরাহ করে যা তাদের uid দ্বারা ব্যবহারকারীদের প্রোফাইল তথ্য আনতে দেয়:

নোড.জেএস

admin
  .auth()
  .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 পরিবর্তে আপনার ব্যবহারকারীর ইমেল থাকবে। ফায়ারবেস অ্যাডমিন এসডিকে একটি ইমেলের সাহায্যে ব্যবহারকারীর তথ্য সন্ধান করা সমর্থন করে:

নোড.জেএস

admin
  .auth()
  .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 ইমেলের সাথে সম্পর্কিত ব্যবহারকারীর জন্য একটি ব্যবহারকারীরেকর্ড অবজেক্ট প্রদান করে।

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

অন্যান্য ক্ষেত্রে, আপনার uid পরিবর্তে আপনার ব্যবহারকারীর ফোন নম্বর থাকবে। ফায়ারবেস অ্যাডমিন এসডিকে ফোন নম্বর দিয়ে ব্যবহারকারীর তথ্য সন্ধান করা সমর্থন করে:

নোড.জেএস

admin
  .auth()
  .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 সাথে সম্পর্কিত ব্যবহারকারীর জন্য একটি ব্যবহারকারীরেকর্ড অবজেক্ট প্রদান করে।

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

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

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

নোড.জেএস

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

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

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

নোড.জেএস

admin
  .auth()
  .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}");

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

নোড.জেএস

admin
  .auth()
  .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 স্ট্রিং ব্যবহারকারীর ছবির ইউআরএল।
disabled বুলিয়ান ব্যবহারকারী অক্ষম কিনা। অক্ষম জন্য true ; সক্ষম জন্য false । যদি সরবরাহ না করা হয় তবে ডিফল্টটি false

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

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

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

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

নোড.জেএস

admin
  .auth()
  .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}");

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

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

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

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

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

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

ফায়ারবেস অ্যাডমিন এসডিকে বিদ্যমান ব্যবহারকারীদের তাদের uid মোছার অনুমতি দেয়:

নোড.জেএস

admin
  .auth()
  .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 যদি কোনও বিদ্যমান ব্যবহারকারীর সাথে সামঞ্জস্য না করে বা ব্যবহারকারীকে অন্য কোনও কারণে মুছে ফেলা যায় না, তবে মুছুন ব্যবহারকারী পদ্ধতিটি একটি ত্রুটি নিক্ষেপ করে। বর্ণনা এবং রেজোলিউশন পদক্ষেপগুলি সহ ত্রুটি কোডগুলির একটি সম্পূর্ণ তালিকার জন্য অ্যাডমিন প্রমাণীকরণের API ত্রুটিগুলি দেখুন

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

ফায়ারবেস অ্যাডমিন এসডিকে একবারে একাধিক ব্যবহারকারীকে মুছতে পারে। তবে নোট করুন যে deleteUsers(uids) একাধিক ব্যবহারকারীকে মুছতে মুছতে মুছতে মুছতে deleteUsers(uids) মতো পদ্ধতি ব্যবহার করা deleteUsers(uids) জন্য ক্লাউড ফাংশনগুলির জন্য onDelete() ইভেন্ট হ্যান্ডলারদের ট্রিগার করবে না। এটি কারণ ব্যাচ মুছা প্রতিটি ব্যবহারকারীর উপর কোনও ব্যবহারকারী মোছার ইভেন্টটি ট্রিগার করে না। আপনি যদি প্রতিটি মুছে যাওয়া ব্যবহারকারীর জন্য ব্যবহারকারী মোছার ইভেন্টগুলি চালিত করতে চান তবে একবারে ব্যবহারকারীদের মুছুন।

নোড.জেএস

admin
  .auth()
  .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}");
}

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

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

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

নোড.জেএস

const listAllUsers = (nextPageToken) => {
  // List batch of users, 1000 at a time.
  admin
    .auth()
    .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)

যাওয়া

0 বি 13 বিবিডিবি 70

সি #

0292fif40

ফলাফলের প্রতিটি ব্যাচে ব্যবহারকারীর একটি তালিকা থাকে এবং ব্যবহারকারীদের পরবর্তী ব্যাচকে তালিকাবদ্ধ করতে পরবর্তী পৃষ্ঠার টোকেন ব্যবহার করা হয়। সমস্ত ব্যবহারকারী ইতিমধ্যে তালিকাভুক্ত করা হয়েছে, কোন পেজ pageToken ফিরে আসে না।

যদি কোনও maxResults ক্ষেত্র নির্দিষ্ট না করা থাকে তবে প্রতি ব্যাচে ডিফল্ট 1000 ব্যবহারকারী ব্যবহৃত হয়। এটি একবারে তালিকাভুক্ত করার অনুমতিপ্রাপ্ত সর্বাধিক সংখ্যক ব্যবহারকারী। সর্বাধিকের চেয়ে বড় যে কোনও মান আর্গুমেন্ট ত্রুটি নিক্ষেপ করবে। কোন যদি pageToken উল্লেখিত থাকে, তবে অপারেশন শুরুতে দ্বারা আদেশ থেকে ব্যবহারকারীদের তালিকা প্রস্তুত করা যাবে uid

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

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

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

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

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

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

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

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