इस पेज पर, Google Chat ऐप्लिकेशन के तौर पर कमांड सेट अप करने और उनका जवाब देने का तरीका बताया गया है.
कमांड की मदद से, उपयोगकर्ता Chat ऐप्लिकेशन की मुख्य सुविधाओं को ढूंढ सकते हैं और उनका इस्तेमाल कर सकते हैं. सिर्फ़ Chat ऐप्लिकेशन ही किसी कमांड का कॉन्टेंट देख सकते हैं. उदाहरण के लिए, अगर कोई उपयोगकर्ता स्लैश कमांड के साथ मैसेज भेजता है, तो वह मैसेज सिर्फ़ उपयोगकर्ता और Chat ऐप्लिकेशन को दिखता है.
कमांड बनाने हैं या नहीं, यह तय करने और उपयोगकर्ता के इंटरैक्शन को डिज़ाइन करने का तरीका जानने के लिए, उपयोगकर्ता के सभी पाथ तय करना लेख पढ़ें.
Chat ऐप्लिकेशन के कमांड के टाइप
Chat ऐप्लिकेशन के कमांड को स्लैश कमांड, क्विक कमांड या मैसेज ऐक्शन के तौर पर बनाया जा सकता है. हर तरह के कमांड का इस्तेमाल करने के लिए, उपयोगकर्ता ये काम कर सकते हैं:-
स्लैश कमांड: उपयोगकर्ता, मेन्यू से कोई स्लैश कमांड चुन सकते हैं या स्लैश (
/) टाइप करके, पहले से तय किया गया कोई टेक्स्ट टाइप कर सकते हैं. जैसे,/about. आम तौर पर, Chat ऐप्लिकेशन को स्लैश कमांड के लिए आर्ग्युमेंट टेक्स्ट की ज़रूरत होती है.अगर आपके Chat ऐप्लिकेशन को उपयोगकर्ता से अतिरिक्त इनपुट की ज़रूरत है, तो स्लैश कमांड बनाएं. उदाहरण के लिए, आप एक स्लैश कमांड बना सकते हैं जिसे
/searchकहा जाता है जो उपयोगकर्ता द्वारा किसी वाक्यांश को खोज के लिए डालने के बाद चलती है, जैसे/search receipts. -
क्विक कमांड: उपयोगकर्ता, Chat मैसेज के जवाब वाले सेक्शन से मेन्यू खोलकर कमांड का इस्तेमाल करते हैं. कमांड का इस्तेमाल करने के लिए, वे जोड़ें
पर क्लिक करते हैं और मेन्यू से कोई कमांड चुनते हैं.
अगर आपका Chat ऐप्लिकेशन, अतिरिक्त इनपुट का इंतज़ार किए बिना, उपयोगकर्ता को तुरंत जवाब दे सकता है, तो क्विक कमांड बनाएं. उदाहरण के लिए, रैंडम इमेज नाम की क्विक कमांड बनाई जा सकती है. यह कमांड, तुरंत किसी इमेज के साथ जवाब देती है.
-
मैसेज ऐक्शन: ( डेवलपर प्रीव्यू) उपयोगकर्ता, किसी मैसेज पर कर्सर घुमाकर और तीन बिंदु वाले मेन्यू पर क्लिक करके, मैसेज ऐक्शन का इस्तेमाल करते हैं. कमांड का इस्तेमाल करने के लिए, वे तीन बिंदु वाला मेन्यू खोलते हैं और मेन्यू से कोई कमांड चुनते हैं.
अगर आपका Chat ऐप्लिकेशन, किसी मैसेज के कॉन्टेक्स्ट के आधार पर कार्रवाइयां कर सकता है, तो मैसेज ऐक्शन बनाएं.
नीचे दी गई इमेज में दिखाया गया है कि उपयोगकर्ता, स्लैश और क्विक कमांड के लिए मेन्यू और मैसेज ऐक्शन कैसे ढूंढते हैं:
ज़रूरी शर्तें
Node.js
एक Google Chat ऐप्लिकेशन जो इंटरैक्शन इवेंट को स्वीकार करता है और उनका जवाब देता है. एचटीटीपी सेवा का इस्तेमाल करके, इंटरैक्टिव Chat ऐप्लिकेशन बनाने के लिए, यह क्विकस्टार्ट पूरा करें.
Apps Script
एक Google Chat ऐप्लिकेशन जो इंटरैक्शन इवेंट को स्वीकार करता है और उनका जवाब देता है. Apps Script में इंटरैक्टिव Chat ऐप्लिकेशन बनाने के लिए, यह क्विकस्टार्ट पूरा करें.
Python
एक Google Chat ऐप्लिकेशन जो इंटरैक्शन इवेंट को स्वीकार करता है और उनका जवाब देता है. एचटीटीपी सेवा का इस्तेमाल करके, इंटरैक्टिव Chat ऐप्लिकेशन बनाने के लिए, यह क्विकस्टार्ट पूरा करें.
Java
एक Google Chat ऐप्लिकेशन जो इंटरैक्शन इवेंट को स्वीकार करता है और उनका जवाब देता है. एचटीटीपी सेवा का इस्तेमाल करके, इंटरैक्टिव Chat ऐप्लिकेशन बनाने के लिए, यह क्विकस्टार्ट पूरा करें.
कमांड सेट अप करना
इस सेक्शन में, कमांड सेट अप करने के लिए, ये चरण पूरे करने का तरीका बताया गया है:
- कमांड के लिए कोई नाम और जानकारी बनाना.
- Google Cloud Console में कमांड कॉन्फ़िगर करना.
कमांड का नाम और जानकारी देना
कमांड का नाम वह टेक्स्ट होता है जिसे टाइप करके या चुनकर, उपयोगकर्ता Chat ऐप्लिकेशन को शुरू करते हैं. नाम के नीचे एक छोटा सा ब्यौरा भी दिखता है, ताकि उपयोगकर्ताओं को कमांड का इस्तेमाल करने के बारे में ज़्यादा जानकारी मिल सके:
अपनी कमांड के लिए नाम और जानकारी चुनते समय, इन सुझावों को ध्यान में रखें:
कमांड का नाम देने के लिए:
- कमांड को उपयोगकर्ताओं के लिए साफ़ तौर पर दिखाने के लिए, छोटे, जानकारी देने वाले, और कार्रवाई करने वाले शब्दों या वाक्यांशों का इस्तेमाल करें. उदाहरण के लिए,
Create a reminderनाम के बजाय,Remind meका इस्तेमाल करें. - अपनी कमांड के लिए कोई यूनीक या सामान्य नाम इस्तेमाल करने पर विचार करें. अगर आपकी कमांड, किसी सामान्य इंटरैक्शन या सुविधा के बारे में बताती है, तो कोई ऐसा सामान्य नाम इस्तेमाल किया जा सकता है जिसे उपयोगकर्ता पहचानते हों और जिसकी उन्हें उम्मीद हो. जैसे,
SettingsयाFeedback. इसके अलावा, कमांड के लिए यूनीक नाम इस्तेमाल करने की कोशिश करें. ऐसा इसलिए, क्योंकि अगर आपकी कमांड का नाम, अन्य Chat ऐप्लिकेशन के लिए भी वही है, तो उपयोगकर्ता को आपकी कमांड ढूंढने और उसका इस्तेमाल करने के लिए, मिलते-जुलते कमांड को फ़िल्टर करना होगा.
कमांड की जानकारी देने के लिए:
- जानकारी को छोटा और साफ़ रखें, ताकि उपयोगकर्ताओं को पता हो कि कमांड का इस्तेमाल करने पर उन्हें क्या मिलेगा.
- उपयोगकर्ताओं को बताएं कि कमांड के लिए फ़ॉर्मैट से जुड़ी कोई ज़रूरी शर्तें हैं या नहीं. उदाहरण के लिए, अगर आपने कोई ऐसी स्लैश कमांड बनाई है जिसके लिए आर्ग्युमेंट टेक्स्ट की ज़रूरत है, तो जानकारी को
Remind me to do [something] at [time]के तौर पर सेट करें. - उपयोगकर्ताओं को बताएं कि Chat ऐप्लिकेशन, स्पेस में मौजूद सभी लोगों को जवाब देता है या
सिर्फ़ उस उपयोगकर्ता को निजी तौर पर जवाब देता है जिसने कमांड शुरू की है. उदाहरण के लिए, क्विक कमांड
Aboutके लिए, जानकारी के तौर परLearn about this app (Only visible to you)लिखा जा सकता है.
Google Cloud Console में कमांड कॉन्फ़िगर करना
स्लैश कमांड, क्विक कमांड या मैसेज ऐक्शन बनाने के लिए, आपको Google Chat API के लिए अपने Chat ऐप्लिकेशन के कॉन्फ़िगरेशन में, कमांड या ऐक्शन के बारे में जानकारी देनी होगी.
Google Chat API में कोई कमांड कॉन्फ़िगर करने के लिए, यह तरीका अपनाएं:
Google Cloud Console में, मेन्यू > एपीआई और सेवाएं > चालू किए गए एपीआई और सेवाएं > Google Chat API पर क्लिक करें
कॉन्फ़िगरेशन पर क्लिक करें.
**कमांड** में जाकर, **कोई कमांड जोड़ें** पर क्लिक करें.
कमांड के लिए कोई कमांड आईडी, जानकारी, कमांड टाइप, और नाम डालें:
- कमांड आईडी: 1 से 1000 तक कोई ऐसा नंबर जिसका इस्तेमाल, आपका Chat ऐप्लिकेशन कमांड की पहचान करने और जवाब देने के लिए करता है.
- जानकारी: वह टेक्स्ट जो बताता है कि कमांड क्या करती है. जानकारी 50 वर्णों तक हो सकती है और इसमें खास वर्ण शामिल किए जा सकते हैं.
- कमांड टाइप: क्विक कमांड, स्लैश कमांड या मैसेज ऐक्शन में से कोई एक विकल्प चुनें.
- कमांड के लिए कोई नाम तय करें:
- क्विक कमांड का नाम: वह डिसप्ले नेम जिसे उपयोगकर्ता, कमांड शुरू करने के लिए मेन्यू से चुनते हैं. यह 50 वर्णों तक हो सकता है और इसमें खास वर्ण शामिल किए जा सकते हैं. उदाहरण के लिए,
Remind me. - स्लैश कमांड का नाम: वह टेक्स्ट जिसे उपयोगकर्ता, किसी मैसेज में कमांड शुरू करने के लिए टाइप करते हैं. यह स्लैश से शुरू होना चाहिए, इसमें सिर्फ़ टेक्स्ट होना चाहिए, और यह 50 वर्णों तक हो सकता है. उदाहरण के लिए,
/remindMe. - मैसेज ऐक्शन का नाम:
( डेवलपर प्रीव्यू)
वह डिसप्ले नेम जिसे उपयोगकर्ता, मैसेज ऐक्शन शुरू करने के लिए
मेन्यू से चुनते हैं. यह 50 वर्णों तक हो सकता है और इसमें खास वर्ण शामिल किए जा सकते हैं. उदाहरण के लिए,
Remind me.
- क्विक कमांड का नाम: वह डिसप्ले नेम जिसे उपयोगकर्ता, कमांड शुरू करने के लिए मेन्यू से चुनते हैं. यह 50 वर्णों तक हो सकता है और इसमें खास वर्ण शामिल किए जा सकते हैं. उदाहरण के लिए,
ज़रूरी नहीं: लोडिंग सूचना का मैसेज: ( Developer Preview) टोस्ट नोटिफ़िकेशन मैसेज, जो मैसेज ऐक्शन के चालू होने के दौरान उपयोगकर्ता को दिखता है. यह सुविधा, सिर्फ़ उन मैसेज ऐक्शन के लिए उपलब्ध है जो डायलॉग नहीं खोलते.
ज़रूरी नहीं: अगर आपको Chat ऐप्लिकेशन से कमांड का जवाब डायलॉग के साथ चाहिए, तो डायलॉग खोलें चेकबॉक्स को चुनें.
सेव करें पर क्लिक करें.
अब Chat ऐप्लिकेशन के लिए कमांड कॉन्फ़िगर हो गई है.
कमांड का जवाब देना
जब उपयोगकर्ता किसी कमांड का इस्तेमाल करते हैं, तो आपके Chat ऐप्लिकेशन को इंटरैक्शन इवेंट मिलता है. इवेंट के पेलोड में, मेटाडेटा होता है. इसमें शुरू की गई कमांड के बारे में जानकारी होती है. जैसे, कमांड आईडी और कमांड टाइप. इससे, आपको सही जवाब देने में मदद मिलती है.
/help का निजी तौर पर जवाब देता है.हर तरह की कमांड का जवाब देने के लिए, आपको इवेंट के पेलोड में अलग-अलग इवेंट टाइप और मेटाडेटा ऑब्जेक्ट मैनेज करने होंगे:
| कमांड टाइप | इवेंट टाइप | कमांड का मेटाडेटा |
|---|---|---|
| स्लैश कमांड | MESSAGE |
message.slashCommand
या message.annotation.slashCommand |
| क्विक कमांड | APP_COMMAND |
appCommandMetadata
|
| मैसेज ऐक्शन | APP_COMMAND |
appCommandMetadata
|
किसी कमांड का जवाब मैसेज के साथ देने का तरीका जानने के लिए, ये सेक्शन देखें.
स्लैश कमांड का जवाब देना
यहां दिए गए कोड में, Chat ऐप्लिकेशन का एक उदाहरण दिखाया गया है. यह स्लैश कमांड /about का जवाब देता है. Chat ऐप्लिकेशन, MESSAGE इंटरैक्शन इवेंट को मैनेज करता है. साथ ही, यह पता लगाता है कि इंटरैक्शन इवेंट में मैचिंग कमांड आईडी है या नहीं. इसके बाद, निजी मैसेज भेजता है:
Node.js
Apps Script
Python
Java
ABOUT_COMMAND_ID की जगह, वह कमांड आईडी डालें जिसे आपने Google Cloud Console में कमांड कॉन्फ़िगर करते समय तय किया था.
क्विक कमांड का जवाब देना
यहां दिए गए कोड में, Chat ऐप्लिकेशन का एक उदाहरण दिखाया गया है. यह Help नाम की क्विक कमांड का जवाब देता है. Chat ऐप्लिकेशन, APP_COMMAND इंटरैक्शन इवेंट को मैनेज करता है. साथ ही, यह पता लगाता है कि इंटरैक्शन इवेंट में मैचिंग कमांड आईडी है या नहीं. इसके बाद, निजी मैसेज भेजता है:
Node.js
Apps Script
Python
Java
HELP_COMMAND_ID की जगह, वह कमांड आईडी डालें जिसे आपने Google Cloud Console में कमांड कॉन्फ़िगर करते समय तय किया था.
मैसेज ऐक्शन का जवाब देना
यहां दिए गए कोड में, Chat ऐप्लिकेशन का एक उदाहरण दिखाया गया है. यह Remind me नाम के मैसेज ऐक्शन का जवाब देता है. Chat ऐप्लिकेशन, APP_COMMAND इंटरैक्शन इवेंट को मैनेज करता है. साथ ही, यह पता लगाता है कि इंटरैक्शन इवेंट में मैचिंग कमांड आईडी है या नहीं. इसके बाद, निजी मैसेज भेजता है:
Node.js
/**
* Responds to an APP_COMMAND interaction event from Google Chat.
*
* @param {Object} event The interaction event from Google Chat.
* @param {Object} res The HTTP response object.
* @return {Object} The JSON response message with a confirmation.
*/
function handleAppCommand(event, res) {
// Collect the command ID and type from the event metadata.
const {appCommandId, appCommandType} = event.appCommandMetadata;
// Use appCommandType to detect message actions.
if (appCommandType === 'MESSAGE_ACTION' &&
appCommandId === REMIND_ME_COMMAND_ID) {
// Message actions can access the context of the message they were
// invoked on, such as the text or sender of that message.
const messageText = event.message.text;
// Return a response that includes details from the original message.
return res.send({
text: `Setting a reminder for this message: "${messageText}"`
});
}
}
Apps Script
/**
* Responds to an APP_COMMAND interaction event in Google Chat.
*
* @param {Object} event The interaction event from Google Chat.
* @return {Object} The JSON response message with a confirmation.
*/
function onAppCommand(event) {
// Collect the command ID and type from the event metadata.
const {appCommandId, appCommandType} = event.appCommandMetadata;
if (appCommandType === 'MESSAGE_ACTION' &&
appCommandId === REMIND_ME_COMMAND_ID) {
// Message actions can access the context of the message they were
// invoked on, such as the text or sender of that message.
const messageText = event.message.text;
// Return a response that includes details from the original message.
return { "text": "Setting a reminder for message: " + messageText };
}
}
Python
def handle_app_command(event):
"""Responds to an APP_COMMAND interaction event from Google Chat.
Args:
event (dict): The interaction event from Google Chat.
Returns:
dict: The JSON response message with a confirmation.
"""
# Collect the command ID and type from the event metadata.
metadata = event.get('appCommandMetadata', {})
if metadata.get('appCommandType') == 'MESSAGE_ACTION' and \
metadata.get('appCommandId') == REMIND_ME_COMMAND_ID:
# Message actions can access the context of the message they were
# invoked on, such as the text or sender of that message.
message_text = event.get('message', {}).get('text')
# Return a response that includes details from the original message.
return {
"text": f'Setting a reminder for message: "{message_text}"'
}
Java
/**
* Responds to an APP_COMMAND interaction event from Google Chat.
*
* @param event The interaction event from Google Chat.
* @param response The HTTP response object.
*/
void handleAppCommand(JsonObject event, HttpResponse response) throws Exception {
// Collect the command ID and type from the event metadata.
JsonObject metadata = event.getAsJsonObject("appCommandMetadata");
String appCommandType = metadata.get("appCommandType").getAsString();
if (appCommandType.equals("MESSAGE_ACTION")) {
int commandId = metadata.get("appCommandId").getAsInt();
if (commandId == REMIND_ME_COMMAND_ID) {
// Message actions can access the context of the message they were
// invoked on, such as the text or sender of that message.
String messageText = event.getAsJsonObject("message").get("text").getAsString();
// Return a response that includes details from the original message.
JsonObject responseMessage = new JsonObject();
responseMessage.addProperty("text", "Setting a reminder for message: " + messageText);
response.getWriter().write(responseMessage.toString());
}
}
}
REMIND_ME_COMMAND_ID की जगह, वह कमांड आईडी डालें जिसे आपने Google Cloud Console में कमांड कॉन्फ़िगर करते समय तय किया था.
कमांड की जांच करना
कमांड और कोड की जांच करने के लिए, Google Chat ऐप्लिकेशन की इंटरैक्टिव सुविधाओं की जांच करना लेख पढ़ें.
Chat यूज़र इंटरफ़ेस (यूआई) में कमांड की जांच करने और उसका इस्तेमाल करने का तरीका जानने के लिए, Google Chat की सहायता से जुड़े दस्तावेज़ में, Google Chat में ऐप्लिकेशन इस्तेमाल करना लेख पढ़ें.
मिलते-जुलते विषय
- कमांड का इस्तेमाल करने वाले Chat ऐप्लिकेशन के सैंपल देखना
- मैसेज भेजना
- इंटरैक्टिव डायलॉग खोलना