aboutsummaryrefslogtreecommitdiff
path: root/admin/index.js
blob: a67b9f3148ba9e13effc14f2a1e9f580a784d7d1 (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
63
64
65
66
67
68
69
70
const express = require("express");
const db = require("../db");
const app = express.Router();
const { checkUser, checkAdmin } = require("../auth");

// app.use("/", checkAdmin, express.static(__dirname + "/public"));
app.use(
    "/",
    (req, res, next) => {
        if ((req.session.loggedIn && req.session.isAdmin) || req.path.startsWith("/api/votes")) next();
        else res.redirect("/");
    },
    express.static(__dirname + "/public"),
);

// For debugging ig
app.get("/api/all", checkAdmin, async (req, res) => {
    const all = [];

    const types = await db.query("SELECT * FROM types ORDER BY id");
    const clazz = await db.query("SELECT * FROM class ORDER BY id");
    const users = await db.query("SELECT * FROM users ORDER BY id");
    const quotes = await db.query("SELECT * FROM quotes ORDER BY id");
    const ranking_questions = await db.query("SELECT * FROM ranking_questions ORDER BY id");
    const ranking_answers = await db.query("SELECT * FROM ranking_answers ORDER BY id");
    const mottos = await db.query("SELECT * FROM mottos ORDER BY id");
    const motto_votes = await db.query("SELECT * FROM motto_votes ORDER BY id");

    all.push(
        { quotes },
        { clazz },
        { users },
        { quotes },
        { ranking_questions },
        { ranking_answers },
        { mottos },
        { motto_votes },
    );
    res.json(all);
});

app.get("/api/questions", checkAdmin, async (req, res) => {
    const questions = await db.query(
        "SELECT q.id, question, t.name type FROM ranking_questions q INNER JOIN types t on type_id = t.id ORDER BY q.id",
    );
    res.json(questions);
});

app.get("/api/answers", checkAdmin, async (req, res) => {
    const answers = await db.query(
        "SELECT question_id, u.name, u.middlename, u.surname, c.name class, count(*) count FROM ranking_questions q INNER JOIN ranking_answers a ON q.id = a.question_id INNER JOIN users u ON answer_id = u.id INNER JOIN class c ON u.class_id = c.id GROUP BY question_id, answer_id ORDER BY count DESC",
    );
    res.json(answers);
});

app.get("/api/votes", checkAdmin, async (req, res) => {
    const votes = await db.query(
        "SELECT m.id, m.name, m.description, SUM(votes) votes FROM motto_votes mv RIGHT JOIN mottos m on mv.motto_id = m.id GROUP BY m.id, m.name, m.description ORDER BY SUM(votes) DESC",
    );
    res.json(votes);
});

app.get("/api/participation", checkAdmin, async (req, res) => {
    const participation = await db.query(
        "SELECT c.name, CAST(COUNT(DISTINCT user_id) AS float) / CAST((SELECT COUNT(*) FROM users WHERE class_id = u.class_id) AS float) * 100 percentage FROM motto_votes INNER JOIN users u ON user_id = u.id INNER JOIN class c ON class_id = c.id GROUP BY class_id",
    );
    res.json(participation);
});

module.exports = app;