mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 08:12:00 +02:00
feat: add preset in server
This commit is contained in:
parent
d76efa7874
commit
80ef5008dd
8 changed files with 224 additions and 72 deletions
46
api/models/Preset.js
Normal file
46
api/models/Preset.js
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
const Preset = require('./schema/presetSchema');
|
||||||
|
|
||||||
|
const getPreset = async (user, presetId) => {
|
||||||
|
try {
|
||||||
|
return await Preset.findOne({ user, presetId }).exec();
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
return { message: 'Error getting single preset' };
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
Preset,
|
||||||
|
getPreset,
|
||||||
|
getPresets: async (user, filter) => {
|
||||||
|
try {
|
||||||
|
return await Preset.find({ ...filter, user }).exec();
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
return { message: 'Error retriving presets' };
|
||||||
|
}
|
||||||
|
},
|
||||||
|
savePreset: async (user, { presetId, newPresetId, ...preset }) => {
|
||||||
|
try {
|
||||||
|
const update = { presetId, ...preset };
|
||||||
|
if (newPresetId) {
|
||||||
|
update.presetId = newPresetId;
|
||||||
|
}
|
||||||
|
|
||||||
|
return await Preset.findOneAndUpdate(
|
||||||
|
{ presetId, user },
|
||||||
|
{ $set: update },
|
||||||
|
{ new: true, upsert: true }
|
||||||
|
).exec();
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
return { message: 'Error saving preset' };
|
||||||
|
}
|
||||||
|
},
|
||||||
|
deletePresets: async (user, filter) => {
|
||||||
|
let toRemove = await Preset.find({ ...filter, user }).select('presetId');
|
||||||
|
const ids = toRemove.map(instance => instance.presetId);
|
||||||
|
let deleteCount = await Preset.deleteMany({ ...filter, user }).exec();
|
||||||
|
return deleteCount;
|
||||||
|
}
|
||||||
|
};
|
|
@ -1,6 +1,13 @@
|
||||||
const { getMessages, saveMessage, saveBingMessage, deleteMessagesSince, deleteMessages } = require('./Message');
|
const {
|
||||||
|
getMessages,
|
||||||
|
saveMessage,
|
||||||
|
saveBingMessage,
|
||||||
|
deleteMessagesSince,
|
||||||
|
deleteMessages
|
||||||
|
} = require('./Message');
|
||||||
const { getCustomGpts, updateCustomGpt, updateByLabel, deleteCustomGpts } = require('./CustomGpt');
|
const { getCustomGpts, updateCustomGpt, updateByLabel, deleteCustomGpts } = require('./CustomGpt');
|
||||||
const { getConvoTitle, getConvo, saveConvo, updateConvo } = require('./Conversation');
|
const { getConvoTitle, getConvo, saveConvo, updateConvo } = require('./Conversation');
|
||||||
|
const { getPreset, getPresets, savePreset, deletePresets } = require('./Preset');
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
getMessages,
|
getMessages,
|
||||||
|
@ -8,12 +15,19 @@ module.exports = {
|
||||||
saveBingMessage,
|
saveBingMessage,
|
||||||
deleteMessagesSince,
|
deleteMessagesSince,
|
||||||
deleteMessages,
|
deleteMessages,
|
||||||
|
|
||||||
getConvoTitle,
|
getConvoTitle,
|
||||||
getConvo,
|
getConvo,
|
||||||
saveConvo,
|
saveConvo,
|
||||||
updateConvo,
|
updateConvo,
|
||||||
|
|
||||||
getCustomGpts,
|
getCustomGpts,
|
||||||
updateCustomGpt,
|
updateCustomGpt,
|
||||||
updateByLabel,
|
updateByLabel,
|
||||||
deleteCustomGpts
|
deleteCustomGpts,
|
||||||
|
|
||||||
|
getPreset,
|
||||||
|
getPresets,
|
||||||
|
savePreset,
|
||||||
|
deletePresets
|
||||||
};
|
};
|
||||||
|
|
70
api/models/schema/conversationPreset.js
Normal file
70
api/models/schema/conversationPreset.js
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
module.exports = {
|
||||||
|
// endpoint: [azureOpenAI, openAI, bingAI, chatGPTBrowser]
|
||||||
|
endpoint: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
required: true
|
||||||
|
},
|
||||||
|
// for azureOpenAI, openAI, chatGPTBrowser only
|
||||||
|
model: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
// for azureOpenAI, openAI only
|
||||||
|
chatGptLabel: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
promptPrefix: {
|
||||||
|
type: String,
|
||||||
|
default: null,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
temperature: {
|
||||||
|
type: Number,
|
||||||
|
default: 1,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
top_p: {
|
||||||
|
type: Number,
|
||||||
|
default: 1,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
presence_penalty: {
|
||||||
|
type: Number,
|
||||||
|
default: 0,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
frequency_penalty: {
|
||||||
|
type: Number,
|
||||||
|
default: 0,
|
||||||
|
required: false
|
||||||
|
},
|
||||||
|
// for bingai only
|
||||||
|
jailbreak: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
jailbreakConversationId: {
|
||||||
|
type: String,
|
||||||
|
default: null
|
||||||
|
},
|
||||||
|
conversationSignature: {
|
||||||
|
type: String,
|
||||||
|
default: null
|
||||||
|
},
|
||||||
|
clientId: {
|
||||||
|
type: String,
|
||||||
|
default: null
|
||||||
|
},
|
||||||
|
invocationId: {
|
||||||
|
type: Number,
|
||||||
|
default: 1
|
||||||
|
},
|
||||||
|
toneStyle: {
|
||||||
|
type: String,
|
||||||
|
default: null
|
||||||
|
}
|
||||||
|
};
|
|
@ -1,5 +1,6 @@
|
||||||
const mongoose = require('mongoose');
|
const mongoose = require('mongoose');
|
||||||
const mongoMeili = require('../plugins/mongoMeili');
|
const mongoMeili = require('../plugins/mongoMeili');
|
||||||
|
const conversationPreset = require('./conversationPreset');
|
||||||
const convoSchema = mongoose.Schema(
|
const convoSchema = mongoose.Schema(
|
||||||
{
|
{
|
||||||
conversationId: {
|
conversationId: {
|
||||||
|
@ -19,74 +20,7 @@ const convoSchema = mongoose.Schema(
|
||||||
default: null
|
default: null
|
||||||
},
|
},
|
||||||
messages: [{ type: mongoose.Schema.Types.ObjectId, ref: 'Message' }],
|
messages: [{ type: mongoose.Schema.Types.ObjectId, ref: 'Message' }],
|
||||||
// endpoint: [azureOpenAI, openAI, bingAI, chatGPTBrowser]
|
...conversationPreset
|
||||||
endpoint: {
|
|
||||||
type: String,
|
|
||||||
default: null,
|
|
||||||
required: true
|
|
||||||
},
|
|
||||||
// for azureOpenAI, openAI, chatGPTBrowser only
|
|
||||||
model: {
|
|
||||||
type: String,
|
|
||||||
default: null,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
// for azureOpenAI, openAI only
|
|
||||||
chatGptLabel: {
|
|
||||||
type: String,
|
|
||||||
default: null,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
promptPrefix: {
|
|
||||||
type: String,
|
|
||||||
default: null,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
temperature: {
|
|
||||||
type: Number,
|
|
||||||
default: 1,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
top_p: {
|
|
||||||
type: Number,
|
|
||||||
default: 1,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
presence_penalty: {
|
|
||||||
type: Number,
|
|
||||||
default: 0,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
frequency_penalty: {
|
|
||||||
type: Number,
|
|
||||||
default: 0,
|
|
||||||
required: false
|
|
||||||
},
|
|
||||||
// for bingai only
|
|
||||||
jailbreak: {
|
|
||||||
type: Boolean,
|
|
||||||
default: false
|
|
||||||
},
|
|
||||||
jailbreakConversationId: {
|
|
||||||
type: String,
|
|
||||||
default: null
|
|
||||||
},
|
|
||||||
conversationSignature: {
|
|
||||||
type: String,
|
|
||||||
default: null
|
|
||||||
},
|
|
||||||
clientId: {
|
|
||||||
type: String,
|
|
||||||
default: null
|
|
||||||
},
|
|
||||||
invocationId: {
|
|
||||||
type: Number,
|
|
||||||
default: 1
|
|
||||||
},
|
|
||||||
toneStyle: {
|
|
||||||
type: String,
|
|
||||||
default: null
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{ timestamps: true }
|
{ timestamps: true }
|
||||||
);
|
);
|
||||||
|
|
27
api/models/schema/presetSchema.js
Normal file
27
api/models/schema/presetSchema.js
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
const mongoose = require('mongoose');
|
||||||
|
const conversationPreset = require('./conversationPreset');
|
||||||
|
const presetSchema = mongoose.Schema(
|
||||||
|
{
|
||||||
|
presetId: {
|
||||||
|
type: String,
|
||||||
|
unique: true,
|
||||||
|
required: true,
|
||||||
|
index: true
|
||||||
|
},
|
||||||
|
title: {
|
||||||
|
type: String,
|
||||||
|
default: 'New Chat',
|
||||||
|
meiliIndex: true
|
||||||
|
},
|
||||||
|
user: {
|
||||||
|
type: String,
|
||||||
|
default: null
|
||||||
|
},
|
||||||
|
...conversationPreset
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
const Preset = mongoose.models.Preset || mongoose.model('Preset', presetSchema);
|
||||||
|
|
||||||
|
module.exports = Preset;
|
|
@ -57,6 +57,7 @@ const projectPath = path.join(__dirname, '..', '..', 'client');
|
||||||
app.use('/api/messages', routes.authenticatedOr401, routes.messages);
|
app.use('/api/messages', routes.authenticatedOr401, routes.messages);
|
||||||
app.use('/api/convos', routes.authenticatedOr401, routes.convos);
|
app.use('/api/convos', routes.authenticatedOr401, routes.convos);
|
||||||
app.use('/api/customGpts', routes.authenticatedOr401, routes.customGpts);
|
app.use('/api/customGpts', routes.authenticatedOr401, routes.customGpts);
|
||||||
|
app.use('/api/presets', routes.authenticatedOr401, routes.presets);
|
||||||
app.use('/api/prompts', routes.authenticatedOr401, routes.prompts);
|
app.use('/api/prompts', routes.authenticatedOr401, routes.prompts);
|
||||||
app.use('/auth', routes.auth);
|
app.use('/auth', routes.auth);
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,21 @@
|
||||||
const ask = require('./ask');
|
const ask = require('./ask');
|
||||||
const messages = require('./messages');
|
const messages = require('./messages');
|
||||||
const convos = require('./convos');
|
const convos = require('./convos');
|
||||||
|
const presets = require('./presets');
|
||||||
const customGpts = require('./customGpts');
|
const customGpts = require('./customGpts');
|
||||||
const prompts = require('./prompts');
|
const prompts = require('./prompts');
|
||||||
const search = require('./search');
|
const search = require('./search');
|
||||||
const { router: auth, authenticatedOr401, authenticatedOrRedirect } = require('./auth');
|
const { router: auth, authenticatedOr401, authenticatedOrRedirect } = require('./auth');
|
||||||
|
|
||||||
module.exports = { search, ask, messages, convos, customGpts, prompts, auth, authenticatedOr401, authenticatedOrRedirect };
|
module.exports = {
|
||||||
|
search,
|
||||||
|
ask,
|
||||||
|
messages,
|
||||||
|
convos,
|
||||||
|
presets,
|
||||||
|
customGpts,
|
||||||
|
prompts,
|
||||||
|
auth,
|
||||||
|
authenticatedOr401,
|
||||||
|
authenticatedOrRedirect
|
||||||
|
};
|
||||||
|
|
48
api/server/routes/presets.js
Normal file
48
api/server/routes/presets.js
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
const express = require('express');
|
||||||
|
const router = express.Router();
|
||||||
|
const { getPreset, getPresets, savePreset, deletePresets } = require('../../models');
|
||||||
|
const crypto = require('crypto');
|
||||||
|
|
||||||
|
router.get('/', async (req, res) => {
|
||||||
|
const presets = (await getPresets(req?.session?.user?.username)).map(preset => {
|
||||||
|
return preset.toObject();
|
||||||
|
});
|
||||||
|
res.status(200).send(presets);
|
||||||
|
});
|
||||||
|
|
||||||
|
router.post('/', async (req, res) => {
|
||||||
|
const update = req.body || {};
|
||||||
|
|
||||||
|
update.presetId = update?.presetId || crypto.randomUUID();
|
||||||
|
|
||||||
|
try {
|
||||||
|
await savePreset(req?.session?.user?.username, update);
|
||||||
|
|
||||||
|
const presets = (await getPresets(req?.session?.user?.username)).map(preset => {
|
||||||
|
return preset.toObject();
|
||||||
|
});
|
||||||
|
res.status(201).send(presets);
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
res.status(500).send(error);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
router.post('/delete', async (req, res) => {
|
||||||
|
const { arg } = req.body;
|
||||||
|
|
||||||
|
try {
|
||||||
|
await deletePresets(req?.session?.user?.username, arg);
|
||||||
|
|
||||||
|
const presets = (await getPresets(req?.session?.user?.username)).map(preset => {
|
||||||
|
return preset.toObject();
|
||||||
|
});
|
||||||
|
res.status(201).send(presets);
|
||||||
|
// res.status(201).send(dbResponse);
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error);
|
||||||
|
res.status(500).send(error);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
Loading…
Add table
Add a link
Reference in a new issue