अपने उपयोगकर्ताओं तक पहुंचकर, ऐप्लिकेशन में यूज़र ऐक्टिविटी बढ़ाएं. Engage SDK टूल को इंटिग्रेट करें, ताकि लोगों को उनकी दिलचस्पी के मुताबिक सुझाव और 'देखना जारी रखें' कॉन्टेंट सीधे उनके डिवाइस पर अलग-अलग जगहों पर दिखे. इनमें कलेक्शन, टीवी, फ़िल्में वगैरह एक ही जगह पर देखने की सुविधा, और Play Store शामिल हैं. इंटिग्रेशन की वजह से, औसत APK में 50 केबी (कंप्रेस किया गया) से कम का डेटा जुड़ता है. साथ ही, ज़्यादातर ऐप्लिकेशन के लिए डेवलपर को एक हफ़्ते का समय लगता है. ज़्यादा जानने के लिए, हमारी कारोबार की साइट पर जाएं.
इस गाइड में, डेवलपर पार्टनर के लिए निर्देश दिए गए हैं. इनकी मदद से, वे Engage की कॉन्टेंट वाली सतहों पर ऑडियो कॉन्टेंट (संगीत, पॉडकास्ट, ऑडियो बुक, लाइव रेडियो) डिलीवर कर सकते हैं.
इंटिग्रेशन की जानकारी
शब्दावली
इस इंटिग्रेशन में, तीन तरह के क्लस्टर शामिल होते हैं: सुझाव, जारी रखें, और खास तौर पर दिखाए गए.
सुझाव के क्लस्टर, किसी एक डेवलपर पार्टनर के कॉन्टेंट में से आपकी दिलचस्पी के हिसाब से सुझाव दिखाते हैं.
आपको इस तरह के सुझाव दिखते हैं:
सुझाव के क्लस्टर: एक यूज़र इंटरफ़ेस (यूआई) दिखता है. इसमें एक ही डेवलपर पार्टनर के कॉन्टेंट में सुझाव दिखाए जाते हैं.
पहली इमेज. यह टीवी, फ़िल्में वगैरह एक ही जगह पर देखने की सुविधा का यूज़र इंटरफ़ेस है. इसमें किसी एक पार्टनर के कॉन्टेंट में से सुझाव दिखाए जा रहे हैं. इकाई: इसमें एक कॉन्टेंट दिखता है. कोई इकाई, प्लेलिस्ट, ऑडियो बुक, पॉडकास्ट वगैरह हो सकती है. इकाई के काम करने वाले टाइप की सूची देखने के लिए, इकाई का डेटा दें सेक्शन देखें.
दूसरी इमेज. यह टीवी, फ़िल्में वगैरह एक ही जगह पर देखने की सुविधा का यूज़र इंटरफ़ेस (यूआई) है. इसमें किसी एक पार्टनर के सुझाव वाले क्लस्टर में एक इकाई दिख रही है.
जारी रखने वाला क्लस्टर, एक ही यूज़र इंटरफ़ेस (यूआई) ग्रुपिंग में, कई डेवलपर पार्टनर के ऐसे ऑडियो कॉन्टेंट को दिखाता है जिसमें उपयोगकर्ताओं ने हाल ही में दिलचस्पी दिखाई है. हर डेवलपर पार्टनर को, जारी रखने वाले क्लस्टर में ज़्यादा से ज़्यादा 10 इकाइयां ब्रॉडकास्ट करने की अनुमति होगी.
तीसरी इमेज. टीवी, फ़िल्में वगैरह एक ही जगह पर देखने की सुविधा वाले यूज़र इंटरफ़ेस (यूआई), जिसमें एक से ज़्यादा पार्टनर के अधूरे सुझावों के साथ, वीडियो देखने के लिए सुझावों का क्लस्टर दिखाया गया है. फ़िलहाल, इसमें सिर्फ़ एक सुझाव दिख रहा है. चुनिंदा क्लस्टर, एक ही यूज़र इंटरफ़ेस (यूआई) ग्रुपिंग में, कई डेवलपर पार्टनर के आइटम दिखाता है. एक ही चुनिंदा क्लस्टर होगा, जो यूज़र इंटरफ़ेस (यूआई) में सबसे ऊपर दिखेगा. इसे सभी सुझाव वाले क्लस्टर से ऊपर रखा जाएगा. हर डेवलपर पार्टनर को, चुनिंदा क्लस्टर में ज़्यादा से ज़्यादा 10 इकाइयां ब्रॉडकास्ट करने की अनुमति होगी.
चौथी इमेज. टीवी, फ़िल्में वगैरह एक ही जगह पर देखने की सुविधा वाले यूज़र इंटरफ़ेस (यूआई) में कई पार्टनर के सुझावों के साथ, चुनिंदा क्लस्टर दिखाया गया है. फ़िलहाल, सिर्फ़ एक सुझाव दिख रहा है.
सेशन की तैयारी
कम से कम एपीआई लेवल: 19
अपने ऐप्लिकेशन में com.google.android.engage:engage-core
लाइब्रेरी जोड़ें:
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'
}
खास जानकारी
यह डिज़ाइन, बाउंड सर्विस को लागू करने पर आधारित है.
कोई क्लाइंट, अलग-अलग क्लस्टर टाइप के लिए इतना डेटा पब्लिश कर सकता है:
क्लस्टर का टाइप | क्लस्टर की सीमाएं | किसी क्लस्टर में ज़्यादा से ज़्यादा कितनी इकाइयां हो सकती हैं |
---|---|---|
सुझाव वाले क्लस्टर | ज़्यादा से ज़्यादा 7 | ज़्यादा से ज़्यादा 50 |
जारी रखने वाला क्लस्टर | ज़्यादा से ज़्यादा 1 | ज़्यादा से ज़्यादा 20 |
चुनिंदा क्लस्टर | ज़्यादा से ज़्यादा 1 | ज़्यादा से ज़्यादा 20 |
पहला चरण: इकाई का डेटा उपलब्ध कराना
एसडीके ने हर आइटम टाइप को दिखाने के लिए अलग-अलग इकाइयां तय की हैं. हम 'सुनें' कैटगरी के लिए, इन इकाइयों के साथ काम करते हैं:
MusicAlbumEntity
MusicArtistEntity
MusicTrackEntity
MusicVideoEntity
PlaylistEntity
PodcastSeriesEntity
PodcastEpisodeEntity
LiveRadioStationEntity
AudiobookEntity
यहाँ दिए गए चार्ट में, हर टाइप के लिए उपलब्ध एट्रिब्यूट और ज़रूरी शर्तों के बारे में बताया गया है.
MusicAlbumEntity
MusicAlbumEntity
ऑब्जेक्ट, किसी संगीत एल्बम को दिखाता है. उदाहरण के लिए, टेलर स्विफ़्ट का Midnights.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | म्यूज़िक एल्बम का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
जानकारी वाले पेज का यूआरआई | ज़रूरी है |
संगीत एल्बम की जानकारी के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
कलाकार | ज़रूरी है | संगीत एल्बम में शामिल कलाकारों की सूची. |
प्लेबैक यूआरआई | वैकल्पिक |
ऐसा डीप लिंक जो सेवा देने वाली कंपनी के ऐप्लिकेशन में एल्बम को चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
गानों की संख्या | वैकल्पिक | म्यूज़िक एल्बम में गानों की संख्या. |
शैलियां | वैकल्पिक | संगीत एल्बम में मौजूद शैलियों की सूची. |
एल्बम का फ़ॉर्मैट | वैकल्पिक |
एल्बम (इसमें एलपी और डबल एलपी शामिल हैं) ईपी सिंगल मिक्सटेप |
संगीत लेबल | वैकल्पिक | एल्बम से जुड़े संगीत लेबल की सूची. |
डिवाइस पर डाउनलोड किया गया | वैकल्पिक | बूलियन से पता चलता है कि संगीत एल्बम को डिवाइस पर डाउनलोड किया गया है या नहीं. |
अश्लील कॉन्टेंट | वैकल्पिक |
बूलियन वैल्यू, यह बताती है कि कॉन्टेंट अश्लील है या नहीं जिन आइटम में यौन गतिविधि दिखाने वाला कॉन्टेंट शामिल है या जिन पर माता-पिता के लिए चेतावनी दी गई है उन्हें TRUE पर सेट किया जाना चाहिए. अश्लील कॉन्टेंट वाले आइटम, "E" टैग के साथ दिखते हैं. |
रिलीज़ की तारीख | वैकल्पिक | एल्बम के रिलीज़ होने की तारीख, एपक मिलीसेकंड में. |
कुल अवधि | वैकल्पिक | एल्बम की अवधि, मिलीसेकंड में. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
प्रोग्रेस का प्रतिशत | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. 0 से 100 के बीच का पूर्णांक |
MusicArtistEntity
MusicArtistEntity
ऑब्जेक्ट, संगीत कलाकार (उदाहरण के लिए, Adele) को दिखाता है.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | संगीत कलाकार का नाम. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
जानकारी वाले पेज का यूआरआई | ज़रूरी है |
संगीत कलाकार के बारे में जानकारी देने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
प्लेबैक यूआरआई | वैकल्पिक |
यह डीप लिंक, सेवा देने वाली कंपनी के ऐप्लिकेशन में कलाकार के गाने चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
MusicTrackEntity
MusicTrackEntity
ऑब्जेक्ट, किसी म्यूज़िक ट्रैक के बारे में बताता है. उदाहरण के लिए, Coldplay का Yellow.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | संगीत ट्रैक का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
ऐसा डीप लिंक जो सेवा देने वाली कंपनी के ऐप्लिकेशन में संगीत ट्रैक चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
कलाकार | ज़रूरी है | संगीत ट्रैक के लिए कलाकारों की सूची. |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
संगीत ट्रैक की जानकारी के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
कुल अवधि | वैकल्पिक | ट्रैक की अवधि, मिलीसेकंड में. |
एल्बम | वैकल्पिक | उस एल्बम का नाम जिसमें यह गाना शामिल है. |
डिवाइस पर डाउनलोड किया गया | वैकल्पिक | बूलियन से पता चलता है कि डिवाइस पर संगीत ट्रैक डाउनलोड किया गया है या नहीं. |
अश्लील कॉन्टेंट | वैकल्पिक |
बूलियन वैल्यू, यह बताती है कि कॉन्टेंट अश्लील है या नहीं जिन आइटम में यौन गतिविधि दिखाने वाला कॉन्टेंट शामिल है या जिन पर माता-पिता के लिए चेतावनी दी गई है उन्हें TRUE पर सेट किया जाना चाहिए. अश्लील कॉन्टेंट वाले आइटम, "E" टैग के साथ दिखते हैं. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
प्रोग्रेस का प्रतिशत | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. 0 से 100 के बीच का पूर्णांक |
MusicVideoEntity
MusicVideoEntity
ऑब्जेक्ट, किसी संगीत वीडियो को दिखाता है. उदाहरण के लिए,
The Weeknd - Take My Breath (Official Music Video).
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | संगीत वीडियो का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
ऐसा डीप लिंक जो सेवा देने वाली कंपनी के ऐप्लिकेशन में संगीत वीडियो चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
संगीत वीडियो की जानकारी दिखाने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
कुल अवधि | वैकल्पिक | वीडियो की अवधि, मिलीसेकंड में. |
व्यू की संख्या | वैकल्पिक | मुफ़्त टेक्स्ट फ़ॉर्मैट में वीडियो के व्यू की संख्या. |
कलाकार | वैकल्पिक | संगीत वीडियो में शामिल कलाकारों की सूची. |
सामग्री रेटिंग | वैकल्पिक | ट्रैक की कॉन्टेंट रेटिंग की सूची. |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
डिवाइस पर डाउनलोड किया गया | वैकल्पिक | बूलियन यह बताता है कि संगीत वीडियो को डिवाइस पर डाउनलोड किया गया है या नहीं. |
अश्लील कॉन्टेंट | वैकल्पिक |
बूलियन वैल्यू, यह बताती है कि कॉन्टेंट अश्लील है या नहीं जिन आइटम में यौन गतिविधि दिखाने वाला कॉन्टेंट शामिल है या जिन पर माता-पिता के लिए चेतावनी दी गई है उन्हें TRUE पर सेट किया जाना चाहिए. अश्लील कॉन्टेंट वाले आइटम, "E" टैग के साथ दिखते हैं. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
प्रोग्रेस का प्रतिशत | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. 0 से 100 के बीच का पूर्णांक |
PlaylistEntity
PlaylistEntity
ऑब्जेक्ट, संगीत की प्लेलिस्ट को दिखाता है. उदाहरण के लिए, अमेरिका की टॉप 10 प्लेलिस्ट.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | प्लेलिस्ट का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
ऐसा डीप लिंक जो सेवा देने वाली कंपनी के ऐप्लिकेशन में संगीत की प्लेलिस्ट चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
संगीत की प्लेलिस्ट के बारे में जानकारी देने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
कुल अवधि | वैकल्पिक | प्लेलिस्ट की अवधि, मिलीसेकंड में. |
गानों की संख्या | वैकल्पिक | संगीत की प्लेलिस्ट में मौजूद गानों की संख्या. |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
डिवाइस पर डाउनलोड किया गया | वैकल्पिक | बूलियन से पता चलता है कि प्लेलिस्ट को डिवाइस पर डाउनलोड किया गया है या नहीं. |
अश्लील कॉन्टेंट | वैकल्पिक |
बूलियन वैल्यू, यह बताती है कि कॉन्टेंट अश्लील है या नहीं जिन आइटम में यौन गतिविधि दिखाने वाला कॉन्टेंट शामिल है या जिन पर माता-पिता के लिए चेतावनी दी गई है उन्हें TRUE पर सेट किया जाना चाहिए. अश्लील कॉन्टेंट वाले आइटम, "E" टैग के साथ दिखते हैं. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
प्रोग्रेस का प्रतिशत | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. 0 से 100 के बीच का पूर्णांक |
PodcastSeriesEntity
PodcastSeriesEntity
ऑब्जेक्ट, पॉडकास्ट सीरीज़ के बारे में जानकारी देता है. उदाहरण के लिए, This American Life.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | पॉडकास्ट सीरीज़ का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
जानकारी वाले पेज का यूआरआई | ज़रूरी है |
पॉडकास्ट सीरीज़ के बारे में जानकारी देने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
प्लेबैक यूआरआई | वैकल्पिक |
एक डीप लिंक, जो पॉडकास्ट सेवा देने वाली कंपनी के ऐप्लिकेशन में पॉडकास्ट सीरीज़ को चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
एपिसोड की कुल संख्या | वैकल्पिक | पॉडकास्ट सीरीज़ में एपिसोड की संख्या. |
प्रोडक्शन का नाम | वैकल्पिक | पॉडकास्ट सीरीज़ के प्रोडक्शन का नाम. |
होस्ट | वैकल्पिक | पॉडकास्ट सीरीज़ के होस्ट की सूची. |
शैलियां | वैकल्पिक | पॉडकास्ट सीरीज़ की शैलियों की सूची. |
डिवाइस पर डाउनलोड किया गया | वैकल्पिक | बूलियन से पता चलता है कि पॉडकास्ट को डिवाइस पर डाउनलोड किया गया है या नहीं. |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
अश्लील कॉन्टेंट | वैकल्पिक |
बूलियन वैल्यू, यह बताती है कि कॉन्टेंट अश्लील है या नहीं जिन आइटम में यौन गतिविधि दिखाने वाला कॉन्टेंट शामिल है या जिन पर माता-पिता के लिए चेतावनी दी गई है उन्हें TRUE पर सेट किया जाना चाहिए. अश्लील कॉन्टेंट वाले आइटम, "E" टैग के साथ दिखते हैं. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
PodcastEpisodeEntity
PodcastEpisodeEntity
ऑब्जेक्ट, पॉडकास्ट सीरीज़ को दिखाता है. उदाहरण के लिए, स्पार्क बर्ड, एपिसोड 754: दिस अमेरिकन लाइफ़.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | पॉडकास्ट के एपिसोड का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
ऐसा डीप लिंक जो सेवा देने वाली कंपनी के ऐप्लिकेशन में पॉडकास्ट का एपिसोड चलाना शुरू करता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
पॉडकास्ट सीरीज़ का टाइटल | ज़रूरी है | यह टैग, पॉडकास्ट सीरीज़ का नाम बताता है. यह उस सीरीज़ का नाम होता है जिसका यह एपिसोड है. |
कुल अवधि | ज़रूरी है | पॉडकास्ट एपिसोड की अवधि, मिलीसेकंड में. |
पब्लिश करने की तारीख | ज़रूरी है | पॉडकास्ट पब्लिश करने की तारीख (इपॉक मिलीसेकंड में) |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
पॉडकास्ट एपिसोड की जानकारी के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
प्रोडक्शन का नाम | वैकल्पिक | पॉडकास्ट सीरीज़ के प्रोडक्शन का नाम. |
एपिसोड इंडेक्स | वैकल्पिक | सीरीज़ में एपिसोड का इंडेक्स. पहला इंडेक्स 1 होता है. |
होस्ट | वैकल्पिक | पॉडकास्ट के एपिसोड के होस्ट की सूची. |
शैलियां | वैकल्पिक | पॉडकास्ट के एपिसोड की शैलियों की सूची. |
डिवाइस पर डाउनलोड किया गया | वैकल्पिक | बूलियन से पता चलता है कि पॉडकास्ट का एपिसोड डिवाइस पर डाउनलोड किया गया है या नहीं. |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
वीडियो पॉडकास्ट | वैकल्पिक | बूलियन से पता चलता है कि पॉडकास्ट के एपिसोड में वीडियो कॉन्टेंट है या नहीं |
अश्लील कॉन्टेंट | वैकल्पिक |
बूलियन वैल्यू, यह बताती है कि कॉन्टेंट अश्लील है या नहीं जिन आइटम में यौन गतिविधि दिखाने वाला कॉन्टेंट शामिल है या जिन पर माता-पिता के लिए चेतावनी दी गई है उन्हें TRUE पर सेट किया जाना चाहिए. अश्लील कॉन्टेंट वाले आइटम, "E" टैग के साथ दिखते हैं. |
'अगला सुनें' टाइप करें | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए सुझाया गया एट्रिब्यूट TYPE_CONTINUE - अधूरे ऑडियो आइटम को फिर से शुरू करें. TYPE_NEXT - किसी सीरीज़ के नए एपिसोड पर जारी रखें. TYPE_NEW - हाल ही में रिलीज़ किया गया. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
प्रोग्रेस का प्रतिशत | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. 0 से 100 के बीच का पूर्णांक |
LiveRadioStationEntity
LiveRadioStationEntity
ऑब्जेक्ट, लाइव रेडियो स्टेशन को दिखाता है. उदाहरण के लिए, 98.1 The Breeze.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | लाइव रेडियो स्टेशन का टाइटल. |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
ऐसा डीप लिंक जो सेवा देने वाली कंपनी के ऐप्लिकेशन में रेडियो स्टेशन चलाना शुरू कर देता है. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
रेडियो स्टेशन के बारे में जानकारी देने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
फ़्रीक्वेंसी | वैकल्पिक | रेडियो स्टेशन की ब्रॉडकास्ट फ़्रीक्वेंसी. उदाहरण के लिए, "98.1 FM". |
शीर्षक दिखाएं | वैकल्पिक | रेडियो स्टेशन पर फ़िलहाल चल रहा शो. |
होस्ट | वैकल्पिक | रेडियो स्टेशन के होस्ट की सूची. |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
पिछली बार कब संपर्क हुआ | वैकल्पिक |
जारी रखने वाले क्लस्टर में मौजूद आइटम के लिए इसका सुझाव दिया जाता है. इसका इस्तेमाल रैंकिंग के लिए किया जा सकता है. एपिक मिलीसेकंड में |
AudiobookEntity
AudiobookEntity
ऑब्जेक्ट, ऑडियो बुक को दिखाता है. उदाहरण के लिए, मिशेल ओबामा की ऑडियो बुक Becoming.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज देनी होगी. दिशा-निर्देशों के लिए, इमेज की खास बातें देखें. |
लेखक | ज़रूरी है | कम से कम एक लेखक का नाम देना ज़रूरी है. |
कार्रवाई करने के लिंक का यूआरआई | ज़रूरी है |
ऑडियो बुक के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल का जवाब देखें |
Narrator | वैकल्पिक | कम से कम एक नेरेटर का नाम देना ज़रूरी है. |
पब्लिश होने की तारीख | वैकल्पिक | अगर दिया गया है, तो एपक मिलीसेकंड में. |
ब्यौरा | वैकल्पिक | अगर जानकारी दी गई है, तो इसमें 200 से ज़्यादा वर्ण नहीं होने चाहिए. |
कीमत | वैकल्पिक | फ़्री टेक्स्ट |
कुल अवधि | वैकल्पिक | अगर यह वैल्यू दी गई है, तो यह पॉज़िटिव होनी चाहिए. |
शैली | वैकल्पिक | किताब से जुड़ी शैलियों की सूची. |
सीरीज़ का नाम | वैकल्पिक | ऑडियो बुक जिस सीरीज़ का हिस्सा है उसका नाम. उदाहरण के लिए, हैरी पॉटर. |
सीरीज़ यूनिट इंडेक्स | वैकल्पिक | सीरीज़ में ऑडियो बुक का इंडेक्स. इसमें 1 का मतलब है कि यह सीरीज़ की पहली ऑडियो बुक है. उदाहरण के लिए, अगर हैरी पॉटर ऐंड द प्रिज़नर ऑफ़ अज़्काबान सीरीज़ की तीसरी किताब है, तो इसे 3 पर सेट किया जाना चाहिए. |
Continue book type | वैकल्पिक |
TYPE_CONTINUE - अधूरी किताब को फिर से शुरू करना. TYPE_NEXT - किसी सीरीज़ के नए एपिसोड पर जारी रखें. TYPE_NEW - हाल ही में रिलीज़ किया गया. |
लास्ट इंटरैक्शन टाइम | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम 'जारी रखने वाले क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपक मिलीसेकंड में. |
प्रोग्रेस का प्रतिशत | कुछ शर्तों के मुताबिक ज़रूरी है |
अगर आइटम 'जारी रखने वाले क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. हाल ही में खरीदी गई ऑडियो बुक, 'पढ़ना जारी रखें' क्लस्टर में शामिल हो सकती हैं. वैल्यू 0 से ज़्यादा और 100 से कम होनी चाहिए. |
DisplayTimeWindow - Set a time window for a content to be shown on the surface | ||
शुरू होने का टाइमस्टैंप | वैकल्पिक |
यह ईपॉक टाइमस्टैंप है. इसके बाद, कॉन्टेंट को प्लैटफ़ॉर्म पर दिखाया जाना चाहिए. इस नीति को सेट न करने पर, कॉन्टेंट को प्लैटफ़ॉर्म पर दिखाया जा सकता है. एपक मिलीसेकंड में. |
खत्म होने का टाइमस्टैंप | वैकल्पिक |
यह ऐसा इपॉक टाइमस्टैंप होता है जिसके बाद, कॉन्टेंट को प्लैटफ़ॉर्म पर नहीं दिखाया जाता. इस नीति को सेट न करने पर, कॉन्टेंट को प्लैटफ़ॉर्म पर दिखाया जा सकता है. एपक मिलीसेकंड में. |
इमेज की जानकारी
इमेज ऐसेट के लिए ज़रूरी शर्तें यहां दी गई हैं:
आसपेक्ट रेशियो | ज़रूरी शर्त | कम से कम पिक्सल | सुझाए गए पिक्सल |
---|---|---|---|
स्क्वेयर (1x1) | ज़रूरी है | 300x300 | 1200x1200 |
लैंडस्केप (1.91x1) | वैकल्पिक | 600x314 | 1200x628 |
पोर्ट्रेट (4x5) | वैकल्पिक | 480x600 | 960x1200 |
फ़ाइल फ़ॉर्मैट
PNG, JPG, स्टैटिक GIF, WebP
फ़ाइल का ज़्यादा से ज़्यादा साइज़
5120 केबी
अन्य सुझाव
- इमेज के लिए सुझाया गया सेफ़ एरिया: अपने मुख्य कॉन्टेंट को इमेज के बीच वाले 80% हिस्से में रखें.
उदाहरण
MusicAlbumEntity musicAlbumEntity =
new MusicAlbumEntity.Builder()
.setName(NAME)
.addPosterImage(new Image.Builder()
.setImageUri(Uri.parse("http://www.x.com/image.png"))
.setImageHeightInPixel(960)
.setImageWidthInPixel(408)
.build())
.setPlayBackUri("https://play.google/album/play")
.setInfoPageUri("https://play.google/album/info")
.setDescription("A description of this album.")
.addArtist("Artist")
.addGenre("Genre")
.addMusicLabel("Label")
.addContentRating("Rating")
.setSongsCount(960)
.setReleaseDateEpochMillis(1633032895L)
.setDurationMillis(1633L)
.build();
AudiobookEntity audiobookEntity =
new AudiobookEntity.Builder()
.setName("Becoming")
.addPosterImage(new Image.Builder()
.setImageUri(Uri.parse("http://www.x.com/image.png"))
.setImageHeightInPixel(960)
.setImageWidthInPixel(408)
.build())
.addAuthor("Michelle Obama")
.addNarrator("Michelle Obama")
.setActionLinkUri(
Uri.parse("https://play.google/audiobooks/1"))
.setDurationMillis(16335L)
.setPublishDateEpochMillis(1633032895L)
.setDescription("An intimate, powerful, and inspiring memoir")
.setPrice("$16.95")
.addGenre("biography")
.build();
दूसरा चरण: क्लस्टर का डेटा देना
हमारा सुझाव है कि कॉन्टेंट पब्लिश करने के टास्क को बैकग्राउंड में पूरा किया जाए. उदाहरण के लिए, WorkManager का इस्तेमाल करके. साथ ही, इसे नियमित तौर पर या किसी इवेंट के आधार पर शेड्यूल किया जाए. उदाहरण के लिए, हर बार जब उपयोगकर्ता ऐप्लिकेशन खोलता है या जब वह कार्ट में कुछ जोड़ता है.
AppEngagePublishClient
, क्लस्टर पब्लिश करने के लिए ज़िम्मेदार है. क्लाइंट में ये एपीआई उपलब्ध हैं:
isServiceAvailable
publishRecommendationClusters
publishFeaturedCluster
publishContinuationCluster
publishUserAccountManagementRequest
updatePublishStatus
deleteRecommendationsClusters
deleteFeaturedCluster
deleteContinuationCluster
deleteUserManagementCluster
deleteClusters
isServiceAvailable
इस एपीआई का इस्तेमाल यह देखने के लिए किया जाता है कि सेवा, इंटिग्रेशन के लिए उपलब्ध है या नहीं. साथ ही, यह भी देखा जाता है कि कॉन्टेंट को डिवाइस पर दिखाया जा सकता है या नहीं.
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
इस एपीआई का इस्तेमाल, RecommendationCluster
ऑब्जेक्ट की सूची पब्लिश करने के लिए किया जाता है.
Kotlin
client.publishRecommendationClusters(
PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Trending music")
.build())
.build())
Java
client.publishRecommendationClusters(
new PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
new RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Trending music")
.build())
.build());
जब सेवा को अनुरोध मिलता है, तो एक लेन-देन में ये कार्रवाइयां होती हैं:
- डेवलपर पार्टनर से मिला मौजूदा
RecommendationCluster
डेटा हटा दिया जाता है. - अनुरोध से मिले डेटा को पार्स करके, अपडेट किए गए 'सुझाव देने वाले क्लस्टर' में सेव किया जाता है.
गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
publishFeaturedCluster
इस एपीआई का इस्तेमाल, FeaturedCluster
ऑब्जेक्ट की सूची पब्लिश करने के लिए किया जाता है.
Kotlin
client.publishFeaturedCluster(
PublishFeaturedClusterRequest.Builder()
.setFeaturedCluster(
FeaturedCluster.Builder()
...
.build())
.build())
Java
client.publishFeaturedCluster(
new PublishFeaturedClusterRequest.Builder()
.setFeaturedCluster(
new FeaturedCluster.Builder()
...
.build())
.build());
जब सेवा को अनुरोध मिलता है, तो एक लेन-देन में ये कार्रवाइयां होती हैं:
- डेवलपर पार्टनर से मिला मौजूदा
FeaturedCluster
डेटा हटा दिया जाता है. - अनुरोध से मिले डेटा को पार्स करके, अपडेट किए गए 'चुनिंदा क्लस्टर' में सेव किया जाता है.
गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
publishContinuationCluster
इस एपीआई का इस्तेमाल, ContinuationCluster
ऑब्जेक्ट को पब्लिश करने के लिए किया जाता है.
Kotlin
client.publishContinuationCluster(
PublishContinuationClusterRequest.Builder()
.setContinuationCluster(
ContinuationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.build())
.build())
Java
client.publishContinuationCluster(
PublishContinuationClusterRequest.Builder()
.setContinuationCluster(
ContinuationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.build())
.build())
जब सेवा को अनुरोध मिलता है, तो एक लेन-देन में ये कार्रवाइयां होती हैं:
- डेवलपर पार्टनर से मिला मौजूदा
ContinuationCluster
डेटा हटा दिया जाता है. - अनुरोध से मिले डेटा को पार्स करके, अपडेट किए गए 'जारी रखने वाले क्लस्टर' में सेव किया जाता है.
गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
publishUserAccountManagementRequest
इस एपीआई का इस्तेमाल, साइन इन कार्ड पब्लिश करने के लिए किया जाता है . साइन इन करने की सुविधा से, लोगों को ऐप्लिकेशन के साइन इन पेज पर रीडायरेक्ट किया जाता है, ताकि ऐप्लिकेशन कॉन्टेंट पब्लिश कर सके या लोगों को उनकी पसंद के हिसाब से ज़्यादा कॉन्टेंट उपलब्ध करा सके
यहां दिया गया मेटाडेटा, साइन इन कार्ड का हिस्सा है -
एट्रिब्यूट | ज़रूरी शर्त | ब्यौरा |
---|---|---|
कार्रवाई का यूआरआई | ज़रूरी है | कार्रवाई का डीपलिंक (यानी कि ऐप्लिकेशन के साइन इन पेज पर ले जाता है) |
इमेज | ज़रूरी नहीं - अगर यह वैल्यू नहीं दी जाती है, तो टाइटल की वैल्यू देना ज़रूरी है |
कार्ड पर दिखाई गई इमेज 16x9 आसपेक्ट रेशियो (चौड़ाई-ऊंचाई का अनुपात) वाली इमेज, जिनका रिज़ॉल्यूशन 1264x712 हो |
शीर्षक | ज़रूरी नहीं - अगर यह जानकारी नहीं दी जाती है, तो इमेज देना ज़रूरी है | कार्ड पर मौजूद टाइटल |
कार्रवाई का टेक्स्ट | वैकल्पिक | सीटीए पर दिखने वाला टेक्स्ट (जैसे, साइन इन करें) |
सबटाइटल | वैकल्पिक | कार्ड पर मौजूद वैकल्पिक सबटाइटल |
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());
जब सेवा को अनुरोध मिलता है, तो एक लेन-देन में ये कार्रवाइयां होती हैं:
- डेवलपर पार्टनर से मिला मौजूदा
UserAccountManagementCluster
डेटा हटा दिया जाता है. - अनुरोध से मिले डेटा को पार्स करके, अपडेट किए गए UserAccountManagementCluster क्लस्टर में सेव किया जाता है.
गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
updatePublishStatus
अगर कारोबार से जुड़ी किसी वजह से, कोई भी क्लस्टर पब्लिश नहीं किया जाता है, तो हमारा सुझाव है कि updatePublishStatus एपीआई का इस्तेमाल करके, पब्लिश करने की स्थिति को अपडेट करें. यह इसलिए ज़रूरी है, क्योंकि :
- सभी स्थितियों में स्टेटस की जानकारी देना ज़रूरी है. भले ही, कॉन्टेंट पब्लिश हो गया हो (STATUS == PUBLISHED). ऐसा इसलिए, ताकि उन डैशबोर्ड में जानकारी भरी जा सके जो इस स्टेटस का इस्तेमाल करके, आपके इंटिग्रेशन की परफ़ॉर्मेंस और अन्य मेट्रिक की जानकारी देते हैं.
- अगर कोई कॉन्टेंट पब्लिश नहीं किया गया है, लेकिन इंटिग्रेशन का स्टेटस ठीक है (STATUS == NOT_PUBLISHED), तो Google, ऐप्लिकेशन के परफ़ॉर्मेंस डैशबोर्ड में सूचनाएं ट्रिगर करने से बच सकता है. इससे पुष्टि होती है कि कॉन्टेंट को पब्लिश नहीं किया गया है, क्योंकि सेवा देने वाली कंपनी के हिसाब से अनुमानित स्थिति है.
- इससे डेवलपर को यह जानकारी मिलती है कि डेटा कब पब्लिश किया गया है और कब नहीं.
- Google, स्टेटस कोड का इस्तेमाल करके उपयोगकर्ता को ऐप्लिकेशन में कुछ कार्रवाइयां करने के लिए सूचना दे सकता है. इससे उपयोगकर्ता को ऐप्लिकेशन का कॉन्टेंट दिखेगा या वह समस्या को हल कर पाएगा.
पब्लिश करने की मंज़ूरी वाले स्टेटस कोड की सूची यहां दी गई है :
// 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
अगर किसी उपयोगकर्ता के लॉग इन न करने की वजह से कॉन्टेंट पब्लिश नहीं किया जाता है, तो Google, साइन इन कार्ड पब्लिश करने का सुझाव देगा. अगर किसी वजह से, सेवा देने वाली कंपनियां 'साइन इन करें' कार्ड पब्लिश नहीं कर पा रही हैं, तो हमारा सुझाव है कि वे updatePublishStatus API को कॉल करें. इसके लिए, स्टेटस कोड NOT_PUBLISHED_REQUIRES_SIGN_IN का इस्तेमाल करें
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
इस एपीआई का इस्तेमाल, सुझाव वाले क्लस्टर का कॉन्टेंट मिटाने के लिए किया जाता है.
Kotlin
client.deleteRecommendationClusters()
Java
client.deleteRecommendationClusters();
अनुरोध मिलने पर, सेवा मौजूदा डेटा को सुझाव क्लस्टर से हटा देती है. गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
deleteFeaturedCluster
इस एपीआई का इस्तेमाल, 'खास तौर पर दिखाए गए क्लस्टर' का कॉन्टेंट मिटाने के लिए किया जाता है.
Kotlin
client.deleteFeaturedCluster()
Java
client.deleteFeaturedCluster();
अनुरोध मिलने पर, सेवा मौजूदा डेटा को चुनिंदा क्लस्टर से हटा देती है. गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
deleteContinuationCluster
इस एपीआई का इस्तेमाल, 'जारी रखने वाले क्लस्टर' का कॉन्टेंट मिटाने के लिए किया जाता है.
Kotlin
client.deleteContinuationCluster()
Java
client.deleteContinuationCluster();
अनुरोध मिलने पर, सेवा मौजूदा डेटा को Continuation Cluster से हटा देती है. गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
deleteUserManagementCluster
इस एपीआई का इस्तेमाल, UserAccountManagement क्लस्टर का कॉन्टेंट मिटाने के लिए किया जाता है.
Kotlin
client.deleteUserManagementCluster()
Java
client.deleteUserManagementCluster();
जब सेवा को अनुरोध मिलता है, तो वह UserAccountManagement क्लस्टर से मौजूदा डेटा हटा देती है. गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति बनी रहती है.
deleteClusters
इस एपीआई का इस्तेमाल, किसी क्लस्टर टाइप का कॉन्टेंट मिटाने के लिए किया जाता है.
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());
अनुरोध मिलने पर, सेवा उन सभी क्लस्टर से मौजूदा डेटा हटा देती है जो बताए गए क्लस्टर टाइप से मेल खाते हैं. क्लाइंट, एक या एक से ज़्यादा क्लस्टर टाइप पास कर सकते हैं. गड़बड़ी होने पर, पूरे अनुरोध को अस्वीकार कर दिया जाता है और मौजूदा स्थिति को बनाए रखा जाता है.
गड़बड़ी ठीक करना
हमारा सुझाव है कि पब्लिश करने वाले एपीआई से टास्क के नतीजे सुनें, ताकि टास्क को वापस लाने और फिर से सबमिट करने के लिए फ़ॉलो-अप कार्रवाई की जा सके.
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
}
}
}
});
गड़बड़ी को AppEngageException
के तौर पर दिखाया जाता है. साथ ही, गड़बड़ी की वजह को गड़बड़ी कोड के तौर पर दिखाया जाता है.
गड़बड़ी कोड | गड़बड़ी का नाम | नोट |
---|---|---|
1 |
SERVICE_NOT_FOUND |
यह सेवा, दिए गए डिवाइस पर उपलब्ध नहीं है. |
2 |
SERVICE_NOT_AVAILABLE |
यह सेवा दिए गए डिवाइस पर उपलब्ध है. हालांकि, कॉल के समय यह उपलब्ध नहीं है. उदाहरण के लिए, इसे साफ़ तौर पर बंद कर दिया गया है. |
3 |
SERVICE_CALL_EXECUTION_FAILURE |
थ्रेडिंग से जुड़ी समस्याओं की वजह से, टास्क पूरा नहीं हो सका. इस मामले में, इसे फिर से आज़माया जा सकता है. |
4 |
SERVICE_CALL_PERMISSION_DENIED |
कॉलर को सेवा से जुड़ा कॉल करने की अनुमति नहीं है. |
5 |
SERVICE_CALL_INVALID_ARGUMENT |
अनुरोध में अमान्य डेटा शामिल है. उदाहरण के लिए, क्लस्टर की तय सीमा से ज़्यादा संख्या. |
6 |
SERVICE_CALL_INTERNAL |
सेवा से जुड़ी कोई गड़बड़ी हुई है. |
7 |
SERVICE_CALL_RESOURCE_EXHAUSTED |
सेवा के लिए कॉल बहुत बार किया गया है. |
तीसरा चरण: ब्रॉडकास्ट इंटेंट मैनेज करना
कॉन्टेंट पब्लिश करने के लिए, नौकरी के ज़रिए एपीआई कॉल करने के अलावा, कॉन्टेंट पब्लिश करने का अनुरोध पाने के लिए, BroadcastReceiver
सेट अप करना भी ज़रूरी है.
ब्रॉडकास्ट इंटेंट का मुख्य मकसद, ऐप्लिकेशन को फिर से चालू करना और डेटा को सिंक करना है. ब्रॉडकास्ट इंटेंट को बार-बार भेजने के लिए डिज़ाइन नहीं किया गया है. यह सिर्फ़ तब ट्रिगर होता है, जब Engage Service को लगता है कि कॉन्टेंट पुराना हो सकता है. उदाहरण के लिए, एक हफ़्ते पुराना कॉन्टेंट. इससे, उपयोगकर्ता को यह भरोसा होता है कि उसे नया कॉन्टेंट मिलेगा. भले ही, ऐप्लिकेशन को लंबे समय से इस्तेमाल न किया गया हो.
BroadcastReceiver
को इन दो तरीकों से सेट अप किया जाना चाहिए:
Context.registerReceiver()
का इस्तेमाल करके,BroadcastReceiver
क्लास के इंस्टेंस को डाइनैमिक तौर पर रजिस्टर करें. इससे उन ऐप्लिकेशन से कम्यूनिकेशन किया जा सकता है जो अब भी मेमोरी में लाइव हैं.
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 continuation cluster publish when PUBLISH_CONTINUATION 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 Continuation Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(Intents.ACTION_PUBLISH_CONTINUATION),
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 continuation cluster publish when PUBLISH_CONTINUATION 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 Continuation Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_CONTINUATION),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
}
अपनी
AndroidManifest.xml
फ़ाइल में<receiver>
टैग का इस्तेमाल करके, स्टैटिक तौर पर लागू करने का एलान करें. इससे ऐप्लिकेशन को ब्रॉडकास्ट इंटेंट मिलते हैं, भले ही वह चल न रहा हो. साथ ही, इससे ऐप्लिकेशन को कॉन्टेंट पब्लिश करने की अनुमति भी मिलती है.
<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.PUBLISH_CONTINUATION" />
</intent-filter>
</receiver>
</application>
सेवा, ये इंटेंट भेजेगी:
com.google.android.engage.action.PUBLISH_RECOMMENDATION
इस इंटेंट को पाने पर,publishRecommendationClusters
कॉल शुरू करने का सुझाव दिया जाता है.com.google.android.engage.action.PUBLISH_FEATURED
इस इंटेंट को पाने पर,publishFeaturedCluster
कॉल शुरू करने का सुझाव दिया जाता है.com.google.android.engage.action.PUBLISH_CONTINUATION
इस इंटेंट को पाने पर,publishContinuationCluster
कॉल शुरू करने का सुझाव दिया जाता है.
इंटिग्रेशन वर्कफ़्लो
इंटिग्रेशन पूरा होने के बाद, उसकी पुष्टि करने के बारे में सिलसिलेवार जानकारी के लिए, Engage डेवलपर इंटिग्रेशन वर्कफ़्लो देखें.
अक्सर पूछे जाने वाले सवाल
अक्सर पूछे जाने वाले सवालों के लिए, Engage SDK के बारे में अक्सर पूछे जाने वाले सवाल देखें.
संपर्क
अगर इंटिग्रेशन की प्रोसेस के दौरान आपका कोई सवाल है, तो engage-developers@google.com
से संपर्क करें. हमारी टीम जल्द से जल्द जवाब देगी.
अगले चरण
इस इंटिग्रेशन को पूरा करने के बाद, आपको ये काम करने होंगे:
engage-developers@google.com
को एक ईमेल भेजें. साथ ही, इंटिग्रेट किया गया वह APK अटैच करें जिसे Google को टेस्ट करना है.- Google, पुष्टि करने और समीक्षा करने की प्रोसेस को अंदरूनी तौर पर पूरा करेगा. इससे यह पक्का किया जा सकेगा कि इंटिग्रेशन उम्मीद के मुताबिक काम कर रहा है. अगर बदलाव करने की ज़रूरत होगी, तो Google आपसे संपर्क करेगा और ज़रूरी जानकारी देगा.
- जब टेस्टिंग पूरी हो जाएगी और कोई बदलाव करने की ज़रूरत नहीं होगी, तब Google आपसे संपर्क करेगा. इसमें आपको बताया जाएगा कि अब Play Store पर अपडेट किया गया और इंटिग्रेट किया गया APK पब्लिश किया जा सकता है.
- Google से यह पुष्टि होने के बाद कि आपका अपडेट किया गया APK, Play Store पर पब्लिश कर दिया गया है, आपके सुझाव, चुनिंदा, और जारी रखें क्लस्टर पब्लिश कर दिए जाएंगे. साथ ही, ये उपयोगकर्ताओं को दिखने लगेंगे.