lolisafe.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. const config = require('./config.js');
  2. const api = require('./routes/api.js');
  3. const album = require('./routes/album.js');
  4. const express = require('express');
  5. const helmet = require('helmet');
  6. const bodyParser = require('body-parser');
  7. const RateLimit = require('express-rate-limit');
  8. const db = require('knex')(config.database);
  9. const fs = require('fs');
  10. const exphbs = require('express-handlebars');
  11. const cookieParser = require('cookie-parser');
  12. const safe = express();
  13. require('./database/db.js')(db);
  14. fs.existsSync('./pages/custom' ) || fs.mkdirSync('./pages/custom');
  15. fs.existsSync('./' + config.logsFolder) || fs.mkdirSync('./' + config.logsFolder);
  16. fs.existsSync('./' + config.uploads.folder) || fs.mkdirSync('./' + config.uploads.folder);
  17. fs.existsSync('./' + config.uploads.folder + '/thumbs') || fs.mkdirSync('./' + config.uploads.folder + '/thumbs');
  18. fs.existsSync('./' + config.uploads.folder + '/zips') || fs.mkdirSync('./' + config.uploads.folder + '/zips')
  19. safe.use(cookieParser());
  20. safe.use(helmet());
  21. safe.set('trust proxy', 1);
  22. safe.engine('handlebars', exphbs({
  23. extname: 'handlebars',
  24. partialsDir: `${__dirname}/views/partials/`
  25. }));
  26. safe.set('view engine', 'handlebars');
  27. safe.enable('view cache');
  28. let limiter = new RateLimit({ windowMs: 5000, max: 2 });
  29. safe.use('/api/login/', limiter);
  30. safe.use('/api/register/', limiter);
  31. safe.use(bodyParser.urlencoded({ extended: true }));
  32. safe.use(bodyParser.json());
  33. if (config.serveFilesWithNode) {
  34. safe.use('/', express.static(config.uploads.folder));
  35. }
  36. safe.use('/', express.static('./public'));
  37. safe.use('/', album);
  38. safe.use('/api', api);
  39. for (let page of config.pages) {
  40. if (page === 'home') {
  41. safe.get('/', (req, res, next) => res.render('home', { layout: false, config: config, appearance: req.cookies.appearance || 'light' }));
  42. } else {
  43. safe.get(`/${page}`, (req, res, next) => res.render(page, { layout:false, config: config, appearance: req.cookies.appearance || 'light' }));
  44. }
  45. }
  46. safe.use((req, res, next) => res.status(404).sendFile('404.html', { root: './pages/error/' }));
  47. safe.use((req, res, next) => res.status(500).sendFile('500.html', { root: './pages/error/' }));
  48. safe.listen(config.port, () => console.log(`lolisafe started on port ${config.port}`));