| 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.unlinkSync(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.unlinkSync(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.unlinkSync(img_path); | |
| invalidateThumbnail(request.user.directories, 'bg', filename); | |
| response.send(filename); | |
| } catch (err) { | |
| console.error(err); | |
| response.sendStatus(500); | |
| } | |
| }); | |