summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-01-04 16:10:12 +0100
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-01-04 16:10:12 +0100
commit35655773d7ea9b3c0319e0376c5e6c2b481732e5 (patch)
tree4c148013807d85766ec9614e148ffa504091e9f8 /src
parentMerge branch 'main' of https://github.com/discord-open-source/discord-cdn int... (diff)
downloadserver-35655773d7ea9b3c0319e0376c5e6c2b481732e5.tar.xz
:sparkles: update to use new Lambert-server
Diffstat (limited to 'src')
-rw-r--r--src/Server.ts85
-rw-r--r--src/routes/attachments.ts6
-rw-r--r--src/routes/external.ts4
3 files changed, 22 insertions, 73 deletions
diff --git a/src/Server.ts b/src/Server.ts

index 7d93c444..5e96c602 100644 --- a/src/Server.ts +++ b/src/Server.ts
@@ -1,93 +1,42 @@ -import express, { Application, Router, Request, Response, NextFunction } from "express"; import { MongoDatabase, Database } from "lambert-db"; -import { Server as HTTPServer } from "http"; -import { traverseDirectory } from "./Util"; -import bodyParser from "body-parser"; -import "express-async-errors"; +import { Server, ServerOptions } from "lambert-server"; const log = console.log; console.log = (content) => { log(`[${new Date().toTimeString().split(" ")[0]}]`, content); }; -export type ServerOptions = { - db: string; - port: number; - host: string; -}; - declare global { namespace Express { interface Request { - server: Server; + cdn: CDNServer; } } } -export class Server { - app: Application; - http: HTTPServer; +export interface CDNServerOptions extends ServerOptions { + db: string; +} + +export class CDNServer extends Server { db: Database; - routes: Router[]; - options: ServerOptions; + public options: CDNServerOptions; + + constructor(options: CDNServerOptions) { + super(options); - constructor(options: Partial<ServerOptions> = { port: 3000, host: "0.0.0.0" }) { - this.app = express(); this.db = new MongoDatabase(options?.db); - this.options = options as ServerOptions; } - async init() { + async start() { + console.log("[Database] connecting ..."); await this.db.init(); - - console.log("[Database] connected..."); - await new Promise((res, rej) => { - this.http = this.app.listen(this.options.port, this.options.host, () => res(null)); - }); - this.routes = await this.registerRoutes(__dirname + "/routes/"); - } - - async registerRoutes(root: string) { - this.app.use((req, res, next) => { - req.server = this; - next(); - }); - const routes = await traverseDirectory({ dirname: root, recursive: true }, this.registerRoute.bind(this, root)); - this.app.use((err: string | Error, req: Request, res: Response, next: NextFunction) => { - res.status(400).send(err); - next(err); - }); - return routes; - } - - registerRoute(root: string, file: string): any { - if (root.endsWith("/") || root.endsWith("\\")) root = root.slice(0, -1); // removes slash at the end of the root dir - let path = file.replace(root, ""); // remove root from path and - path = path.split(".").slice(0, -1).join("."); // trancate .js/.ts file extension of path - if (path.endsWith("/index")) path = path.slice(0, -6); // delete index from path - - try { - var router = require(file); - if (router.router) router = router.router; - if (router.default) router = router.default; - if (!router || router?.prototype?.constructor?.name !== "router") - throw `File doesn't export any default router`; - this.app.use(path, <Router>router); - console.log(`[Routes] ${path} registerd`); - - return router; - } catch (error) { - console.error(new Error(`[Server] ¯\\_(ツ)_/¯ Failed to register route ${path}: ${error}`)); - } + console.log("[Database] connected"); + return super.start(); } - async destroy() { + async stop() { await this.db.destroy(); - await new Promise((res, rej) => { - this.http.close((err) => { - if (err) return rej(err); - return res(""); - }); - }); + return super.stop(); } } diff --git a/src/routes/attachments.ts b/src/routes/attachments.ts
index 7d09e402..9f016174 100644 --- a/src/routes/attachments.ts +++ b/src/routes/attachments.ts
@@ -15,7 +15,7 @@ type Attachment = { router.post("/:filename", multer_.single("attachment"), async (req, res) => { const { buffer, mimetype } = req.file; const { filename } = req.params; - const { db } = req.server; + const { db } = req.cdn; const File: Attachment = { filename, @@ -30,7 +30,7 @@ router.post("/:filename", multer_.single("attachment"), async (req, res) => { }); router.get("/:hash/:filename", async (req, res) => { - const { db } = req.server; + const { db } = req.cdn; const { hash, filename } = req.params; const File: Attachment = await db.data.attachments({ id: hash, filename: filename }).get(); @@ -41,7 +41,7 @@ router.get("/:hash/:filename", async (req, res) => { router.delete("/:hash/:filename", async (req, res) => { const { hash, filename } = req.params; - const { db } = req.server; + const { db } = req.cdn; await db.data.attachments({ id: hash, filename: filename }).delete(); return res.send({ success: true, message: "attachment deleted" }); diff --git a/src/routes/external.ts b/src/routes/external.ts
index be680003..f75f6a66 100644 --- a/src/routes/external.ts +++ b/src/routes/external.ts
@@ -30,7 +30,7 @@ const DEFAULT_FETCH_OPTIONS: any = { router.post("/", bodyParser.json(), async (req, res) => { if (!req.body) throw new Error("Invalid Body (url missing) \nExample: url:https://discord.com"); - const { db } = req.server; + const { db } = req.cdn; const { url } = req.body; const ID = btoa(url); @@ -72,7 +72,7 @@ router.post("/", bodyParser.json(), async (req, res) => { }); router.get("/:id/:filename", async (req, res) => { - const { db } = req.server; + const { db } = req.cdn; const { id, filename } = req.params; const { image, type } = await db.data.externals({ id: id }).get(); const imageBuffer = Buffer.from(image, "base64");