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ılavuz, geliştirici iş ortaklarının Engage içerik yüzeylerine yemek içeriği (yemek siparişi, yemek veya restoran incelemeleri ve keşfi, yemek abonelikleri, tarifler) sunmasıyla ilgili talimatlar içerir.
Entegrasyon ayrıntıları
Terminoloji
Bu entegrasyon aşağıdaki beş küme türünü içerir: Öneri, Öne Çıkanlar, Yemek Alışverişi Sepeti, Yemek Alışverişi Listesi ve Yeniden Sipariş.
Öneri kümeleri, bağımsız bir geliştirici iş ortağından kişiselleştirilmiş yemekle ilgili öneriler gösterir. Bu öneriler kullanıcıya göre kişiselleştirilebilir veya genelleştirilebilir (ör. indirimdeki yeni ürünler). Tarifleri, mağazaları, yemekleri, market ürünlerini vb. uygun gördüğünüz şekilde göstermek için bunları kullanın.
- Öneri kümesi
ProductEntity
,StoreEntity
veyaRecipeEntity
listelemelerinden oluşabilir ancak farklı öğe türlerinin karışımından oluşamaz.
Şekil : "ProductEntity", "StoreEntity" ve "RecipeEntity". (*Kullanıcı arayüzü yalnızca açıklama amaçlıdır) - Öneri kümesi
Ö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.
Şekil : "RecipeEntity" ile öne çıkarılan küme. (*Kullanıcı arayüzü yalnızca örnek amaçlıdır) Yemek Alışverişi Sepeti kümesi, birden fazla geliştirici iş ortağının market alışverişi sepetlerine dair bir önizleme gösterir. Bu sayede kullanıcılar, bekleyen sepetlerini tamamlamaya teşvik edilir. Tek bir Yemek Alışverişi Sepeti kümesi vardır.
Yemek Alışverişi Sepeti Kümesi, sepetin içindeki toplam öğe sayısını göstermeli ve kullanıcının sepetindeki X öğesinin resimlerini de içerebilir.
Şekil: Tek bir iş ortağının sunduğu gıda alışveriş sepeti kümesi. (*Kullanıcı arayüzü yalnızca örnek amaçlıdır)
Yemek Alışverişi Listesi kümesi, birden fazla geliştirici iş ortağının market alışverişi listelerine dair bir önizleme gösterir. Kullanıcıları, listelerini güncellemek ve tamamlamak için ilgili uygulamaya dönmeye yönlendirir. Tek bir Yemek Alışverişi Listesi kümesi vardır.
Şekil: Tek bir iş ortağının sunduğu Yemek Alışverişi Listesi kümesi. (*Kullanıcı arayüzü yalnızca örnek amaçlıdı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.
Şekil: Tek bir iş ortağından alınan yemek yeniden sipariş etme kümesi. (*Kullanıcı arayüzü yalnızca örnek amaçlıdır)
Ö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'
}
Ö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 (ProductEntity , RecipeEntity veya
StoreEntity ) |
Öne Çıkan Küme | En fazla 1 | En fazla 20 (ProductEntity , RecipeEntity veya StoreEntity ) |
Gıda Alışverişi Sepeti Kümesi | En fazla 1 | En fazla 1 ShoppingCartEntity |
Yemek Alışverişi Listesi Kümesi | En fazla 1 | En fazla 1 ShoppingListEntity |
Yemek Yeniden Sipariş Kümesi | En fazla 1 | En fazla 1 ReorderEntity |
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. Yemek kategorisinde aşağıdaki öğeler desteklenir:
ProductEntity
StoreEntity
RecipeEntity
FoodShoppingCart
FoodShoppingList
FoodReorderCluster
Aşağıdaki grafiklerde, her tür için kullanılabilir özellikler ve şartlar özetlenmiştir.
ProductEntity
ProductEntity
nesnesi, geliştirici iş ortaklarının yayınlamak istediği bağımsız bir öğeyi (ör. market ürünü, restorandaki yemek veya promosyon) temsil eder.

ProductEntity
özellikler
Ö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 ürünle 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ı | Ürünü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 | Ürünü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 ürünle 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 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ı | Ürünü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ı | Ürünü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ı |
StoreEntity
StoreEntity
nesnesi, geliştirici iş ortaklarının yayınlamak istediği bağımsız bir mağazayı (ör. restoran veya market) temsil eder.

StoreEntity
özellikler
Ö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 mağaza hakkında 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ı | Mağazanın adı. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Konum | İsteğe bağlı | Mağazanın konumu. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Açıklama metni | İsteğe bağlı | Varsa mağazanın tanıtımını, 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) |
Açıklama | İsteğe bağlı | Mağazanın açıklaması. | Serbest metin Önerilen metin boyutu: 90 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Kategori | İsteğe bağlı | Yemek yerleri bağlamında mağaza kategorisi, "Fransız", "Yeni Amerikan", "Ramen", "Fine Dining" gibi mutfak türleri olabilir. |
Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Not: Tüm puanlar, standart yıldız puanı 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ı | Mağazanın puan sayısıdır. Not: Uygulamanızın, bunun kullanıcılara nasıl gösterileceğini kontrol etmek istemesi durumunda bu alanı sağlayın. Kullanıcıya gösterilebilecek kısa dizeyi sağlayın. Örneğin, sayı 1.000.000 ise daha küçük ekran boyutlarında kesilmemesi için 1M gibi kısaltmalar kullanabilirsiniz. |
Dize |
Derecelendirme - Sayı Değeri | İsteğe bağlı | Mağazanın puan sayısıdır. Not: Gösterim kısaltma mantığını kendiniz yönetmek istemiyorsanız bu alanı sağlayın. Hem Sayı hem de Sayı Değeri varsa kullanıcılara göstermek için Sayı'yı kullanırız. |
Uzun |
RecipeEntity
RecipeEntity
nesnesi, geliştirici iş ortaklarının yayınlamak istediği bir yemek tarifi öğesini temsil eder.

RecipeEntity
özellikler
Ö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 tarifle 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ı | Tarifin adı. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Yazar | İsteğe bağlı | Yemek tarifinin yazarı. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Pişirme/hazırlama süresi | İsteğe bağlı | Tarifin pişirme süresi. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Açıklama metni | İsteğe bağlı | Varsa tarifle 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) |
Kategori | İsteğe bağlı | Yemek tarifinin kategorisi. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Açıklama | İsteğe bağlı | Yemek tarifinin açıklaması. | Serbest metin Önerilen metin boyutu: 90 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Not: Tüm puanlar standart yıldız puanı 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ı | Tarifin puan sayısı. Not: Uygulamanızın, bunun kullanıcılara nasıl gösterileceğini kontrol etmek istemesi durumunda bu alanı sağlayın. Kullanıcıya gösterilebilecek kısa dizeyi sağlayın. Örneğin, sayı 1.000.000 ise daha küçük ekran boyutlarında kesilmemesi için 1M gibi kısaltmalar kullanabilirsiniz. |
Dize |
Derecelendirme - Sayı Değeri | İsteğe bağlı | Tarifin puan sayısı. Not: Gösterim kısaltma mantığını kendiniz yönetmek istemiyorsanız bu alanı sağlayın. Hem Sayı hem de Sayı Değeri varsa kullanıcılara göstermek için Sayı'yı kullanırız. |
Uzun |
FoodShoppingCart

Ö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ün sayısı değil). Örneğin: Sepette 3 portakal ve 1 elma varsa bu sayı 4 olmalıdır. |
Tamsayı >= 1 |
Başlık | İsteğe bağlı | Alışveriş sepetinin başlığı (örneğin, Alışveriş sepetiniz). Geliştirici tarafından başlık sağlanmazsa varsayılan başlık Alışveriş sepetiniz olur. |
Serbest metin Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
İş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 |
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) |
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ı |
FoodShoppingList

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

Ö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. |
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) Tercih edilen |
300x300 | 1200x1200 |
Yatay (1,91x1) | 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.
Yemek kümelerinin yayınlanmasından AppEngageFoodClient
sorumludur.
İstemcide kümeleri yayınlamak için aşağıdaki API'ler kullanılabilir:
isServiceAvailable
publishRecommendationClusters
publishFeaturedCluster
publishFoodShoppingCart
publishFoodShoppingList
publishReorderCluster
publishUserAccountManagementRequest
updatePublishStatus
deleteRecommendationsClusters
deleteFeaturedCluster
deleteFoodShoppingCartCluster
deleteFoodShoppingListCluster
deleteReorderCluster
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 |
---|---|---|
ProductEntity, StoreEntity veya RecipeEntity listesi | Zorunlu | Bu Öneri Kümesi'ndeki önerileri oluşturan öğelerin listesi. Tek bir kümedeki varlıklar aynı türde olmalıdır. |
Başlık | Zorunlu | Öneri kümesinin başlığı (ör. Şükran Günü menüsünde büyük indirimler). Ö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("Big savings on Thanksgiving menu")
.build())
.build())
Java
client.publishRecommendationClusters(
new PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
new RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Big savings on Thanksgiving menu")
.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.
publishFoodShoppingCart
Bu API, FoodShoppingCart
nesnesini yayınlamak için kullanılır.
Kotlin
client.publishFoodShoppingCart(
PublishFoodShoppingCartClusterRequest.Builder()
.setShoppingCart(
FoodShoppingCart.Builder()
...
.build())
.build())
Java
client.publishFoodShoppingCart(
new PublishFoodShoppingCartClusterRequest.Builder()
.setShoppingCart(
new FoodShoppingCart.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
FoodShoppingCart
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.
publishFoodShoppingList
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.
publishReorderCluster
Bu API, FoodReorderCluster
nesnesini yayınlamak için kullanılır.
Kotlin
client.publishReorderCluster(
PublishReorderClusterRequest.Builder()
.setReorderCluster(
FoodReorderCluster.Builder()
...
.build())
.build())
Java
client.publishReorderCluster(
new PublishReorderClusterRequest.Builder()
.setReorderCluster(
new FoodReorderCluster.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
FoodReorderCluster
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.
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.
deleteFoodShoppingCartCluster
Bu API, Yemek Alışverişi Sepeti Kümesi'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteFoodShoppingCartCluster()
Java
client.deleteFoodShoppingCartCluster();
Hizmet, isteği aldığında mevcut verileri Yemek Alışverişi Sepeti Kümesi'nden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
deleteFoodShoppingListCluster
Bu API, Yemek Alışverişi Listesi Kümesi'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteFoodShoppingListCluster()
Java
client.deleteFoodShoppingListCluster();
Hizmet, isteği aldığında mevcut verileri Yemek Alışveriş Listesi Kümesi'nden kaldırır. Hata durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
deleteReorderCluster
Bu API, FoodReorderCluster'ın içeriğini silmek için kullanılır.
Kotlin
client.deleteReorderCluster()
Java
client.deleteReorderCluster();
Hizmet isteği aldığında mevcut verileri yeniden sıralama kümesinden 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, 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ü 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.
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ğiniContext.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 food shopping cart cluster publish when PUBLISH_FOOD_SHOPPING_CART broadcast
// is received
// Trigger food shopping list cluster publish when PUBLISH_FOOD_SHOPPING_LIST broadcast
// is received
// Trigger reorder cluster publish when PUBLISH_REORDER_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 food Shopping Cart Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_FOOD_SHOPPING_CART),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register food Shopping List Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_FOOD_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)
}
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 food shopping cart cluster publish when PUBLISH_FOOD_SHOPPING_CART broadcast is
// received
// Trigger food shopping list cluster publish when PUBLISH_FOOD_SHOPPING_LIST broadcast is
// received
// Trigger reorder cluster publish when PUBLISH_REORDER_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 food Shopping Cart Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_FOOD_SHOPPING_CART),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register food Shopping List Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_FOOD_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);
}
<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.food.PUBLISH_FOOD_SHOPPING_CART" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.food.PUBLISH_FOOD_SHOPPING_LIST" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.food.PUBLISH_REORDER_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ığındapublishRecommendationClusters
araması başlatmanız önerilir.com.google.android.engage.action.PUBLISH_FEATURED
Bu amaç alındığındapublishFeaturedCluster
araması başlatılması önerilir.com.google.android.engage.action.food.PUBLISH_FOOD_SHOPPING_CART
Bu amaç alındığındapublishFoodShoppingCart
araması başlatılması önerilir.com.google.android.engage.action.food.PUBLISH_FOOD_SHOPPING_LIST
Bu amaç alındığındapublishFoodShoppingList
araması başlatılması önerilir.com.google.android.engage.action.food.PUBLISH_REORDER_CLUSTER
Bu amaç alındığındapublishReorderCluster
araması başlatılması ö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 sorularınız olursa engage-developers@google.com
ile iletişime geçin. Ekibimiz en kısa sürede yanıt verecektir.
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 dahili olarak doğrulama ve inceleme yapar. 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 ve Yeniden Sipariş kümeleriniz yayınlanır ve kullanıcılar tarafından görülebilir.