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

Google, kullanıcıların uygulamalarını sektörlere göre düzenleyen ve kişiselleştirilmiş uygulama içeriğinin tüketilmesi ve keşfedilmesi için yeni bir etkileyici deneyim sunan cihaz üzerinde bir yüzey oluşturuyor. Bu tam ekran deneyimi, geliştirici iş ortaklarına en iyi zengin içeriklerini uygulamalarının dışında özel bir kanalda sergileme fırsatı sunar.

Bu kılavuzda, geliştirici iş ortaklarının hem bu yeni yüzey alanını hem de Eğlence Alanı gibi mevcut Google yüzeylerini doldurmak için Engage SDK'sını kullanarak alışveriş içeriklerini entegre etme talimatları yer almaktadır.

Entegrasyon ayrıntıları

Terminoloji

Bu entegrasyon şu beş küme türünü içerir: Öneri, Öne Çıkan, Alışveriş Sepeti, Alışveriş Listesi, Yeniden Sıralama ve Alışveriş Siparişi İzleme.

  • Öneri kümeleri, tek bir geliştirici iş ortağının kişiselleştirilmiş alışveriş önerilerini gösterir. Bu öneriler kullanıcıya göre kişiselleştirilebilir veya genelleştirilebilir (ör. trend olan öğeler). Ürünleri, etkinlikleri, indirimleri, promosyonları ve abonelikleri uygun gördüğünüz şekilde göstermek için bunları kullanın.

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

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

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

  • Öne Çıkan kümesi, birden fazla geliştirici iş ortağından alınmış çeşitli varlıkları tek bir kullanıcı arayüzü gruplandırmasında 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 Öneriler kümelerinin üzerinde öncelikli olarak yerleştirilir. Her geliştirici iş ortağının, Öne Çıkanlar kümesinde en fazla 10 öğe yayınlamasına izin verilir.

  • Alışveriş Sepeti kümesi, tek bir kullanıcı arayüzü grubunda birçok geliştirici iş ortağından gelen alışveriş sepetlerine kısa bir bakış sunarak kullanıcıları bekleyen sepetlerini tamamlamaya yönlendirir. Tek bir Alışveriş Sepeti kümesi vardır. Bu küme, kullanıcı arayüzünün üst kısmına yakın bir yerde gösterilir ve tüm öneri kümelerinin üzerinde öncelikli bir yerleşime sahiptir. 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: Tek bir geliştirici iş ortağı için alışveriş sepeti önizlemesini temsil eden ve Alışveriş sepeti kümesinde gösterilecek bir nesne. ShoppingCart, alışveriş sepetindeki toplam öğe sayısını göstermelidir. Ayrıca kullanıcının alışveriş sepetindeki bazı ürünlerin resimlerini de içerebilir.

  • Alışveriş Listesi kümesi, birden fazla geliştirici iş ortağının alışveriş listelerinin bir kullanıcı arayüzü gruplandırmasında önizlemesini gösterir. Bu sayede kullanıcılar listelerini güncellemek ve tamamlamak için ilgili uygulamaya geri dönebilir. Tek bir Alışveriş Listesi kümesi vardır.

  • Yeniden sipariş ver kümesi, birden fazla geliştirici iş ortağının önceki siparişlerini tek bir kullanıcı arayüzü gruplandırmasında gösterir ve kullanıcıları yeniden sipariş vermeye teşvik eder. Tek bir yeniden sıralama kümesi vardır.

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

      • Kullanıcının önceki siparişindeki X öğenin resimleri.
      • Kullanıcının önceki siparişindeki X öğe 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şlerini tek bir kullanıcı arayüzü gruplandırmasında gösterir. Bu sayede kullanıcılar siparişlerini takip edebilir.

    Kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm öneri kümelerinin üzerinde öncelikli yerleşim alan tek bir ShoppingOrderTracking kümesi vardır. Her geliştirici iş ortağının Alışveriş Sipariş İzleme kümesinde birden fazla Shopping OrderTrackingEntity öğesi yayınlamasına izin verilir.

    • ShoppingOrderTrackingCluster aşağıdaki yapıya sahiptir:

      • Shopping OrderTracking Cluster: Birçok geliştirici iş ortağının sipariş takibi önizlemelerini içeren bir kullanıcı arayüzü görünümü
      • ShoppingOrderTrackingEntity: Alışveriş siparişi izleme kümesinde gösterilecek, tek bir geliştirici iş ortağı için alışveriş siparişi izleme önizlemesini temsil eden bir nesne. ShoppingOrderTrackingEntity, siparişin durumunu ve sipariş zamanını göstermelidir. Shopping OrderTrackingEntity için beklenen teslimat süresi, sağlandığında kullanıcılara gösterildiği için bu süreyi doldurmanızı önemle tavsiye ederiz.

Ön çalışma

Minimum API düzeyi: 19

com.google.android.engage:engage-core kitaplığını uygulamanıza 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ı hizmet uygulaması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 çok 5 En fazla 25 ShoppingEntity
Öne Çıkan Küme En fazla 1 En fazla 10 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ş sepetleri olan uygulamalarda beklenir.

Alışveriş Listesi Kümesi En fazla 1 En fazla 1 ShoppingListEntity
Alışveriş Yeniden Sıralama Kümesi En fazla 1 En fazla 1 ReorderEntity
Alışveriş Siparişi İzleme Kümesi En fazla 3 En fazla 3 ShoppingOrderTrackingEntity

1. adım: Öğe 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ılabilen özellikler ve şartlar özetlenmiştir.

ShoppingEntity

ShoppingEntity nesnesi, geliştirici iş ortaklarının yayınlamak istediği bir ürünü, promosyonu, anlaşmayı, 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 Zorunlu

Uygulamada varlıkla ilgili ayrıntıları gösteren sayfanın derin bağlantısı.

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

URI
Başlık İsteğe bağlı Tüzel kişinin adı.

Serbest metin

Önerilen metin boyutu: 90 karakterden az (Çok uzun metinde üç nokta gösterilebilir)

Fiyat - mevcut Koşullu olarak zorunlu

Öğenin mevcut fiyatı.

Üstü çizili fiyat sağlanmışsa bu değer de belirtilmelidir.

Serbest metin
Fiyat - üstü çizili İsteğe bağlı Öğenin orijinal fiyatı. Bu fiyat, kullanıcı arayüzünde üstü çizili olarak gösterilir. Serbest metin
Açıklama metni İsteğe bağlı Varsa öğeyle ilgili bir promosyonu, etkinliği veya güncellemeyi öne çıkaran açıklama metni.

Serbest metin

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

Açıklama metni ayrıntıları İsteğe bağlı Açıklama metni için 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 puanı sistemimiz kullanılarak gösterilir.
Derecelendirme - Maksimum değer İsteğe bağlı

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

Derecelendirmenin mevcut değeri de sağlanıyorsa sağlanmalıdır.

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

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

Derecelendirmenin maksimum değeri de sağlanıyorsa sağlanmalıdır.

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

Öğenin aldığı puanların sayısı.

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

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

Öğenin aldığı puanların sayısı.

Not: Gösterim kısaltması mantığını kendiniz yönetmezseniz bu alanı sağlayın. 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österilmesi için bir zaman aralığı ayarlayın
Başlangıç zaman damgası İsteğe bağlı

Sonrasında içeriğin yüzeyde gösterilmesi gereken dönem zaman damgasıdır.

Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur.

Milisaniye cinsinden Unix sıfır zaman damgası
Bitiş zaman damgası İsteğe bağlı

İçeriğin artık ilk sayfada gösterilmediği dönem zaman damgası.

Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur.

Milisaniye cinsinden Unix sıfır zaman damgası

ShoppingCart

Özellik Şartlar Açıklama Biçim
İşlem Uri Zorunlu

İş ortağının uygulamasındaki alışveriş sepetinin derin bağlantısı.

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

URI
Ürün sayısı Zorunlu

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

Örneğin: Alışveriş sepetinde 3 adet aynı gömlek ve 1 şapka varsa bu sayı 4 olmalıdır.

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

Alışveriş Sepeti'ndeki düğmenin harekete geçirici mesaj metni (örneğin, 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 sürümü ve sonraki sürümlerde desteklenir.

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

Alışveriş sepetinin 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ğı her satıcı için 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 metinde üç 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 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 etiketlerinin listesi.

Gösterilen etiketlerin gerçek sayısı cihaz 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 seple son kez etkileşime geçtiği zamanı tanımlayan, başlangıç zamanından geçen milisaniye sayısı.

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

Milisaniye cinsinden Unix sıfır zaman damgası
DisplayTimeWindow (İsteğe bağlı) - İçeriğin yüzeyde gösterilmesi için bir zaman aralığı ayarlayın
Başlangıç Zaman Damgası İsteğe bağlı

Sonrasında içeriğin yüzeyde gösterilmesi gereken dönem zaman damgasıdır.

Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur.

Milisaniye cinsinden Unix sıfır zaman damgası
Bitiş zaman damgası İsteğe bağlı

İçeriğin artık ilk sayfada gösterilmediği dönem zaman damgası.

Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur.

Milisaniye cinsinden Unix sıfır zaman damgası

ShoppingList

Özellik Şartlar Açıklama Biçim
İşlem Uri Zorunlu

İş ortağının uygulamasındaki alışveriş listesinin derin bağlantısı.

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

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

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

Geliştirici tarafından başlık sağlanmazsa varsayılan olarak Alışveriş listesi kullanılır.

Serbest metin

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

Öğe etiketleri Zorunlu

Alışveriş listesindeki öğelerin etiketlerinin 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 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 Zorunlu

İş ortağının uygulamasında yeniden sipariş verilecek derin bağlantı.

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

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

Yeniden sipariş ver üzerindeki düğmenin harekete geçirici mesaj metni (örneğin, Tekrar sipariş ver).

Geliştirici herhangi bir işlem metni sağlamıyorsa varsayılan olarak Yeniden sırala ayarı kullanılır.

Bu özellik 1.1.0 sürümü 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.

Tam sayı >= 1
Başlık Zorunlu Yeniden sipariş verilen öğenin başlığı.

Serbest metin

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

Öğe etiketleri

İsteğe bağlı

(Yayınlanmamışsa poster resimleri sağlanmalıdır)

Önceki siparişin öğe etiketlerinin listesi.

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

Serbest metin listesi

Etiket başına önerilen metin boyutu: 20 karakterden kısa (Çok uzun metinler üç noktayla 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örüntülenen gerçek resim 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 kısa başlığı veya takip numarası.

Serbest metin

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

Sipariş Türü Zorunlu

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

Enum: IN_STORE_PICKUP, SAME_DAY_DELIVERY, MULTI_DAY_DELIVERY

Durum Zorunlu

Siparişin mevcut durumu.

Örneğin: "Gecikeceğim", "Nakliyede", "Gecikmeli", "Gönderildi", "Teslim edildi", "Stokta yok", "Sipariş hazır"

Serbest metin

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

Sipariş zamanı Zorunlu

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

Beklenen teslimat süresi aralığı mevcut değilse sipariş saati gösterilir

Milisaniye cinsinden Epoch zaman damgası
İşlem Uri Zorunlu

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

URI
OrderDeliveryTimeWindow (İsteğe bağlı) - İzlenen sipariş için siparişin verildiği andan itibaren beklenen/gerçek teslimat süresine kadar bir zaman aralığı ayarlayın.
OrderDeliveryTimeWindow - Start Time İsteğe bağlı

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

Milisaniye cinsinden Unix sıfır zaman damgası
OrderDeliveryTimeWindow - End Time İsteğe bağlı

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

Milisaniye cinsinden Epoch zaman damgası
Poster resimleri İsteğe bağlı

Siparişe dahil olan bir öğenin/ürünün resmi.

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

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

Siparişteki öğeleri tanımlayan tek bir paragraflık metin.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir, ikisi birden gösterilmez.

Serbest metin

Önerilen metin boyutu: 180 karakter

Altyazı listesi İsteğe bağlı

Her biri tek satırdan oluşan en fazla 3 altyazı.

Not: Kullanıcıya açıklama veya altyazı listesi gösterilir.

Serbest metin

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

Sipariş Değeri - Mevcut Fiyat İsteğe bağlı Siparişin mevcut değeri. Serbest metin
Sipariş numarası İsteğe bağlı Siparişi benzersiz bir ş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ş/kargo teslimatı gerekiyorsa sipariş/kargo teslimatı için takip numarası

Serbest metin

Önerilen metin boyutu: en fazla 25 karakter

Resim özellikleri

Resim öğeleri için gerekli ö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 1.200x1.200

Yatay (1,91x1)

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

600x314 1.200x628
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 ortaya, resmin% 80'lik kısmına yerleştirin.
  • Resmin koyu ve açık tema ayarlarında düzgün şekilde gösterilmesi için şeffaf bir arka plan kullanın.

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

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

AppEngageShoppingClient, alışveriş kümelerini yayınlamaktan sorumludur.

Aşağıdaki API'ler, istemcideki kümeleri yayınlamada kullanılabilir:

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

isServiceAvailable

Bu API, hizmetin entegrasyon için uygun olup olmadığını ve içeriğin cihazda sunulup sunulamayacağını kontrol etmek amacıyla 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 nesneleri 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 İsteğe bağlı

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

Not: İlişkilendirme için derin bağlantıları 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, bir işlem içinde aşağıdaki işlemler gerçekleştirilir:

  • Mevcut tüm öneri kümesi verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve yeni öneri kümelerinde depolanır.

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

publishFeaturedCluster

Bu API, FeaturedCluster nesnesi 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ğının mevcut FeaturedCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Öne Çıkan Küme'de depolanır.

Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingCart

Bu API, ShoppingCartCluster nesnesi 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ğının mevcut ShoppingCart verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Sepeti Kümesi'nde depolanır.

Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingCarts

Bu API, birden fazla ShoppingCart nesnesi yayınlamak için kullanılır. Bu, satıcı başına ayrı alışveriş sepetleri yayınlayan geliştirici iş ortakları için 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ğının mevcut ShoppingCart verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Sepeti Kümesi'nde depolanır.

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

publishShoppingList

Bu API, FoodShoppingList nesnesi 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ğının mevcut FoodShoppingList verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Listesi Kümesi'nde depolanır.

Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.

publishShoppingReorderCluster

Bu API, ShoppingReorderCluster nesnesi 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ğının mevcut ShoppingReorderCluster verileri kaldırılır.
  • İstekten gelen veriler ayrıştırılır ve güncellenen yeniden sıralama kümesinde depolanır.

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

publishShoppingOrderTrackingCluster

Bu API, ShoppingOrderTrackingCluster nesnesi 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ğının mevcut ShoppingOrderTrackingCluster verileri kaldırılır.
  • İstekten elde edilen veriler ayrıştırılır ve güncellenmiş Alışveriş Sipariş İzleme Kümesinde depolanır.

Hata olması 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, uygulamanın içerik yayınlayabilmesi (veya daha kişiselleştirilmiş içerik sunabilmesi) için kullanıcıları uygulamanın oturum açma sayfasına yönlendirir.

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

Özellik Şartlar Açıklama
İşlem URI'sı Zorunlu İşleme derin bağlantı (ör. uygulamanın oturum açma sayfasına yönlendirme)
Resim İsteğe bağlı: Sağlanmamışsa başlık belirtilmelidir.

Kartta gösterilen resim

1264x712 çözünürlüklü, 16x9 en boy oranında resimler

Başlık İsteğe bağlı: Sağlanmazsa resim sağlanmalıdır Karttaki başlık
İşlem metni İsteğe bağlı CTA'da Gösterilen Metin (ör. Oturum aç)
Alt başlık İsteğe bağlı Kartta isteğ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, bir işlem içinde aşağıdaki işlemler gerçekleştirilir:

  • Geliştirici iş ortağının mevcut UserAccountManagementCluster verileri kaldırılır.
  • İstekten elde edilen veriler ayrıştırılır ve güncellenmiş UserAccountManagementCluster Kümesinde depolanır.

Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.

updatePublishStatus

Dahili bir işletme nedeniyle kümelerin hiçbiri yayınlanmıyorsa updatePublishStatus API'sini kullanarak yayınlama durumunu güncellemenizi önemle tavsiye ederiz. Bu önemlidir, çünkü :

  • İçerik yayınlandığında bile tüm senaryolarda durumu belirtmek (STATUS == YAYINLANDI) entegrasyonunuzun durumunu ve diğer metriklerini iletmek için bu uygunsuz durumu kullanan kontrol panellerini doldurmak açısından çok önemlidir.
  • Hiçbir içerik yayınlanmamışsa ancak entegrasyon durumu bozulmamışsa (STATUS == NOT_PUBLISHED) Google, uygulama sağlığı kontrol panellerinde uyarı tetiklemekten kaçınabilir. Sağlayıcı açısından beklenen bir durum nedeniyle içeriğin yayınlanmadığını onaylar.
  • Geliştiricilerin verilerin ne zaman yayınlandığı ve ne zaman yayınlanmadığı hakkında analizler sunmasına yardımcı olur.
  • Google, uygulama içeriğini görebilmeleri veya üstesinden gelebilmesi amacıyla, durum kodlarını kullanıcıyı uygulamada belirli işlemleri yapmaya yönlendirmek için kullanabilir.

Uygun yayınlama durumu kodlarının listesi şunlardır:

// 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, bir kullanıcı giriş yapmadığı için yayınlanmazsa Google, Oturum Açma kartını yayınlamanızı önerir. Sağlayıcılar herhangi bir nedenle oturum açma kartını yayınlayamıyorsa NOT_PUBLISHED_REQUIRES_SIGN_IN durum koduyla updatePublishStatus API'sini çağırmanızı öneririz.

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 kümelerinin içeriğini silmek için kullanılır.

Kotlin

client.deleteRecommendationClusters()

Java

client.deleteRecommendationClusters();

Hizmet, isteği aldığında mevcut verileri öneri kümelerinden kaldırır. Bir hata olması 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 Öne Çıkan Küme'deki mevcut verileri kaldırır. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteShoppingCartCluster

Bu API, Alışveriş Sepeti Kümesi'nin 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ümesi'nden kaldırır. Hata olması 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 olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

deleteShoppingReorderCluster

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

Kotlin

client.deleteShoppingReorderCluster()

Java

client.deleteShoppingReorderCluster();

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

deleteShoppingOrderTrackingCluster

Bu API, Alışveriş 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şi İzleme Kümesi'nden kaldırır. Bir hata olması 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ğinin 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 belirtilen küme türleriyle eşleşen tüm kümelerdeki mevcut verileri kaldırır. İstemciler bir veya daha fazla küme türünü iletmeyi seçebilir. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.

Hata işleme

Yayınlama API'lerinden görev sonucunu dinlemeniz önemle tavsiye edilir. Böylece, başarılı bir görevi kurtarıp yeniden göndermek için takip işlemi yapabilirsiniz.

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, hata kodu olarak nedeni dahil edilerek 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, belirli bir 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 Görev yürütme, mesaj dizileriyle ilgili sorunlar nedeniyle başarısız oldu. Bu durumda, işlem yeniden denenebilir.
4 SERVICE_CALL_PERMISSION_DENIED Arayan kullanıcının servis araması yapmasına izin verilmiyor.
5 SERVICE_CALL_INVALID_ARGUMENT İstek geçersiz veriler içeriyor (örneğin, izin verilenden daha fazla sayıda 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 intent'lerini işleme

İçerik yayınlama isteğini almak için bir iş üzerinden Content API çağrıları yapmanın yanı sıra bir BroadcastReceiver oluşturmak da gerekir.

Amaca dayalı yayınların amacı, temel olarak uygulamanın yeniden etkinleştirilmesini sağlamak ve veri senkronizasyonunu zorunlu kılmaktır. Yayın niyeti, çok sık gönderilecek şekilde tasarlanmamıştır. Bu işlem yalnızca Etkileşim Hizmeti tarafından içeriğin eski olabileceğini (örneğin, bir hafta önce) belirlediğinde tetiklenir. Bu sayede, uygulama uzun süre çalıştırılmamış olsa bile kullanıcının yeni bir içerik deneyimi yaşayabileceğinden emin olabilirsiniz.

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

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

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))

// Register Featured Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_FEATURED))

// Register Shopping Cart Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_CART))

// Register Shopping List Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_LIST))

// Register Reorder Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_REORDER_CLUSTER))

// Register Shopping Order Tracking Cluster Publish Intent
  context.registerReceiver(AppEngageBroadcastReceiver(),
                           IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER))
}

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));

// Register Featured Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED));

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

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

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

// 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));

}
  • AndroidManifest.xml dosyanızda <receiver> etiketiyle uygulamayı statik olarak beyan edin. Bu, uygulamanın çalışmadığında yayın intent'leri almasına ve içeriği yayınlamasına olanak tanır.
<application>
   <receiver
      android:name=".AppEngageBroadcastReceiver"
      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 intent'ler gönderilir:

  • com.google.android.engage.action.PUBLISH_RECOMMENDATION Bu niyet karşılandığında bir publishRecommendationClusters araması başlatmanız önerilir.
  • com.google.android.engage.action.PUBLISH_FEATURED Bu intent alındığında bir publishFeaturedCluster çağrısı başlatmanız önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CART Bu intent alındığında bir publishShoppingCart çağrısı başlatmanız önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST Bu intent alındığında bir publishShoppingList çağrısı başlatmanız önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER Bu intent alındığında bir publishReorderCluster çağrısı başlatmanız önerilir.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER Bu niyet alındığında publishShoppingOrderTrackingCluster çağrısı başlatmanız önerilir.

Entegrasyon iş akışı

Entegrasyonunuz tamamlandıktan sonra doğrulamayla ilgili adım adım açıklamalı bir kılavuz için Engage geliştirici entegrasyon iş akışı başlıklı makaleyi inceleyin.

SSS

SSS'ler için Etkileşim SDK'sıyla İlgili Sık Sorulan Sorular bölümüne bakın.

İletişim

Entegrasyon işlemi sırasında sorularınız olursa engage-developers@google.com adresinden bizimle iletişime geçebilirsiniz. Ekibimiz en kısa sürede yanıt verir.

Sonraki adımlar

Bu entegrasyonu tamamladıktan sonra uygulayacağınız adımlar şunlardır:

  • engage-developers@google.com adresine bir 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 bir doğrulama ve şirket içi inceleme gerçekleştirir. Değişiklik yapılması gerekiyorsa Google gerekli tüm bilgileri sizinle paylaşır.
  • Test tamamlandığında ve herhangi bir değişiklik gerekmediğinde Google, güncellenmiş ve entegre APK'yı Play Store'da yayınlamaya başlayabileceğinizi bildirmek için sizinle iletişime geçer.
  • Google, güncellenmiş APK'nızın Play Store'da yayınlandığını onayladıktan sonra Öneri, Öne Çıkan, Alışveriş Sepeti, Alışveriş Listesi, Yeniden Sipariş Kümesi ve Alışveriş Siparişi Takip Kümesi kümeleriniz yayınlanabilir ve kullanıcılar tarafından görülebilir.