इस सेक्शन में, JSON पेलोड के फ़ॉर्मैट के बारे में बताया गया है. इसे तब भेजा जाएगा, जब Actions on Google ने कार्रवाइयां SDK टूल के ज़रिए कार्रवाई पूरी करनी होगी.
बातचीत शुरू होने पर, उसकी पहचान एक यूनीक conversationId
से की जाती है. हर एक बाद के उपयोगकर्ता के लिए
Assistant से क्वेरी करते हैं, तो आपके पूरे ऑर्डर को एक मकसद मिलता है जो
आपका वेबहुक प्रोसेस होना चाहिए और उसे जवाब देना चाहिए. यह conversationId
हर अनुरोध में मौजूद रहता है और
बातचीत खत्म होने तक, जवाब देने वाला जोड़ा.
अनुरोध का मुख्य भाग
जब लोग कोई शुरुआती क्वेरी करते हैं या बाद में कोई इनपुट देते हैं, तब Assistant एक अनुरोध भेजती है आपकी ज़रूरत को पूरा करते हैं. बातचीत के लिए वेबहुक के अनुरोध इसमें ट्रिगर किया गया इंटेंट और उपयोगकर्ता का रॉ टेक्स्ट शामिल होता है और उपयोगकर्ता के डिवाइस की सतह की क्षमताओं को शामिल किया जाता है.
बातचीत के वेबहुक फ़ॉर्मैट में, किसी अनुरोध के मुख्य फ़ील्ड की खास जानकारी यहां दी गई है:
फ़ील्ड | ब्यौरा |
---|---|
isInSandbox |
इस बूलियन वैरिएबल का इस्तेमाल मुख्य रूप से
लेन-देन सुविधा की मदद से यह बताना चाहते हैं कि आपके वेबहुक को सैंडबॉक्स में इस अनुरोध को हैंडल करना चाहिए या नहीं
मोड. सैंडबॉक्स मोड में, वेबहुक को न तो उपयोगकर्ताओं के किसी परचेज़ ऑर्डर (पीओ) से शुल्क लेना चाहिए और न ही उसे पूरा करना चाहिए.
डिफ़ॉल्ट रूप से, यह "true " पर सेट होता है. |
surface |
उपयोगकर्ता किस प्लैटफ़ॉर्म से इंटरैक्ट कर रहा है और उसकी क्षमताओं के बारे में जानकारी. |
Inputs |
कॉल शुरू करने के अनुरोध के बारे में जानकारी. ट्रिगर करने के लिए, इसमें इंटेंट जो किसी कार्रवाई पर मैप होता है. बाद वाले अनुरोध है, तो इस ऑब्जेक्ट में आपके फ़ुलफ़िलमेंट के ज़रिए तय किए गए अनुमानित इनपुट. |
User |
अनुरोध करने वाले उपयोगकर्ता की जानकारी. इस जानकारी में अनुमतियां शामिल हैं और उपयोगकर्ता की भाषा से मिलती है. |
Conversation |
बातचीत के कॉन्टेक्स्ट के बारे में जानकारी. इसमें बातचीत का आईडी, टाइप (उदाहरण के लिए, क्या यह अनुरोध नई बातचीत शुरू कर रहा है) और बातचीत टोकन का इस्तेमाल किया जा सकता है. |
availableSurfaces |
इस जानकारी का इस्तेमाल इसके लिए किया जाता है कई प्लैटफ़ॉर्म पर बातचीत करने के लिए. |
बातचीत शुरू करने के अनुरोध का आसान उदाहरण
नीचे दिया गया स्निपेट बातचीत के वेबहुक फ़ॉर्मैट में शुरू करने के अनुरोध का एक उदाहरण दिखाता है.
{ "user": { "userId": "ABwppHEF...", "locale": "en-US", "lastSeen": "2018-03-21T17:59:52Z", "userStorage": "{\"data\":{}}" }, "device": {}, "surface": { "capabilities": [ { "name": "actions.capability.SCREEN_OUTPUT" }, { "name": "actions.capability.AUDIO_OUTPUT" }, { "name": "actions.capability.MEDIA_RESPONSE_AUDIO" }, { "name": "actions.capability.WEB_BROWSER" } ] }, "conversation": { "conversationId": "1521784527171", "type": "NEW" }, "inputs": [ { "intent": "actions.intent.MAIN", "rawInputs": [ { "inputType": "VOICE", "query": "Talk to my test app" } ] } ], "availableSurfaces": [ { "capabilities": [ { "name": "actions.capability.SCREEN_OUTPUT" }, { "name": "actions.capability.AUDIO_OUTPUT" }, { "name": "actions.capability.MEDIA_RESPONSE_AUDIO" }, { "name": "actions.capability.WEB_BROWSER" } ] } ] }
बातचीत के अनुरोध का उदाहरण
नीचे दिए गए स्निपेट में, बातचीत के वेबहुक फ़ॉर्मैट में बातचीत वाले अनुरोध का एक उदाहरण दिया गया है. जहां उपयोगकर्ता का इनपुट एक टेक्स्ट स्ट्रिंग है (उदाहरण के लिए, “मेरा लकी नंबर 88 है.”):
{ "user": { "userId": "ABwppHEF...", "locale": "en-US", "lastSeen": "2018-03-21T17:59:52Z", "userStorage": "{\"data\":{}}" }, "device": {}, "surface": { "capabilities": [ { "name": "actions.capability.SCREEN_OUTPUT" }, { "name": "actions.capability.AUDIO_OUTPUT" }, { "name": "actions.capability.MEDIA_RESPONSE_AUDIO" }, { "name": "actions.capability.WEB_BROWSER" } ] }, "conversation": { "conversationId": "1521784527171", "type": "NEW" }, "inputs": [ { "intent": "actions.intent.TEXT", "rawInputs": [ { "inputType": "VOICE", "query": "My lucky number is 88." } ] } ], "availableSurfaces": [ { "capabilities": [ { "name": "actions.capability.SCREEN_OUTPUT" }, { "name": "actions.capability.AUDIO_OUTPUT" }, { "name": "actions.capability.MEDIA_RESPONSE_AUDIO" }, { "name": "actions.capability.WEB_BROWSER" } ] } ] }
जवाब का मुख्य भाग
आपके फ़ुलफ़िलमेंट एंडपॉइंट से जुड़े एचटीटीपी पोस्ट के हेडर में Content-Type
और Assistant, application/json
होनी चाहिए.
जवाब: बातचीत के वेबहुक फ़ॉर्मैट में, असल यूज़र इंटरफ़ेस (यूआई) जैसा डेटा होता है. इस फ़ॉर्मैट में, उपयोगकर्ता (इसमें ऑडियो और विज़ुअल कॉम्पोनेंट भी शामिल हैं) और इंटेंट बाद वाले अनुरोध में ट्रिगर किया जाता है (इसे उम्मीद के मुताबिक कहा जाता है). उम्मीद इंटेंट ऐसा कोई भी इंटेंट हो सकता है जिसे Assistant समझती है. जैसा कि बताया गया है को Intents एपीआई के रेफ़रंस में देख सकते हैं.
अपने जवाबों के लिए यूज़र इंटरफ़ेस को फ़ॉर्मैट करने के बारे में ज़्यादा जानने के लिए, वे Assistant में दिखते हैं, तो जवाबों से जुड़ा दस्तावेज़.
जवाब का आसान उदाहरण
नीचे दिया गया स्निपेट बातचीत में आसान जवाब का एक उदाहरण दिखाता है वेबहुक फ़ॉर्मैट.
{ "expectUserResponse": true, "expectedInputs": [ { "possibleIntents": [ { "intent": "actions.intent.TEXT" } ], "inputPrompt": { "richInitialPrompt": { "items": [ { "simpleResponse": { "textToSpeech": "You are using the Actions SDK. Do you want to hear more about it?" } } ] } } } ] }
हेल्पर का उदाहरण
नीचे दिए गए स्निपेट में, बातचीत में हेल्पर इंटेंट का इस्तेमाल करने का उदाहरण दिया गया है
वेबहुक फ़ॉर्मैट. इस उदाहरण में, वेबहुक
actions.intent.OPTIONS
हेल्पर, Assistant को
कई विकल्पों में से उपयोगकर्ता को चुना जाता है.
हेल्पर इंटेंट का इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, मददगार गाइड.
{ "expectUserResponse": true, "expectedInputs": [ { "possibleIntents": [ { "intent": "actions.intent.OPTION", "inputValueData": { "@type": "type.googleapis.com/google.actions.v2.OptionValueSpec", "carouselSelect": { "items": [ { "optionInfo": { "key": "one", "synonyms": [ "synonym of KEY_ONE 1", "synonym of KEY_ONE 2" ] }, "description": "Description of number one", "title": "Number one" }, { "optionInfo": { "key": "two", "synonyms": [ "synonym of KEY_TWO 1", "synonym of KEY_TWO 2" ] }, "description": "Description of number two", "title": "Number two" } ] } } } ], "inputPrompt": { "richInitialPrompt": { "items": [ { "simpleResponse": { "textToSpeech": "this shows an example of a carousel" } } ], "suggestions": [ { "title": "1" }, { "title": "2" } ] } } } ] }
बातचीत खत्म करने का उदाहरण
नीचे दिया गया स्निपेट बातचीत खत्म करने के लिए एक आसान जवाब का उदाहरण दिखाता है सेशन के दौरान वेबहुक रिस्पॉन्स फ़ॉर्मैट में होना चाहिए.
expectedUserResponse
जवाब में आने वाले मैसेज में false
की वैल्यू, Assistant को यह सिग्नल देती है कि कोई और उपयोगकर्ता नहीं है
इनपुट ज़रूरी है और इसे मौजूदा बातचीत को खत्म करना चाहिए. कॉन्टेंट बनाने
finalResponse
वैल्यू से पता चलता है कि Assistant को उपयोगकर्ता को पहले क्या दिखाना चाहिए या क्या आउटपुट देना चाहिए
बातचीत खत्म हो जाती है.
{ "expectUserResponse": false, "finalResponse": { "richResponse": { "items": [ { "simpleResponse": { "textToSpeech": "Good bye" } } ] } } }
जब उपयोगकर्ता किसी स्टैंडर्ड को शुरू करते हैं, तो डिफ़ॉल्ट ऐक्शन को बदलने का तरीका जानने के लिए Assistant के साथ बातचीत को ख़त्म करने के लिए, वाक्यांश देखें, बातचीत के एग्ज़िट.