簡體   English   中英

如何使用雲功能通過webhook將Dialogflow中的用戶響應保存到google雲端防火牆

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM