gpt4 book ai didi

javascript - Dialogflow 履行内联编辑器 api 请求

转载 作者:行者123 更新时间:2023-11-28 03:24:20 24 4
gpt4 key购买 nike

我试图让机器人回答从 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() 需要返回 axios.get() 返回的 Promise。同样,调用 callAPI() 的 Intent Handler 也需要返回该 Promise(或来自 then() block 的另一个 Promise)。

Dialogflow 库需要这样做,以便它知道在将任何内容返回给用户之前等待 API 调用完成(并因此解决 Promise)。

就您而言,这就像将对 axios.get() 的调用更改为类似的内容一样简单

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

关于javascript - Dialogflow 履行内联编辑器 api 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58793969/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com