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ı ile Kullanıcı Rızası 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östermeyin. 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.
- Firebase konsolunda yeni bir In-App Messaging kampanyası oluşturun.
- Uygulama içi mesajları istediğiniz içerikle doldurun ve mesajın
app_launch
etkinliğinde tetiklenmesini ayarlayı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.
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.