Spaces:
Running
Running
import fs from 'node:fs'; | |
import path from 'node:path'; | |
import express from 'express'; | |
import sanitize from 'sanitize-filename'; | |
import { invalidateThumbnail } from './thumbnails.js'; | |
import { getImages } from '../util.js'; | |
import { getFileNameValidationFunction } from '../middleware/validateFileName.js'; | |
export const router = express.Router(); | |
router.post('/all', function (request, response) { | |
var images = getImages(request.user.directories.backgrounds); | |
response.send(JSON.stringify(images)); | |
}); | |
router.post('/delete', getFileNameValidationFunction('bg'), function (request, response) { | |
if (!request.body) return response.sendStatus(400); | |
if (request.body.bg !== sanitize(request.body.bg)) { | |
console.error('Malicious bg name prevented'); | |
return response.sendStatus(403); | |
} | |
const fileName = path.join(request.user.directories.backgrounds, sanitize(request.body.bg)); | |
if (!fs.existsSync(fileName)) { | |
console.error('BG file not found'); | |
return response.sendStatus(400); | |
} | |
fs.rmSync(fileName); | |
invalidateThumbnail(request.user.directories, 'bg', request.body.bg); | |
return response.send('ok'); | |
}); | |
router.post('/rename', function (request, response) { | |
if (!request.body) return response.sendStatus(400); | |
const oldFileName = path.join(request.user.directories.backgrounds, sanitize(request.body.old_bg)); | |
const newFileName = path.join(request.user.directories.backgrounds, sanitize(request.body.new_bg)); | |
if (!fs.existsSync(oldFileName)) { | |
console.error('BG file not found'); | |
return response.sendStatus(400); | |
} | |
if (fs.existsSync(newFileName)) { | |
console.error('New BG file already exists'); | |
return response.sendStatus(400); | |
} | |
fs.copyFileSync(oldFileName, newFileName); | |
fs.rmSync(oldFileName); | |
invalidateThumbnail(request.user.directories, 'bg', request.body.old_bg); | |
return response.send('ok'); | |
}); | |
router.post('/upload', function (request, response) { | |
if (!request.body || !request.file) return response.sendStatus(400); | |
const img_path = path.join(request.file.destination, request.file.filename); | |
const filename = request.file.originalname; | |
try { | |
fs.copyFileSync(img_path, path.join(request.user.directories.backgrounds, filename)); | |
fs.rmSync(img_path); | |
invalidateThumbnail(request.user.directories, 'bg', filename); | |
response.send(filename); | |
} catch (err) { | |
console.error(err); | |
response.sendStatus(500); | |
} | |
}); | |