2025-03-24 14:51:13 +01:00
|
|
|
import { Document, model, Schema, Types } from "mongoose";
|
2025-03-24 12:53:09 +01:00
|
|
|
import { ILeaderboardEntryDatabase } from "../types/leaderboardTypes";
|
|
|
|
|
|
|
|
const leaderboardEntrySchema = new Schema<ILeaderboardEntryDatabase>(
|
|
|
|
{
|
|
|
|
leaderboard: { type: String, required: true },
|
2025-03-24 22:19:54 +01:00
|
|
|
ownerId: { type: Schema.Types.ObjectId, required: true },
|
2025-03-24 23:00:23 +01:00
|
|
|
displayName: { type: String, required: true },
|
2025-03-24 12:53:09 +01:00
|
|
|
score: { type: Number, required: true },
|
2025-03-24 23:00:23 +01:00
|
|
|
guildId: Schema.Types.ObjectId,
|
2025-03-24 12:53:09 +01:00
|
|
|
expiry: { type: Date, required: true }
|
|
|
|
},
|
|
|
|
{ id: false }
|
|
|
|
);
|
|
|
|
|
|
|
|
leaderboardEntrySchema.index({ leaderboard: 1 });
|
2025-03-24 23:00:23 +01:00
|
|
|
leaderboardEntrySchema.index({ leaderboard: 1, ownerId: 1 }, { unique: true });
|
2025-03-24 12:53:09 +01:00
|
|
|
leaderboardEntrySchema.index({ expiry: 1 }, { expireAfterSeconds: 0 }); // With this, MongoDB will automatically delete expired entries.
|
|
|
|
|
|
|
|
export const Leaderboard = model<ILeaderboardEntryDatabase>("Leaderboard", leaderboardEntrySchema);
|
2025-03-24 14:51:13 +01:00
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
|
|
export type TLeaderboardEntryDocument = Document<unknown, {}, ILeaderboardEntryDatabase> & {
|
|
|
|
_id: Types.ObjectId;
|
|
|
|
__v: number;
|
|
|
|
} & ILeaderboardEntryDatabase;
|