summary refs log tree commit diff
path: root/src/middlewares/GlobalRateLimit.ts
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-01-30 19:57:28 +0100
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-01-30 19:57:28 +0100
commit879dafb5d12cc56ab9c8362e818cf8dccc4e5ea5 (patch)
tree7a6e6b1bded0c85bfcf25265ca60fe98f4a0e1c7 /src/middlewares/GlobalRateLimit.ts
parent:sparkles: Authentication (diff)
downloadserver-879dafb5d12cc56ab9c8362e818cf8dccc4e5ea5.tar.xz
:sparkles: RateLimit
Diffstat (limited to 'src/middlewares/GlobalRateLimit.ts')
-rw-r--r--src/middlewares/GlobalRateLimit.ts43
1 files changed, 43 insertions, 0 deletions
diff --git a/src/middlewares/GlobalRateLimit.ts b/src/middlewares/GlobalRateLimit.ts
new file mode 100644

index 00000000..5c5f690a --- /dev/null +++ b/src/middlewares/GlobalRateLimit.ts
@@ -0,0 +1,43 @@ +import { NextFunction, Request, Response } from "express"; +import Config from "../util/Config"; +import db from "../util/Database"; + +export async function GlobalRateLimit(req: Request, res: Response, next: NextFunction) { + if (!Config.get().server.ipRateLimit.enabled) return next(); + + const ip = getIpAdress(req); + let limit = (await db.data.ratelimit.global[ip].get()) || { start: Date.now(), count: 0 }; + if (limit.start < Date.now() - Config.get().server.ipRateLimit.timespan) { + limit.start = Date.now(); + limit.count = 0; + } + + if (limit.count > Config.get().server.ipRateLimit.count) { + const timespan = Date.now() - limit.start; + + return res + .set("Retry-After", `${timespan.toFixed(0)}`) + .set("X-RateLimit-Global", "true") + .status(429) + .json({ + message: "You are being rate limited.", + retry_after: timespan, + global: true, + }); + } + + res.once("close", async () => { + if (res.statusCode >= 400) { + limit.count++; + await db.data.ratelimit.global[ip].set(limit); + } + }); + + return next(); +} + +export function getIpAdress(req: Request): string { + const { forwadedFor } = Config.get().server; + const ip = forwadedFor ? <string>req.headers[forwadedFor] : req.ip; + return ip.replaceAll(".", "_").replaceAll(":", "_"); +}