Невозможно прочитать контекст при выполнении диалогового потока (неожиданно не определено) - PullRequest
5 голосов
/ 07 марта 2019

Мы создали агент Dialogflow с использованием облачных функций Google в качестве webhook, который работал должным образом до вчерашнего вечера.В то время я экспортировал агент, а затем снова импортировал его, и он некоторое время работал.

Что перестало работать, так это то, что agent.context.get('...'); (также agent.getContext('...')) действительно возвращает undefined, даже если установлен контекств соответствии с пользовательским интерфейсом и необработанным ответом API.

В качестве примера у меня есть намерение, у которого есть обязательный слот shop, включен веб-крючок для заполнения слотов.Когда я тестирую агента, намерение с именем info сопоставляется правильно, а также контекст info_dialog_params_store, кажется, там:

Intent

И здесьявляется частью выходного контекста в соответствии с необработанным ответом API:

"outputContexts": [
      {
        "name": "projects/MYAGENTNAME/agent/sessions/0b753e8e-b377-587b-3db6-3c8dc898879b/contexts/info_dialog_params_store",
        "lifespanCount": 1,
        "parameters": {
          "store": "",
          "store.original": "",
          "kpi": "counts",
          "date_or_period": "",
          "kpi.original": "trafico",
          "date_or_period.original": ""
        }
      }

В webhook я правильно сопоставил намерение с функцией js:

let intentMap = new Map();
intentMap.set('info', info);
agent.handleRequest(intentMap);

И первая строкаФункция info выглядит следующим образом:

function info(agent) {
    store_context = agent.context.get('info_dialog_params_store');
}

Что возвращает

TypeError: Cannot read property 'get' of undefined
    at info (/user_code/index.js:207:36)
    at WebhookClient.handleRequest (/user_code/node_modules/dialogflow-fulfillment/src/dialogflow-fulfillment.js:303:44)
    at exports.dialogflowFirebaseFulfillment.functions.https.onRequest (/user_code/index.js:382:9)
    at cloudFunction (/user_code/node_modules/firebase-functions/lib/providers/https.js:57:9)
    at /var/tmp/worker/worker.js:762:7
    at /var/tmp/worker/worker.js:745:11
    at _combinedTickCallback (internal/process/next_tick.js:73:7)
    at process._tickDomainCallback (internal/process/next_tick.js:128:9)

Я совершенно уверен, что я не изменил ничего, что могло бы повлиять на правильное функционирование агента, кроме некоторого рефакторинга.

Я также пробовал активировать и деактивировать бета-функции, когда читал, что могут быть проблемы со средами, но это ничего не изменило.

Кто-нибудь знает, в каком направлении я могу продолжить исследование

Ответы [ 2 ]

4 голосов
/ 06 мая 2019

У меня была такая же проблема, я решил ее, обновив диалоговое окно-выполнение в package.json:

из "dialogflow-выполнение": "^ 0.5.0" на "диалоговое выполнение-выполнение": "^ 0.6.0"

0 голосов
/ 08 марта 2019

На самом деле я мог бы исправить это следующими «волшебными» шагами:

  • Скопировал мою оригинальную функцию в текстовый файл
  • Скопируйте и вставьте исходный пример кода в редактор кода выполнения GUI ( Код на GitHub )
  • Развернутая функция
  • Создан минимальный пример для моей info функции:
function info(agent) {
    store_context = agent.context.get('info_dialog_params_store');
}
  • Протестировал, и все заработало
  • Скопировал обратно мой оригинальный код
  • Все снова было хорошо
...