monkeytype/backend/dao/leaderboards.js

130 lines
3.4 KiB
JavaScript
Raw Normal View History

2021-09-06 07:00:40 +08:00
const MonkeyError = require("../handlers/error");
const { mongoDB } = require("../init/mongodb");
const { ObjectID } = require("mongodb");
2021-09-10 00:41:13 +08:00
const Logger = require("../handlers/logger");
2021-09-10 02:09:17 +08:00
const { performance } = require("perf_hooks");
2021-09-06 07:00:40 +08:00
class LeaderboardsDAO {
static async get(mode, mode2, language, skip, limit = 50) {
if (limit > 50 || limit <= 0) limit = 50;
2021-09-07 07:56:29 +08:00
if (skip < 0) skip = 0;
2021-09-06 07:00:40 +08:00
const preset = await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.find()
2021-09-10 21:11:38 +08:00
.sort({ rank: 1 })
2021-09-07 03:36:09 +08:00
.skip(parseInt(skip))
.limit(parseInt(limit))
2021-09-06 07:00:40 +08:00
.toArray();
return preset;
}
static async getRank(mode, mode2, language, uid) {
const res = await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.findOne({ uid });
2021-09-18 03:59:45 +08:00
if (res)
res.count = await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.estimatedDocumentCount();
2021-09-07 00:35:37 +08:00
return res;
2021-09-06 07:00:40 +08:00
}
static async update(mode, mode2, language, uid = undefined) {
2021-09-06 07:11:09 +08:00
let str = `lbPersonalBests.${mode}.${mode2}.${language}`;
2021-09-10 02:24:34 +08:00
let start1 = performance.now();
2021-09-06 07:00:40 +08:00
let lb = await mongoDB()
.collection("users")
.aggregate([
{
$match: {
2021-09-06 07:11:09 +08:00
[str + ".wpm"]: {
$exists: true,
2021-09-06 07:00:40 +08:00
},
2021-09-06 07:11:09 +08:00
[str + ".acc"]: {
$exists: true,
2021-09-06 07:00:40 +08:00
},
2021-09-08 03:14:25 +08:00
banned: { $exists: false },
2021-09-06 07:00:40 +08:00
},
},
{
$set: {
2021-09-06 07:11:09 +08:00
[str + ".uid"]: "$uid",
[str + ".name"]: "$name",
2021-09-14 21:54:03 +08:00
[str + ".discordId"]: "$discordId",
2021-09-06 07:00:40 +08:00
},
},
{
$replaceRoot: {
2021-09-06 07:11:09 +08:00
newRoot: "$" + str,
2021-09-06 07:00:40 +08:00
},
},
{
$sort: {
wpm: -1,
acc: -1,
timestamp: -1,
},
},
])
.toArray();
2021-09-10 02:24:34 +08:00
let end1 = performance.now();
2021-09-06 07:00:40 +08:00
2021-09-10 02:24:34 +08:00
let start2 = performance.now();
2021-09-07 22:03:11 +08:00
let retval = undefined;
2021-09-06 07:00:40 +08:00
lb.forEach((lbEntry, index) => {
lbEntry.rank = index + 1;
if (uid && lbEntry.uid === uid) {
2021-09-07 22:03:11 +08:00
retval = index + 1;
2021-09-06 07:00:40 +08:00
}
});
2021-09-10 02:24:34 +08:00
let end2 = performance.now();
let start3 = performance.now();
2021-09-06 07:00:40 +08:00
try {
await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.drop();
} catch (e) {}
await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.insertMany(lb);
2021-09-10 02:24:34 +08:00
let end3 = performance.now();
2021-09-10 21:11:38 +08:00
let start4 = performance.now();
await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.createIndex({
uid: -1,
});
await mongoDB()
.collection(`leaderboards.${language}.${mode}.${mode2}`)
.createIndex({
rank: 1,
});
2021-09-10 21:11:38 +08:00
let end4 = performance.now();
2021-09-10 02:24:34 +08:00
let timeToRunAggregate = (end1 - start1) / 1000;
let timeToRunLoop = (end2 - start2) / 1000;
let timeToRunInsert = (end3 - start3) / 1000;
2021-09-10 21:11:38 +08:00
let timeToRunIndex = (end4 - start4) / 1000;
2021-09-10 00:41:13 +08:00
Logger.log(
2021-09-10 07:00:56 +08:00
`system_lb_update_${language}_${mode}_${mode2}`,
2021-09-10 21:11:38 +08:00
`Aggregate ${timeToRunAggregate}s, loop ${timeToRunLoop}s, insert ${timeToRunInsert}s, index ${timeToRunIndex}s`,
2021-09-10 00:41:13 +08:00
uid
);
2021-09-07 22:03:11 +08:00
if (retval) {
2021-09-06 07:00:40 +08:00
return {
message: "Successfully updated leaderboard",
rank: retval,
};
} else {
return {
message: "Successfully updated leaderboard",
};
}
}
}
module.exports = LeaderboardsDAO;