आप प्रमाणीकरण प्रदाता क्रेडेंशियल्स को मौजूदा उपयोगकर्ता खाते से लिंक करके एकाधिक प्रमाणीकरण प्रदाताओं का उपयोग करके उपयोगकर्ताओं को अपने ऐप में साइन इन करने की अनुमति दे सकते हैं। उपयोगकर्ताओं को उसी Firebase उपयोगकर्ता आईडी से पहचाना जा सकता है, भले ही वे प्रमाणीकरण प्रदाता द्वारा साइन इन करने के लिए उपयोग किए गए हों। उदाहरण के लिए, पासवर्ड के साथ साइन इन करने वाला उपयोगकर्ता Google खाते को लिंक कर सकता है और भविष्य में किसी भी विधि से साइन इन कर सकता है। या, कोई अनाम उपयोगकर्ता किसी Facebook खाते को लिंक कर सकता है और फिर बाद में, आपके ऐप का उपयोग जारी रखने के लिए Facebook से साइन इन कर सकता है।
शुरू करने से पहले
अपने ऐप में दो या अधिक प्रमाणीकरण प्रदाताओं (संभवतः अनाम प्रमाणीकरण सहित) के लिए समर्थन जोड़ें।
FirebaseAuth
वर्ग सभी API कॉल के लिए प्रवेश द्वार है। इसे FirebaseAuth.DefaultInstance के माध्यम से एक्सेस किया जा सकता है।Firebase.Auth.FirebaseAuth auth = Firebase.Auth.FirebaseAuth.DefaultInstance;
प्रमाणीकरण प्रदाता क्रेडेंशियल को उपयोगकर्ता खाते से लिंक करें
प्रमाणीकरण प्रदाता क्रेडेंशियल्स को किसी मौजूदा उपयोगकर्ता खाते से लिंक करने के लिए:
- किसी भी प्रमाणीकरण प्रदाता या विधि का उपयोग करके उपयोगकर्ता में साइन इन करें।
- नए प्रमाणीकरण प्रदाता के लिए
Firebase.Auth.FirebaseAuth.SignInWithCredentialAsync
विधियों में से किसी एक को कॉल करने तक, लेकिन इसमें शामिल नहीं, तक साइन-इन प्रवाह पूरा करें। उदाहरण के लिए, उपयोगकर्ता का Google आईडी टोकन, फेसबुक एक्सेस टोकन, या ईमेल और पासवर्ड प्राप्त करें। नए प्रमाणीकरण प्रदाता के लिए एक
Google साइन-इनFirebase.Auth.Credential
प्राप्त करें:Firebase.Auth.Credential credential = Firebase.Auth.GoogleAuthProvider.GetCredential(googleIdToken, googleAccessToken);
Facebook लॉग इनFirebase.Auth.Credential credential = Firebase.Auth.FacebookAuthProvider.GetCredential(accessToken);
3 ईमेल-पासवर्ड साइन-इनFirebase.Auth.Credential credential = Firebase.Auth.EmailAuthProvider.GetCredential(email, password);
4साइन-इन किए गए उपयोगकर्ता की
LinkWithCredentialAsync
विधि मेंFirebase.Auth.Credential
ऑब्जेक्ट पास करें:auth.CurrentUser.LinkWithCredentialAsync(credential).ContinueWith(task => { if (task.IsCanceled) { Debug.LogError("LinkWithCredentialAsync was canceled."); return; } if (task.IsFaulted) { Debug.LogError("LinkWithCredentialAsync encountered an error: " + task.Exception); return; } Firebase.Auth.FirebaseUser newUser = task.Result; Debug.LogFormat("Credentials successfully linked to Firebase user: {0} ({1})", newUser.DisplayName, newUser.UserId); });
यदि क्रेडेंशियल पहले से ही किसी अन्य उपयोगकर्ता खाते से लिंक हैं, तो
LinkWithCredentialAsync
पर कॉल विफल हो जाएगी। इस स्थिति में, आपको अपने ऐप के लिए उपयुक्त खातों और संबद्ध डेटा को मर्ज करने का प्रबंधन करना चाहिए:// Gather data for the currently signed in User. string currentUserId = auth.CurrentUser.UserId; string currentEmail = auth.CurrentUser.Email; string currentDisplayName = auth.CurrentUser.DisplayName; System.Uri currentPhotoUrl = auth.CurrentUser.PhotoUrl; // Sign in with the new credentials. auth.SignInWithCredentialAsync(credential).ContinueWith(task => { if (task.IsCanceled) { Debug.LogError("SignInWithCredentialAsync was canceled."); return; } if (task.IsFaulted) { Debug.LogError("SignInWithCredentialAsync encountered an error: " + task.Exception); return; } Firebase.Auth.FirebaseUser newUser = task.Result; Debug.LogFormat("User signed in successfully: {0} ({1})", newUser.DisplayName, newUser.UserId); // TODO: Merge app specific details using the newUser and values from the // previous user, saved above. });
यदि LinkWithCredentialAsync
को कॉल सफल होती है, तो उपयोगकर्ता अब किसी भी लिंक किए गए प्रमाणीकरण प्रदाता का उपयोग करके साइन इन कर सकता है और उसी Firebase डेटा तक पहुंच बना सकता है।
किसी उपयोगकर्ता खाते से प्रमाणीकरण प्रदाता को अनलिंक करें
आप किसी प्रमाणीकरण प्रदाता को किसी खाते से अनलिंक कर सकते हैं, ताकि उपयोगकर्ता अब उस प्रदाता के साथ साइन इन न कर सके।
किसी उपयोगकर्ता खाते से प्रमाणीकरण प्रदाता को अनलिंक करने के लिए, प्रदाता आईडी को UnlinkAsync
विधि में पास करें। आप ProviderData
पर कॉल करके किसी उपयोगकर्ता से लिंक किए गए प्रमाणीकरण प्रदाताओं की प्रदाता आईडी प्राप्त कर सकते हैं।
// Unlink the sign-in provider from the currently active user. // providerIdString is a string identifying a provider, // retrieved via FirebaseAuth.FetchProvidersForEmail(). auth.CurrentUser.UnlinkAsync(providerIdString).ContinueWith(task => { if (task.IsCanceled) { Debug.LogError("UnlinkAsync was canceled."); return; } if (task.IsFaulted) { Debug.LogError("UnlinkAsync encountered an error: " + task.Exception); return; } // The user has been unlinked from the provider. Firebase.Auth.FirebaseUser newUser = task.Result; Debug.LogFormat("Credentials successfully unlinked from user: {0} ({1})", newUser.DisplayName, newUser.UserId); });