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üresini yaklaşık bir hafta uzatır. Daha fazla bilgi için işletme sitemizi ziyaret edin.
Bu kılavuzda, geliştirici iş ortaklarının Engage içerik yüzeylerine sosyal medya içeriği sunmasıyla ilgili talimatlar yer almaktadır.
Entegrasyon ayrıntıları
Entegrasyonla ilgili ayrıntılar aşağıdaki bölümde verilmiştir.
Terminoloji
Öneri kümeleri, tek bir geliştirici iş ortağından kişiselleştirilmiş öneriler gösterir.
Önerileriniz aşağıdaki yapıya sahiptir:
Öneri Kümesi: Aynı geliştirici iş ortağının bir grup önerisini içeren kullanıcı arayüzü görünümü.
Her Öneri Kümesi aşağıdaki iki türden birini içerir :
- PortraitMediaEntity
- SocialPostEntity
PortraitMediaEntity, gönderi için 1 dikey resim içermelidir. Profil ve etkileşimle ilgili meta veriler isteğe bağlıdır.
Gönderi
- Dikey modda görüntü ve zaman damgası veya
- Dikey modda resim + metin içeriği ve zaman damgası
Profil
- Avatar, ad veya herkese açık kullanıcı adı, ek resim
Etkileşimler
- Yalnızca sayma ve etiketleme veya
- Sayı ve görsel (simge)
SocialPostEntity; profil, gönderi ve etkileşimle ilgili meta verileri içerir.
Profil
- Avatar, ad veya herkese açık kullanıcı adı, ek metin, ek resim
Gönderi
- Metin ve zaman damgası veya
- Rich media (resim veya rich URL) ve zaman damgası ya da
- Metin ve rich media (resim veya rich URL) ve zaman damgası ya da
- Video önizlemesi (küçük resim ve süre) ve zaman damgası
Etkileşimler
- Yalnızca sayma ve etiketleme veya
- Sayı ve görsel (simge)
Ö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.12'
}
Ö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 minimum öğe sınırları | Bir kümedeki maksimum öğe sınırları |
|---|---|---|---|
| Öneri kümeleri | En fazla 7 | En az 1 (PortraitMediaEntity veya
SocialPostEntity) |
En fazla 50 (PortraitMediaEntity veya
SocialPostEntity) |
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. SDK, Sosyal kategorisi için aşağıdaki öğeleri destekler:
PortraitMediaEntitySocialPostEntity
Aşağıdaki grafiklerde, her tür için kullanılabilir özellikler ve şartlar özetlenmektedir.
PortraitMediaEntity
| Özellik | Şartlar | Açıklama | Biçim |
|---|---|---|---|
| İşlem URI'si | Google TV dışındaki tüm platformlar için zorunludur. |
Sağlayıcı uygulamasındaki öğeye derin bağlantı oluşturun. Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın |
URI |
| PlatformSpecificPlayback | Google TV yüzeyi için zorunlu |
Google TV ve mobil gibi platformlar için sağlayıcı uygulamasındaki tüzel kişiye derin bağlantı oluşturun. |
PlatformSpecificPlayback nesnelerinin listesi |
| Öneri Nedeni | İsteğe bağlı | İçeriğin kullanıcıya önerilme gerekçesi. | RecommendationReason nesnesi |
| Yorum Özeti | İsteğe bağlı | Yayına yapılan yorumların özeti. | Dize |
| Gönderiyle ilgili meta veriler (zorunlu) | |||
| Resimler | Zorunlu |
Resimler dikey en boy oranında olmalıdır. Birden fazla resim sağlandığında kullanıcı arayüzünde yalnızca 1 resim gösterilebilir. Ancak kullanıcı arayüzü, uygulamada daha fazla resim olduğunu gösteren görsel bir işaret sağlayabilir. Gönderi bir videodan oluşuyorsa sağlayıcı, resim olarak gösterilecek videonun küçük resmini sağlamalıdır. |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| Metin içeriği | İsteğe bağlı | Yayın, güncelleme vb. öğelerin ana metni. | Dize (önerilen maksimum 140 karakter) |
| Zaman damgası | İsteğe bağlı | Gönderinin yayınlandığı zaman. | Milisaniye cinsinden dönem zaman damgası |
| Video içeriği | İsteğe bağlı | Gönderi video mu? | boole |
| Video süresi | İsteğe bağlı | Videonun milisaniye cinsinden süresi. | Uzun |
| Profille ilgili meta veriler (isteğe bağlı) | |||
| Ad | Zorunlu | Profil adı, kimliği veya kullanıcı adı (ör. "John Doe", "@TeamPixel") | Dize(önerilen maksimum uzunluk 25 karakter) |
| Avatar | Zorunlu |
Kullanıcının profil resmi veya avatar resmi. Kare resim (1:1) |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| Ek Resim | İsteğe bağlı |
Profil rozeti (ör. doğrulama rozeti) Kare resim (1:1) |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| Etkileşimlerle ilgili meta veriler (isteğe bağlı) | |||
| Sayı | İsteğe bağlı |
Etkileşim sayısını belirtin (ör. "3, 7 milyon"). Not: Hem Sayı hem de Sayı Değeri sağlanırsa Sayı kullanılır. Not: İş ortakları Count veya CountWithOptionalLabel'ı kullanmalıdır. |
Dize |
| CountWithOptionalLabel | İsteğe bağlı |
İsteğe bağlı bir etiketle etkileşim sayısını belirtin. Örneğin, "3,7 milyon beğeni". Not: Hem CountWithOptionalLabel hem de Count Value sağlanırsa bunlardan biri kullanılır. Not: İş ortakları Count veya CountWithOptionalLabel'ı kullanmalıdır. |
Dize |
| Sayı Değeri | İsteğe bağlı | Etkileşim sayısı değer olarak gösterilir. Not: Uygulamanız, çok sayıda öğenin farklı ekran boyutları için nasıl optimize edileceğiyle ilgili mantığı ele almıyorsa Count yerine Count Value değerini sağlayın. Hem Sayı hem de Sayı Değeri sağlanırsa Sayı kullanılır. |
Uzun |
| Etiket | İsteğe bağlı | Etkileşim etiketinin ne için olduğunu belirtin. Örneğin, "Beğenmeler". | Dize |
| Görsel | İsteğe bağlı |
Etkileşimin amacını belirtin. Örneğin, beğenme simgesi ve emoji gösteren resim. Tüm form faktörlerinde gösterilmeyebilecek olsa da birden fazla resim sağlayabilir. Not: Kare 1:1 resim olmalıdır. |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| 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ı |
SocialPostEntity
| Özellik | Şartlar | Açıklama | Biçim |
|---|---|---|---|
| İşlem URI'si | Zorunlu |
Sağlayıcı uygulamasındaki öğeye derin bağlantı oluşturun. Not: Derin bağlantıları ilişkilendirme için kullanabilirsiniz. Bu SSS'ye bakın |
URI |
| PlatformSpecificPlayback URIs | Google TV yüzeyi için zorunlu |
Google TV ve mobil gibi platformlar için sağlayıcı uygulamasındaki tüzel kişiye derin bağlantı oluşturun. |
PlatformSpecificPlayback nesnelerinin listesi |
| Öneri Nedeni | İsteğe bağlı | İçeriğin kullanıcıya önerilme gerekçesi. | RecommendationReason nesnesi |
| Yorum Özeti | İsteğe bağlı | Yayına yapılan yorumların özeti. | Dize |
|
Gönderiyle ilgili meta veriler (zorunlu) TextContent, Image veya WebContent'ten en az biri gereklidir. |
|||
| Resimler | İsteğe bağlı |
Resimler dikey en boy oranında olmalıdır. Birden fazla resim sağlandığında kullanıcı arayüzünde yalnızca 1 resim gösterilebilir. Ancak kullanıcı arayüzü, uygulamada daha fazla resim olduğunu gösteren görsel bir işaret sağlayabilir. Gönderi bir videodan oluşuyorsa sağlayıcı, resim olarak gösterilecek videonun küçük resmini sağlamalıdır. |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| Metin içeriği | İsteğe bağlı | Yayın, güncelleme vb. öğelerin ana metni. | Dize (önerilen maksimum 140 karakter) |
| Video İçeriği (İsteğe Bağlı) | |||
| Süre | Zorunlu | Videonun milisaniye cinsinden süresi. | Uzun |
| Resim | Zorunlu | Video içeriğinin önizleme resmi. | Yönergeler için Resim Özellikleri bölümüne bakın. |
| Bağlantı Önizlemesi (İsteğe Bağlı) | |||
| Bağlantı Önizlemesi - Başlık | Zorunlu | Web sayfası içeriğinin başlığını belirten metin | Dize |
| Bağlantı Önizlemesi - Ana Bilgisayar Adı | Zorunlu | Web sayfası sahibini belirten metin (ör. "INSIDER") | Dize |
| Bağlantı Önizlemesi - Resim | İsteğe bağlı | Web içeriği için hero resim | Yönergeler için Resim Özellikleri bölümüne bakın. |
| Zaman damgası | İsteğe bağlı | Gönderinin yayınlandığı zaman. | Milisaniye cinsinden dönem zaman damgası |
| Profille ilgili meta veriler (isteğe bağlı) | |||
| Ad | Zorunlu | Profil adı, kimliği veya kullanıcı adı (ör. "John Doe", "@TeamPixel"). | Dize(önerilen maksimum uzunluk 25 karakter) |
| Ek Metin | İsteğe bağlı |
Profil kimliği, kullanıcı adı veya ek meta veri olarak kullanılabilir. Örneğin "@John-Doe", "5M followers", "You might like", "Trending", "5 new posts" |
Dize(önerilen maksimum 40 karakter) |
| Avatar | Zorunlu |
Kullanıcının profil resmi veya avatar resmi. Kare resim (1:1) |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| Ek Resim | İsteğe bağlı |
Profil rozeti (ör. doğrulandı rozeti) Kare resim (1:1) |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| Etkileşimlerle ilgili meta veriler (isteğe bağlı) | |||
| Sayı | Zorunlu |
Etkileşim sayısını belirtin.Örneğin, "3,7 milyon". Not: İş ortakları Count veya CountWithOptionalLabel'ı kullanmalıdır. |
Dize |
| CountWithOptionalLabel | Zorunlu |
İsteğe bağlı bir etiketle etkileşim sayısını belirtin.Örneğin, "3,7 milyon beğeni". Not: İş ortakları Count veya CountWithOptionalLabel'ı kullanmalıdır. |
Dize |
| Etiket |
İsteğe bağlı Bu değer sağlanmazsa Visual değeri sağlanmalıdır. |
Etkileşimin amacını belirtin. Örneğin, "Beğenmeler". | Dize (sayı ve etiket birleştirilmiş olarak en fazla 20 karakter önerilir) |
| Görsel |
İsteğe bağlı Bu değer sağlanmazsa Label sağlanmalıdır. |
Etkileşimin amacını belirtin. Örneğin, beğenme simgesini ve emojiyi gösteren resim. Tüm form faktörlerinde gösterilmeyebilecek olsa da birden fazla resim sağlayabilir. Kare resim (1:1) |
Yönergeler için Resim Özellikleri bölümüne bakın. |
| 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ı |
Resim özellikleri
Google'ın erişebilmesi için resimlerin herkese açık CDN'lerde barındırılması gerekir.
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 yürütülmesi (ör. WorkManager kullanılarak) ve düzenli olarak veya etkinlik bazında (ör. kullanıcı uygulamayı her açtığında ya da yeni bir hesabı takip ettiğinde) planlanması önerilir.
AppEngageSocialClient, sosyal kümelerin yayınlanmasından sorumludur.
İstemcide kümeleri yayınlamak için aşağıdaki API'ler kullanılır:
isServiceAvailablepublishRecommendationClusterspublishUserAccountManagementRequestupdatePublishStatusdeleteRecommendationsClustersdeleteUserManagementClusterdeleteClusters
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 |
|---|---|---|
| SocialPostEntity veya PortraitMediaEntity 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ığı (örneğin, Arkadaşlarınızdan gelen son içerikler). Ö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("Latest from your friends")
.build())
.build())
Java
client.publishRecommendationClusters(
new PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
new RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Latest from your friends")
.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.
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ın üzerindeki 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 İ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
UserAccountManagementClusterverileri 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 işletme nedeniyle kümelerden hiçbiri yayınlanmıyorsa updatePublishStatus API'sini kullanarak yayın durumunu güncellemenizi şiddetle tavsiye ederiz. Bu önemlidir, çünkü :
- İçerik yayınlanmış olsa bile (STATUS == PUBLISHED) tüm senaryolarda durumu sağlamak, bu açık durumu kullanarak entegrasyonunuzun durumunu ve diğer metriklerini ileten kontrol panellerini doldurmak için 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.
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_RECOMMENDATION)
...
.build())
Java
client.deleteClusters(
new DeleteClustersRequest.Builder()
.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.
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ş üzerinden yapmanın yanı sıra, içerik yayınlama isteğini almak için bir BroadcastReceiver de ayarlamanız gerekir.
Yayın amaçlarının temel hedefi, 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:
BroadcastReceiversınıfının bir örneğiniContext.registerReceiver()kullanarak dinamik olarak kaydedin. Bu, bellekte hâlâ etkin olan uygulamalardan gelen iletişime olanak tanır.
Kotlin
class AppEngageBroadcastReceiver : BroadcastReceiver(){
// Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION
// 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)
}
Java
class AppEngageBroadcastReceiver extends BroadcastReceiver {
// Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION 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);
}
<receiver>etiketiyle bir uygulamayıAndroidManifest.xmldosyanızda statik olarak bildirin. Bu izin, 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>
</receiver>
</application>
Hizmet tarafından aşağıdaki amaçlar gönderilir:
com.google.android.engage.action.PUBLISH_RECOMMENDATIONBu amaç alındığındapublishRecommendationClustersaraması 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 verecektir.
Sonraki adımlar
Bu entegrasyonu tamamladıktan sonraki adımlarınız şunlardır:
engage-developers@google.comadresine 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 kümeleriniz yayınlanır ve kullanıcılar tarafından görülebilir.