развертывание моего кода встроенного редактора в Dialogflow Essentials для отображения веб-страницы

#actions-on-google

#действия в Google

Вопрос:

Я хочу, чтобы мое приложение отображало веб-страницу при запуске моего AoG, но я не мог понять, как сделать это возможным с помощью моего кода. Вот мой код :

 'use strict';
 
const functions = require('firebase-functions');
const {WebhookClient} = require('dialogflow-fulfillment');
const {Card, Suggestion} = require('dialogflow-fulfillment');
const {dialogflow, HtmlResponse} = require('actions-on-google');
const CANVAS_URL = 'http://www.example.com';

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!`);
    agent.add(new Canvas({
      url: CANVAS_URL,
    }));
  }
 
  function fallback(agent) {
    agent.add(`Fullfillment_Fallback`);
  }


  // Run the proper function handler based on the matched Dialogflow intent name
  let intentMap = new Map();
  intentMap.set('Default Welcome Intent', welcome);
  intentMap.set('Default Fallback Intent', fallback);
  agent.handleRequest(intentMap);
});
  

Ответ №1:

Эй, похоже, вы смешиваете несколько библиотек программирования таким образом, что это не работает. Давайте упростим это только до использования actions-on-google . Обратите внимание, что некоторые похожие концепции называются по-разному.

В actions-on-google библиотеке Canvas элементу присваивается имя HtmlResponse .

 'use strict';
 
const functions = require('firebase-functions');
const {dialogflow, HtmlResponse} = require('actions-on-google');
const CANVAS_URL = 'http://www.example.com';

process.env.DEBUG = 'dialogflow:debug'; // enables lib debugging statements

const app = dialogflow({debug: true});

app.intent('Default Welcome Intent', conv => {
    conv.ask('Welcome to my agent!');
    conv.ask(new HtmlResponse({
        url: CANVAS_URL,
    });
});

app.intent('Default Fallback Intent', conv => {
    conv.ask('Fullfillment_Fallback');
});

exports.dialogflowFirebaseFulfillment = functions.https.onRequest(app);
  

Комментарии:

1. Возможно, вы захотите посмотреть документы о том, как включить это в консоли.