54 lines
1.0 KiB
JavaScript
54 lines
1.0 KiB
JavaScript
"use strict";
|
|
|
|
var express = require('express');
|
|
var router = express.Router();
|
|
var _ = require('lodash');
|
|
|
|
var validPathRe = new RegExp("^([a-z0-9\\/-]+\\.[a-z0-9]+)$");
|
|
var validPathThumbsRe = new RegExp("^([0-9]+\\.png)$");
|
|
|
|
// ==========================================
|
|
// SERVE UPLOADS FILES
|
|
// ==========================================
|
|
|
|
router.get('/t/*', (req, res, next) => {
|
|
|
|
let fileName = req.params[0];
|
|
if(!validPathThumbsRe.test(fileName)) {
|
|
return res.sendStatus(404).end();
|
|
}
|
|
|
|
//todo: Authentication-based access
|
|
|
|
res.sendFile(fileName, {
|
|
root: lcdata.getThumbsPath(),
|
|
dotfiles: 'deny'
|
|
}, (err) => {
|
|
if (err) {
|
|
res.status(err.status).end();
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
router.get('/*', (req, res, next) => {
|
|
|
|
let fileName = req.params[0];
|
|
if(!validPathRe.test(fileName)) {
|
|
return res.sendStatus(404).end();
|
|
}
|
|
|
|
//todo: Authentication-based access
|
|
|
|
res.sendFile(fileName, {
|
|
root: git.getRepoPath() + '/uploads/',
|
|
dotfiles: 'deny'
|
|
}, (err) => {
|
|
if (err) {
|
|
res.status(err.status).end();
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
module.exports = router; |