Move middlewear to seperate file, Files can expire
This commit is contained in:
parent
da127b3118
commit
521390fde7
10 changed files with 2044 additions and 375 deletions
82
app.js
82
app.js
|
@ -1,47 +1,51 @@
|
|||
require('dotenv').config();
|
||||
require("dotenv").config();
|
||||
|
||||
let createError = require('http-errors');
|
||||
let express = require('express');
|
||||
let path = require('path');
|
||||
let cookieParser = require('cookie-parser');
|
||||
let passport = require('passport');
|
||||
let session = require('express-session');
|
||||
|
||||
let SQLiteStore = require('connect-sqlite3')(session);
|
||||
let express = require("express");
|
||||
let passport = require("passport");
|
||||
let session = require("express-session");
|
||||
let createError = require("http-errors");
|
||||
let cookieParser = require("cookie-parser");
|
||||
let SQLiteStore = require("connect-sqlite3")(session);
|
||||
|
||||
let indexRouter = require('./routes/index');
|
||||
let authRouter = require('./routes/auth');
|
||||
let fs = require("fs");
|
||||
let path = require("path");
|
||||
|
||||
let authRouter = require("./routes/auth");
|
||||
let indexRouter = require("./routes/index");
|
||||
|
||||
let db = require("./db");
|
||||
|
||||
let app = express();
|
||||
app.enable('trust proxy');
|
||||
app.enable("trust proxy");
|
||||
|
||||
// view engine setup
|
||||
app.set('views', path.join(__dirname, 'views'));
|
||||
app.set('view engine', 'ejs');
|
||||
app.set("views", path.join(__dirname, "views"));
|
||||
app.set("view engine", "ejs");
|
||||
|
||||
app.use(express.json());
|
||||
app.use(express.urlencoded({
|
||||
extended: false
|
||||
}));
|
||||
app.use(cookieParser());
|
||||
app.use(express.static(path.join(__dirname, 'public')));
|
||||
app.use(express.static(path.join(__dirname, "public")));
|
||||
|
||||
app.use(express.static(path.join(__dirname, 'public')));
|
||||
app.use(express.static(path.join(__dirname, "public")));
|
||||
app.use(session({
|
||||
secret: process.env.EBSECRET || 'pleasechangeme',
|
||||
secret: process.env.EBSECRET || "pleasechangeme",
|
||||
resave: false,
|
||||
saveUninitialized: false,
|
||||
store: new SQLiteStore({
|
||||
db: 'sessions.db',
|
||||
dir: './var/db'
|
||||
db: "sessions.db",
|
||||
dir: "./var/db"
|
||||
})
|
||||
}));
|
||||
app.use(passport.authenticate('session'));
|
||||
app.use(passport.authenticate("session"));
|
||||
|
||||
app.use('/', indexRouter);
|
||||
app.use('/', authRouter);
|
||||
app.use("/", indexRouter);
|
||||
app.use("/", authRouter);
|
||||
|
||||
app.use('/uploads', express.static('uploads'))
|
||||
app.use("/uploads", express.static("uploads"));
|
||||
|
||||
// catch 404 and forward to error handler
|
||||
app.use(function(req, res, next) {
|
||||
|
@ -49,15 +53,41 @@ app.use(function(req, res, next) {
|
|||
});
|
||||
|
||||
// error handler
|
||||
app.use(function(err, req, res, next) {
|
||||
app.use(function(err, req, res) {
|
||||
// set locals, only providing error in development
|
||||
console.log(err)
|
||||
console.log(err);
|
||||
res.locals.message = err.message;
|
||||
res.locals.error = req.app.get('env') === 'development' ? err : {};
|
||||
res.locals.error = req.app.get("env") === "development" ? err : {};
|
||||
|
||||
// render the error page
|
||||
res.status(err.status || 500);
|
||||
res.render('error');
|
||||
res.render("error");
|
||||
});
|
||||
|
||||
function prune () {
|
||||
console.log("Vacuuming database...");
|
||||
db.run("VACUUM");
|
||||
|
||||
db.all("SELECT * FROM media WHERE expire > ?", [Date.now()], (err, rows) => {
|
||||
console.log("Expired rows: " + rows);
|
||||
if (err) return console.error(err);
|
||||
rows.forEach((row) => {
|
||||
console.log("Deleting " + row.path);
|
||||
fs.unlink("uploads/" + row.path, (err) => {
|
||||
if (err) {
|
||||
if(err.errno == -4058) return; //file doesn't exist
|
||||
return console.error(err);
|
||||
}
|
||||
console.log("Deleted " + row.path);
|
||||
});
|
||||
db.run("DELETE FROM media WHERE expire > ?", [Date.now()], (err) => {
|
||||
if (err) return console.error(err);
|
||||
console.log("Deleted " + row.path + " from database");
|
||||
});
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
setInterval(prune, 1000 * 60 * 30); //prune every 30 minutes
|
||||
|
||||
module.exports = app;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue