Контекст диалогового потока неожиданно не определен
Мы создали агента 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');
}
- Протестировал и все заработало
- Скопировал обратно мой оригинальный код
- Все снова было хорошо