2017-10-03 22:48:26 +00:00
|
|
|
const config = require('./config.js');
|
|
|
|
const api = require('./routes/api.js');
|
|
|
|
const album = require('./routes/album.js');
|
|
|
|
const express = require('express');
|
|
|
|
const helmet = require('helmet');
|
|
|
|
const bodyParser = require('body-parser');
|
|
|
|
const RateLimit = require('express-rate-limit');
|
|
|
|
const db = require('knex')(config.database);
|
|
|
|
const fs = require('fs');
|
|
|
|
const exphbs = require('express-handlebars');
|
|
|
|
const safe = express();
|
2017-01-13 07:34:21 +00:00
|
|
|
|
2017-10-04 03:59:18 +00:00
|
|
|
require('./database/db.js')(db);
|
2017-01-14 08:50:18 +00:00
|
|
|
|
2018-01-23 18:00:55 +00:00
|
|
|
fs.existsSync('./pages/custom') || fs.mkdirSync('./pages/custom');
|
|
|
|
fs.existsSync(`./${config.logsFolder}`) || fs.mkdirSync(`./${ config.logsFolder}`);
|
|
|
|
fs.existsSync(`./${config.uploads.folder}`) || fs.mkdirSync(`./${config.uploads.folder}`);
|
|
|
|
fs.existsSync(`./${config.uploads.folder}/thumbs`) || fs.mkdirSync(`./${config.uploads.folder }/thumbs`);
|
|
|
|
fs.existsSync(`./${config.uploads.folder }/zips`) || fs.mkdirSync(`./${config.uploads.folder}/zips`);
|
2017-01-13 07:34:21 +00:00
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.use(helmet());
|
|
|
|
safe.set('trust proxy', 1);
|
2017-02-01 22:46:10 +00:00
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.engine('handlebars', exphbs({ defaultLayout: 'main' }));
|
|
|
|
safe.set('view engine', 'handlebars');
|
|
|
|
safe.enable('view cache');
|
2017-09-20 06:03:31 +00:00
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
let limiter = new RateLimit({ windowMs: 5000, max: 2 });
|
|
|
|
safe.use('/api/login/', limiter);
|
|
|
|
safe.use('/api/register/', limiter);
|
2017-02-01 22:56:47 +00:00
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.use(bodyParser.urlencoded({ extended: true }));
|
|
|
|
safe.use(bodyParser.json());
|
2017-01-19 05:37:35 +00:00
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
if (config.serveFilesWithNode) {
|
2017-10-04 02:45:23 +00:00
|
|
|
safe.use('/', express.static(config.uploads.folder));
|
2017-10-03 22:48:26 +00:00
|
|
|
}
|
2017-09-20 06:03:31 +00:00
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.use('/', express.static('./public'));
|
|
|
|
safe.use('/', album);
|
|
|
|
safe.use('/api', api);
|
2017-01-14 06:01:23 +00:00
|
|
|
|
2017-03-17 04:14:24 +00:00
|
|
|
for (let page of config.pages) {
|
2017-10-03 22:48:26 +00:00
|
|
|
let root = './pages/';
|
2017-03-17 04:14:24 +00:00
|
|
|
if (fs.existsSync(`./pages/custom/${page}.html`)) {
|
2017-10-03 22:48:26 +00:00
|
|
|
root = './pages/custom/';
|
2017-03-17 04:14:24 +00:00
|
|
|
}
|
|
|
|
if (page === 'home') {
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.get('/', (req, res, next) => res.sendFile(`${page}.html`, { root: root }));
|
2017-03-17 04:14:24 +00:00
|
|
|
} else {
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.get(`/${page}`, (req, res, next) => res.sendFile(`${page}.html`, { root: root }));
|
2017-03-17 04:14:24 +00:00
|
|
|
}
|
2017-02-06 03:06:33 +00:00
|
|
|
}
|
|
|
|
|
2017-10-03 22:48:26 +00:00
|
|
|
safe.use((req, res, next) => res.status(404).sendFile('404.html', { root: './pages/error/' }));
|
|
|
|
safe.use((req, res, next) => res.status(500).sendFile('500.html', { root: './pages/error/' }));
|
2017-01-13 07:34:21 +00:00
|
|
|
|
2017-10-04 00:13:15 +00:00
|
|
|
safe.listen(config.port, () => console.log(`lolisafe started on port ${config.port}`));
|