Apple platformlarında birden fazla uygulama veya uzantıda kimlik doğrulama durumlarını paylaşmak için Store Anahtar Zinciri Hizmetleri'ni kullanan paylaşılan bir anahtar zincirindeki kimlik doğrulama durumu ve uygulamalarınızı paylaşılan anahtar zincirini kullanacak şekilde yapılandırın.
Bu sayede kullanıcılar:
- Bir kez oturum açtıktan sonra aynı erişime ait tüm uygulamalarda oturum açın grubu.
- Bir kez çıkış yaptığınızda aynı erişime ait tüm uygulamalarda oturumunuz kapatılır grubu.
Kimlik doğrulama durumunu uygulamalar arasında paylaş
Kimlik doğrulama durumunu uygulamalar arasında paylaşmak için:
Uygulamalarınız için bir erişim grubu oluşturun.
Anahtar zinciri erişim grubu veya uygulama grubu kullanabilirsiniz. Bkz. Bir Uygulama Koleksiyonu Arasında Anahtar Zinciri Öğelerine Erişimi Paylaşma inceleyebilirsiniz.
Anahtar zinciri erişim grubu oluşturmak için her uygulamada aşağıdakileri yapın:
- Xcode'da Proje ayarları > Özellikler.
- Anahtar Zinciri Paylaşımını etkinleştir.
- Bir anahtar zinciri grup tanımlayıcısı ekleyin. Tüm uygulama durumunu seçin.
Her uygulamada, erişim grubunu anahtar zinciri erişim grubu veya uygulama grubu olarak ayarlayın son adımdır.
do { try Auth.auth().useUserAccessGroup("TEAMID.com.example.group1") } catch let error as NSError { print("Error changing user access group: %@", error) }
[FIRAuth.auth useUserAccessGroup:@"TEAMID.com.example.group1" error:nil];
En az bir uygulamada, herhangi bir oturum açma yöntemiyle kullanıcının oturum açın.
Auth.auth().signInAnonymously { result, error in // User signed in }
[FIRAuth signInAnonymouslyWithCompletion:^(FIRAuthDataResult *_Nullable result, NSError *_Nullable error) { // User signed in }];
Aynı geçerli kullanıcı, erişim grubundaki tüm uygulamalarda kullanılabilir.
var user = Auth.auth().currentUser
FIRUser *user = FIRAuth.auth.currentUser;
Paylaşılmamış bir anahtar zincirine geri dön
Kimlik doğrulama durumunu paylaşmayı durdurmak için erişim grubunu
nil
olarak ayarlayın.do { try Auth.auth().useUserAccessGroup(nil) } catch let error as NSError { print("Error changing user access group: %@", error) }
[FIRAuth.auth useUserAccessGroup:nil error:nil];
Herhangi bir oturum açma yöntemiyle kullanıcının oturumunu açın. Kullanıcı durumu kullanılamayacak geçiş yapabilirsiniz.
Auth.auth().signInAnonymously { result, error in // User signed in }
[FIRAuth signInAnonymouslyWithCompletion:^(FIRAuthDataResult *_Nullable result, NSError *_Nullable error) { // User signed in }];
Oturum açmış bir kullanıcıyı paylaşılan bir anahtar zincirine taşıma
Paylaşılan durumda oturum açmış bir kullanıcıyı taşımak için:
Gelecekte kullanmak üzere mevcut kullanıcıya atıfta bulunun.
var user = Auth.auth().currentUser
FIRUser *user = FIRAuth.auth.currentUser;
(İsteğe bağlı) Paylaşmak istediğiniz erişim grubunun yetkilendirme durumunu kontrol edin.
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 }
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 }
Daha önce proje ayarlarında belirlediğiniz bir erişim grubunu kullanın.
do { try Auth.auth().useUserAccessGroup(accessGroup) } catch let error as NSError { print("Error changing user access group: %@", error) }
[FIRAuth.auth useUserAccessGroup:accessGroup error:nil];
Geçerli kullanıcıyı güncelleyin.
Auth.auth().updateCurrentUser(user!) { error in // Error handling }
[FIRAuth.auth updateCurrentUser:user completion:^(NSError * _Nullable error) { // Error handling }];
Artık aynı erişim grubuna erişimi olan diğer uygulamalar, kullanıcıya erişebilir.