aboutsummaryrefslogtreecommitdiff
path: root/app.js
blob: 9f9c8230cfe235041fc0c2ed2d0d68715d6f370c (plain) (blame)
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}`));