C++'yı Kullanarak Firebase ile Anonim Kimlik Doğrulama

Firebase ile kimlik doğrulamak amacıyla geçici anonim hesaplar oluşturmak ve kullanmak için Firebase Authentication'ı kullanabilirsiniz. Bu geçici anonim hesaplar, henüz uygulamanıza kaydolmamış kullanıcıların güvenlik kurallarıyla korunan verilerle çalışmasına olanak tanımak için kullanılabilir. Anonim bir kullanıcı uygulamanıza kaydolmaya karar verirse oturum açma kimlik bilgilerini anonim hesaba bağlayarak gelecekteki oturumlarda korunan verileriyle çalışmaya devam edebilir.

Başlamadan önce

  1. Firebase'i C++ projenize ekleyin.
  2. Uygulamanızı henüz Firebase projenize bağlamadıysanız bunu Firebase konsolundan yapın.
  3. Anonim kimlik doğrulamayı etkinleştirin:
    1. Firebase konsolunda Auth bölümünü açın.
    2. Oturum Açma Yöntemleri sayfasında Anonim oturum açma yöntemini etkinleştirin.
    3. İsteğe bağlı: Projenizi Identity Platform ile Firebase Authentication'a yükselttiyseniz otomatik temizlemeyi etkinleştirebilirsiniz. Bu ayarı etkinleştirdiğinizde 30 günden daha eski anonim hesaplar otomatik olarak silinir. Otomatik temizlemenin etkin olduğu projelerde, anonim kimlik doğrulama artık kullanım sınırlarına veya faturalandırma kotalarına dahil edilmez. Otomatik temizlik konusuna bakın.

Firebase ile anonim olarak kimlik doğrulama

Oturumu kapalı olan bir kullanıcı Firebase ile kimlik doğrulama gerektiren bir uygulama özelliği kullandığında aşağıdaki adımları uygulayarak kullanıcının anonim olarak oturum açmasını sağlayın:

Auth sınıfı, tüm API çağrılarına yönelik ağ geçididir.
  1. Auth ve Uygulama başlığı dosyalarını ekleyin:
    #include "firebase/app.h"
    #include "firebase/auth.h"
    
  2. İlk kullanıma hazırlama kodunuzda bir firebase::App sınıfı oluşturun.
    #if defined(__ANDROID__)
      firebase::App* app =
          firebase::App::Create(firebase::AppOptions(), my_jni_env, my_activity);
    #else
      firebase::App* app = firebase::App::Create(firebase::AppOptions());
    #endif  // defined(__ANDROID__)
    
  3. firebase::App için firebase::auth::Auth sınıfını edinin. App ile Auth arasında bire bir eşleme var.
    firebase::auth::Auth* auth = firebase::auth::Auth::GetAuth(app);
    
  • Auth::SignInAnonymously numaralı telefonu arayın.
    firebase::Future<firebase::auth::AuthResult> result =
        auth->SignInAnonymously();
    
  • Programınızda düzenli olarak çalışan bir güncelleme döngüsü varsa (örneğin, saniyede 30 veya 60 kez) sonuçları her güncelleme için Auth::SignInAnonymouslyLastResult ile kontrol edebilirsiniz:
    firebase::Future<firebase::auth::AuthResult> result =
        auth->SignInAnonymouslyLastResult();
    if (result.status() == firebase::kFutureStatusComplete) {
      if (result.error() == firebase::auth::kAuthErrorNone) {
        firebase::auth::AuthResult auth_result = *result.result();
        printf("Sign in succeeded for `%s`\n",
               auth_result.user.display_name().c_str());
      } else {
        printf("Sign in failed with error '%s'\n", result.error_message());
      }
    }
    
    Programınız etkinliğe dayalıysa gelecek için bir geri çağırma kaydını tercih edebilirsiniz.
  • Anonim bir hesabı kalıcı hesaba dönüştürme

    Anonim bir kullanıcı uygulamanıza kaydolduğunda, işine yeni hesabıyla devam etmesine izin vermek isteyebilirsiniz. Örneğin, kullanıcının kaydolmadan önce alışveriş sepetine eklediği ürünleri yeni hesabının alışveriş sepetine eklemeyi düşünebilirsiniz. Bunun için aşağıdaki adımları tamamlayın:

    1. Kullanıcı kaydolduğunda, kullanıcının kimlik doğrulama sağlayıcısı için (Auth::SignInWith yöntemlerinden birini çağırarak (dahil değil)) oturum açma akışını tamamlayın. Örneğin, kullanıcının Google kimliği jetonunu, Facebook erişim jetonunu veya e-posta adresini ve şifresini alabilirsiniz.
    2. Yeni kimlik doğrulama sağlayıcı için bir auth::Credential alın:

      Google ile Oturum Açma
      firebase::auth::Credential credential =
          firebase::auth::GoogleAuthProvider::GetCredential(google_id_token,
                                                            nullptr);
      
      Facebook'ta Giriş
      firebase::auth::Credential credential =
          firebase::auth::FacebookAuthProvider::GetCredential(access_token);
      
      E-posta şifresiyle oturum açma
      firebase::auth::Credential credential =
          firebase::auth::EmailAuthProvider::GetCredential(email, password);
      
    3. auth::Credential nesnesini, oturum açan kullanıcının LinkWithCredential yöntemine iletin:

      // 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 çağrısı başarılı olursa kullanıcının yeni hesabı, anonim hesabın Firebase verilerine erişebilir.

    Otomatik temizleme

    Projenizi Kimlik Platformu ile Firebase Authentication'a yükselttiyseniz Firebase konsolunda otomatik temizlemeyi etkinleştirebilirsiniz. Bu özelliği etkinleştirdiğinizde Firebase'in 30 günden daha eski anonim hesapları otomatik olarak silmesine izin vermiş olursunuz. Otomatik temizlemenin etkinleştirildiği projelerde, anonim kimlik doğrulama kullanım sınırlarına veya faturalandırma kotalarına dahil edilmez.

    • Otomatik temizleme etkinleştirildikten sonra oluşturulan tüm anonim hesaplar, oluşturulduktan 30 gün sonra herhangi bir zamanda otomatik olarak silinebilir.
    • Mevcut anonim hesaplar, otomatik temizlik özelliği etkinleştirildikten 30 gün sonra otomatik olarak silinebilir.
    • Otomatik temizlemeyi kapatırsanız silinmesi planlanan tüm anonim hesaplar silinmek üzere programlanmış olarak kalır.
    • Anonim bir hesabı herhangi bir oturum açma yöntemine bağlayarak "yükseltilir"seniz hesap otomatik olarak silinmez.

    Bu özelliği etkinleştirmeden önce kaç kullanıcının etkileneceğini görmek istiyorsanız ve projenizi Firebase Authentication with Identity Platform'a yükselttiyseniz Cloud Logging'de is_anon ölçütüne göre filtreleme yapabilirsiniz.

    Sonraki adımlar

    Kullanıcılar artık Firebase ile kimlik doğrulaması yapabildiğine göre Firebase kurallarını kullanarak Firebase veritabanınızdaki verilere erişimlerini kontrol edebilirsiniz.