lolisafe.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536
  1. const config = require('./config.js')
  2. const api = require('./routes/api.js')
  3. const express = require('express')
  4. const bodyParser = require('body-parser')
  5. const rateLimit = require('express-rate-limit')
  6. const db = require('knex')(config.database)
  7. const fs = require('fs')
  8. const safe = express()
  9. require('./database/db.js')(db)
  10. fs.existsSync('./' + config.logsFolder) || fs.mkdirSync('./' + config.logsFolder)
  11. fs.existsSync('./' + config.uploads.folder) || fs.mkdirSync('./' + config.uploads.folder)
  12. fs.existsSync('./' + config.uploads.folder + '/thumbs') || fs.mkdirSync('./' + config.uploads.folder + '/thumbs')
  13. safe.enable('trust proxy')
  14. safe.use(bodyParser.urlencoded({ extended: true }))
  15. safe.use(bodyParser.json())
  16. safe.use('/', express.static('./uploads'))
  17. safe.use('/', express.static('./public'))
  18. safe.use('/api', api)
  19. let limiter = new rateLimit({ windowMs: 5, max: 2 })
  20. safe.use('/api/login', limiter)
  21. safe.use('/api/register', limiter)
  22. safe.get('/', (req, res, next) => res.sendFile('home.html', { root: './pages/' }))
  23. safe.get('/faq', (req, res, next) => res.sendFile('faq.html', { root: './pages/' }))
  24. safe.get('/auth', (req, res, next) => res.sendFile('auth.html', { root: './pages/' }))
  25. safe.get('/dashboard', (req, res, next) => res.sendFile('dashboard.html', { root: './pages/' }))
  26. safe.use((req, res, next) => res.status(404).sendFile('404.html', { root: './pages/error/' }))
  27. safe.use((req, res, next) => res.status(500).sendFile('500.html', { root: './pages/error/' }))
  28. safe.listen(config.port, () => console.log(`loli-safe started on port ${config.port}`))