From f44f5d7ac2d24ff836c2e1d4b2fa58da04b13052 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sun, 25 Sep 2022 18:24:21 +1000 Subject: Refactor to mono-repo + upgrade packages --- src/api/routes/-/healthz.ts | 13 +++++++++++++ src/api/routes/-/monitorz.ts | 18 ++++++++++++++++++ src/api/routes/-/readyz.ts | 13 +++++++++++++ 3 files changed, 44 insertions(+) create mode 100644 src/api/routes/-/healthz.ts create mode 100644 src/api/routes/-/monitorz.ts create mode 100644 src/api/routes/-/readyz.ts (limited to 'src/api/routes/-') diff --git a/src/api/routes/-/healthz.ts b/src/api/routes/-/healthz.ts new file mode 100644 index 00000000..d9d1c026 --- /dev/null +++ b/src/api/routes/-/healthz.ts @@ -0,0 +1,13 @@ +import { Router, Response, Request } from "express"; +import { route } from "@fosscord/api"; +import { getDatabase } from "@fosscord/util"; + +const router = Router(); + +router.get("/", route({}), (req: Request, res: Response) => { + if (!getDatabase()) return res.sendStatus(503); + + return res.sendStatus(200); +}); + +export default router; diff --git a/src/api/routes/-/monitorz.ts b/src/api/routes/-/monitorz.ts new file mode 100644 index 00000000..f85cd099 --- /dev/null +++ b/src/api/routes/-/monitorz.ts @@ -0,0 +1,18 @@ +import { Router, Response, Request } from "express"; +import { route } from "@fosscord/api"; +import { Session } from "@fosscord/util"; +import os from "os"; + +const router = Router(); + +router.get("/", route({ right: "OPERATOR" }), async (req: Request, res: Response) => { + return res.json({ + load: os.loadavg(), + procUptime: process.uptime(), + sysUptime: os.uptime(), + memPercent: 100 - ((os.freemem() / os.totalmem()) * 100), + sessions: await Session.count(), + }) +}) + +export default router; \ No newline at end of file diff --git a/src/api/routes/-/readyz.ts b/src/api/routes/-/readyz.ts new file mode 100644 index 00000000..d9d1c026 --- /dev/null +++ b/src/api/routes/-/readyz.ts @@ -0,0 +1,13 @@ +import { Router, Response, Request } from "express"; +import { route } from "@fosscord/api"; +import { getDatabase } from "@fosscord/util"; + +const router = Router(); + +router.get("/", route({}), (req: Request, res: Response) => { + if (!getDatabase()) return res.sendStatus(503); + + return res.sendStatus(200); +}); + +export default router; -- cgit 1.5.1