mirror of
https://github.com/monkeytypegame/monkeytype.git
synced 2025-02-27 00:04:37 +08:00
* Feat:Update response structure (#2427) * Fix:response and error structure * update:response message * update:response class * update * Update response message Co-authored-by: Mustafiz Kaifee Mumtaz <mustafiz.mumtaz@freecharge.com> * Add MonkeyToken foundation (#2487) by Bruception * Api changes (#2492) * API changes * Remove unused import * Add Ape client (#2513) * Add all endpoints (#2514) * Merged backend typescript into api overhaul (#2515) * Install typescript and add backend tsconfig Cannot yet build due to a number of compilation errors in JS code Signed-off-by: Brian Evans <ebrian101@gmail.com> * Fix typescript compilation errors Signed-off-by: Brian Evans <ebrian101@gmail.com> * Migrated backend to ES modules Switched to import export syntax Signed-off-by: Brian Evans <ebrian101@gmail.com> * Add typescript declaration for anticheat Signed-off-by: Brian Evans <ebrian101@gmail.com> * Rename top level files to .ts Fix service account json file typing Signed-off-by: Brian Evans <ebrian101@gmail.com> * Add dev build scripts for backend typescript Signed-off-by: Brian Evans <ebrian101@gmail.com> * Removed empty lines and switched to using db Cleaned up imports by removing needless empty lines and migrated to the new db.js instead of mongodb.js. Signed-off-by: Brian Evans <ebrian101@gmail.com> * Fixed backend commonjs syntax to ES module syntax Signed-off-by: Brian Evans <ebrian101@gmail.com> * Add build to backend start script Signed-off-by: Brian Evans <ebrian101@gmail.com> * Migrate some endpoints to Ape * Strict equals * Remove artifact * ape -> Ape * Ape migration p2 (#2522) * Migrate leaderboard endpoints to ape * Fixed comment * Init backend types * Fail * Return * Migrate Quotes to Ape (#2528) * Migrate quotes to Ape * Fix backend response * Fix issue * Fix rate limit (#2533) * fix rate limit * Fix import * Fix issues * Ape migration p4 (#2547) * Migrate results endpoints to ape * Remove unused import * Remove unused import * Fix loaders * Make function async * Hide try saving results * Migrate some users endpoints to Ape (#2548) * Complete Ape Migration (#2553) * Complete ape migration * Fix preset * Return preset data * Add typings * Move captcha reset * Read from params * Fix result tags endpoint * Fix stuck loader * fixed lb memory not saving * fixed quote rating popup not showing up for new users Co-authored-by: Mustafiz Kaifee <49086821+Mustafiz04@users.noreply.github.com> Co-authored-by: Mustafiz Kaifee Mumtaz <mustafiz.mumtaz@freecharge.com> Co-authored-by: Brian Evans <53117772+mrbrianevans@users.noreply.github.com> Co-authored-by: Miodec <bartnikjack@gmail.com>
134 lines
3.5 KiB
JavaScript
134 lines
3.5 KiB
JavaScript
import { mongoDB } from "../init/mongodb";
|
|
import Logger from "../handlers/logger";
|
|
import { performance } from "perf_hooks";
|
|
|
|
class LeaderboardsDAO {
|
|
static async get(mode, mode2, language, skip, limit = 50) {
|
|
if (limit > 50 || limit <= 0) limit = 50;
|
|
if (skip < 0) skip = 0;
|
|
const preset = await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.find()
|
|
.sort({ rank: 1 })
|
|
.skip(parseInt(skip))
|
|
.limit(parseInt(limit.toString()))
|
|
.toArray();
|
|
return preset;
|
|
}
|
|
|
|
static async getRank(mode, mode2, language, uid) {
|
|
const res = await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.findOne({ uid });
|
|
if (res)
|
|
res.count = await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.estimatedDocumentCount();
|
|
return res;
|
|
}
|
|
|
|
static async update(mode, mode2, language, uid = undefined) {
|
|
let str = `lbPersonalBests.${mode}.${mode2}.${language}`;
|
|
let start1 = performance.now();
|
|
let lb = await mongoDB()
|
|
.collection("users")
|
|
.aggregate(
|
|
[
|
|
{
|
|
$match: {
|
|
[str + ".wpm"]: {
|
|
$exists: true,
|
|
},
|
|
[str + ".acc"]: {
|
|
$exists: true,
|
|
},
|
|
[str + ".timestamp"]: {
|
|
$exists: true,
|
|
},
|
|
banned: { $exists: false },
|
|
},
|
|
},
|
|
{
|
|
$set: {
|
|
[str + ".uid"]: "$uid",
|
|
[str + ".name"]: "$name",
|
|
[str + ".discordId"]: "$discordId",
|
|
},
|
|
},
|
|
{
|
|
$replaceRoot: {
|
|
newRoot: "$" + str,
|
|
},
|
|
},
|
|
{
|
|
$sort: {
|
|
wpm: -1,
|
|
acc: -1,
|
|
timestamp: -1,
|
|
},
|
|
},
|
|
],
|
|
{ allowDiskUse: true }
|
|
)
|
|
.toArray();
|
|
let end1 = performance.now();
|
|
|
|
let start2 = performance.now();
|
|
let retval = undefined;
|
|
lb.forEach((lbEntry, index) => {
|
|
lbEntry.rank = index + 1;
|
|
if (uid && lbEntry.uid === uid) {
|
|
retval = index + 1;
|
|
}
|
|
});
|
|
let end2 = performance.now();
|
|
let start3 = performance.now();
|
|
try {
|
|
await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.drop();
|
|
} catch (e) {}
|
|
if (lb && lb.length !== 0)
|
|
await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.insertMany(lb);
|
|
let end3 = performance.now();
|
|
|
|
let start4 = performance.now();
|
|
await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.createIndex({
|
|
uid: -1,
|
|
});
|
|
await mongoDB()
|
|
.collection(`leaderboards.${language}.${mode}.${mode2}`)
|
|
.createIndex({
|
|
rank: 1,
|
|
});
|
|
let end4 = performance.now();
|
|
|
|
let timeToRunAggregate = (end1 - start1) / 1000;
|
|
let timeToRunLoop = (end2 - start2) / 1000;
|
|
let timeToRunInsert = (end3 - start3) / 1000;
|
|
let timeToRunIndex = (end4 - start4) / 1000;
|
|
|
|
Logger.log(
|
|
`system_lb_update_${language}_${mode}_${mode2}`,
|
|
`Aggregate ${timeToRunAggregate}s, loop ${timeToRunLoop}s, insert ${timeToRunInsert}s, index ${timeToRunIndex}s`,
|
|
uid
|
|
);
|
|
|
|
if (retval) {
|
|
return {
|
|
message: "Successfully updated leaderboard",
|
|
rank: retval,
|
|
};
|
|
} else {
|
|
return {
|
|
message: "Successfully updated leaderboard",
|
|
};
|
|
}
|
|
}
|
|
}
|
|
|
|
export default LeaderboardsDAO;
|