123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- const config = require('./config.js')
- const api = require('./routes/api.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 safe = express()
- require('./database/db.js')(db)
- 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')
- safe.use(helmet())
- safe.set('trust proxy', 1)
- let limiter = new RateLimit({ windowMs: 5000, max: 2 })
- safe.use('/api/login/', limiter)
- safe.use('/api/register/', limiter)
- safe.use(bodyParser.urlencoded({ extended: true }))
- safe.use(bodyParser.json())
- safe.use('/', express.static('./uploads'))
- safe.use('/', express.static('./public'))
- safe.use('/api', api)
- safe.get('/a/:identifier', (req, res, next) => res.sendFile('album.html', { root: './pages/' }))
- for (let page of config.pages) {
- let root = './pages/'
- if (fs.existsSync(`./pages/custom/${page}.html`)) {
- root = './pages/custom/'
- }
- if (page === 'home') {
- safe.get('/', (req, res, next) => res.sendFile(`${page}.html`, { root: root }))
- } else {
- safe.get(`/${page}`, (req, res, next) => res.sendFile(`${page}.html`, { root: root }))
- }
- }
- 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/' }))
- safe.listen(config.port, () => console.log(`loli-safe started on port ${config.port}`))
|