1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
require("dotenv").config();
require("./db").init();
const express = require("express");
const session = require("express-session");
const fs = require("fs").promises;
require("log-timestamp");
const { auth, checkUser, checkAdmin, checkSuperAdmin } = require("./auth");
// const mottovote = require("./mottovote");
const quotes = require("./quotes");
const poll = require("./poll");
const profile = require("./profile");
const admin = require("./admin");
const questions = require("./questions");
const prediction = require("./prediction");
const secrets = require("./secrets");
const superAdmin = require("./superadmin");
const app = express();
// TODO: Use secure: true in production
const redis = require("redis");
const RedisStore = require("connect-redis")(session);
const redisClient = redis.createClient();
const ttl = 15778800000; // 6 Months
app.use(
session({
store: new RedisStore({ client: redisClient }),
secret: process.env.sessionSecret,
resave: false,
saveUninitialized: true,
cookie: { secure: false, expires: new Date(Date.now() + ttl), maxAge: ttl },
}),
);
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
app.use("/", express.static(__dirname + "/overview/public"));
//app.use("/mottovote", checkUser, mottovote);
app.use("/quotes", checkUser, quotes);
app.use("/poll", checkUser, poll);
app.use("/profile", checkUser, profile);
app.use("/questions", checkUser, questions);
app.use("/prediction", checkUser, prediction);
app.use("/secrets", checkUser, secrets);
app.use("/admin", checkAdmin, admin); // Lel
app.use("/super", checkSuperAdmin, superAdmin);
app.use("/auth", auth);
app.get("/images", checkUser, async (req, res) => {
const links = (await fs.readFile(__dirname + "/images.txt", "utf8")).split("\n");
res.redirect(links[req.session.cid - 1]);
});
app.get("/zeitung", checkAdmin, (req, res) => {
res.sendFile(__dirname + "/zeitung.pdf");
});
app.get("*", (req, res) => res.redirect("/"));
app.listen(process.env.PORT || 5005, () => console.log(`Server started on http://localhost:${process.env.PORT}`));
|