Engage SDK Shopping: Üçüncü taraf teknik entegrasyon talimatları

Kullanıcılarınıza bulundukları yerde ulaşarak uygulama etkileşimini artırın. Engage SDK'yı entegre ederek Koleksiyonlar, Entertainment Space ve Play Store gibi cihaz üzerindeki birden fazla yüzeyde kullanıcılara doğrudan kişiselleştirilmiş öneriler ve devam içerikleri sunun. Entegrasyon, ortalama APK boyutuna 50 KB'tan daha az (sıkıştırılmış) ekler ve çoğu uygulamanın geliştirici süresi yaklaşık bir hafta sürer. Daha fazla bilgi için işletme sitemizi ziyaret edin.

Bu kılavuzda, geliştirici iş ortaklarının Engage içerik yüzeylerine alışveriş içeriği sunmayla ilgili talimatlar yer almaktadır.

Entegrasyon ayrıntıları

Terminoloji

Bu entegrasyon aşağıdaki beş küme türünü içerir: Öneri, Öne Çıkan, Alışveriş Sepeti, Alışveriş Listesi, Yeniden Sipariş ve Alışveriş Siparişi Takibi.

  • Öneri kümeleri, tek bir geliştirici iş ortağından kişiselleştirilmiş alışveriş önerileri gösterir. Bu öneriler, kullanıcıya göre kişiselleştirilebilir veya genel (ör. trend olan öğeler) olabilir. Bunları kullanarak ürünleri, etkinlikleri, indirimleri, promosyonları ve abonelikleri dilediğiniz gibi öne çıkarabilirsiniz.

    Önerileriniz aşağıdaki yapıya sahiptir:

    • Öneri Kümesi: Aynı geliştirici iş ortağının önerilerinden oluşan bir grubu içeren kullanıcı arayüzü görünümü.

    • ShoppingEntity: Bir kümedeki tek bir öğeyi temsil eden nesne.

  • Öne çıkanlar kümesi, birden fazla geliştirici iş ortağının seçilmiş öğelerini tek bir kullanıcı arayüzü grubunda gösterir. Tek bir Öne Çıkan küme bulunur. Bu küme, kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm Öneri kümelerinin üzerinde öncelikli bir yerleşimle gösterilir. Her geliştirici iş ortağı, Öne Çıkan kümede en fazla 10 öğe yayınlayabilir.

  • Alışveriş sepeti kümesi, birçok geliştirici iş ortağının alışveriş sepetlerinden bir önizleme göstererek kullanıcıları bekleyen alışveriş sepetlerini tamamlamaya teşvik eder. Kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm Öneri kümelerinin üzerinde öncelikli bir yerleşimle gösterilen tek bir Alışveriş Sepeti kümesi vardır. Her geliştirici iş ortağının, alışveriş sepeti kümesinde en fazla 3 ShoppingCart örneği yayınlamasına izin verilir.

    Alışveriş sepetiniz aşağıdaki yapıya sahiptir:

    • Alışveriş Sepeti Kümesi: Birçok geliştirici iş ortağının alışveriş sepeti önizlemelerini içeren bir kullanıcı arayüzü görünümü.

    • ShoppingCart: Alışveriş sepeti kümesinde gösterilecek, tek bir geliştirici iş ortağının alışveriş sepeti önizlemesini temsil eden bir nesne. ShoppingCart, alışveriş sepetindeki toplam öğe sayısını göstermeli ve kullanıcının alışveriş sepetindeki bazı öğelerin resimlerini de içerebilir.

  • Alışveriş Listesi kümesi, birden fazla geliştirici iş ortağının alışveriş listelerine dair bir önizleme gösterir. Bu sayede kullanıcılar, listelerini güncellemek ve tamamlamak için ilgili uygulamaya geri dönmeye teşvik edilir. Tek bir Alışveriş Listesi kümesi vardır.

  • Yeniden sipariş kümesi, tek bir kullanıcı arayüzü gruplandırmasında birden fazla geliştirici iş ortağının önceki siparişlerine dair bir önizleme göstererek kullanıcıları yeniden sipariş vermeye teşvik eder. Tek bir Yeniden Sipariş Ver kümesi vardır.

    • Yeniden sipariş kümesi, kullanıcının önceki siparişindeki toplam öğe sayısını göstermeli ve aşağıdakilerden birini içermelidir:

      • Kullanıcının önceki siparişindeki X öğelerinin resimleri.
      • Kullanıcının önceki siparişindeki X öğesi için etiketler.
  • Alışveriş Siparişi Takibi kümesi, birçok geliştirici iş ortağının bekleyen veya yakın zamanda tamamlanan alışveriş siparişlerinin önizlemesini tek bir kullanıcı arayüzü grubunda göstererek kullanıcıların siparişlerini takip etmesine olanak tanır.

    Kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm Öneri kümelerinin üzerinde öncelikli bir yerleşimle tek bir AlışverişSiparişTakibi kümesi gösterilir. Her geliştirici iş ortağının, Alışveriş Siparişi Takibi kümesinde birden fazla ShoppingOrderTrackingEntity öğesi yayınlamasına izin verilir.

    • ShoppingOrderTrackingCluster'ınız aşağıdaki yapıya sahiptir:

      • ShoppingOrderTracking Kümesi: Birçok geliştirici iş ortağının sipariş takibi önizlemelerini içeren bir kullanıcı arayüzü görünümü
      • ShoppingOrderTrackingEntity: Tek bir geliştirici iş ortağı için alışveriş siparişi takibi önizlemesini temsil eden ve Alışveriş Siparişi Takibi kümesinde gösterilecek bir nesne. ShoppingOrderTrackingEntity, siparişin durumunu ve sipariş zamanını göstermelidir. ShoppingOrderTrackingEntity için beklenen teslimat süresini girmenizi önemle tavsiye ederiz. Bu süre, sağlandığında kullanıcılara gösterilir.

Ön çalışma

Minimum API düzeyi: 19

Uygulamanıza com.google.android.engage:engage-core kitaplığını ekleyin:

dependencies {
    // Make sure you also include that repository in your project's build.gradle file.
    implementation 'com.google.android.engage:engage-core:1.5.2'
}

Daha fazla bilgi için Android 11'de paket görünürlüğü başlıklı makaleyi inceleyin.

Özet

Tasarım, bağlı bir hizmetin uygulanmasına dayanır.

Bir istemcinin yayınlayabileceği veriler, farklı küme türleri için aşağıdaki sınırlara tabidir:

Küme türü Küme sınırları Bir kümedeki maksimum öğe sınırları
Öneri kümeleri En fazla 7 En fazla 50 ShoppingEntity
Öne Çıkan Küme En fazla 1 En fazla 20 ShoppingEntity
Alışveriş Sepeti Kümesi En fazla 1 En fazla 3 ShoppingCart

Birden fazla alışveriş sepeti yalnızca satıcı başına ayrı alışveriş sepeti olan uygulamalarda beklenir.

Alışveriş Listesi Kümesi En fazla 1 En fazla 1 ShoppingListEntity
Alışveriş'te yeniden sipariş verme kümesi En fazla 1 En fazla 1 ReorderEntity
Alışveriş Siparişi Takibi Kümesi En fazla 3 En fazla 3 ShoppingOrderTrackingEntity

1. adım: Tüzel kişi verilerini sağlayın

SDK, her öğe türünü temsil etmek için farklı öğeler tanımlamıştır. Alışveriş kategorisi için aşağıdaki varlıklar desteklenir:

  1. ShoppingEntity
  2. ShoppingCart
  3. ShoppingList
  4. Reorder
  5. ShoppingOrderTracking

Aşağıdaki grafiklerde, her tür için kullanılabilir özellikler ve şartlar özetlenmiştir.

ShoppingEntity

ShoppingEntity nesnesi, geliştirici iş ortaklarının yayınlamak istediği bir ürünü, tanıtımı, fırsatı, aboneliği veya etkinliği temsil eder.

ShoppingEntity
Özellik Şartlar Açıklama Biçim
Poster resimleri Zorunlu En az bir resim sağlanmalıdır. Yardım için Resim Özellikleri bölümüne bakın.
İşlem URI'si Zorunlu

Uygulamada öğeyle ilgili ayrıntıların gösterildiği sayfaya yönlendiren derin bağlantı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

URI
Başlık İsteğe bağlı Varlığın adı.

Serbest metin

Önerilen metin boyutu: 90 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Fiyat - mevcut Koşula bağlı olarak gerekli

Varlığın mevcut fiyatı.

Üzeri çizili fiyat sağlanıyorsa bu özellik de sağlanmalıdır.

Serbest metin
Fiyat - üstü çizili İsteğe bağlı Öğenin orijinal fiyatı, kullanıcı arayüzünde üstü çizili olarak gösterilir. Serbest metin
Açıklama metni İsteğe bağlı Varsa tüzel kişiliğin promosyonunu, etkinliğini veya güncellemesini öne çıkaran açıklama metni.

Serbest metin

Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Açıklama metnindeki ek bilgiler İsteğe bağlı Açıklama metninin küçük yazı metni.

Serbest metin

Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Puan (İsteğe bağlı) - Not: Tüm puanlar standart yıldız puanlama sistemimiz kullanılarak gösterilir.
Puan - Maksimum değer İsteğe bağlı

Derecelendirme ölçeğinin maksimum değeri.

Puanın mevcut değeri de sağlanıyorsa bu özellik sağlanmalıdır.

Sayı >= 0,0
Derecelendirme - Geçerli değer İsteğe bağlı

Puan ölçeğinin mevcut değeri.

Derecelendirmenin maksimum değeri de sağlanıyorsa belirtilmelidir.

Sayı >= 0,0
Puan - Sayı İsteğe bağlı

Varlığın puan sayısı.

Not: Uygulamanız, sayının kullanıcılara nasıl gösterileceğini kontrol ediyorsa bu alanı sağlayın. Kısa bir dize kullanın. Örneğin, sayı 1.000.000 ise daha küçük ekran boyutlarında sayının kesilmemesi için 1M gibi bir kısaltma kullanabilirsiniz.

Dize
Derecelendirme - Sayı Değeri İsteğe bağlı

Varlığın puan sayısı.

Not: Gösterim kısaltma mantığını kendiniz yönetmiyorsanız bu alanı doldurun. Hem Sayı hem de Sayı Değeri varsa kullanıcılara Sayı gösterilir.

Uzun
DisplayTimeWindow (İsteğe bağlı) - İçeriğin yüzeyde gösterileceği bir zaman aralığı belirleyin
Başlangıç zaman damgası İsteğe bağlı

İçeriğin yüzeyde gösterilmesi gereken epoch zaman damgası.

Ayarlanmazsa içerik, yüzeyde gösterilmeye uygun olur.

Milisaniye cinsinden dönem zaman damgası
Bitiş zaman damgası İsteğe bağlı

İçeriğin yüzeyde gösterilmeyeceği dönemin zaman damgası.

Ayarlanmazsa içerik, yüzeyde gösterilmeye uygun olur.

Milisaniye cinsinden dönem zaman damgası

ShoppingCart

Özellik Şartlar Açıklama Biçim
İşlem URI'si Zorunlu

İş ortağının uygulamasındaki alışveriş sepetine yönlendiren derin bağlantı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

URI
Ürün sayısı Zorunlu

Alışveriş sepetindeki öğelerin sayısı (yalnızca ürünlerin sayısı değil).

Örneğin: Sepette 3 özdeş gömlek ve 1 şapka varsa bu sayı 4 olmalıdır.

Tamsayı >= 1
İşlem Metni İsteğe bağlı

Alışveriş sepetindeki düğmenin harekete geçirici mesaj metni (ör. Alışveriş Çantanız).

Geliştirici tarafından işlem metni sağlanmazsa, varsayılan olarak Alışveriş sepetini görüntüle kullanılır.

Bu özellik, 1.1.0 ve sonraki sürümlerde desteklenir.

Dize
Başlık İsteğe bağlı

Sepetin başlığı (örneğin, Alışveriş Çantanız).

Geliştirici tarafından başlık sağlanmazsa varsayılan başlık Alışveriş sepetiniz olur.

Geliştirici iş ortağı, satıcı başına ayrı bir alışveriş sepeti yayınlıyorsa lütfen başlığa satıcı adını ekleyin.

Serbest metin

Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Alışveriş sepeti resimleri İsteğe bağlı

Sepetteki her ürünün resimleri.

Öncelik sırasına göre en fazla 10 resim sağlanabilir. Gösterilen resimlerin gerçek sayısı, cihazın form faktörüne bağlıdır.

Yardım için Resim Özellikleri bölümüne bakın.
Öğe etiketleri İsteğe bağlı

Alışveriş listesindeki öğelerin etiket listesi.

Gösterilen etiketlerin gerçek sayısı cihazın form faktörüne bağlıdır.

Serbest metin etiketlerinin listesi

Önerilen metin boyutu: 20 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Son kullanıcı etkileşimi zaman damgası İsteğe bağlı Kullanıcının alışveriş sepetiyle son etkileşiminden bu yana geçen milisaniye sayısı.

Bu, satıcı başına ayrı alışveriş sepeti yayınlayan geliştirici iş ortakları tarafından giriş olarak iletilir ve sıralama için kullanılabilir.

Milisaniye cinsinden dönem zaman damgası
DisplayTimeWindow (İsteğe bağlı) - İçeriğin yüzeyde gösterileceği bir zaman aralığı belirleyin
Başlangıç zaman damgası İsteğe bağlı

İçeriğin yüzeyde gösterilmesi gereken epoch zaman damgası.

Ayarlanmazsa içerik, yüzeyde gösterilmeye uygun olur.

Milisaniye cinsinden dönem zaman damgası
Bitiş zaman damgası İsteğe bağlı

İçeriğin yüzeyde gösterilmeyeceği dönemin zaman damgası.

Ayarlanmazsa içerik, yüzeyde gösterilmeye uygun olur.

Milisaniye cinsinden dönem zaman damgası

ShoppingList

Özellik Şartlar Açıklama Biçim
İşlem URI'si Zorunlu

İş ortağının uygulamasındaki alışveriş listesine yönlendiren derin bağlantı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

URI
Ürün sayısı Zorunlu Alışveriş listesindeki öğe sayısı. Tamsayı >= 1
Başlık İsteğe bağlı

Listenin başlığı (örneğin, Alışveriş Listeniz).

Geliştirici tarafından başlık sağlanmamışsa varsayılan başlık Alışveriş listesi olur.

Serbest metin

Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Öğe etiketleri Zorunlu

Alışveriş listesindeki öğelerin etiket listesi.

En az 1 etiket sağlanmalıdır ve öncelik sırasına göre en fazla 10 etiket sağlanabilir. Gösterilen etiketlerin gerçek sayısı, cihazın form faktörüne bağlıdır.

Serbest metin etiketlerinin listesi

Önerilen metin boyutu: 20 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

ShoppingReorderCluster

Özellik Şartlar Açıklama Biçim
İşlem URI'si Zorunlu

İş ortağının uygulamasında yeniden sipariş vermek için kullanılan derin bağlantı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

URI
İşlem Metni İsteğe bağlı

Yeniden sipariş ver düğmesindeki harekete geçirici mesaj metni (ör. Tekrar sipariş ver).

Geliştirici tarafından işlem metni sağlanmazsa varsayılan olarak Yeniden sipariş ver kullanılır.

Bu özellik, 1.1.0 ve sonraki sürümlerde desteklenir.

Dize
Ürün sayısı Zorunlu

Önceki siparişteki öğe sayısı (yalnızca ürün sayısı değil).

Örneğin: Önceki siparişte 3 küçük kahve ve 1 kruvasan varsa bu sayı 4 olmalıdır.

Tamsayı >= 1
Başlık Zorunlu Yeniden sipariş edilen öğenin başlığı.

Serbest metin

Önerilen metin boyutu: 40 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Öğe etiketleri

İsteğe bağlı

(Sağlanmadıysa poster resimleri sağlanmalıdır)

Önceki siparişin öğe etiketlerinin listesi.

Öncelik sırasına göre 10 adede kadar etiket sağlanabilir. Gösterilen etiketlerin gerçek sayısı, cihazın form faktörüne bağlıdır.

Serbest metin listesi

Etiket başına önerilen metin boyutu: 20 karakterden az (Çok uzun metinlerde üç nokta gösterilebilir)

Poster resimleri

İsteğe bağlı

(Sağlanmamışsa öğe etiketleri sağlanmalıdır)

Önceki siparişteki öğelerin resimleri.

Öncelik sırasına göre en fazla 10 resim sağlanabilir. Gösterilen resimlerin gerçek sayısı, cihazın form faktörüne bağlıdır.

Yardım için Resim Özellikleri bölümüne bakın.

ShoppingOrderTrackingCluster

Özellik Şartlar Açıklama Biçim
Başlık Zorunlu

Takip edilen paketin/öğelerin veya takip numarasının kısa başlığı.

Serbest metin

Önerilen metin boyutu: 50 karakter (Çok uzun metinlerde üç nokta gösterilir)

Sipariş Türü Zorunlu

Takip edilen paketin/öğelerin veya takip numarasının kısa başlığı.

Enum: IN_STORE_PICKUP, SAME_DAY_DELIVERY, MULTI_DAY_DELIVERY

Durum Zorunlu

Siparişin mevcut durumu.

Örneğin: "Gecikme var", "Yolda", "Gecikti", "Kargoya verildi", "Teslim edildi", "Stokta yok", "Sipariş hazır"

Serbest metin

Önerilen metin boyutu: 25 karakter (Çok uzun metinlerde üç nokta gösterilir)

Sipariş Saati Zorunlu

Siparişin verildiği sıradaki milisaniye cinsinden sıfır zaman damgası.

Tahmini teslimat süresi aralığı yoksa sipariş saati gösterilir

Milisaniye cinsinden dönem zaman damgası
İşlem URI'si Zorunlu

İş ortağının uygulamasındaki sipariş takibine derin bağlantı.

URI
OrderDeliveryTimeWindow (İsteğe bağlı) - Bir zaman aralığı ayarlayın Siparişin verildiği andan beklenen/gerçek teslimat zamanına kadar takip edilen sipariş için bir zaman aralığı ayarlayın.
OrderDeliveryTimeWindow - Başlangıç Saati İsteğe bağlı

Siparişin teslim edileceği veya teslim alınmaya hazır olacağı milisaniye cinsinden sıfır zaman damgası.

Milisaniye cinsinden dönem zaman damgası
OrderDeliveryTimeWindow - End Time İsteğe bağlı

Siparişin teslim edileceği veya teslim alınmaya hazır olacağı, milisaniye cinsinden sıfır zaman damgası.

Milisaniye cinsinden dönem zaman damgası
Poster resimleri İsteğe bağlı

Siparişin bir parçası olan bir öğenin/ürünün resmi.

Önerilen en boy oranı 1:1'dir.

Yardım için Resim Özellikleri bölümüne bakın.
Ürün sayısı İsteğe bağlı Siparişin içerdiği öğelerin sayısı. Tamsayı >= 1
Açıklama İsteğe bağlı

Siparişin içeriğini açıklayan tek bir metin paragrafı.

Not: Kullanıcıya açıklama veya alt başlık listesi gösterilir, ikisi birden gösterilmez.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırlık metin olan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya alt başlık listesi gösterilir, ikisi birden gösterilmez.

Serbest metin

Her altyazı için önerilen metin boyutu: en fazla 50 karakter

Sipariş Değeri - CurrentPrice İsteğe bağlı Siparişin mevcut değeri. Serbest metin
Sipariş numarası İsteğe bağlı Siparişi benzersiz şekilde tanımlamak için kullanılabilecek sipariş numarası/kimliği.

Serbest metin

Önerilen metin boyutu: en fazla 25 karakter

Takip numarası İsteğe bağlı Siparişin teslimat gerektirmesi durumunda sipariş/paket teslimatının takip numarası.

Serbest metin

Önerilen metin boyutu: en fazla 25 karakter

Resim özellikleri

Resim öğeleri için zorunlu özellikler aşağıda listelenmiştir:

En boy oranı Minimum piksel sayısı Önerilen piksel sayısı

Kare (1x1)

Öne çıkarılmayan kümeler için tercih edilir

300x300 1200x1200

Yatay (1,91x1)

Öne çıkan kümeler için tercih edilen

600x314 1200x628
Dikey (4x5) 480x600 960x1200

Dosya biçimleri

PNG, JPG, statik GIF, WebP

Maksimum dosya boyutu

5.120 KB

Ek öneriler

  • Resim güvenli alanı: Önemli içeriklerinizi yatay ve dikey yönde ortalanmış olarak resmin% 80'ini kaplayacak şekilde yerleştirin.
  • Resmin koyu ve açık tema ayarlarında düzgün şekilde gösterilebilmesi için şeffaf bir arka plan kullanın.

2. adım: Küme verilerini sağlama

İçerik yayınlama işinin arka planda (örneğin, WorkManager kullanılarak) yürütülmesi ve düzenli olarak veya etkinlik bazında (örneğin, kullanıcı uygulamayı her açtığında ya da sepete bir öğe eklediğinde) planlanması önerilir.

Alışveriş kümelerini yayınlamaktan AppEngageShoppingClient sorumludur.

İstemcide kümeleri yayınlamak için aşağıdaki API'ler kullanıma sunulur:

  • isServiceAvailable
  • publishRecommendationClusters
  • publishFeaturedCluster
  • publishShoppingCart
  • publishShoppingCarts
  • publishShoppingList
  • publishShoppingReorderCluster
  • publishShoppingOrderTrackingCluster
  • publishUserAccountManagementRequest
  • updatePublishStatus
  • deleteRecommendationsClusters
  • deleteFeaturedCluster
  • deleteShoppingCartCluster
  • deleteShoppingListCluster
  • deleteShoppingReorderCluster
  • deleteShoppingOrderTrackingCluster
  • deleteUserManagementCluster
  • deleteClusters

isServiceAvailable

Bu API, hizmetin entegrasyona uygun olup olmadığını ve içeriğin cihazda sunulup sunulamayacağını kontrol etmek için kullanılır.

Kotlin

client.isServiceAvailable.addOnCompleteListener { task ->
    if (task.isSuccessful) {
        // Handle IPC call success
        if(task.result) {
          // Service is available on the device, proceed with content publish
          // calls.
        } else {
          // Service is not available, no further action is needed.
        }
    } else {
      // The IPC call itself fails, proceed with error handling logic here,
      // such as retry.
    }
}

Java

client.isServiceAvailable().addOnCompleteListener(task - > {
    if (task.isSuccessful()) {
        // Handle success
        if(task.getResult()) {
          // Service is available on the device, proceed with content
          // publish calls.
        } else {
          // Service is not available, no further action is needed.
        }
    } else {
      // The IPC call itself fails, proceed with error handling logic here,
      // such as retry.
    }
});

publishRecommendationClusters

Bu API, RecommendationCluster nesnelerinin listesini yayınlamak için kullanılır.

RecommendationCluster nesnesi aşağıdaki özelliklere sahip olabilir:

Özellik Şartlar Açıklama
ShoppingEntity listesi Zorunlu Bu öneri kümesi için önerileri oluşturan ShoppingEntity nesnelerinin listesi.
Başlık Zorunlu

Öneri kümesinin başlığı.

Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir)

Alt başlık İsteğe bağlı Öneri kümesinin alt başlığı.
İşlem URI'si İsteğe bağlı

Kullanıcıların önerilerin tam listesini görebileceği iş ortağı uygulamasındaki sayfaya yönlendiren derin bağlantı.

Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın

Kotlin

client.publishRecommendationClusters(
            PublishRecommendationClustersRequest.Builder()
                .addRecommendationCluster(
                    RecommendationCluster.Builder()
                        .addEntity(entity1)
                        .addEntity(entity2)
                        .setTitle("Black Friday Deals")
                        .build())
                .build())

Java

client.publishRecommendationClusters(
            new PublishRecommendationClustersRequest.Builder()
                .addRecommendationCluster(
                    new RecommendationCluster.Builder()
                        .addEntity(entity1)
                        .addEntity(entity2)
                        .setTitle("Black Friday Deals")
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Mevcut tüm Öneri Kümesi verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve yeni Öneri Kümeleri'nde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishFeaturedCluster

Bu API, FeaturedCluster nesnesini yayınlamak için kullanılır.

Kotlin

client.publishFeaturedCluster(
            PublishFeaturedClusterRequest.Builder()
                .setFeaturedCluster(
                    FeaturedCluster.Builder()
                        ...
                        .build())
                .build())

Java

client.publishFeaturedCluster(
            new PublishFeaturedClusterRequest.Builder()
                .setFeaturedCluster(
                    new FeaturedCluster.Builder()
                        ...
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut FeaturedCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Öne Çıkan Küme'de saklanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingCart

Bu API, ShoppingCartCluster nesnesini yayınlamak için kullanılır.

Kotlin

client.publishShoppingCart(
            PublishShoppingCartRequest.Builder()
                .setShoppingCart(
                    ShoppingCart.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingCart(
            new PublishShoppingCartRequest.Builder()
                .setShoppingCart(
                    new ShoppingCart.Builder()
                        ...
                        .build())
                .build())

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut ShoppingCart verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen alışveriş sepeti kümesinde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingCarts

Bu API, birden fazla ShoppingCart nesnesini yayınlamak için kullanılır. Bu, geliştirici iş ortağının her satıcı için ayrı alışveriş sepetleri yayınlaması durumunda geçerlidir. Bu API'yi kullanırken başlığa satıcı adını ekleyin.

Kotlin

client.publishShoppingCarts(
            PublishShoppingCartClustersRequest.Builder()
                .addShoppingCart(
                    ShoppingCart.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingCarts(
            new PublishShoppingCartClustersRequest.Builder()
                .addShoppingCart(
                    new ShoppingCart.Builder()
                        ...
                        .build())
                .build())

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut ShoppingCart verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen alışveriş sepeti kümesinde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingList

Bu API, FoodShoppingList nesnesini yayınlamak için kullanılır.

Kotlin

client.publishFoodShoppingList(
            PublishFoodShoppingListRequest.Builder()
                .setFoodShoppingList(
                    FoodShoppingListEntity.Builder()
                        ...
                        .build())
                .build())

Java

client.publishFoodShoppingList(
            new PublishFoodShoppingListRequest.Builder()
                .setFoodShoppingList(
                    new FoodShoppingListEntity.Builder()
                        ...
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut FoodShoppingList verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Listesi kümesinde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingReorderCluster

Bu API, ShoppingReorderCluster nesnesini yayınlamak için kullanılır.

Kotlin

client.publishShoppingReorderCluster(
            PublishShoppingReorderClusterRequest.Builder()
                .setReorderCluster(
                    ShoppingReorderCluster.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingReorderCluster(
            new PublishShoppingReorderClusterRequest.Builder()
                .setReorderCluster(
                    new ShoppingReorderCluster.Builder()
                        ...
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut ShoppingReorderCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Yeniden Sıralama Kümesi'nde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingOrderTrackingCluster

Bu API, ShoppingOrderTrackingCluster nesnesini yayınlamak için kullanılır.

Kotlin

client.publishShoppingOrderTrackingCluster(
            PublishShoppingOrderTrackingClusterRequest.Builder()
                .setShoppingOrderTrackingCluster(
                    ShoppingOrderTrackingCluster.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingOrderTrackingCluster(
            new PublishShoppingOrderTrackingClusterRequest.Builder()
                .setShoppingOrderTrackingCluster(
                    new ShoppingOrderTrackingCluster.Builder()
                        ...
                        .build())
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut ShoppingOrderTrackingCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Siparişi İzleme Kümesi'nde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

publishUserAccountManagementRequest

Bu API, oturum açma kartı yayınlamak için kullanılır . Oturum açma işlemi, kullanıcıları uygulamanın oturum açma sayfasına yönlendirir. Böylece uygulama, içerik yayınlayabilir (veya daha kişiselleştirilmiş içerikler sunabilir).

Aşağıdaki meta veriler, oturum açma kartının bir parçasıdır:

Özellik Şartlar Açıklama
İşlem URI'si Zorunlu İşleme derin bağlantı (ör. uygulama oturum açma sayfasına yönlendirir)
Resim İsteğe bağlıdır. Sağlanmazsa başlık sağlanmalıdır.

Kartta Gösterilen Resim

1264x712 çözünürlüğünde 16:9 en boy oranına sahip resimler

Başlık İsteğe bağlıdır. Sağlanmazsa resim sağlanmalıdır. Kart üzerindeki başlık
İşlem Metni İsteğe bağlı CTA'da Gösterilen Metin (ör. Oturum açın)
Alt başlık İsteğe bağlı Kartta İsteğe Bağlı Altyazı

Kotlin

var SIGN_IN_CARD_ENTITY =
      SignInCardEntity.Builder()
          .addPosterImage(
              Image.Builder()
                  .setImageUri(Uri.parse("http://www.x.com/image.png"))
                  .setImageHeightInPixel(500)
                  .setImageWidthInPixel(500)
                  .build())
          .setActionText("Sign In")
          .setActionUri(Uri.parse("http://xx.com/signin"))
          .build()

client.publishUserAccountManagementRequest(
            PublishUserAccountManagementRequest.Builder()
                .setSignInCardEntity(SIGN_IN_CARD_ENTITY)
                .build());

Java

SignInCardEntity SIGN_IN_CARD_ENTITY =
      new SignInCardEntity.Builder()
          .addPosterImage(
              new Image.Builder()
                  .setImageUri(Uri.parse("http://www.x.com/image.png"))
                  .setImageHeightInPixel(500)
                  .setImageWidthInPixel(500)
                  .build())
          .setActionText("Sign In")
          .setActionUri(Uri.parse("http://xx.com/signin"))
          .build();

client.publishUserAccountManagementRequest(
            new PublishUserAccountManagementRequest.Builder()
                .setSignInCardEntity(SIGN_IN_CARD_ENTITY)
                .build());

Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:

  • Geliştirici iş ortağından alınan mevcut UserAccountManagementCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen UserAccountManagementCluster kümesinde depolanır.

Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

updatePublishStatus

Herhangi bir dahili ticari nedenden dolayı kümelerin hiçbiri yayınlanmıyorsa updatePublishStatus API'yi kullanarak yayın durumunu güncellemenizi önemle tavsiye ederiz. Bu önemlidir, çünkü :

  • İçerik yayınlanmış olsa bile (STATUS == PUBLISHED) tüm senaryolarda durumu sağlamak, entegrasyonunuzun durumunu ve diğer metriklerini iletmek için bu açık durumu kullanan kontrol panellerini doldurmak açısından kritik öneme sahiptir.
  • İçerik yayınlanmamış ancak entegrasyon durumu bozulmamışsa (STATUS == NOT_PUBLISHED), Google, uygulama sağlığı kontrol panellerinde uyarı tetiklemeyi önleyebilir. İçeriğin, sağlayıcının bakış açısıyla beklenen bir durum nedeniyle yayınlanmadığını onaylar.
  • Geliştiricilerin, verilerin ne zaman yayınlandığına dair bilgi vermesine yardımcı olur.
  • Google, kullanıcıyı uygulamada belirli işlemleri yapmaya yönlendirmek için durum kodlarını kullanabilir. Böylece kullanıcılar uygulama içeriğini görebilir veya sorunları aşabilir.

Uygun yayınlama durumu kodlarının listesi :

// Content is published
AppEngagePublishStatusCode.PUBLISHED,

// Content is not published as user is not signed in
AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN,

// Content is not published as user is not subscribed
AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SUBSCRIPTION,

// Content is not published as user location is ineligible
AppEngagePublishStatusCode.NOT_PUBLISHED_INELIGIBLE_LOCATION,

// Content is not published as there is no eligible content
AppEngagePublishStatusCode.NOT_PUBLISHED_NO_ELIGIBLE_CONTENT,

// Content is not published as the feature is disabled by the client
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_FEATURE_DISABLED_BY_CLIENT,

// Content is not published as the feature due to a client error
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_CLIENT_ERROR,

// Content is not published as the feature due to a service error
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_SERVICE_ERROR,

// Content is not published due to some other reason
// Reach out to engage-developers@ before using this enum.
AppEngagePublishStatusCode.NOT_PUBLISHED_OTHER

İçerik, oturum açmamış bir kullanıcı nedeniyle yayınlanmıyorsa Google, oturum açma kartının yayınlanmasını önerir. Sağlayıcılar herhangi bir nedenle oturum açma kartını yayınlayamıyorsa updatePublishStatus API'sinin NOT_PUBLISHED_REQUIRES_SIGN_IN durum koduyla çağrılması önerilir.

Kotlin

client.updatePublishStatus(
   PublishStatusRequest.Builder()
     .setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN)
     .build())

Java

client.updatePublishStatus(
    new PublishStatusRequest.Builder()
        .setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN)
        .build());

deleteRecommendationClusters

Bu API, Öneri Grupları'nın içeriğini silmek için kullanılır.

Kotlin

client.deleteRecommendationClusters()

Java

client.deleteRecommendationClusters();

Hizmet isteği aldığında mevcut verileri Öneri Kümeleri'nden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteFeaturedCluster

Bu API, Öne Çıkan Küme'nin içeriğini silmek için kullanılır.

Kotlin

client.deleteFeaturedCluster()

Java

client.deleteFeaturedCluster();

Hizmet isteği aldığında mevcut verileri Öne Çıkan Küme'den kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteShoppingCartCluster

Bu API, alışveriş sepeti kümesinin içeriğini silmek için kullanılır.

Kotlin

client.deleteShoppingCartCluster()

Java

client.deleteShoppingCartCluster();

Hizmet isteği aldığında mevcut verileri alışveriş sepeti kümesinden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteShoppingListCluster

Bu API, Alışveriş Listesi Kümesi'nin içeriğini silmek için kullanılır.

Kotlin

client.deleteShoppingListCluster()

Java

client.deleteShoppingListCluster();

Hizmet isteği aldığında mevcut verileri Alışveriş Listesi Kümesi'nden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteShoppingReorderCluster

Bu API, Alışveriş'te yeniden sipariş kümesinin içeriğini silmek için kullanılır.

Kotlin

client.deleteShoppingReorderCluster()

Java

client.deleteShoppingReorderCluster();

Hizmet isteği aldığında mevcut verileri Alışveriş'te yeniden sipariş verme kümesinden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteShoppingOrderTrackingCluster

Bu API, Shopping Sipariş İzleme Kümesi'nin içeriğini silmek için kullanılır.

Kotlin

client.deleteShoppingOrderTrackingCluster()

Java

client.deleteShoppingOrderTrackingCluster();

Hizmet isteği aldığında mevcut verileri Alışveriş Sipariş Takibi Kümesi'nden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteUserManagementCluster

Bu API, UserAccountManagement kümesinin içeriğini silmek için kullanılır.

Kotlin

client.deleteUserManagementCluster()

Java

client.deleteUserManagementCluster();

Hizmet isteği aldığında mevcut verileri UserAccountManagement kümesinden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteClusters

Bu API, belirli bir küme türünün içeriğini silmek için kullanılır.

Kotlin

client.deleteClusters(
    DeleteClustersRequest.Builder()
      .addClusterType(ClusterType.TYPE_FEATURED)
      .addClusterType(ClusterType.TYPE_RECOMMENDATION)
      ...
      .build())

Java

client.deleteClusters(
            new DeleteClustersRequest.Builder()
                .addClusterType(ClusterType.TYPE_FEATURED)
                .addClusterType(ClusterType.TYPE_RECOMMENDATION)
                ...
                .build());

Hizmet isteği aldığında mevcut verileri, belirtilen küme türleriyle eşleşen tüm kümelerden kaldırır. İstemciler bir veya daha fazla küme türü iletmeyi seçebilir. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

Hata işleme

Başarılı bir görevi kurtarmak ve yeniden göndermek için takip işlemi yapılabilmesi amacıyla yayınlama API'lerinden gelen görev sonucunu dinlemeniz önemle tavsiye edilir.

Kotlin

client.publishRecommendationClusters(
        PublishRecommendationClustersRequest.Builder()
          .addRecommendationCluster(..)
          .build())
      .addOnCompleteListener { task ->
        if (task.isSuccessful) {
          // do something
        } else {
          val exception = task.exception
          if (exception is AppEngageException) {
            @AppEngageErrorCode val errorCode = exception.errorCode
            if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) {
              // do something
            }
          }
        }
      }

Java

client.publishRecommendationClusters(
              new PublishRecommendationClustersRequest.Builder()
                  .addRecommendationCluster(...)
                  .build())
          .addOnCompleteListener(
              task -> {
                if (task.isSuccessful()) {
                  // do something
                } else {
                  Exception exception = task.getException();
                  if (exception instanceof AppEngageException) {
                    @AppEngageErrorCode
                    int errorCode = ((AppEngageException) exception).getErrorCode();
                    if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) {
                      // do something
                    }
                  }
                }
              });

Hata, nedenini içeren bir AppEngageException olarak döndürülür.

Hata kodu Hata adı Not
1 SERVICE_NOT_FOUND Hizmet, belirtilen cihazda kullanılamıyor.
2 SERVICE_NOT_AVAILABLE Hizmet, söz konusu cihazda kullanılabilir ancak arama sırasında kullanılamaz (örneğin, açıkça devre dışı bırakılmıştır).
3 SERVICE_CALL_EXECUTION_FAILURE İş parçacığı sorunları nedeniyle görev yürütme başarısız oldu. Bu durumda, işlem yeniden denenebilir.
4 SERVICE_CALL_PERMISSION_DENIED Arayan kullanıcının hizmet çağrısı yapmasına izin verilmiyor.
5 SERVICE_CALL_INVALID_ARGUMENT İstek geçersiz veriler içeriyor (örneğin, izin verilen küme sayısından daha fazla küme).
6 SERVICE_CALL_INTERNAL Hizmet tarafında bir hata var.
7 SERVICE_CALL_RESOURCE_EXHAUSTED Hizmet çağrısı çok sık yapılıyor.

3. adım: Yayın amaçlarını işleme

İçerik yayınlama API çağrılarını bir iş aracılığıyla yapmanın yanı sıra, içerik yayınlama isteğini almak için BroadcastReceiver ayarlamanız da gerekir.

Yayın niyetlerinin temel amacı, uygulamayı yeniden etkinleştirmek ve veri senkronizasyonunu zorlamaktır. Yayın amaçları çok sık gönderilmek üzere tasarlanmamıştır. Bu özellik yalnızca Engage Hizmeti, içeriğin eski olabileceğini (örneğin, bir hafta önce yayınlanmış) belirlediğinde tetiklenir. Bu sayede, uygulama uzun süredir çalıştırılmamış olsa bile kullanıcının yeni bir içerik deneyimi yaşayabileceğine dair daha fazla güven duyulur.

BroadcastReceiver aşağıdaki iki şekilde ayarlanmalıdır:

  • BroadcastReceiver sınıfının bir örneğini Context.registerReceiver() kullanarak dinamik olarak kaydedin. Bu, bellekte hâlâ etkin olan uygulamalardan iletişime izin verir.

Kotlin

class AppEngageBroadcastReceiver : BroadcastReceiver(){
  // Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION
  // broadcast is received
  // Trigger featured cluster publish when PUBLISH_FEATURED broadcast is
  // received
  // Trigger shopping cart cluster publish when PUBLISH_SHOPPING_CART broadcast
  // is received
  // Trigger shopping list cluster publish when PUBLISH_SHOPPING_LIST broadcast
  // is received
  // Trigger reorder cluster publish when PUBLISH_REORDER_CLUSTER broadcast is
  // received
  // Trigger shopping order tracking cluster publish when
  // PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER broadcast is received
}

fun registerBroadcastReceivers(context: Context){
  var  context = context
  context = context.applicationContext

// Register Recommendation Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_RECOMMENDATION),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Featured Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_FEATURED),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Shopping Cart Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_CART),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Shopping List Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_LIST),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Reorder Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_REORDER_CLUSTER),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)

// Register Shopping Order Tracking Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER),
                           com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                           /*scheduler=*/null)
}

Java

class AppEngageBroadcastReceiver extends BroadcastReceiver {
// Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION broadcast
// is received

// Trigger featured cluster publish when PUBLISH_FEATURED broadcast is received

// Trigger shopping cart cluster publish when PUBLISH_SHOPPING_CART broadcast is
// received

// Trigger shopping list cluster publish when PUBLISH_SHOPPING_LIST broadcast is
// received

// Trigger reorder cluster publish when PUBLISH_REORDER_CLUSTER broadcast is
// received

// Trigger reorder cluster publish when PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER
// broadcast is received
}

public static void registerBroadcastReceivers(Context context) {

context = context.getApplicationContext();

// Register Recommendation Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_RECOMMENDATION),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Featured Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Shopping Cart Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_CART),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Shopping List Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_LIST),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Reorder Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_REORDER_CLUSTER),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

// Register Shopping Order Tracking Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
                         new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER),
                         com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
                         /*scheduler=*/null);

}
  • <receiver> etiketiyle bir uygulamayı AndroidManifest.xml dosyanızda statik olarak bildirin. Bu, uygulamanın çalışmadığı zamanlarda yayın amaçlarını almasına ve içeriği yayınlamasına olanak tanır.

<application>
   <receiver
      android:name=".AppEngageBroadcastReceiver"
      android:permission="com.google.android.engage.REQUEST_ENGAGE_DATA"
      android:exported="true"
      android:enabled="true">
      <intent-filter>
         <action android:name="com.google.android.engage.action.PUBLISH_RECOMMENDATION" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.PUBLISH_FEATURED" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CART" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER" />
      </intent-filter>
      <intent-filter>
         <action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER" />
      </intent-filter>
   </receiver>
</application>

Hizmet tarafından aşağıdaki amaçlar gönderilir:

  • com.google.android.engage.action.PUBLISH_RECOMMENDATION Bu amaç alındığında publishRecommendationClusters araması başlatılması önerilir.
  • com.google.android.engage.action.PUBLISH_FEATURED Bu amaç alındığında publishFeaturedCluster araması başlatılması önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CART Bu amaç alındığında publishShoppingCart araması başlatılması önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST Bu amaç alındığında publishShoppingList araması başlatılması önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER Bu amaç alındığında publishReorderCluster araması başlatılması önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER Bu amaç alındığında publishShoppingOrderTrackingCluster araması başlatmanız önerilir.

Entegrasyon iş akışı

Entegrasyonunuz tamamlandıktan sonra doğrulama ile ilgili adım adım kılavuz için Geliştirici entegrasyonu iş akışını kullanma başlıklı makaleyi inceleyin.

SSS

SSS için Engage SDK ile ilgili sık sorulan sorular bölümüne bakın.

İletişim

Entegrasyon işlemi sırasında herhangi bir sorunuz olursa engage-developers@google.com ile iletişime geçin. Ekibimiz en kısa sürede yanıt verir.

Sonraki adımlar

Bu entegrasyonu tamamladıktan sonraki adımlarınız şunlardır:

  • engage-developers@google.com adresine e-posta gönderin ve Google tarafından test edilmeye hazır olan entegre APK'nızı ekleyin.
  • Google, entegrasyonun beklendiği gibi çalıştığından emin olmak için doğrulama yapar ve şirket içinde inceleme gerçekleştirir. Değişiklik yapılması gerekiyorsa Google, gerekli ayrıntıları paylaşmak için sizinle iletişime geçer.
  • Test tamamlandığında ve herhangi bir değişiklik yapılması gerekmediğinde Google, güncellenmiş ve entegre edilmiş APK'yı Play Store'da yayınlamaya başlayabileceğinizi bildirmek için sizinle iletişime geçer.
  • Google, güncellenen APK'nızın Play Store'da yayınlandığını onayladıktan sonra Öneri, Öne Çıkanlar, Alışveriş Sepeti, Alışveriş Listesi, Yeniden Sipariş Kümesi ve Alışveriş Siparişi Takibi Kümesi kümeleriniz yayınlanabilir ve kullanıcılar tarafından görülebilir.