إدارة المستخدمين في Firebase

إنشاء مستخدم

تتوفّر لك الخيارات التالية لإنشاء مستخدم جديد:

الحصول على المستخدم الذي سجَّل الدخول حاليًا

الطريقة المقترَحة للحصول على المستخدم الحالي هي ضبط مستمع على عنصر المصادقة (Auth):

Swift

handle = Auth.auth().addStateDidChangeListener { auth, user in
  // ...
}

Objective-C

self.handle = [[FIRAuth auth]
    addAuthStateDidChangeListener:^(FIRAuth *_Nonnull auth, FIRUser *_Nullable user) {
      // ...
    }];

من خلال استخدام مستمع، يمكنك التأكّد من أنّ عنصر المصادقة (Auth) ليس في حالة وسيطة، مثل حالة التهيئة، عند الحصول على المستخدم الحالي.

يمكنك أيضًا الحصول على المستخدم الذي سجَّل الدخول حاليًا باستخدام السمة currentUser. إذا لم يسجِّل المستخدم الدخول، تكون قيمة currentUser هي nil:

Swift

if Auth.auth().currentUser != nil {
  // User is signed in.
  // ...
} else {
  // No user is signed in.
  // ...
}

Objective-C

if ([FIRAuth auth].currentUser) {
  // User is signed in.
  // ...
} else {
  // No user is signed in.
  // ...
}

الحصول على الملف الشخصي للمستخدم

للحصول على معلومات الملف الشخصي للمستخدم، استخدِم سمات مثيل FIRUser. على سبيل المثال:

Swift

let user = Auth.auth().currentUser
if let user = user {
  // The user's ID, unique to the Firebase project.
  // Do NOT use this value to authenticate with your backend server,
  // if you have one. Use getTokenWithCompletion:completion: instead.
  let uid = user.uid
  let email = user.email
  let photoURL = user.photoURL
  var multiFactorString = "MultiFactor: "
  for info in user.multiFactor.enrolledFactors {
    multiFactorString += info.displayName ?? "[DispayName]"
    multiFactorString += " "
  }
  // ...
}

Objective-C

FIRUser *user = [FIRAuth auth].currentUser;
if (user) {
  // The user's ID, unique to the Firebase project.
  // Do NOT use this value to authenticate with your backend server,
  // if you have one. Use getTokenWithCompletion:completion: instead.
  NSString *email = user.email;
  NSString *uid = user.uid;
  NSMutableString *multiFactorString = [NSMutableString stringWithFormat:@"MultiFactor: "];
  for (FIRMultiFactorInfo *info in user.multiFactor.enrolledFactors) {
    [multiFactorString appendString:info.displayName];
    [multiFactorString appendString:@" "];
  }
  NSURL *photoURL = user.photoURL;
  // ...
}

الحصول على معلومات الملف الشخصي للمستخدم الخاصة بموفّر معيّن

للحصول على معلومات الملف الشخصي التي تم استردادها من موفّري تسجيل الدخول المرتبطين بمستخدم، استخدِم السمة providerData. على سبيل المثال:

Swift

let userInfo = Auth.auth().currentUser?.providerData[indexPath.row]
cell?.textLabel?.text = userInfo?.providerID
// Provider-specific UID
cell?.detailTextLabel?.text = userInfo?.uid

Objective-C

id<FIRUserInfo> userInfo = [FIRAuth auth].currentUser.providerData[indexPath.row];
cell.textLabel.text = [userInfo providerID];
// Provider-specific UID
cell.detailTextLabel.text = [userInfo uid];

تعديل الملف الشخصي للمستخدم

يمكنك تعديل معلومات الملف الشخصي الأساسية للمستخدم، أي اسم العرض وعنوان URL لصورة الملف الشخصي، باستخدام الفئة UserProfileChangeRequest. على سبيل المثال:

Swift

let changeRequest = Auth.auth().currentUser?.createProfileChangeRequest()
changeRequest?.displayName = displayName
changeRequest?.commitChanges { error in
  // ...
}

Objective-C

FIRUserProfileChangeRequest *changeRequest = [[FIRAuth auth].currentUser profileChangeRequest];
changeRequest.displayName = userInput;
[changeRequest commitChangesWithCompletion:^(NSError *_Nullable error) {
  // ...
}];

ضبط عنوان البريد الإلكتروني للمستخدم

يمكنك ضبط عنوان البريد الإلكتروني للمستخدم باستخدام طريقة updateEmail. على سبيل المثال:

Swift

Auth.auth().currentUser?.updateEmail(to: email) { error in
  // ...
}

Objective-C

[[FIRAuth auth].currentUser updateEmail:userInput completion:^(NSError *_Nullable error) {
  // ...
}];

إرسال رسالة إلكترونية لتأكيد عنوان البريد الإلكتروني إلى المستخدم

يمكنك إرسال رسالة إلكترونية لتأكيد عنوان البريد الإلكتروني إلى مستخدم باستخدام الطريقة sendEmailVerificationWithCompletion:. على سبيل المثال:

Swift

Auth.auth().currentUser?.sendEmailVerification { error in
  // ...
}

Objective-C

[[FIRAuth auth].currentUser sendEmailVerificationWithCompletion:^(NSError *_Nullable error) {
  // ...
}];

يمكنك تخصيص نموذج الرسالة الإلكترونية المستخدَم في علامة التبويب الأمان > المصادقة > النماذج في وحدة تحكّم Firebase. يُرجى الاطّلاع على نماذج الرسائل الإلكترونية في مركز مساعدة Firebase.

من الممكن أيضًا تمرير الحالة من خلال عنوان URL للمتابعة لإعادة التوجيه إلى التطبيق عند إرسال رسالة إلكترونية لتأكيد عنوان البريد الإلكتروني.

بالإضافة إلى ذلك، يمكنك توطين الرسالة الإلكترونية لتأكيد عنوان البريد الإلكتروني من خلال تعديل رمز اللغة في مثيل المصادقة (Auth) قبل إرسال الرسالة الإلكترونية. على سبيل المثال:

Swift

Auth.auth().languageCode = "fr"
// To apply the default app language instead of explicitly setting it.
// Auth.auth().useAppLanguage()

Objective-C

[FIRAuth auth].languageCode = @"fr";
// To apply the default app language instead of explicitly setting it.
// [[FIRAuth auth] useAppLanguage];

ضبط كلمة مرور للمستخدم

يمكنك ضبط كلمة مرور للمستخدم باستخدام طريقة updatePassword. على سبيل المثال:

Swift

Auth.auth().currentUser?.updatePassword(to: password) { error in
  // ...
}

Objective-C

[[FIRAuth auth].currentUser updatePassword:userInput completion:^(NSError *_Nullable error) {
  // ...
}];

إرسال رسالة إلكترونية لإعادة ضبط كلمة المرور

يمكنك إرسال رسالة إلكترونية لإعادة ضبط كلمة المرور إلى مستخدم باستخدام طريقة sendPasswordReset. على سبيل المثال:

Swift

Auth.auth().sendPasswordReset(withEmail: email) { error in
  // ...
}

Objective-C

[[FIRAuth auth] sendPasswordResetWithEmail:userInput completion:^(NSError *_Nullable error) {
  // ...
}];

يمكنك تخصيص نموذج الرسالة الإلكترونية المستخدَم في قسم "المصادقة" في وحدة تحكّم Firebase، وذلك في صفحة "نماذج الرسائل الإلكترونية". يُرجى الاطّلاع على نماذج الرسائل الإلكترونية في مركز مساعدة Firebase.

من الممكن أيضًا تمرير الحالة من خلال عنوان URL للمتابعة لإعادة التوجيه إلى التطبيق عند إرسال رسالة إلكترونية لإعادة ضبط كلمة المرور.

بالإضافة إلى ذلك، يمكنك توطين الرسالة الإلكترونية لإعادة ضبط كلمة المرور من خلال تعديل رمز اللغة في مثيل المصادقة (Auth) قبل إرسال الرسالة الإلكترونية. على سبيل المثال:

Swift

Auth.auth().languageCode = "fr"
// To apply the default app language instead of explicitly setting it.
// Auth.auth().useAppLanguage()

Objective-C

[FIRAuth auth].languageCode = @"fr";
// To apply the default app language instead of explicitly setting it.
// [[FIRAuth auth] useAppLanguage];

يمكنك أيضًا إرسال رسائل إلكترونية لإعادة ضبط كلمة المرور من وحدة تحكّم Firebase.

حذف مستخدم

يمكنك حذف حساب مستخدم باستخدام طريقة delete. على سبيل المثال:

Swift

let user = Auth.auth().currentUser

user?.delete { error in
  if let error = error {
    // An error happened.
  } else {
    // Account deleted.
  }
}

Objective-C

FIRUser *user = [FIRAuth auth].currentUser;

[user deleteWithCompletion:^(NSError *_Nullable error) {
  if (error) {
    // An error happened.
  } else {
    // Account deleted.
  }
}];

يمكنك أيضًا حذف المستخدمين في وحدة تحكّم Firebase ضمن علامة التبويب الأمان > المصادقة > المستخدمون.

إعادة مصادقة مستخدم

تتطلّب بعض الإجراءات الحساسة من الناحية الأمنية، مثل حذف حساب، و ضبط عنوان البريد الإلكتروني الرئيسي، و تغيير كلمة مرور، أن يكون المستخدم قد سجَّل الدخول مؤخرًا. إذا نفّذت أحد هذه الإجراءات وكان المستخدم قد سجَّل الدخول منذ فترة طويلة جدًا، سيتعذّر تنفيذ الإجراء وسيظهر الخطأ FIRAuthErrorCodeCredentialTooOld. عند حدوث ذلك، أعِد مصادقة المستخدم من خلال الحصول على بيانات تسجيل دخول جديدة منه وتمرير بيانات الاعتماد إلى reauthenticate. على سبيل المثال:

Swift

let user = Auth.auth().currentUser
var credential: AuthCredential

// Prompt the user to re-provide their sign-in credentials

user?.reauthenticate(with: credential) { error in
  if let error = error {
    // An error happened.
  } else {
    // User re-authenticated.
  }
}

Objective-C

FIRUser *user = [FIRAuth auth].currentUser;
FIRAuthCredential *credential;

// Prompt the user to re-provide their sign-in credentials

[user reauthenticateWithCredential:credential completion:^(NSError *_Nullable error) {
  if (error) {
    // An error happened.
  } else {
    // User re-authenticated.
  }
}];

استيراد حسابات المستخدمين

يمكنك استيراد حسابات المستخدمين من ملف إلى مشروع Firebase باستخدام الأمر auth:import في Firebase CLI. على سبيل المثال:

firebase auth:import users.json --hash-algo=scrypt --rounds=8 --mem-cost=14