आप प्रमाणीकरण प्रदाता क्रेडेंशियल्स को किसी मौजूदा उपयोगकर्ता खाते से लिंक करके उपयोगकर्ताओं को एकाधिक प्रमाणीकरण प्रदाताओं का उपयोग करके अपने ऐप में साइन इन करने की अनुमति दे सकते हैं। उपयोगकर्ता साइन इन करने के लिए जिस प्रमाणीकरण प्रदाता का उपयोग करते हैं, उसकी परवाह किए बिना उपयोगकर्ता उसी फायरबेस उपयोगकर्ता आईडी द्वारा पहचाने जा सकते हैं। उदाहरण के लिए, पासवर्ड के साथ साइन इन करने वाला उपयोगकर्ता Google खाते को लिंक कर सकता है और भविष्य में किसी भी विधि से साइन इन कर सकता है। या, कोई अज्ञात उपयोगकर्ता किसी Facebook खाते को लिंक कर सकता है और फिर, बाद में, अपने ऐप का उपयोग जारी रखने के लिए Facebook के साथ साइन इन कर सकता है।
शुरू करने से पहले
अपने ऐप में दो या अधिक प्रमाणीकरण प्रदाताओं (संभवतः अनाम प्रमाणीकरण सहित) के लिए समर्थन जोड़ें।
प्रमाणीकरण प्रदाता क्रेडेंशियल्स को उपयोगकर्ता खाते से लिंक करें
प्रामाणिक प्रदाता क्रेडेंशियल्स को किसी मौजूदा उपयोगकर्ता खाते से लिंक करने के लिए:
- किसी प्रमाणीकरण प्रदाता या विधि का उपयोग करके उपयोगकर्ता में साइन इन करें।
- नए प्रमाणीकरण प्रदाता के लिए साइन-इन प्रवाह को पूरा करें, लेकिन
firebase::auth::Auth::SignInWithCredential
विधियों में से किसी एक को कॉल करना शामिल नहीं है। उदाहरण के लिए, उपयोगकर्ता का Google ID टोकन, Facebook एक्सेस टोकन, या ईमेल और पासवर्ड प्राप्त करें। नए प्रमाणीकरण प्रदाता के लिए एक
Google साइन-इनfirebase::auth::Credential
प्राप्त करें:firebase::auth::Credential credential = firebase::auth::GoogleAuthProvider::GetCredential(google_id_token, nullptr);
Facebook लॉगfirebase::auth::Credential credential = firebase::auth::FacebookAuthProvider::GetCredential(access_token);
ईमेल-पासवर्ड साइन-इनfirebase::auth::Credential credential = firebase::auth::EmailAuthProvider::GetCredential(email, password);
firebase::auth::Credential
ऑब्जेक्ट को साइन-इन किए हुए उपयोगकर्ता केLinkWithCredential
मेथड में पास करें:// Link the new credential to the currently active user. firebase::auth::User current_user = auth->current_user(); firebase::Future<firebase::auth::AuthResult> result = current_user.LinkWithCredential(credential);
यदि क्रेडेंशियल पहले से ही किसी अन्य उपयोगकर्ता खाते से लिंक हैं, तो
LinkWithCredential
को कॉल विफल हो जाएगी। इस स्थिति में, आपको अपने ऐप के लिए खातों और संबंधित डेटा को मर्ज करने के लिए उपयुक्त होना चाहिए:// Gather data for the currently signed in User. firebase::auth::User current_user = auth->current_user(); std::string current_email = current_user.email(); std::string current_provider_id = current_user.provider_id(); std::string current_display_name = current_user.display_name(); std::string current_photo_url = current_user.photo_url(); // Sign in with the new credentials. firebase::Future<firebase::auth::AuthResult> result = auth->SignInAndRetrieveDataWithCredential(credential); // To keep example simple, wait on the current thread until call completes. while (result.status() == firebase::kFutureStatusPending) { Wait(100); } // The new User is now active. if (result.error() == firebase::auth::kAuthErrorNone) { firebase::auth::User* new_user = *result.result(); // Merge new_user with the user in details. // ... (void)new_user; }
यदि LinkWithCredential
पर कॉल सफल हो जाता है, तो उपयोगकर्ता अब किसी भी लिंक किए गए प्रमाणीकरण प्रदाता का उपयोग करके साइन इन कर सकता है और उसी फायरबेस डेटा तक पहुंच सकता है।
प्रमाणीकरण प्रदाता को उपयोगकर्ता खाते से अनलिंक करें
आप किसी प्रमाणीकरण प्रदाता को किसी खाते से अनलिंक कर सकते हैं, ताकि उपयोगकर्ता अब उस प्रदाता के साथ साइन इन नहीं कर सके।
किसी उपयोगकर्ता खाते से किसी प्रामाणिक प्रदाता को अनलिंक करने के लिए, प्रदाता आईडी को Unlink
विधि में पास करें। आप ProviderData
कॉल करके उपयोगकर्ता से जुड़े प्रमाणीकरण प्रदाताओं की प्रदाता आईडी प्राप्त कर सकते हैं।
// Unlink the sign-in provider from the currently active user. firebase::auth::User current_user = auth->current_user(); firebase::Future<firebase::auth::AuthResult> result = current_user.Unlink(providerId);