mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 00:40:14 +01:00
wip: feat: abort messages and continue conversation
fix(addToCache.js): remove unused variables and parameters feat(addToCache.js): add message to cache with id, parentMessageId, role, and text fix(askOpenAI.js): remove parentMessageId parameter from addToCache call feat(MessageHandler.jsx): add latestMessage to store on cancel of submission, and generate messageId and parentMessageId for latestMessage
This commit is contained in:
parent
a81bd27b39
commit
a953fc9f2b
3 changed files with 25 additions and 22 deletions
|
|
@ -1,21 +1,16 @@
|
|||
const Keyv = require('keyv');
|
||||
const { KeyvFile } = require('keyv-file');
|
||||
const crypto = require('crypto');
|
||||
const { saveMessage } = require('../../../models');
|
||||
|
||||
const addToCache = async ({
|
||||
endpointOption,
|
||||
conversationId,
|
||||
userMessage,
|
||||
latestMessage,
|
||||
parentMessageId
|
||||
}) => {
|
||||
const addToCache = async ({ endpointOption, userMessage, latestMessage }) => {
|
||||
try {
|
||||
const conversationsCache = new Keyv({
|
||||
store: new KeyvFile({ filename: './data/cache.json' }),
|
||||
namespace: 'chatgpt', // should be 'bing' for bing/sydney
|
||||
namespace: 'chatgpt' // should be 'bing' for bing/sydney
|
||||
});
|
||||
|
||||
const { conversationId, messageId, parentMessageId, text } = latestMessage;
|
||||
|
||||
let conversation = await conversationsCache.get(conversationId);
|
||||
// used to generate a title for the conversation if none exists
|
||||
// let isNewConversation = false;
|
||||
|
|
@ -38,13 +33,13 @@ const addToCache = async ({
|
|||
}
|
||||
};
|
||||
|
||||
const messageId = crypto.randomUUID();
|
||||
// const messageId = crypto.randomUUID();
|
||||
|
||||
let responseMessage = {
|
||||
id: messageId,
|
||||
parentMessageId,
|
||||
role: roles(endpointOption),
|
||||
message: latestMessage
|
||||
message: text
|
||||
};
|
||||
|
||||
await saveMessage({
|
||||
|
|
@ -52,7 +47,7 @@ const addToCache = async ({
|
|||
conversationId,
|
||||
messageId,
|
||||
sender: responseMessage.role,
|
||||
text: latestMessage
|
||||
text
|
||||
});
|
||||
|
||||
conversation.messages.push(userMessage, responseMessage);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue