Disable /admin* endpoints when no adminPass is set
This commit is contained in:
@@ -55,11 +55,13 @@ app.get('/config.json', (req, res) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
app.get('/admin', (req, res) => {
|
app.get('/admin', (req, res, next) => {
|
||||||
|
if(!config.adminPass) return next();
|
||||||
res.sendFile(path.join(__dirname, '../public/html/admin.html'));
|
res.sendFile(path.join(__dirname, '../public/html/admin.html'));
|
||||||
});
|
});
|
||||||
app.get('/admin/data.json', (req, res) => {
|
app.get('/admin/data.json', (req, res, next) => {
|
||||||
if(!config.adminPass || !req.get('x-passwd')) return res.status(401).send('Unauthorized');
|
if(!config.adminPass) return next();
|
||||||
|
if(!req.get('x-passwd')) return res.status(401).send('Unauthorized');
|
||||||
if(req.get('x-passwd') !== config.adminPass) return res.status(403).send('Forbidden');
|
if(req.get('x-passwd') !== config.adminPass) return res.status(403).send('Forbidden');
|
||||||
|
|
||||||
const result = _.chain(db.db)
|
const result = _.chain(db.db)
|
||||||
@@ -77,7 +79,10 @@ app.get('/admin/data.json', (req, res) => {
|
|||||||
})
|
})
|
||||||
.value();
|
.value();
|
||||||
|
|
||||||
res.json(result);
|
// make bruteforce attack more difficult
|
||||||
|
setTimeout(() => {
|
||||||
|
res.json(result);
|
||||||
|
},250);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user