LibreChat/api/server/routes/ask.js

174 lines
4.8 KiB
JavaScript
Raw Normal View History

2023-02-12 16:38:33 -05:00
const express = require('express');
const crypto = require('crypto');
const router = express.Router();
2023-02-25 09:04:32 -05:00
const askBing = require('./askBing');
2023-03-08 19:47:23 -05:00
const askSydney = require('./askSydney');
2023-03-03 15:52:06 -05:00
const {
titleConvo,
askClient,
browserClient,
customClient,
detectCode
} = require('../../app/');
const { getConvo, saveMessage, deleteMessagesSince, deleteMessages, saveConvo } = require('../../models');
2023-02-25 09:04:32 -05:00
const { handleError, sendMessage } = require('./handlers');
2023-02-12 16:38:33 -05:00
router.use('/bing', askBing);
router.use('/sydney', askSydney);
2023-02-12 16:38:33 -05:00
router.post('/', async (req, res) => {
let { model, text, parentMessageId, conversationId, chatGptLabel, promptPrefix } = req.body;
2023-03-11 12:10:00 -05:00
if (text.length === 0) {
return handleError(res, 'Prompt empty or too short');
2023-02-12 16:38:33 -05:00
}
const userMessageId = crypto.randomUUID();
const userParentMessageId = parentMessageId || '00000000-0000-0000-0000-000000000000'
let userMessage = {
messageId: userMessageId,
sender: 'User',
text,
parentMessageId: userParentMessageId,
conversationId,
isCreatedByUser: true
};
2023-02-12 16:38:33 -05:00
2023-03-03 15:52:06 -05:00
console.log('ask log', {
model,
...userMessage,
parentMessageId: userParentMessageId,
2023-03-03 15:52:06 -05:00
conversationId,
chatGptLabel,
promptPrefix
});
let client;
2023-02-12 16:38:33 -05:00
2023-03-03 15:52:06 -05:00
if (model === 'chatgpt') {
client = askClient;
} else if (model === 'chatgptCustom') {
client = customClient;
} else {
client = browserClient;
}
if (model === 'chatgptCustom' && !chatGptLabel && conversationId) {
const convo = await getConvo({ conversationId });
if (convo) {
console.log('found convo for custom gpt', { convo })
chatGptLabel = convo.chatGptLabel;
promptPrefix = convo.promptPrefix;
}
}
// if (messageId) {
// // existing conversation
// await saveMessage(userMessage);
// await deleteMessagesSince(userMessage);
// } else {}
2023-02-12 16:38:33 -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'
});
try {
let i = 0;
let tokens = '';
2023-02-12 16:38:33 -05:00
const progressCallback = async (partial) => {
if (i === 0 && typeof partial === 'object') {
2023-02-12 16:38:33 -05:00
userMessage.conversationId = conversationId ? conversationId : partial.conversationId;
await saveMessage(userMessage);
sendMessage(res, { ...partial, initial: true });
2023-02-12 16:38:33 -05:00
i++;
}
if (typeof partial === 'object') {
sendMessage(res, { ...partial, message: true });
} else {
2023-02-25 09:04:32 -05:00
tokens += partial === text ? '' : partial;
if (tokens.match(/^\n/)) {
tokens = tokens.replace(/^\n/, '');
}
if (tokens.includes('[DONE]')) {
tokens = tokens.replace('[DONE]', '');
}
2023-02-25 09:04:32 -05:00
// tokens = await detectCode(tokens);
2023-02-24 16:31:59 -05:00
sendMessage(res, { text: tokens, message: true, initial: i === 0 ? true : false });
i++;
}
2023-02-12 16:38:33 -05:00
};
let gptResponse = await client({
text,
progressCallback,
convo: {
parentMessageId: userParentMessageId,
conversationId
2023-03-03 15:52:06 -05:00
},
chatGptLabel,
promptPrefix
});
console.log('CLIENT RESPONSE', gptResponse);
if (!gptResponse.parentMessageId) {
gptResponse.text = gptResponse.response;
// gptResponse.id = gptResponse.messageId;
gptResponse.parentMessageId = userMessage.messageId;
userMessage.conversationId = conversationId
? conversationId
: gptResponse.conversationId;
await saveMessage(userMessage);
delete gptResponse.response;
}
2023-02-12 16:38:33 -05:00
if (
(gptResponse.text.includes('2023') && !gptResponse.text.trim().includes(' ')) ||
gptResponse.text.toLowerCase().includes('no response') ||
gptResponse.text.toLowerCase().includes('no answer')
2023-02-12 16:38:33 -05:00
) {
return handleError(res, 'Prompt empty or too short');
2023-02-12 16:38:33 -05:00
}
// if (!parentMessageId) {
// gptResponse.title = await titleConvo({
// model,
// message: text,
// response: JSON.stringify(gptResponse.text)
// });
// }
2023-03-03 15:52:06 -05:00
gptResponse.sender = model === 'chatgptCustom' ? chatGptLabel : model;
// gptResponse.final = true;
gptResponse.text = await detectCode(gptResponse.text);
if (chatGptLabel?.length > 0 && model === 'chatgptCustom') {
gptResponse.chatGptLabel = chatGptLabel;
}
if (promptPrefix?.length > 0 && model === 'chatgptCustom') {
gptResponse.promptPrefix = promptPrefix;
}
2023-02-12 16:38:33 -05:00
await saveMessage(gptResponse);
await saveConvo(gptResponse);
sendMessage(res, {
final: true,
requestMessage: userMessage,
responseMessage: gptResponse
});
2023-02-12 16:38:33 -05:00
res.end();
} catch (error) {
console.log(error);
await deleteMessages({ messageId: userMessageId });
handleError(res, error.message);
2023-02-12 16:38:33 -05:00
}
});
module.exports = router;