LibreChat/api/server/routes/askBing.js

115 lines
3.4 KiB
JavaScript
Raw Normal View History

2023-02-25 09:04:32 -05:00
const express = require('express');
const crypto = require('crypto');
const router = express.Router();
2023-03-09 18:42:36 -05:00
const { titleConvo, getCitations, citeText, askBing } = require('../../app/');
const { saveMessage, getConvoTitle, saveConvo } = require('../../models');
2023-02-25 09:04:32 -05:00
const { handleError, sendMessage } = require('./handlers');
2023-03-09 18:42:36 -05:00
const citationRegex = /\[\^\d+?\^]/g;
2023-02-25 09:04:32 -05:00
router.post('/', async (req, res) => {
const { model, text, parentMessageId, conversationId: oldConversationId, ...convo } = req.body;
2023-03-11 12:10:00 -05:00
if (text.length === 0) {
2023-02-25 09:04:32 -05:00
return handleError(res, 'Prompt empty or too short');
}
const conversationId = oldConversationId || crypto.randomUUID();
2023-02-25 09:04:32 -05:00
const userMessageId = messageId;
const userParentMessageId = parentMessageId || '00000000-0000-0000-0000-000000000000'
let userMessage = {
messageId: userMessageId,
sender: 'User',
text,
parentMessageId: userParentMessageId,
conversationId,
isCreatedByUser: true
};
2023-02-25 09:04:32 -05:00
console.log('ask log', {
model,
...userMessage,
...convo
});
2023-02-25 09:04:32 -05:00
res.writeHead(200, {
Connection: 'keep-alive',
'Content-Type': 'text/event-stream',
'Cache-Control': 'no-cache, no-transform',
'Access-Control-Allow-Origin': '*',
'X-Accel-Buffering': 'no'
});
await saveMessage(userMessage);
await saveConvo({ ...userMessage, model, chatGptLabel, promptPrefix });
sendMessage(res, { message: userMessage, created: true });
2023-02-25 09:04:32 -05:00
try {
let tokens = '';
const progressCallback = async (partial) => {
tokens += partial === text ? '' : partial;
// tokens = appendCode(tokens);
2023-03-09 18:42:36 -05:00
tokens = citeText(tokens, true);
2023-02-25 09:04:32 -05:00
sendMessage(res, { text: tokens, message: true });
};
let response = await askBing({
text,
progressCallback,
convo: {
parentMessageId: userParentMessageId,
conversationId,
...convo
},
2023-02-25 09:04:32 -05:00
});
console.log('BING RESPONSE');
2023-03-09 18:42:36 -05:00
// console.dir(response, { depth: null });
2023-03-09 20:29:44 -05:00
const hasCitations = response.response.match(citationRegex)?.length > 0;
2023-02-25 09:04:32 -05:00
userMessage.conversationSignature =
convo.conversationSignature || response.conversationSignature;
userMessage.conversationId = conversationId || response.conversationId;
2023-02-25 09:04:32 -05:00
userMessage.invocationId = response.invocationId;
await saveMessage(userMessage);
// if (!convo.conversationSignature) {
// response.title = await titleConvo({
// model,
// message: text,
// response: JSON.stringify(response.response)
// });
// }
2023-02-25 09:04:32 -05:00
response.text = response.response;
2023-03-09 18:42:36 -05:00
delete response.response;
// response.id = response.details.messageId;
2023-02-25 09:04:32 -05:00
response.suggestions =
response.details.suggestedResponses &&
response.details.suggestedResponses.map((s) => s.text);
response.sender = model;
response.parentMessageId = gptResponse.parentMessageId || userMessage.messageId
// response.final = true;
2023-03-09 18:42:36 -05:00
const links = getCitations(response);
response.text =
citeText(response) +
(links?.length > 0 && hasCitations ? `\n<small>${links}</small>` : '');
2023-02-25 09:04:32 -05:00
await saveMessage(response);
await saveConvo(response);
sendMessage(res, {
title: await getConvoTitle(conversationId),
final: true,
requestMessage: userMessage,
responseMessage: gptResponse
});
2023-02-25 09:04:32 -05:00
res.end();
} catch (error) {
console.log(error);
// await deleteMessages({ messageId: userMessageId });
2023-02-25 09:04:32 -05:00
handleError(res, error.message);
}
});
module.exports = router;