Контекст диалогового потока неожиданно не определен

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

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

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

А вот часть выходного контекста в соответствии с необработанным ответом 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 ответа

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

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

Я решил проблему, отключив "Бета-функции", введите описание изображения здесь

На самом деле я мог бы исправить это с помощью следующих "магических" шагов:

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