Dialogflow 实现内联编辑器 api 请求

Dialogflow fulfillment inline editor api request

我正在尝试让机器人回答从 API 收到的信息,但无法正常工作。

在 firebase 控制台日志中,我可以看到 api 确实响应了我需要的信息。

以下所有代码:


'use strict';

const axios = require('axios');

const functions = require('firebase-functions');
const {WebhookClient} = require('dialogflow-fulfillment');
const {Card, Suggestion} = 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(`Welcome to my agent!`);
  }

  function fallback(agent) {
    agent.add(`I didn't understand`);
    agent.add(`I'm sorry, can you try again?`);
  }



  function callAPI(agent){

    const food = agent.parameters.Food;
    const subject = agent.parameters.Subject;
    const number = agent.parameters.number;

    const question = subject + " "+number +" "+food;
    const questionReady = question.replace(/ /g, '+');

    const apiKey = "key";
    const baseUrl = "https://api.spoonacular.com/recipes/quickAnswer?q=";

    const apiUrl =  baseUrl + questionReady + "&apiKey=" + apiKey;

    axios.get(apiUrl).then((result) => {
        console.log(result);   
        console.log(result.data);   
        console.log(result.data.answer);

        agent.add(result);
        agent.add(result.data);
        agent.add(result.data.answer);

    });


  }


  let intentMap = new Map();
  intentMap.set('Default Welcome Intent', welcome);
  intentMap.set('Default Fallback Intent', fallback);
  intentMap.set('food', callAPI);
  agent.handleRequest(intentMap);
});

Firebase 控制台日志:

View post on imgur.com

最可能的原因是您没有使用 Promiseasync 函数调用,因此在您调用 API 完成。

要解决此问题,callAPI() 需要 return axios.get() return 的 Promise。同样,调用 callAPI() 的 Intent Handler 也需要 return 该 Promise(或来自 then() 块的另一个 promise)。

Dialogflow 库需要这个,所以它知道在 return 向用户发送任何内容之前等待 API 调用完成(以及因此解决的 Promise)。

在您的情况下,这就像将对 axios.get() 的调用更改为类似

一样简单
return axios.get(apiUrl).then((result) => {
  // Rest of this call here