2

下面的函数应该提供对 share_your_phone_number 意图的实现。调用意图时,会在电报中为用户显示共享您的电话号码键盘。

function share_your_phone_number(agent) {
agent.add(`Welcome.`);
agent.add(new Payload("telegram", {
    "text": "Please click on button below to share your number",
    "reply_markup": {
      "one_time_keyboard": true,
      "resize_keyboard": true,
      "keyboard": [
        [
          {
            "text": "Share my phone number",
            "callback_data": "phone",
            "request_contact": true
          }
        ],
        [
          {
            "text": "Cancel",
            "callback_data": "Cancel"
          }
        ]
      ]
    }
  }
 ));
} 

当我在内联编辑器中部署 API 时,电报机器人聊天中只返回“欢迎”字符串。不显示键盘按钮。

我需要一个线索来解决这个问题。

4

2 回答 2

3

在创建 [此处] https://dialogflow.com/docs/reference/fulfillment-library/rich-responses#new_payloadplatform_payload中记录的有效负载对象的构造函数时,需要platformpayload参数。

new Payload(platform, payload)

platform参数是 WebhookClient 对象的一个​​属性,应该这样定义(agent.SLACK、agent.TELEGRAM 等)假设 webhookClient 已实例化并存储在agent

例子:

agent.add(new Payload(agent.ACTIONS_ON_GOOGLE, {/*your Google payload here*/}); agent.add(new Payload(agent.SLACK, {/*your Slack payload here*/});

agent.add(new Payload(agent.TELEGRAM, {/*your telegram payload here*/});

参考:https ://blog.dialogflow.com/post/fulfillment-library-beta/ 。

对于我在问题中概述的用例,这是我的完整解决方案:

    // See https://github.com/dialogflow/dialogflow-fulfillment-nodejs
    // for Dialogflow fulfillment library docs, samples, and to report issues
    'use strict';

    const functions = require('firebase-functions');
    const {WebhookClient} = require('dialogflow-fulfillment');
    const {Text, Card, Image, Suggestion, Payload} = require('dialogflow-fulfillment'); 
    process.env.DEBUG = 'dialogflow:debug'; // enables lib debugging statements

    exports.dialogflowFirebaseFulfillment = functions.https.onRequest((request, response) => {
    const agent = new WebhookClient({ request, response });
    console.log('Dialogflow Request headers: ' + JSON.stringify(request.headers));
    console.log('Dialogflow Request body: ' + JSON.stringify(request.body));

    function welcome(agent) {
      agent.add(new Payload(agent.TELEGRAM, {

        "text": "Please click on button below to share your number",
        "reply_markup": {
          "one_time_keyboard": true,
          "resize_keyboard": true,
          "keyboard": [
            [
              {
                "text": "Share my phone number",
                "callback_data": "phone",
                "request_contact": true
              }
            ],
            [
              {
                "text": "Cancel",
                "callback_data": "Cancel"
              }
            ]
          ]
        }
       }));
      }

      // Run the proper function handler based on the matched Dialogflow intent name
      let intentMap = new Map();
      intentMap.set('Default Welcome Intent', welcome);
      agent.handleRequest(intentMap);
    });
于 2019-03-03T08:36:48.427 回答
0

这是我的结果:

  function welcome(agent) {
    const payload = {
      "text": "Pick a color",
      "reply_markup": {
        "inline_keyboard": [
          [
            {
              "text": "Yellow",
              "callback_data": "Yellow"
            }
          ],
          [
            {
              "text": "Blue",
              "callback_data": "Blue"
            }
          ]
        ]
      }
    };

    console.log('queryText ' + JSON.stringify(agent.request_.body.queryResult.queryText));
    console.log('displayName ' + JSON.stringify(agent.request_.body.queryResult.intent.displayName)

    agent.add(
      new Payload(agent.TELEGRAM, payload, {rawPayload: false, sendAsMessage: true})
    );
  }

此外,您必须将dialogflow-fulfillmentpackage.json 中的版本更新为最新版本。现在我有这个版本 -"dialogflow-fulfillment": "^0.6.1"

于 2020-11-26T23:39:23.253 回答