Google, डिवाइस पर एक ऐसा प्लैटफ़ॉर्म बना रहा है जो उपयोगकर्ताओं के ऐप्लिकेशन को वर्टिकल के हिसाब से व्यवस्थित करता है. साथ ही, ऐप्लिकेशन के कॉन्टेंट को उपयोगकर्ताओं के हिसाब से इस्तेमाल करने और खोजने के लिए, एक नया अनुभव देता है. फ़ुलस्क्रीन में दिखने वाले इस अनुभव की मदद से, डेवलपर पार्टनर को अपने ऐप्लिकेशन के बाहर, एक खास चैनल पर अपना बेहतरीन कॉन्टेंट दिखाने का मौका मिलता है.
इस गाइड में, डेवलपर पार्टनर के लिए निर्देश दिए गए हैं. इन निर्देशों की मदद से, वे Engage SDK टूल का इस्तेमाल करके अपने वीडियो कॉन्टेंट को इंटिग्रेट कर सकते हैं. इससे, इस नए प्लैटफ़ॉर्म और Google के मौजूदा प्लैटफ़ॉर्म, दोनों पर वीडियो दिखाए जा सकेंगे.
इंटिग्रेशन की जानकारी
शब्दावली
इस इंटिग्रेशन में तीन तरह के क्लस्टर शामिल हैं: सुझाव, जारी रखना, और चुनिंदा.
सुझाव क्लस्टर, किसी डेवलपर पार्टनर के कॉन्टेंट के लिए, आपके हिसाब से सुझाव दिखाते हैं.
आपके सुझावों का स्ट्रक्चर इस तरह का होता है:
सुझाव क्लस्टर: एक यूज़र इंटरफ़ेस (यूआई) व्यू, जिसमें एक ही डेवलपर पार्टनर के सुझावों का ग्रुप होता है.
पहली इमेज. Entertainment Space का यूज़र इंटरफ़ेस, जिसमें किसी एक पार्टनर से मिले सुझावों का क्लस्टर दिखाया गया है. इकाई: क्लस्टर में किसी एक आइटम को दिखाने वाला ऑब्जेक्ट. इकाई, एक फ़िल्म, टीवी शो, टीवी सीरीज़, लाइव वीडियो वगैरह हो सकती है. इकाई के काम करने वाले टाइप की सूची देखने के लिए, इकाई का डेटा दें सेक्शन देखें.
दूसरी इमेज. Entertainment Space का यूज़र इंटरफ़ेस (यूआई), जिसमें किसी एक पार्टनर के सुझाव वाले क्लस्टर में एक इकाई दिख रही है.
जारी रखें क्लस्टर, एक यूज़र इंटरफ़ेस (यूआई) ग्रुपिंग में कई डेवलपर पार्टनर के अधूरे वीडियो और हाल ही में रिलीज़ किए गए काम के एपिसोड दिखाता है. हर डेवलपर पार्टनर को, जारी रखने वाले क्लस्टर में ज़्यादा से ज़्यादा 10 इकाइयां ब्रॉडकास्ट करने की अनुमति होगी. रिसर्च से पता चला है कि उपयोगकर्ताओं के हिसाब से कॉन्टेंट के साथ-साथ, उनके हिसाब से सुझाव दिखाने से, उपयोगकर्ताओं के जुड़ाव में बढ़ोतरी होती है.
तीसरी इमेज. Entertainment Space का यूज़र इंटरफ़ेस (यूआई), जिसमें एक से ज़्यादा पार्टनर के अधूरे सुझावों के साथ, वीडियो देखने के लिए सुझावों का क्लस्टर दिखाया गया है. फ़िलहाल, इसमें सिर्फ़ एक सुझाव दिख रहा है. चुनिंदा क्लस्टर में, एक यूज़र इंटरफ़ेस ग्रुपिंग में कई डेवलपर पार्टनर की चुनिंदा इकाइयां दिखती हैं. इसमें एक हाइलाइट किया गया क्लस्टर होगा. यह यूज़र इंटरफ़ेस (यूआई) के सबसे ऊपर दिखेगा. साथ ही, सुझाव वाले सभी क्लस्टर के ऊपर प्राथमिकता के तौर पर दिखेगा. हर डेवलपर पार्टनर को, 'चुनिंदा क्लस्टर' में ज़्यादा से ज़्यादा 10 इकाइयों को ब्रॉडकास्ट करने की अनुमति होगी.
चौथी इमेज. Entertainment Space का यूज़र इंटरफ़ेस (यूआई), जिसमें कई पार्टनर के सुझावों के साथ, चुनिंदा क्लस्टर दिखाया गया है. फ़िलहाल, सिर्फ़ एक सुझाव दिख रहा है.
सेशन की तैयारी
कम से कम एपीआई लेवल: 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'
}
ज़्यादा जानकारी के लिए, Android 11 में पैकेज की जानकारी दिखने की सुविधा देखें.
खास जानकारी
यह डिज़ाइन, बाउंड सेवा को लागू करने पर आधारित है.
क्लाइंट, अलग-अलग क्लस्टर टाइप के लिए, यहां दी गई सीमाओं के हिसाब से डेटा पब्लिश कर सकता है:
क्लस्टर का टाइप | क्लस्टर की सीमाएं | किसी क्लस्टर में इकाइयों की ज़्यादा से ज़्यादा संख्या |
---|---|---|
सुझाव क्लस्टर | ज़्यादा से ज़्यादा सात | ज़्यादा से ज़्यादा 50 |
कंटिन्यूऐशन क्लस्टर | ज़्यादा से ज़्यादा एक | ज़्यादा से ज़्यादा 20 |
चुनिंदा क्लस्टर | ज़्यादा से ज़्यादा एक | ज़्यादा से ज़्यादा 20 |
पहला चरण: Media Home SDK टूल के मौजूदा इंटिग्रेशन से माइग्रेट करना
मौजूदा इंटिग्रेशन से डेटा मॉडल मैप करना
अगर किसी मौजूदा Media Home इंटिग्रेशन से माइग्रेट किया जा रहा है, तो यहां दी गई टेबल में मौजूदा SDK टूल में मौजूद डेटा मॉडल को नए Engage SDK टूल में मैप करने का तरीका बताया गया है:
MediaHomeVideoContract इंटिग्रेशन के बराबर | Engage SDK टूल के इंटिग्रेशन के बराबर |
---|---|
com.google.android.mediahome.video.PreviewChannel
|
com.google.android.engage.common.datamodel.RecommendationCluster
|
com.google.android.mediahome.video.PreviewChannel.Builder
|
com.google.android.engage.common.datamodel.RecommendationCluster.Builder
|
com.google.android.mediahome.video.PreviewChannelHelper
|
com.google.android.engage.video.service.AppEngageVideoClient
|
com.google.android.mediahome.video.PreviewProgram |
अलग-अलग क्लास में बांटा गया: EventVideo ,
LiveStreamingVideo , Movie ,
TvEpisode , TvSeason , TvShow ,
VideoClipEntity
|
com.google.android.mediahome.video.PreviewProgram.Builder
|
अलग-अलग क्लास में बंटे बिल्डर: EventVideo ,
LiveStreamingVideo , Movie ,
TvEpisode , TvSeason , TvShow ,
VideoClipEntity
|
com.google.android.mediahome.video.VideoContract |
अब ज़रूरी नहीं है. |
com.google.android.mediahome.video.WatchNextProgram |
अलग-अलग क्लास में एट्रिब्यूट में बांटा गया:
EventVideoEntity , LiveStreamingVideoEntity ,
MovieEntity , TvEpisodeEntity ,
TvSeasonEntity , TvShowEntity ,
VideoClipEntity |
com.google.android.mediahome.video.WatchNextProgram.Builder
|
अलग-अलग क्लास में एट्रिब्यूट में बांटा गया:
EventVideoEntity , LiveStreamingVideoEntity ,
MovieEntity , TvEpisodeEntity ,
TvSeasonEntity , TvShowEntity ,
VideoClipEntity |
Media Home SDK बनाम Engage SDK में पब्लिशिंग क्लस्टर
Media Home SDK की मदद से, क्लस्टर और इकाइयों को अलग-अलग एपीआई के ज़रिए पब्लिश किया जाता था:
// 1. Fetch existing channels
List<PreviewChannel> channels = PreviewChannelHelper.getAllChannels();
// 2. If there are no channels, publish new channels
long channelId = PreviewChannelHelper.publishChannel(builder.build());
// 3. If there are existing channels, decide whether to update channel contents
PreviewChannelHelper.updatePreviewChannel(channelId, builder.build());
// 4. Delete all programs in the channel
PreviewChannelHelper.deleteAllPreviewProgramsByChannelId(channelId);
// 5. publish new programs in the channel
PreviewChannelHelper.publishPreviewProgram(builder.build());
Engage SDK टूल की मदद से, क्लस्टर और इकाई पब्लिश करने की प्रोसेस को एक ही एपीआई कॉल में जोड़ा जाता है. किसी क्लस्टर से जुड़ी सभी इकाइयां, उस क्लस्टर के साथ पब्लिश की जाती हैं:
Kotlin
RecommendationCluster.Builder() .addEntity(MOVIE_ENTITY) .addEntity(MOVIE_ENTITY) .addEntity(MOVIE_ENTITY) .setTitle("Top Picks For You") .build()
Java
new RecommendationCluster.Builder() .addEntity(MOVIE_ENTITY) .addEntity(MOVIE_ENTITY) .addEntity(MOVIE_ENTITY) .setTitle("Top Picks For You") .build();
पहला चरण: इकाई का डेटा देना
SDK ने हर तरह के आइटम को दिखाने के लिए अलग-अलग इकाइयां तय की हैं. 'वॉच' कैटगरी के लिए, ये इकाइयां इस्तेमाल की जा सकती हैं:
नीचे दिए गए चार्ट में, हर टाइप के लिए एट्रिब्यूट और ज़रूरी शर्तों के बारे में बताया गया है.
MovieEntity
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज होनी चाहिए. साथ ही, उसमें आसपेक्ट रेशियो होना चाहिए. (लैंडस्केप को प्राथमिकता दी जाती है, लेकिन अलग-अलग स्थितियों के लिए पोर्ट्रेट और लैंडस्केप, दोनों तरह की इमेज पास करने का सुझाव दिया जाता है.)
दिशा-निर्देश के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
फ़िल्म चलाने के लिए, कॉन्टेंट उपलब्ध कराने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
फ़िल्म के बारे में जानकारी दिखाने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
रिलीज़ की तारीख | ज़रूरी है | एपिक मिलीसेकंड में. |
उपलब्धता | ज़रूरी है | उपलब्ध है: उपयोगकर्ता को कॉन्टेंट बिना किसी और कार्रवाई के ऐक्सेस मिल जाता है. FREE_WITH_SUBSCRIPTION: उपयोगकर्ता के सदस्यता खरीदने के बाद, कॉन्टेंट उपलब्ध होता है. PAID_CONTENT: इस तरह के कॉन्टेंट को खरीदने या किराये पर लेने के लिए, उपयोगकर्ता को पैसे चुकाने होंगे. खरीदा गया: उपयोगकर्ता ने कॉन्टेंट को खरीदा है या किराये पर लिया है. |
ऑफ़र की कीमत | वैकल्पिक | फ़्री टेक्स्ट |
कुल अवधि | ज़रूरी है | मिलीसेकंड में. |
शैली | ज़रूरी है | फ़्री टेक्स्ट |
कॉन्टेंट रेटिंग | ज़रूरी है | फ़्री टेक्स्ट, इंडस्ट्री स्टैंडर्ड के मुताबिक होना चाहिए. (उदाहरण) |
अगला वीडियो देखने का तरीका | कुछ शर्तों के मुताबिक ज़रूरी है | यह एट्रिब्यूट तब देना ज़रूरी होता है, जब आइटम, कंटिन्यूएशन क्लस्टर में हो. साथ ही, यह इन चार में से किसी एक टाइप का होना चाहिए: जारी रखें: उपयोगकर्ता ने इस कॉन्टेंट को पहले से ही एक मिनट से ज़्यादा समय तक देखा है. नया: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट के सभी उपलब्ध एपिसोड देख लिए हैं, लेकिन एक नया एपिसोड उपलब्ध हो गया है और एक ऐसा एपिसोड है जिसे अब तक नहीं देखा गया है. यह सुविधा, टीवी शो, किसी सीरीज़ में रिकॉर्ड किए गए फ़ुटबॉल मैच वगैरह के लिए काम करती है. अगला: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट का एक या एक से ज़्यादा एपिसोड पूरा देख लिया है, लेकिन एक से ज़्यादा एपिसोड बचे हैं या एक ही एपिसोड बचा है. साथ ही, आखिरी एपिसोड "नया" नहीं है और उपयोगकर्ता ने एपिसोड वाला कॉन्टेंट देखना शुरू करने से पहले ही उसे रिलीज़ कर दिया था. वॉचलिस्ट: उपयोगकर्ता ने साफ़ तौर पर किसी फ़िल्म, इवेंट या सीरीज़ को वॉचलिस्ट में जोड़ने का विकल्प चुना है, ताकि वह मैन्युअल तरीके से यह तय कर सके कि उसे अगला क्या देखना है. |
दर्शकों के जुड़ाव का आखिरी समय | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम, 'जारी रखने के लिए क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपिक मिलीसेकंड में. |
वीडियो जितना चल चुका है उसकी पिछली स्थिति का समय | कुछ शर्तों के मुताबिक ज़रूरी है | यह तब देना ज़रूरी है, जब आइटम, 'जारी रखने के लिए क्लस्टर' में हो और WatchNextType, 'जारी रखें' हो. एपिक मिलीसेकंड में. |
TvShowEntity
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज होनी चाहिए. साथ ही, उसमें आसपेक्ट रेशियो होना चाहिए. (लैंडस्केप को प्राथमिकता दी जाती है, लेकिन अलग-अलग स्थितियों के लिए पोर्ट्रेट और लैंडस्केप, दोनों तरह की इमेज पास करने का सुझाव दिया जाता है.)
दिशा-निर्देश के लिए, इमेज की जानकारी देखें. |
जानकारी वाले पेज का यूआरआई | ज़रूरी है |
टीवी शो की जानकारी दिखाने के लिए, सेवा देने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
प्लेबैक यूआरआई | वैकल्पिक |
टीवी शो चलाने के लिए, सेवा देने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
पहले एपिसोड के प्रसारण की तारीख | ज़रूरी है | एपिक मिलीसेकंड में. |
सबसे नए एपिसोड के प्रसारण की तारीख | वैकल्पिक | एपिक मिलीसेकंड में. |
उपलब्धता | ज़रूरी है | उपलब्ध है: उपयोगकर्ता को कॉन्टेंट बिना किसी और कार्रवाई के ऐक्सेस मिल जाता है. FREE_WITH_SUBSCRIPTION: उपयोगकर्ता के सदस्यता खरीदने के बाद, कॉन्टेंट उपलब्ध होता है. PAID_CONTENT: इस तरह के कॉन्टेंट को खरीदने या किराये पर लेने के लिए, उपयोगकर्ता को पैसे चुकाने होंगे. खरीदा गया: उपयोगकर्ता ने कॉन्टेंट को खरीदा है या किराये पर लिया है. |
ऑफ़र की कीमत | वैकल्पिक | फ़्री टेक्स्ट |
सीज़न की संख्या | ज़रूरी है | धनात्मक पूर्णांक |
शैली | ज़रूरी है | फ़्री टेक्स्ट |
कॉन्टेंट रेटिंग | ज़रूरी है | फ़्री टेक्स्ट, इंडस्ट्री स्टैंडर्ड के मुताबिक होना चाहिए. (उदाहरण) |
अगला वीडियो देखने का तरीका | कुछ शर्तों के मुताबिक ज़रूरी है | यह एट्रिब्यूट तब देना ज़रूरी होता है, जब आइटम, कंटिन्यूएशन क्लस्टर में हो. साथ ही, यह इन चार में से किसी एक टाइप का होना चाहिए: जारी रखें: उपयोगकर्ता ने इस कॉन्टेंट को पहले से ही एक मिनट से ज़्यादा समय तक देखा है. नया: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट के सभी उपलब्ध एपिसोड देख लिए हैं, लेकिन एक नया एपिसोड उपलब्ध हो गया है और एक ऐसा एपिसोड है जिसे अब तक नहीं देखा गया है. यह सुविधा, टीवी शो, किसी सीरीज़ में रिकॉर्ड किए गए फ़ुटबॉल मैच वगैरह के लिए काम करती है. अगला: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट का एक या एक से ज़्यादा एपिसोड पूरा देख लिया है, लेकिन एक से ज़्यादा एपिसोड बचे हैं या एक ही एपिसोड बचा है. साथ ही, आखिरी एपिसोड "नया" नहीं है और उपयोगकर्ता ने एपिसोड वाला कॉन्टेंट देखना शुरू करने से पहले ही उसे रिलीज़ कर दिया था. वॉचलिस्ट: उपयोगकर्ता ने साफ़ तौर पर किसी फ़िल्म, इवेंट या सीरीज़ को वॉचलिस्ट में जोड़ने का विकल्प चुना है, ताकि वह मैन्युअल तरीके से यह तय कर सके कि उसे अगला क्या देखना है. |
दर्शकों के जुड़ाव का आखिरी समय | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम, 'जारी रखने के लिए क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपिक मिलीसेकंड में. |
वीडियो जितना चल चुका है उसकी पिछली स्थिति का समय | कुछ शर्तों के मुताबिक ज़रूरी है | यह तब देना ज़रूरी है, जब आइटम, 'जारी रखने के लिए क्लस्टर' में हो और WatchNextType, 'जारी रखें' हो. एपिक मिलीसेकंड में. |
TvSeasonEntity
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज होनी चाहिए. साथ ही, उसमें आसपेक्ट रेशियो होना चाहिए. (लैंडस्केप फ़ॉर्मैट का इस्तेमाल करना बेहतर होता है. हालांकि, हमारा सुझाव है कि अलग-अलग स्थितियों के लिए पोर्ट्रेट और लैंडस्केप, दोनों फ़ॉर्मैट की इमेज इस्तेमाल करें.)
दिशा-निर्देश के लिए, इमेज की जानकारी देखें. |
जानकारी वाले पेज का यूआरआई | ज़रूरी है |
टीवी शो के सीज़न की जानकारी दिखाने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
प्लेबैक यूआरआई | वैकल्पिक |
टीवी शो का सीज़न चलाने के लिए, सेवा देने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
सीज़न नंबर दिखाएं |
ज़रूरी नहीं है यह सुविधा v1.3.1 में उपलब्ध है |
स्ट्रिंग |
पहले एपिसोड के प्रसारण की तारीख | ज़रूरी है | एपिक मिलीसेकंड में. |
सबसे नए एपिसोड के प्रसारण की तारीख | वैकल्पिक | एपिक मिलीसेकंड में. |
उपलब्धता | ज़रूरी है | उपलब्ध है: उपयोगकर्ता को कॉन्टेंट बिना किसी और कार्रवाई के ऐक्सेस मिल जाता है. FREE_WITH_SUBSCRIPTION: उपयोगकर्ता के सदस्यता खरीदने के बाद, कॉन्टेंट उपलब्ध होता है. PAID_CONTENT: इस तरह के कॉन्टेंट को खरीदने या किराये पर लेने के लिए, उपयोगकर्ता को पैसे चुकाने होंगे. खरीदा गया: उपयोगकर्ता ने कॉन्टेंट को खरीदा है या किराये पर लिया है. |
ऑफ़र की कीमत | वैकल्पिक | फ़्री टेक्स्ट |
एपिसोड की संख्या | ज़रूरी है | धनात्मक पूर्णांक |
शैली | ज़रूरी है | फ़्री टेक्स्ट |
कॉन्टेंट रेटिंग | ज़रूरी है | फ़्री टेक्स्ट, इंडस्ट्री स्टैंडर्ड के मुताबिक होना चाहिए. (उदाहरण) |
अगला वीडियो देखने का तरीका | कुछ शर्तों के मुताबिक ज़रूरी है | यह एट्रिब्यूट तब देना ज़रूरी होता है, जब आइटम, कंटिन्यूएशन क्लस्टर में हो. साथ ही, यह इन चार में से किसी एक टाइप का होना चाहिए: जारी रखें: उपयोगकर्ता ने इस कॉन्टेंट को पहले से ही एक मिनट से ज़्यादा समय तक देखा है. नया: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट के सभी उपलब्ध एपिसोड देख लिए हैं, लेकिन एक नया एपिसोड उपलब्ध हो गया है और एक ऐसा एपिसोड है जिसे अब तक नहीं देखा गया है. यह सुविधा, टीवी शो, किसी सीरीज़ में रिकॉर्ड किए गए फ़ुटबॉल मैच वगैरह के लिए काम करती है. अगला: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट का एक या एक से ज़्यादा एपिसोड पूरा देख लिया है, लेकिन एक से ज़्यादा एपिसोड बचे हैं या एक ही एपिसोड बचा है. साथ ही, आखिरी एपिसोड "नया" नहीं है और उपयोगकर्ता ने एपिसोड वाला कॉन्टेंट देखना शुरू करने से पहले ही उसे रिलीज़ कर दिया था. वॉचलिस्ट: उपयोगकर्ता ने साफ़ तौर पर किसी फ़िल्म, इवेंट या सीरीज़ को वॉचलिस्ट में जोड़ने का विकल्प चुना है, ताकि वह मैन्युअल तरीके से यह तय कर सके कि उसे अगला क्या देखना है. |
दर्शकों के जुड़ाव का आखिरी समय | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम, 'जारी रखने के लिए क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपिक मिलीसेकंड में. |
वीडियो जितना चल चुका है उसकी पिछली स्थिति का समय | कुछ शर्तों के मुताबिक ज़रूरी है | यह तब देना ज़रूरी है, जब आइटम, 'जारी रखने के लिए क्लस्टर' में हो और WatchNextType, 'जारी रखें' हो. एपिक मिलीसेकंड में. |
TvEpisodeEntity
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज होनी चाहिए. साथ ही, उसमें आसपेक्ट रेशियो होना चाहिए. (लैंडस्केप को प्राथमिकता दी जाती है, लेकिन अलग-अलग स्थितियों के लिए पोर्ट्रेट और लैंडस्केप, दोनों तरह की इमेज पास करने का सुझाव दिया जाता है.)
दिशा-निर्देश के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
एपिसोड चलाने के लिए, कॉन्टेंट उपलब्ध कराने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
जानकारी वाले पेज का यूआरआई | वैकल्पिक |
टीवी शो के एपिसोड के बारे में जानकारी दिखाने के लिए, सेवा देने वाली कंपनी के ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
एपिसोड नंबर दिखाएं |
ज़रूरी नहीं है यह सुविधा v1.3.1 में उपलब्ध है |
स्ट्रिंग |
प्रसारण का तारीख | ज़रूरी है | एपिक मिलीसेकंड में. |
उपलब्धता | ज़रूरी है | उपलब्ध है: उपयोगकर्ता को कॉन्टेंट बिना किसी और कार्रवाई के ऐक्सेस मिल जाता है. FREE_WITH_SUBSCRIPTION: उपयोगकर्ता के सदस्यता खरीदने के बाद, कॉन्टेंट उपलब्ध होता है. PAID_CONTENT: इस तरह के कॉन्टेंट को खरीदने या किराये पर लेने के लिए, उपयोगकर्ता को पैसे चुकाने होंगे. खरीदा गया: उपयोगकर्ता ने कॉन्टेंट को खरीदा है या किराये पर लिया है. |
ऑफ़र की कीमत | वैकल्पिक | फ़्री टेक्स्ट |
कुल अवधि | ज़रूरी है | यह वैल्यू मिलीसेकंड में होनी चाहिए और पॉज़िटिव होनी चाहिए. |
शैली | ज़रूरी है | फ़्री टेक्स्ट |
कॉन्टेंट रेटिंग | ज़रूरी है | फ़्री टेक्स्ट, इंडस्ट्री स्टैंडर्ड के मुताबिक होना चाहिए. (उदाहरण) |
अगला वीडियो देखने का तरीका | कुछ शर्तों के मुताबिक ज़रूरी है | यह एट्रिब्यूट तब देना ज़रूरी होता है, जब आइटम, कंटिन्यूएशन क्लस्टर में हो. साथ ही, यह इन चार में से किसी एक टाइप का होना चाहिए: जारी रखें: उपयोगकर्ता ने इस कॉन्टेंट को पहले से ही एक मिनट से ज़्यादा समय तक देखा है. नया: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट के सभी उपलब्ध एपिसोड देख लिए हैं, लेकिन एक नया एपिसोड उपलब्ध हो गया है और एक ऐसा एपिसोड है जिसे अब तक नहीं देखा गया है. यह सुविधा, टीवी शो, किसी सीरीज़ में रिकॉर्ड किए गए फ़ुटबॉल मैच वगैरह के लिए काम करती है. अगला: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट का एक या एक से ज़्यादा एपिसोड पूरा देख लिया है, लेकिन एक से ज़्यादा एपिसोड बचे हैं या एक ही एपिसोड बचा है. साथ ही, आखिरी एपिसोड "नया" नहीं है और उपयोगकर्ता ने एपिसोड वाला कॉन्टेंट देखना शुरू करने से पहले ही उसे रिलीज़ कर दिया था. वॉचलिस्ट: उपयोगकर्ता ने साफ़ तौर पर किसी फ़िल्म, इवेंट या सीरीज़ को वॉचलिस्ट में जोड़ने का विकल्प चुना है, ताकि वह मैन्युअल तरीके से यह तय कर सके कि उसे अगला क्या देखना है. |
दर्शकों के जुड़ाव का आखिरी समय | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम, 'जारी रखने के लिए क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपिक मिलीसेकंड में. |
वीडियो जितना चल चुका है उसकी पिछली स्थिति का समय | कुछ शर्तों के मुताबिक ज़रूरी है | यह तब देना ज़रूरी है, जब आइटम, 'जारी रखने के लिए क्लस्टर' में हो और WatchNextType, 'जारी रखें' हो. एपिक मिलीसेकंड में. |
LiveStreamingVideoEntity
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज होनी चाहिए. साथ ही, उसमें आसपेक्ट रेशियो होना चाहिए. (लैंडस्केप को प्राथमिकता दी जाती है, लेकिन अलग-अलग स्थितियों के लिए पोर्ट्रेट और लैंडस्केप, दोनों तरह की इमेज पास करने का सुझाव दिया जाता है.)
दिशा-निर्देश के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
वीडियो चलाने के लिए, सेवा देने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
प्रसारणकर्ता | ज़रूरी है | फ़्री टेक्स्ट |
शुरू होने का समय | वैकल्पिक | एपिक मिलीसेकंड में. |
खत्म होने का समय | वैकल्पिक | एपिक मिलीसेकंड में. |
व्यू की संख्या | वैकल्पिक | फ़्री टेक्स्ट, स्थानीय भाषा में होना चाहिए. |
अगला वीडियो देखने का तरीका | कुछ शर्तों के मुताबिक ज़रूरी है | यह एट्रिब्यूट तब देना ज़रूरी होता है, जब आइटम, कंटिन्यूएशन क्लस्टर में हो. साथ ही, यह इन चार में से किसी एक टाइप का होना चाहिए: जारी रखें: उपयोगकर्ता ने इस कॉन्टेंट को पहले से ही एक मिनट से ज़्यादा समय तक देखा है. नया: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट के सभी उपलब्ध एपिसोड देख लिए हैं, लेकिन एक नया एपिसोड उपलब्ध हो गया है और एक ऐसा एपिसोड है जिसे अब तक नहीं देखा गया है. यह सुविधा, टीवी शो, किसी सीरीज़ में रिकॉर्ड किए गए फ़ुटबॉल मैच वगैरह के लिए काम करती है. अगला: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट का एक या एक से ज़्यादा एपिसोड पूरा देख लिया है, लेकिन एक से ज़्यादा एपिसोड बचे हैं या एक ही एपिसोड बचा है. साथ ही, आखिरी एपिसोड "नया" नहीं है और उपयोगकर्ता ने एपिसोड वाला कॉन्टेंट देखना शुरू करने से पहले ही उसे रिलीज़ कर दिया था. वॉचलिस्ट: उपयोगकर्ता ने साफ़ तौर पर किसी फ़िल्म, इवेंट या सीरीज़ को वॉचलिस्ट में जोड़ने का विकल्प चुना है, ताकि वह मैन्युअल तरीके से यह तय कर सके कि उसे अगला क्या देखना है. |
दर्शकों के जुड़ाव का आखिरी समय | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम, 'जारी रखने के लिए क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपिक मिलीसेकंड में. |
वीडियो जितना चल चुका है उसकी पिछली स्थिति का समय | कुछ शर्तों के मुताबिक ज़रूरी है | यह तब देना ज़रूरी है, जब आइटम, 'जारी रखने के लिए क्लस्टर' में हो और WatchNextType, 'जारी रखें' हो. एपिक मिलीसेकंड में. |
VideoClipEntity
VideoClipEntity
ऑब्जेक्ट, सोशल मीडिया से आने वाली वीडियो इकाई को दिखाता है. जैसे, TikTok या YouTube.
एट्रिब्यूट | ज़रूरी शर्त | नोट |
---|---|---|
नाम | ज़रूरी है | |
पोस्टर इमेज | ज़रूरी है | कम से कम एक इमेज होनी चाहिए. साथ ही, उसमें आसपेक्ट रेशियो होना चाहिए. (लैंडस्केप को प्राथमिकता दी जाती है, लेकिन अलग-अलग स्थितियों के लिए पोर्ट्रेट और लैंडस्केप, दोनों तरह की इमेज पास करने का सुझाव दिया जाता है.)
दिशा-निर्देश के लिए, इमेज की जानकारी देखें. |
प्लेबैक यूआरआई | ज़रूरी है |
वीडियो चलाने के लिए, सेवा देने वाले ऐप्लिकेशन का डीप लिंक. ध्यान दें: एट्रिब्यूशन के लिए डीप लिंक का इस्तेमाल किया जा सकता है. अक्सर पूछे जाने वाले इस सवाल को देखें |
बनाए जाने का समय | ज़रूरी है | एपिक मिलीसेकंड में. |
कुल अवधि | ज़रूरी है | यह वैल्यू मिलीसेकंड में होनी चाहिए और पॉज़िटिव होनी चाहिए. |
क्रिएटर | ज़रूरी है | फ़्री टेक्स्ट |
क्रिएटर की इमेज | वैकल्पिक | क्रिएटर के अवतार की इमेज |
व्यू की संख्या | वैकल्पिक | फ़्री टेक्स्ट, स्थानीय भाषा में होना चाहिए. |
अगला वीडियो देखने का तरीका | कुछ शर्तों के मुताबिक ज़रूरी है | यह एट्रिब्यूट तब देना ज़रूरी होता है, जब आइटम, कंटिन्यूएशन क्लस्टर में हो. साथ ही, यह इन चार में से किसी एक टाइप का होना चाहिए: जारी रखें: उपयोगकर्ता ने इस कॉन्टेंट को पहले से ही एक मिनट से ज़्यादा समय तक देखा है. नया: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट के सभी उपलब्ध एपिसोड देख लिए हैं, लेकिन एक नया एपिसोड उपलब्ध हो गया है और एक ऐसा एपिसोड है जिसे अब तक नहीं देखा गया है. यह सुविधा, टीवी शो, किसी सीरीज़ में रिकॉर्ड किए गए फ़ुटबॉल मैच वगैरह के लिए काम करती है. अगला: उपयोगकर्ता ने किसी एपिसोड वाले कॉन्टेंट का एक या एक से ज़्यादा एपिसोड पूरा देख लिया है, लेकिन एक से ज़्यादा एपिसोड बचे हैं या एक ही एपिसोड बचा है. साथ ही, आखिरी एपिसोड "नया" नहीं है और उपयोगकर्ता ने एपिसोड वाला कॉन्टेंट देखना शुरू करने से पहले ही उसे रिलीज़ कर दिया था. वॉचलिस्ट: उपयोगकर्ता ने साफ़ तौर पर किसी फ़िल्म, इवेंट या सीरीज़ को वॉचलिस्ट में जोड़ने का विकल्प चुना है, ताकि वह मैन्युअल तरीके से यह तय कर सके कि उसे अगला क्या देखना है. |
दर्शकों के जुड़ाव का आखिरी समय | कुछ शर्तों के मुताबिक ज़रूरी है | अगर आइटम, 'जारी रखने के लिए क्लस्टर' में है, तो यह एट्रिब्यूट देना ज़रूरी है. एपिक मिलीसेकंड में. |
वीडियो जितना चल चुका है उसकी पिछली स्थिति का समय | कुछ शर्तों के मुताबिक ज़रूरी है | यह तब देना ज़रूरी है, जब आइटम, 'जारी रखने के लिए क्लस्टर' में हो और WatchNextType, 'जारी रखें' हो. एपिक मिलीसेकंड में. |
इमेज की जानकारी
इस सेक्शन में, इमेज ऐसेट के लिए ज़रूरी खास बातें दी गई हैं:
फ़ाइल फ़ॉर्मैट
PNG, JPG, स्टैटिक GIF, WebP
फ़ाइल का ज़्यादा से ज़्यादा साइज़
5120 केबी
कुछ और सुझाव
- इमेज के लिए सेफ़ एरिया: अपने मुख्य कॉन्टेंट को इमेज के बीच वाले 80% हिस्से में रखें.
उदाहरण
Kotlin
var movie = MovieEntity.Builder() .setName("Avengers") .addPosterImage(Image.Builder() .setImageUri(Uri.parse("http://www.x.com/image.png")) .setImageHeightInPixel(960) .setImageWidthInPixel(408) .build()) .setPlayBackUri(Uri.parse("http://tv.com/playback/1")) .setReleaseDateEpochMillis(1633032895L) .setAvailability(ContentAvailability.AVAILABILITY_AVAILABLE) .setDurationMillis(12345678L) .addGenre("action") .addContentRating("R") .setWatchNextType(WatchNextType.TYPE_NEW) .setLastEngagementTimeMillis(1664568895L) .build()
Java
MovieEntity movie = new MovieEntity.Builder() .setName("Avengers") .addPosterImage( new Image.Builder() .setImageUri(Uri.parse("http://www.x.com/image.png")) .setImageHeightInPixel(960) .setImageWidthInPixel(408) .build()) .setPlayBackUri(Uri.parse("http://tv.com/playback/1")) .setReleaseDateEpochMillis(1633032895L) .setAvailability(ContentAvailability.AVAILABILITY_AVAILABLE) .setDurationMillis(12345678L) .addGenre("action") .addContentRating("R") .setWatchNextType(WatchNextType.TYPE_NEW) .setLastEngagementTimeMillis(1664568895L) .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("Top Picks For You") .build() ) .build() )
Java
client.publishRecommendationClusters( new PublishRecommendationClustersRequest.Builder() .addRecommendationCluster( new RecommendationCluster.Builder() .addEntity(entity1) .addEntity(entity2) .setTitle("Top Picks For You") .build()) .build());
जब सेवा को अनुरोध मिलता है, तो एक ही लेन-देन में ये कार्रवाइयां होती हैं:
- डेवलपर पार्टनर का मौजूदा
RecommendationCluster
डेटा हटा दिया जाता है. - अनुरोध से मिले डेटा को पार्स करके, अपडेट किए गए सुझाव क्लस्टर में सेव किया जाता है.
गड़बड़ी होने पर, पूरा अनुरोध अस्वीकार कर दिया जाता है और मौजूदा स्थिति को बनाए रखा जाता है.
publishFeaturedCluster
इस एपीआई का इस्तेमाल, FeaturedCluster
ऑब्जेक्ट की सूची पब्लिश करने के लिए किया जाता है.
Kotlin
client.publishFeaturedCluster( PublishFeaturedClusterRequest.Builder() .setFeaturedCluster( FeaturedCluster.Builder() .addEntity(entity1) .addEntity(entity2) .build()) .build())
Java
client.publishFeaturedCluster( new PublishFeaturedClustersRequest.Builder() .addFeaturedCluster( new FeaturedCluster.Builder() .addEntity(entity1) .addEntity(entity2) .build()) .build());
जब सेवा को अनुरोध मिलता है, तो एक ही लेन-देन में ये कार्रवाइयां होती हैं:
- डेवलपर पार्टनर का मौजूदा
FeaturedCluster
डेटा हटा दिया जाता है. - अनुरोध से मिले डेटा को पार्स करके, अपडेट किए गए हाइलाइट किए गए क्लस्टर में सेव किया जाता है.
गड़बड़ी होने पर, पूरा अनुरोध अस्वीकार कर दिया जाता है और मौजूदा स्थिति को बनाए रखा जाता है.
publishContinuationCluster
इस एपीआई का इस्तेमाल, ContinuationCluster
ऑब्जेक्ट को पब्लिश करने के लिए किया जाता है.
Kotlin
client.publishContinuationCluster( PublishContinuationClusterRequest.Builder() .setContinuationCluster( ContinuationCluster.Builder() .addEntity(entity1) .addEntity(entity2) .build()) .build())
Java
client.publishContinuationCluster( new PublishContinuationClusterRequest.Builder() .setContinuationCluster( new 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 एपीआई को कॉल करें. साथ ही, स्टेटस कोड के तौर पर 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();
सेवा को अनुरोध मिलने पर, वह 'जारी रखने वाले क्लस्टर' से मौजूदा डेटा हटा देती है. गड़बड़ी होने पर, पूरा अनुरोध अस्वीकार कर दिया जाता है और मौजूदा स्थिति में कोई बदलाव नहीं किया जाता.
deleteUserManagementCluster
इस एपीआई का इस्तेमाल, UserAccountManagement क्लस्टर का कॉन्टेंट मिटाने के लिए किया जाता है.
Kotlin
client.deleteUserManagementCluster()
Java
client.deleteUserManagementCluster();
जब सेवा को अनुरोध मिलता है, तो वह UserAccountManagement क्लस्टर से मौजूदा डेटा को हटा देती है. गड़बड़ी होने पर, पूरा अनुरोध अस्वीकार कर दिया जाता है और मौजूदा स्थिति में कोई बदलाव नहीं किया जाता.
deleteClusters
इस एपीआई का इस्तेमाल, किसी क्लस्टर टाइप का कॉन्टेंट मिटाने के लिए किया जाता है.
Kotlin
client.deleteClusters( DeleteClustersRequest.Builder() .addClusterType(ClusterType.TYPE_CONTINUATION) .addClusterType(ClusterType.TYPE_FEATURED) .addClusterType(ClusterType.TYPE_RECOMMENDATION) .build())
Java
client.deleteClusters( new DeleteClustersRequest.Builder() .addClusterType(ClusterType.TYPE_CONTINUATION) .addClusterType(ClusterType.TYPE_FEATURED) .addClusterType(ClusterType.TYPE_RECOMMENDATION) .build());
जब सेवा को अनुरोध मिलता है, तो वह तय किए गए क्लस्टर टाइप से मैच करने वाले सभी क्लस्टर से मौजूदा डेटा हटा देती है. क्लाइंट एक या कई तरह के क्लस्टर पास कर सकते हैं. गड़बड़ी होने पर, पूरा अनुरोध अस्वीकार कर दिया जाता है और मौजूदा स्थिति में कोई बदलाव नहीं किया जाता.
गड़बड़ी ठीक करना
हमारा सुझाव है कि पब्लिश करने वाले एपीआई से टास्क के नतीजे को सुनें, ताकि किसी टास्क को फिर से सबमिट करने और उसे वापस पाने के लिए, फ़ॉलो-अप कार्रवाई की जा सके.
Kotlin
client.publishRecommendationClusters( PublishRecommendationClustersRequest.Builder() .addRecommendationCluster(..) .build()) .addOnCompleteListener { task -> if (task.isSuccessful) { // do something } else { val exception = task.exception if (exception is AppEngageException) { @AppEngageErrorCode val errorCode = exception.errorCode if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) { // do something } } } }
Java
client.publishRecommendationClusters( new PublishRecommendationClustersRequest.Builder() .addRecommendationCluster(...) .build()) .addOnCompleteListener( task -> { if (task.isSuccessful()) { // do something } else { Exception exception = task.getException(); if (exception instanceof AppEngageException) { @AppEngageErrorCode int errorCode = ((AppEngageException) exception).getErrorCode(); if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) { // do something } } } });
गड़बड़ी को 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 |
सेवा कॉल बहुत बार किया जाता है. |
तीसरा चरण: ब्रॉडकास्ट इंटेंट मैनेज करना
किसी जॉब के ज़रिए कॉन्टेंट पब्लिश करने के लिए Content API कॉल करने के अलावा, कॉन्टेंट पब्लिश करने का अनुरोध पाने के लिए, BroadcastReceiver
सेट अप करना भी ज़रूरी है.
ब्रॉडकास्ट इंटेंट का मकसद, मुख्य रूप से ऐप्लिकेशन को फिर से चालू करना और डेटा को सिंक करना है. ब्रॉडकास्ट इंटेंट को बार-बार भेजने के लिए डिज़ाइन नहीं किया गया है. यह सिर्फ़ तब ट्रिगर होता है, जब Engage सेवा यह तय करती है कि कॉन्टेंट पुराना हो सकता है. उदाहरण के लिए, एक हफ़्ते पुराना. इससे यह भरोसा बढ़ता है कि उपयोगकर्ता को नया कॉन्टेंट देखने का अनुभव मिल सकता है. भले ही, ऐप्लिकेशन को लंबे समय से इस्तेमाल न किया गया हो.
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)) // Register Featured Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_FEATURED)) // Register Continuation Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_CONTINUATION)) }
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)); // Register Featured Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED)); // Register Continuation Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_CONTINUATION)); }
- अपनी
AndroidManifest.xml
फ़ाइल में,<receiver>
टैग के साथ लागू करने का एलान करें. इससे ऐप्लिकेशन को ब्रॉडकास्ट के लिए भेजे गए इंटेंट तब भी मिल सकते हैं, जब वह ऐप्लिकेशन बंद हो. साथ ही, ऐप्लिकेशन को कॉन्टेंट पब्लिश करने की अनुमति भी मिलती है.
<application>
<receiver
android:name=".AppEngageBroadcastReceiver"
android:exported="true"
android:enabled="true">
<intent-filter>
<action android:name="com.google.android.engage.action.PUBLISH_RECOMMENDATION" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.PUBLISH_FEATURED" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.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 SDK के बारे में अक्सर पूछे जाने वाले सवाल देखें.
संपर्क
अगर इंटिग्रेशन की प्रोसेस के दौरान आपका कोई सवाल है, तो engage-developers@google.com पर संपर्क करें.
अगले चरण
इस इंटिग्रेशन को पूरा करने के बाद, आपको ये चरण पूरे करने होंगे:
- engage-developers@google.com पर ईमेल भेजें और Google से टेस्ट कराने के लिए, इंटिग्रेट किया गया अपना APK अटैच करें.
- Google, पुष्टि करने के लिए अंदरूनी तौर पर समीक्षा करता है, ताकि यह पक्का किया जा सके कि इंटिग्रेशन उम्मीद के मुताबिक काम कर रहा है. अगर बदलाव ज़रूरी हैं, तो Google आपसे संपर्क करेगा और ज़रूरी जानकारी देगा.
- जांच पूरी होने और कोई बदलाव न किए जाने पर, Google आपसे संपर्क करके यह सूचना देता है कि अपडेट किए गए और इंटिग्रेट किए गए APK को Play Store पर पब्लिश किया जा सकता है.
- Google के यह पुष्टि करने के बाद कि आपका अपडेट किया गया APK, Play Store पर पब्लिश हो गया है, आपके सुझाव, चुनिंदा, और जारी रखें क्लस्टर पब्लिश किए जा सकते हैं और उपयोगकर्ताओं को दिख सकते हैं.