mirror of
https://github.com/SillyTavern/SillyTavern.git
synced 2025-01-07 07:06:05 +01:00
Use Express router for thumbnails endpoint
This commit is contained in:
parent
414c9bd5fb
commit
2d54a67a1f
@ -3587,8 +3587,8 @@ require('./src/endpoints/presets').registerEndpoints(app, jsonParser);
|
|||||||
// Secrets managemenet
|
// Secrets managemenet
|
||||||
require('./src/endpoints/secrets').registerEndpoints(app, jsonParser);
|
require('./src/endpoints/secrets').registerEndpoints(app, jsonParser);
|
||||||
|
|
||||||
// Thumbnail generation
|
// Thumbnail generation. These URLs are saved in chat, so this route cannot be renamed!
|
||||||
require('./src/endpoints/thumbnails').registerEndpoints(app, jsonParser);
|
app.use('/thumbnail', require('./src/endpoints/thumbnails').router);
|
||||||
|
|
||||||
// NovelAI generation
|
// NovelAI generation
|
||||||
require('./src/endpoints/novelai').registerEndpoints(app, jsonParser);
|
require('./src/endpoints/novelai').registerEndpoints(app, jsonParser);
|
||||||
|
@ -1,10 +1,12 @@
|
|||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
const express = require('express');
|
||||||
const sanitize = require('sanitize-filename');
|
const sanitize = require('sanitize-filename');
|
||||||
const jimp = require('jimp');
|
const jimp = require('jimp');
|
||||||
const writeFileAtomicSync = require('write-file-atomic').sync;
|
const writeFileAtomicSync = require('write-file-atomic').sync;
|
||||||
const { DIRECTORIES } = require('../constants');
|
const { DIRECTORIES } = require('../constants');
|
||||||
const { getConfigValue } = require('../util');
|
const { getConfigValue } = require('../util');
|
||||||
|
const { jsonParser } = require('../express-common');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a path to thumbnail folder based on the type.
|
* Gets a path to thumbnail folder based on the type.
|
||||||
@ -150,53 +152,46 @@ async function ensureThumbnailCache() {
|
|||||||
console.log(`Done! Generated: ${bgFiles.length} preview images`);
|
console.log(`Done! Generated: ${bgFiles.length} preview images`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
/**
|
// Important: This route must be mounted as '/thumbnail'. It is used in the client code and saved to chat files.
|
||||||
* Registers the endpoints for the thumbnail management.
|
router.get('/', jsonParser, async function (request, response) {
|
||||||
* @param {import('express').Express} app Express app
|
if (typeof request.query.file !== 'string' || typeof request.query.type !== 'string') return response.sendStatus(400);
|
||||||
* @param {any} jsonParser JSON parser middleware
|
|
||||||
*/
|
|
||||||
function registerEndpoints(app, jsonParser) {
|
|
||||||
// Important: Do not change a path to this endpoint. It is used in the client code and saved to chat files.
|
|
||||||
app.get('/thumbnail', jsonParser, async function (request, response) {
|
|
||||||
if (typeof request.query.file !== 'string' || typeof request.query.type !== 'string') return response.sendStatus(400);
|
|
||||||
|
|
||||||
const type = request.query.type;
|
const type = request.query.type;
|
||||||
const file = sanitize(request.query.file);
|
const file = sanitize(request.query.file);
|
||||||
|
|
||||||
if (!type || !file) {
|
if (!type || !file) {
|
||||||
return response.sendStatus(400);
|
return response.sendStatus(400);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(type == 'bg' || type == 'avatar')) {
|
if (!(type == 'bg' || type == 'avatar')) {
|
||||||
return response.sendStatus(400);
|
return response.sendStatus(400);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sanitize(file) !== file) {
|
if (sanitize(file) !== file) {
|
||||||
console.error('Malicious filename prevented');
|
console.error('Malicious filename prevented');
|
||||||
return response.sendStatus(403);
|
return response.sendStatus(403);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getConfigValue('disableThumbnails', false) == true) {
|
if (getConfigValue('disableThumbnails', false) == true) {
|
||||||
let folder = getOriginalFolder(type);
|
let folder = getOriginalFolder(type);
|
||||||
if (folder === undefined) return response.sendStatus(400);
|
if (folder === undefined) return response.sendStatus(400);
|
||||||
const pathToOriginalFile = path.join(folder, file);
|
const pathToOriginalFile = path.join(folder, file);
|
||||||
return response.sendFile(pathToOriginalFile, { root: process.cwd() });
|
return response.sendFile(pathToOriginalFile, { root: process.cwd() });
|
||||||
}
|
}
|
||||||
|
|
||||||
const pathToCachedFile = await generateThumbnail(type, file);
|
const pathToCachedFile = await generateThumbnail(type, file);
|
||||||
|
|
||||||
if (!pathToCachedFile) {
|
if (!pathToCachedFile) {
|
||||||
return response.sendStatus(404);
|
return response.sendStatus(404);
|
||||||
}
|
}
|
||||||
|
|
||||||
return response.sendFile(pathToCachedFile, { root: process.cwd() });
|
return response.sendFile(pathToCachedFile, { root: process.cwd() });
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
invalidateThumbnail,
|
invalidateThumbnail,
|
||||||
registerEndpoints,
|
|
||||||
ensureThumbnailCache,
|
ensureThumbnailCache,
|
||||||
|
router,
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user