Apple के प्लैटफ़ॉर्म पर मौजूद एक से ज़्यादा ऐप्लिकेशन या एक्सटेंशन में, पुष्टि करने की स्थिति शेयर करने के लिए, Keychain Services का इस्तेमाल करके, शेयर किए गए कीचेन में पुष्टि करने की स्थिति सेव करें. इसके बाद, शेयर किए गए कीचेन का इस्तेमाल करने के लिए, अपने ऐप्लिकेशन कॉन्फ़िगर करें.
इससे उपयोगकर्ताओं को ये काम करने की सुविधा मिलती है:
- एक बार साइन इन करने पर, एक ही ऐक्सेस ग्रुप से जुड़े सभी ऐप्लिकेशन में साइन इन रहना.
- एक बार साइन आउट करने पर, एक ही ऐक्सेस ग्रुप से जुड़े सभी ऐप्लिकेशन से साइन आउट हो जाना.
ऐप्लिकेशन के बीच, पुष्टि करने की स्थिति शेयर करना
ऐप्लिकेशन के बीच, पुष्टि करने की स्थिति शेयर करने के लिए:
अपने ऐप्लिकेशन के लिए, ऐक्सेस ग्रुप सेट अप करें.
कीचेन ऐक्सेस ग्रुप या ऐप्लिकेशन ग्रुप का इस्तेमाल किया जा सकता है. ज़्यादा जानकारी के लिए, ऐप्लिकेशन के कलेक्शन के बीच कीचेन आइटम का ऐक्सेस शेयर करना लेख पढ़ें.
कीचेन ऐक्सेस ग्रुप सेट अप करने के लिए, हर ऐप्लिकेशन के लिए यह तरीका अपनाएं:
- Xcode में, प्रोजेक्ट सेटिंग > कैपेबिलिटी पर जाएं.
- कीचेन शेयर करने की सुविधा चालू करें.
- कीचेन ग्रुप आइडेंटिफ़ायर जोड़ें. जिन सभी ऐप्लिकेशन के लिए आपको स्थिति शेयर करनी है उनके लिए एक ही आइडेंटिफ़ायर का इस्तेमाल करें.
हर ऐप्लिकेशन में, ऐक्सेस ग्रुप को कीचेन ऐक्सेस ग्रुप या पिछले चरण में बनाए गए ऐप्लिकेशन ग्रुप पर सेट करें.
Swift
do { try Auth.auth().useUserAccessGroup("TEAMID.com.example.group1") } catch let error as NSError { print("Error changing user access group: %@", error) }Objective-C
[FIRAuth.auth useUserAccessGroup:@"TEAMID.com.example.group1" error:nil];कम से कम एक ऐप्लिकेशन में, साइन इन करने के किसी भी तरीके से किसी उपयोगकर्ता को साइन इन कराएं.
Swift
Auth.auth().signInAnonymously { result, error in // User signed in }Objective-C
[FIRAuth signInAnonymouslyWithCompletion:^(FIRAuthDataResult *_Nullable result, NSError *_Nullable error) { // User signed in }];मौजूदा उपयोगकर्ता, ऐक्सेस ग्रुप के सभी ऐप्लिकेशन में उपलब्ध होता है.
Swift
var user = Auth.auth().currentUserObjective-C
FIRUser *user = FIRAuth.auth.currentUser;
शेयर नहीं किए गए कीचेन पर वापस जाना
पुष्टि करने की स्थिति शेयर करने की सुविधा बंद करने के लिए, ऐक्सेस ग्रुप को
nilपर सेट करें.Swift
do { try Auth.auth().useUserAccessGroup(nil) } catch let error as NSError { print("Error changing user access group: %@", error) }Objective-C
[FIRAuth.auth useUserAccessGroup:nil error:nil];साइन इन करने के किसी भी तरीके से किसी उपयोगकर्ता को साइन इन कराएं. उपयोगकर्ता की स्थिति, किसी दूसरे ऐप्लिकेशन के लिए उपलब्ध नहीं होगी.
Swift
Auth.auth().signInAnonymously { result, error in // User signed in }Objective-C
[FIRAuth signInAnonymouslyWithCompletion:^(FIRAuthDataResult *_Nullable result, NSError *_Nullable error) { // User signed in }];
साइन इन किए हुए उपयोगकर्ता को शेयर किए गए कीचेन पर माइग्रेट करना
पहले से साइन इन किए हुए उपयोगकर्ता को शेयर की गई स्थिति पर माइग्रेट करने के लिए:
भविष्य में इस्तेमाल करने के लिए, मौजूदा उपयोगकर्ता का रेफ़रंस बनाएं.
Swift
var user = Auth.auth().currentUserObjective-C
FIRUser *user = FIRAuth.auth.currentUser;(ज़रूरी नहीं) उस ऐक्सेस ग्रुप की पुष्टि करने की स्थिति देखें जिसे आपको शेयर करना है.
Swift
let accessGroup = "TEAMID.com.example.group1" var tempUser: User? do { try tempUser = Auth.auth().getStoredUser(forAccessGroup: accessGroup) } catch let error as NSError { print("Error getting stored user: %@", error) } if tempUser != nil { // A user exists in the access group } else { // No user exists in the access group }Objective-C
NSString *accessGroup = @"TEAMID.com.example.group1"; FIRUser *tempUser = [FIRAuth getStoredUserForAccessGroup:accessGroup error:nil]; if (tempUser) { // A user exists in the access group } else { // No user exists in the access group }ऐसे ऐक्सेस ग्रुप का इस्तेमाल करें जिसे आपने पहले प्रोजेक्ट सेटिंग में सेट किया था.
Swift
do { try Auth.auth().useUserAccessGroup(accessGroup) } catch let error as NSError { print("Error changing user access group: %@", error) }Objective-C
[FIRAuth.auth useUserAccessGroup:accessGroup error:nil];मौजूदा उपयोगकर्ता को अपडेट करें.
Swift
Auth.auth().updateCurrentUser(user!) { error in // Error handling }Objective-C
[FIRAuth.auth updateCurrentUser:user completion:^(NSError * _Nullable error) { // Error handling }];उपयोगकर्ता को अब उन दूसरे ऐप्लिकेशन से ऐक्सेस किया जा सकता है जिनके पास एक ही ऐक्सेस ग्रुप का ऐक्सेस है.