إنشاء مستخدم
يمكنك إنشاء مستخدم جديد في مشروع Firebase من خلال استدعاء الطريقة
createUser
أو من خلال تسجيل دخول مستخدم لأول مرة باستخدام موفّر هوية موحّدة،
مثل تسجيل الدخول باستخدام حساب Google أو
تسجيل الدخول باستخدام Facebook.
يمكنك أيضًا إنشاء مستخدمين جدد تمت مصادقتهم باستخدام كلمة المرور من قسم "المصادقة" في وحدة تحكّم Firebase، وذلك في صفحة "المستخدمون".
الحصول على المستخدم الذي سجّل الدخول حاليًا
الطريقة المقترَحة للحصول على المستخدم الحالي هي ضبط أداة معالجة على كائن Auth:
Swift
handle = Auth.auth().addStateDidChangeListener { auth, user in // ... }
Objective-C
self.handle = [[FIRAuth auth] addAuthStateDidChangeListener:^(FIRAuth *_Nonnull auth, FIRUser *_Nullable user) { // ... }];
باستخدام متتبِّع، يمكنك التأكّد من أنّ المصادقة ليست في حالة وسيطة، مثل الإعداد، عند الحصول على المستخدم الحالي.
يمكنك أيضًا الحصول على المستخدم المسجّل الدخول حاليًا باستخدام السمة currentUser. إذا لم يسجّل المستخدم الدخول، تكون قيمة currentUser فارغة:
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