LibreChat/api/server/routes/presets.js
Danny Avila dbe4dd96b4
🧹 chore: Cleanup Logger and Utility Imports (#9935)
* 🧹 chore: Update logger imports to use @librechat/data-schemas across multiple files and remove unused sleep function from queue.js (#9930)

* chore: Replace local isEnabled utility with @librechat/api import across multiple files, update test files

* chore: Replace local logger import with @librechat/data-schemas logger in countTokens.js and fork.js

* chore: Update logs volume path in docker-compose.yml to correct directory

* chore: import order of isEnabled in static.js
2025-10-01 23:30:47 -04:00

48 lines
1.4 KiB
JavaScript

const crypto = require('crypto');
const express = require('express');
const { logger } = require('@librechat/data-schemas');
const { getPresets, savePreset, deletePresets } = require('~/models');
const requireJwtAuth = require('~/server/middleware/requireJwtAuth');
const router = express.Router();
router.use(requireJwtAuth);
router.get('/', async (req, res) => {
const presets = (await getPresets(req.user.id)).map((preset) => preset);
res.status(200).json(presets);
});
router.post('/', async (req, res) => {
const update = req.body || {};
update.presetId = update?.presetId || crypto.randomUUID();
try {
const preset = await savePreset(req.user.id, update);
res.status(201).json(preset);
} catch (error) {
logger.error('[/presets] error saving preset', error);
res.status(500).send('There was an error when saving the preset');
}
});
router.post('/delete', async (req, res) => {
let filter = {};
const { presetId } = req.body || {};
if (presetId) {
filter = { presetId };
}
logger.debug('[/presets/delete] delete preset filter', filter);
try {
const deleteCount = await deletePresets(req.user.id, filter);
res.status(201).json(deleteCount);
} catch (error) {
logger.error('[/presets/delete] error deleting presets', error);
res.status(500).send('There was an error deleting the presets');
}
});
module.exports = router;