monkeytype/backend/server.js

191 lines
5.5 KiB
JavaScript
Raw Normal View History

const express = require("express");
2021-06-07 00:32:37 +08:00
const { config } = require("dotenv");
const path = require("path");
2021-07-08 19:30:06 +08:00
const MonkeyError = require("./handlers/error");
2021-06-07 00:32:37 +08:00
config({ path: path.join(__dirname, ".env") });
const CronJob = require("cron").CronJob;
const cors = require("cors");
const admin = require("firebase-admin");
const Logger = require("./handlers/logger.js");
2021-06-07 00:32:37 +08:00
const serviceAccount = require("./credentials/serviceAccountKey.json");
const { connectDB, mongoDB } = require("./init/mongodb");
2021-09-14 21:54:03 +08:00
const BotDAO = require("./dao/bot");
2021-05-20 06:39:18 +08:00
2021-06-16 07:47:34 +08:00
const PORT = process.env.PORT || 5005;
// MIDDLEWARE & SETUP
const app = express();
2021-06-07 00:32:37 +08:00
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
2021-08-17 01:01:52 +08:00
app.use(cors());
2021-08-28 04:52:49 +08:00
app.set("trust proxy", 1);
2021-09-06 07:52:05 +08:00
app.use((req, res, next) => {
if (process.env.MAINTENANCE === "true") {
2021-09-06 07:52:32 +08:00
res.status(503).json({ message: "Server is down for maintenance" });
2021-09-06 07:52:05 +08:00
} else {
next();
}
});
2021-12-14 05:43:02 +08:00
let startingPath = "";
if (process.env.API_PATH_OVERRIDE) {
startingPath = "/" + process.env.API_PATH_OVERRIDE;
}
const userRouter = require("./api/routes/user");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/user", userRouter);
2021-07-06 21:52:36 +08:00
const configRouter = require("./api/routes/config");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/config", configRouter);
2021-07-06 22:22:05 +08:00
const resultRouter = require("./api/routes/result");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/results", resultRouter);
const presetRouter = require("./api/routes/preset");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/presets", presetRouter);
2021-08-28 03:10:00 +08:00
const quoteRatings = require("./api/routes/quote-ratings");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/quote-ratings", quoteRatings);
2021-08-29 21:30:45 +08:00
const psaRouter = require("./api/routes/psa");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/psa", psaRouter);
2021-09-06 06:57:07 +08:00
const leaderboardsRouter = require("./api/routes/leaderboards");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/leaderboard", leaderboardsRouter);
const newQuotesRouter = require("./api/routes/new-quotes");
2021-12-14 05:43:02 +08:00
app.use(startingPath + "/new-quotes", newQuotesRouter);
2021-06-07 01:26:12 +08:00
app.use(function (e, req, res, next) {
let monkeyError;
if (e.errorID) {
//its a monkey error
monkeyError = e;
} else {
//its a server error
monkeyError = new MonkeyError(e.status, e.message, e.stack);
}
if (!monkeyError.uid && req.decodedToken) {
monkeyError.uid = req.decodedToken.uid;
}
if (process.env.MODE !== "dev" && monkeyError.status > 400) {
2021-09-10 07:03:01 +08:00
Logger.log(
`system_error`,
`${monkeyError.status} ${monkeyError.message}`,
monkeyError.uid
);
mongoDB().collection("errors").insertOne({
_id: monkeyError.errorID,
timestamp: Date.now(),
status: monkeyError.status,
uid: monkeyError.uid,
message: monkeyError.message,
stack: monkeyError.stack,
});
}
2021-07-08 19:30:06 +08:00
return res.status(e.status || 500).json(monkeyError);
});
2021-06-14 14:49:23 +08:00
2021-08-11 07:02:17 +08:00
app.get("/test", (req, res) => {
res.send("Hello World!");
});
const LeaderboardsDAO = require("./dao/leaderboards");
2021-06-16 07:47:34 +08:00
app.listen(PORT, async () => {
console.log(`listening on port ${PORT}`);
2021-06-14 14:49:23 +08:00
await connectDB();
admin.initializeApp({
credential: admin.credential.cert(serviceAccount),
});
console.log("Database Connected");
2021-09-06 06:57:07 +08:00
2021-09-14 21:54:35 +08:00
let lbjob = new CronJob("30 4/5 * * * *", async () => {
2021-09-14 21:54:03 +08:00
let before15 = await mongoDB()
.collection("leaderboards.english.time.15")
.find()
.limit(10)
.toArray();
LeaderboardsDAO.update("time", "15", "english").then(async () => {
let after15 = await mongoDB()
.collection("leaderboards.english.time.15")
.find()
.limit(10)
.toArray();
let changed;
let recent = false;
2021-09-14 21:54:03 +08:00
for (let index in before15) {
if (before15[index].uid !== after15[index].uid) {
//something changed at this index
if (after15[index].timestamp > Date.now() - 1000 * 60 * 10) {
//checking if test is within 10 minutes
recent = true;
}
2021-09-14 21:54:03 +08:00
changed = after15[index];
break;
}
}
if (changed && recent) {
2021-09-14 21:54:03 +08:00
let name = changed.discordId ?? changed.name;
BotDAO.announceLbUpdate(
name,
changed.rank,
"time 15 english",
changed.wpm,
changed.raw,
changed.acc,
changed.consistency
);
}
});
let before60 = await mongoDB()
.collection("leaderboards.english.time.60")
.find()
.limit(10)
.toArray();
LeaderboardsDAO.update("time", "60", "english").then(async () => {
let after60 = await mongoDB()
.collection("leaderboards.english.time.60")
.find()
.limit(10)
.toArray();
let changed;
let recent = false;
2021-09-14 21:54:03 +08:00
for (let index in before60) {
if (before60[index].uid !== after60[index].uid) {
//something changed at this index
if (after60[index].timestamp > Date.now() - 1000 * 60 * 10) {
//checking if test is within 10 minutes
recent = true;
}
2021-09-14 21:54:03 +08:00
changed = after60[index];
break;
}
}
if (changed && recent) {
2021-09-14 21:54:03 +08:00
let name = changed.discordId ?? changed.name;
BotDAO.announceLbUpdate(
name,
changed.rank,
"time 60 english",
changed.wpm,
changed.raw,
changed.acc,
changed.consistency
);
}
});
});
lbjob.start();
2021-09-14 07:10:56 +08:00
let logjob = new CronJob("0 0 0 * * *", async () => {
let data = await mongoDB()
.collection("logs")
.deleteMany({ timestamp: { $lt: Date.now() - 604800000 } });
Logger.log(
"system_logs_deleted",
`${data.deletedCount} logs deleted older than 7 days`,
undefined
);
});
logjob.start();
});