![](/img/trans.png)
[英]Dialogflow + external API + Google Cloud Functions *without* Firebase: how to return fulfillment response?
[英]How to save the user response in Dialogflow via webhook to google cloud firestore using cloud functions
我在dialogflow中構建了一個bot,它由一系列意圖組成,我希望將用戶響應保存在集合中的firestore中。 我在node.js中編寫了后端代碼但遇到了一些問題。 我正面臨一個名為“App不是exports.dialogflowFirebaseFulfillment.functions.https.onRequest”的構造函數的問題
const functions = require('firebase-functions');
const admin = require('firebase-admin');
const Firestore = require('@google-cloud/firestore');
const firestore = new Firestore();
const {WebhookClient} = require('dialogflow-fulfillment');
const {Card, Suggestion} = require('dialogflow-fulfillment');
process.env.DEBUG = 'dialogflow:debug'; // enables lib debugging statements
const array = require('array');
admin.initializeApp();
var db = admin.firestore();
var users = array();
const App = require('actions-on-google').DialogflowApp;
const NAME_ACTION = 'Welcome';
exports.dialogflowFirebaseFulfillment = functions.https.onRequest((request, response) => {
const app = new App({request, response});
console.log('Request headers: ' + JSON.stringify(request.headers));
console.log('Request body: ' + JSON.stringify(request.body));
let action = request.body.result.action; // https://dialogflow.com/docs/actions-and-parameters
console.log('Actions = '+ JSON.stringify(action));
let query = request.body.result.resolvedQuery;
const parameters = request.body.result.parameters; // https://dialogflow.com/docs/actions-and-parameters
const inputContexts = request.body.result.contexts; // https://dialogflow.com/docs/contexts
function makeName (app) {
// early age
let Name = app.getArgument(Name_Argument);
if(action === 'Welcome'){
var data = {
0: Name,
};
var setDoc = db.collection('data').doc('one').set(data);
}
}
let actionMap = new Map();
actionMap.set(NAME_ACTION, makeName);
app.handleRequest(actionMap);
function sendResponse (responseToUser) {
if (typeof responseToUser === 'string') {
let responseJson = {};
responseJson.text = responseToUser; // spoken response
responseJson.displayText = responseToUser; // displayed response
response.json(responseJson); // Send response to Dialogflow
} else {
let responseJson = {};
responseJson.text = responseToUser.text || responseToUser.displayText;
responseJson.displayText = responseToUser.displayText || responseToUser.text;
responseJson.data = responseToUser.richResponses;
responseJson.contextOut = responseToUser.outputContexts;
response.json(responseJson); // Send response to Dialogflow
}
}
});
檢查下面的代碼,
exports.dialogflowFirebaseFulfillment = functions.https.onRequest((request, response) => {
var name = 'test';
const app = new WebhookClient({ request, response });
console.log('Dialogflow Request headers: ' + JSON.stringify(request.headers));
console.log('Dialogflow Request body: ' + JSON.stringify(request.body));
使用const app = new WebhookClient({ request, response });
而不是const app = new App({request, response});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.