iOS 14 destekleniyor

Apple, iOS 14.5 ile birlikte geliştiricilerin kullanıcıları izlemek veya cihazlarının reklam kimliğine (IDFA) erişmek için App Tracking Transparency çerçevesi aracılığıyla kullanıcının iznini almasını zorunlu kıldı. Daha fazla bilgi için Apple'ın Kullanıcı Gizliliği ve Veri Kullanımı ile Apple'ın Uygulama İzleme Şeffaflığı belgelerini inceleyin.

Etkilenen Firebase ürünleri

Firebase SDK'ları IDFA'ya erişmez ancak bazılarında IDFA erişimini içerebilecek Google Analytics entegrasyonları vardır.

Aşağıdaki tabloda, Apple platformlarında kullanılabilen Firebase ürünleri listelenmiştir ve IDFA'ya erişilememesi durumunda her ürünün işlevselliğinin nasıl etkilendiği açıklanmaktadır.

Ürün IDFA'ya erişilememesi durumundaki etki
A/B Testing A/B Testing ile Google Analytics entegrasyonundaki bazı hedefleme verileri (ör. demografi) IDFA'dan türetilir. IDFA'ya erişimi olmayan uygulamalarda bu hedefleme kullanılamaz.
App Check Etkisi yok
App Distribution Etkisi yok
Authentication Google ile oturum açma ve telefonla kimlik doğrulama gibi Authentication ve birinci taraf Authentication sağlayıcılar üzerinde etkisi yoktur.
Crashlytics Etkisi yok. Gerçek zamanlı kilitlenme verileri ve içerik haritası sağlayan Crashlytics ile Google Analytics entegrasyonu IDFA'ya bağlı değildir.
Dynamic Links Bağlantı açma işlevi etkilenmez. Google Analytics ile kullanıldığında, bağlantı dönüşümü etkinlikleri için ilişkilendirme kullanılamaz.
Cloud Firestore Etkisi yok
Cloud Functions Etkisi yok
In-App Messaging Etkisi yok
Firebase yükleme Etkisi yok
InstanceID Etkisi yok
Cloud Messaging Google Analytics ile birlikte kullanıldığında Google Analytics, FCM ile ilgili bazı dönüşüm etkinliklerini otomatik olarak kaydeder. Bu etkinliklerin ilişkilendirilmesi için IDFA erişimi gerekir.
Firebase ML Etkisi yok
Performance Monitoring Etkisi yok
Remote Config Google Analytics ile birlikte kullanıldığında Remote Config, IDFA erişimi olmadan hedefleme için otomatik olarak oluşturulan kullanıcı özelliklerine izin vermez.
Realtime Database Etkisi yok
Cloud Storage Etkisi yok
Vertex AI in Firebase Etkisi yok

Etkilenen Firebase entegrasyonları

Aşağıdaki tabloda, IDFA'ya erişilemediği takdirde etkilenen Firebase entegre ürünleri listelenmiştir.

Ürün IDFA'ya erişilememesi durumundaki etki
Google Analytics Analytics etkinlik günlüğü, etkinlik raporlaması ve dönüşüm ölçümü etkilenmez ancak IDFA'ya erişilemezse ilişkilendirme etkilenir. Google'ın iOS 14'e verdiği yanıt hakkında daha fazla bilgi edinmek için blog yayınımızı inceleyin.

iOS 14'te uygulama izleme izni isteme

Apple uygulamanızın IDFA'ya erişebilmesini istiyorsanız Apple'ın App Tracking Transparency çerçevesini uygulamanıza ekleyebilir ve kullanıcılarınızın IDFA'sını izlemek veya bu tanımlayıcıya erişmek için izin isteyebilirsiniz.

Birçok uygulama, izin istemeden önce bir tanıtım veya açıklama ekranı sunmayı tercih eder. Açıklama ekranı, erişim isteğinde bulunmadan önce kullanıcılara uygulamanızın IDFA'yı nasıl kullandığı hakkında daha fazla bilgi sunmanızı sağlar.

AdMob veya Ad Manager uygulama yayıncısıysanız kişiselleştirilmiş reklam yayınlama ve Apple'ın yönergelerine göre kullanıcıyı otomatik olarak izleme izni alma işlemlerini yürüten Funding Choices'ı kullanabilirsiniz. Daha fazla bilgi için AdMob Kullanıcı Mesajlarıyla Kullanıcı Rızası Alma sayfasına bakın.

Aşağıdaki kılavuzda, App Tracking Transparency aracılığıyla izleme erişimi istemeden önce açıklama ekranı oluşturmak ve görüntülemek için Firebase In-App Messaging kullanan bir çözüm sunulmaktadır.

Uygulamanıza In-App Messaging ekleme

In-App Messaging'yi Apple uygulamanıza ekleme talimatlarını uygulayın.

Uygulama içi mesajları kapatma

Öncelikle, iOS 13 çalıştıran cihazlar gibi izin iletişim kutusunu gösteremeyen cihazlarda açıklama ekranını göstermekten kaçının. Bu kodun FirebaseApp.configure()'den hemen sonra çalıştırılacağından emin olun.

Swift

if NSClassFromString("ATTrackingManager") == nil {
  // Avoid showing the App Tracking Transparency explainer if the
  // framework is not linked.
  InAppMessaging.inAppMessaging().messageDisplaySuppressed = true
}

Kullanıcı açıklama ekranını kapattığında etkinlikleri işlemek için InAppMessagingDisplayDelegate protokolünü uygulayın. Kullanıcı Tamam'a dokunursa uygulama izleme şeffaflığı çerçevesi aracılığıyla sistem istemini gösterin.

Swift

// The InAppMessaging delegate must be assigned before events can be handled.
InAppMessaging.inAppMessaging().delegate = self

func messageClicked(_ inAppMessage: InAppMessagingDisplayMessage,
                    with action: InAppMessagingAction) {
  switch action.actionText {
  case "OK":
    ATTrackingManager.requestTrackingAuthorization { status in
      switch status {
      case .authorized:
        // Optionally, log an event when the user accepts.
        Analytics.logEvent("tracking_authorized", parameters: nil)
      case _:
        // Optionally, log an event here with the rejected value.
      }
    }
  case _:
    // do nothing
  }
}

In-App Messaging kampanyası oluşturma

Kod uygulamanıza yerleştirildikten sonra Firebase konsolunda bir uygulama içi mesaj oluşturun.

  1. Firebase konsolunda yeni bir In-App Messaging kampanyası oluşturun.
  2. Uygulama içi mesajları istediğiniz içerikle doldurun ve mesajın app_launch etkinliğinde tetiklenmesini ayarlayın.
  3. Hedefleme bölümünde, kampanyanın yalnızca uygulamanızın en son sürümünü ve sonraki sürümleri hedeflediğinden emin olun.

In-App Messaging dokümanlarında yer alan talimatları uygulayarak açıklama ekranının görünümünü özelleştirebilirsiniz.

İsteğe bağlı: Farklı açıklama ekranlarını A/B testi

In-App Messaging, farklı açıklama ekranlarıyla denemeler yapmak için kullanabileceğiniz Firebase A/B Testing ile yerleşik entegrasyona sahiptir.

Firebase A/B Testing, deneme gruplarını otomatik olarak oluşturur ve kullanıcıların uygulamanızın farklı varyantlarıyla nasıl etkileşimde bulunduğunu görselleştirmenize yardımcı olur.

Uygulama izleme izinlerini kaydetme

Uygulama izleme izinleri yanıtını işlerken bir Google Analytics etkinliği günlüğe kaydetmediyseniz A/B denemesi çalıştırırken yanıt oranındaki değişiklikleri ölçmek için bunu yapmanız gerekir.

Swift

ATTrackingManager.requestTrackingAuthorization { status in
  switch status {
  case .authorized:
    // Optionally, log an event when the user accepts.
    Analytics.logEvent("tracking_authorized", parameters: nil)
  case _:
    // Optionally, log an event here with the rejected value.
  }
}

Yeni bir dönüşüm etkinliği oluşturma

Firebase konsolunun Analytics bölümünde Dönüşümler menüsüne gidin ve ardından yukarıdaki örnek kodla kaydedilen etkinlikle aynı ada sahip yeni bir dönüşüm etkinliği ekleyin.

Yeni deneme oluşturun

Console'un In-App Messaging menüsünde Yeni Deneme'yi tıklayın ve ardından açılan ekranlardaki talimatları uygulayın.

  • Hedefleme bölümünde, kampanyanın yalnızca uygulamanızın en son sürümünü ve sonraki sürümleri hedeflediğinden emin olun.
  • Hedefler bölümünde, yukarıdaki örnek kodla oluşturduğunuz dönüşüm etkinliğini ve izlemek istediğiniz diğer metrikleri seçin.

Denemeniz yayınlandıktan sonra, kesin sonuçlar elde edebilmesi için bir süre boyunca veri toplaması gerekir.

Bir denemeyi nasıl izleyeceğiniz ve başarılı bir varyantı nasıl kullanıma sunacağınız hakkında bilgi edinmek için Firebase A/B Testing dokümanlarını okuyun.