mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 08:20:14 +01:00
* 🧹 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
42 lines
1.4 KiB
JavaScript
42 lines
1.4 KiB
JavaScript
const multer = require('multer');
|
|
const express = require('express');
|
|
const { logger } = require('@librechat/data-schemas');
|
|
const { CacheKeys } = require('librechat-data-provider');
|
|
const { getVoices, streamAudio, textToSpeech } = require('~/server/services/Files/Audio');
|
|
const { getLogStores } = require('~/cache');
|
|
|
|
const router = express.Router();
|
|
const upload = multer();
|
|
|
|
router.post('/manual', upload.none(), async (req, res) => {
|
|
await textToSpeech(req, res);
|
|
});
|
|
|
|
const logDebugMessage = (req, message) =>
|
|
logger.debug(`[streamAudio] user: ${req?.user?.id ?? 'UNDEFINED_USER'} | ${message}`);
|
|
|
|
// TODO: test caching
|
|
router.post('/', async (req, res) => {
|
|
try {
|
|
const audioRunsCache = getLogStores(CacheKeys.AUDIO_RUNS);
|
|
const audioRun = await audioRunsCache.get(req.body.runId);
|
|
logDebugMessage(req, 'start stream audio');
|
|
if (audioRun) {
|
|
logDebugMessage(req, 'stream audio already running');
|
|
return res.status(401).json({ error: 'Audio stream already running' });
|
|
}
|
|
audioRunsCache.set(req.body.runId, true);
|
|
await streamAudio(req, res);
|
|
logDebugMessage(req, 'end stream audio');
|
|
res.status(200).end();
|
|
} catch (error) {
|
|
logger.error(`[streamAudio] user: ${req.user.id} | Failed to stream audio: ${error}`);
|
|
res.status(500).json({ error: 'Failed to stream audio' });
|
|
}
|
|
});
|
|
|
|
router.get('/voices', async (req, res) => {
|
|
await getVoices(req, res);
|
|
});
|
|
|
|
module.exports = router;
|