summary refs log tree commit diff
path: root/src/models/RateLimit.ts
diff options
context:
space:
mode:
authorDiego Magdaleno <38844659+DiegoMagdaleno@users.noreply.github.com>2021-07-21 15:37:24 -0500
committerGitHub <noreply@github.com>2021-07-21 15:37:24 -0500
commit2752f481b6b7479d9ca16eb11537ec78e3fd103c (patch)
treef218c16bbe8e0f95ea7a55326cfc139376e57949 /src/models/RateLimit.ts
parentFix: Edited timestamp is Date or NULL (diff)
parent1.3.31 (diff)
downloadserver-2752f481b6b7479d9ca16eb11537ec78e3fd103c.tar.xz
Merge branch 'fosscord:master' into master
Diffstat (limited to 'src/models/RateLimit.ts')
-rw-r--r--src/models/RateLimit.ts25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/models/RateLimit.ts b/src/models/RateLimit.ts
new file mode 100644

index 00000000..6a0e1ffd --- /dev/null +++ b/src/models/RateLimit.ts
@@ -0,0 +1,25 @@ +import { Schema, Document, Types } from "mongoose"; +import db from "../util/Database"; + +export interface Bucket { + id: "global" | "error" | string; // channel_239842397 | guild_238927349823 | webhook_238923423498 + user_id: string; + hits: number; + blocked: boolean; + expires_at: Date; +} + +export interface BucketDocument extends Bucket, Document { + id: string; +} + +export const BucketSchema = new Schema({ + id: { type: String, required: true }, + user_id: { type: String, required: true }, // bot, user, oauth_application, webhook + hits: { type: Number, required: true }, // Number of times the user hit this bucket + blocked: { type: Boolean, required: true }, + expires_at: { type: Date, required: true }, +}); + +// @ts-ignore +export const BucketModel = db.model<BucketDocument>("Bucket", BucketSchema, "ratelimits");