Перейти к основному содержимому

rag.chat.processQuery

Метод генерирует ответ на запрос пользователя в рамках чата. При ответе учитывается история в чате базы знаний.

Синтаксис

Метод принимает 4 аргумента:

АргументТипОписаниеОбязательный
secretNameСтрокаНазвание токена для базы знаний.Да
chatIdЧисло

chatId — идентификатор чата.

Вы можете получить идентификатор с помощью $rag.chat.create.
Да
queryСтрокаТекстовый запрос пользователя.Да
settingsОбъектНастройки обработки запроса. По умолчанию используются настройки из проекта Jay Knowledge Hub.Нет
подсказка

Формат settings совпадает с форматом одноименного объекта в запросе POST /api/knowledge-hub/chat/{chatId}/query в Jay Knowledge Hub API.

Метод доступен только в среде ECMAScript 6 и является асинхронным:

await $rag.query.processQuery(secretName, chatId, query, settings);

Возвращаемое значение

Метод возвращает объект с результатом обработки запроса. Поле response содержит ответ на вопрос пользователя.

{
"id": 11111,
"chatId": 12345,
"request": "Что делает сервис Example",
"status": "FINISHED",
"createdAt": "2024-12-03T16:43:30.279222Z",
"response": "Сервис Example обрабатывает запросы пользователей …",
"updatedAt": "2024-12-03T16:44:42.774798Z",
"comment": null
}

Объект имеет такой же формат, как ответ на запрос POST /api/knowledge-hub/chat/{chatId}/query в Jay Knowledge Hub API.

Использование в сценарии

state: Answer
intent!: /вопрос
scriptEs6:
$client.chat = $client.chat || await $rag.chat.create("MyKnowledgeHub", "Мой чат");

$rag.chat.processQuery("MyKnowledgeHub", $client.chat.id, $request.query)
.then(chatResponse => {
$conversationApi.sendTextToClient(chatResponse.response);
})
.catch(error => {
$conversationApi.sendTextToClient("Произошла ошибка: " + error);
});

В этом стейте:

  1. Если чата еще нет, бот создает чат.
  2. Бот отправляет пользователю ответ из базы знаний.
подсказка

Примеры работы с базой знаний и различные варианты вызова смотрите в статье Использование в сценарии.