summary refs log tree commit diff
path: root/src/Server.ts
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-02-01 21:49:01 +0100
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-02-01 21:49:01 +0100
commit2026ea59112b89dd8829e23236fa482ef84a2e31 (patch)
treec236474edb8e5a9f39193d518da2219759835bfd /src/Server.ts
parent:globe_with_meridians: localization (diff)
downloadserver-2026ea59112b89dd8829e23236fa482ef84a2e31.tar.xz
:sparkles: added defaults to config
Diffstat (limited to 'src/Server.ts')
-rw-r--r--src/Server.ts21
1 files changed, 17 insertions, 4 deletions
diff --git a/src/Server.ts b/src/Server.ts

index ba829eaa..15e70b7f 100644 --- a/src/Server.ts +++ b/src/Server.ts
@@ -3,6 +3,9 @@ import { Server, ServerOptions } from "lambert-server"; import { Authentication, GlobalRateLimit } from "./middlewares/"; import Config from "./util/Config"; import db from "./util/Database"; +import i18next from "i18next"; +import i18nextMiddleware from "i18next-http-middleware"; +import { Request } from "express"; export interface DiscordServerOptions extends ServerOptions {} @@ -18,7 +21,7 @@ export class DiscordServer extends Server { public options: DiscordServerOptions; constructor(opts?: Partial<DiscordServerOptions>) { - super(opts); + super({ ...opts, errorHandler: false }); } async start() { @@ -28,11 +31,21 @@ export class DiscordServer extends Server { this.app.use(GlobalRateLimit); this.app.use(Authentication); + const namespaces = await fs.readdir(__dirname + "/locales/de/"); + const ns = namespaces.filter((x) => x.endsWith(".json")).map((x) => x.slice(0, x.length - 5)); + + i18next.use(i18nextMiddleware.LanguageDetector).init({ + preload: ["en", "de"], + fallbackLng: "en", + ns, + backend: { + loadPath: "locales/{{lng}}/{{ns}}.json", + }, + }); + this.app.use(i18nextMiddleware.handle(i18next, {})); - // recursively loads files in routes/ this.routes = await this.registerRoutes(__dirname + "/routes/"); - // const indexHTML = await (await fetch("https://discord.com/app")).buffer(); - const indexHTML = await fs.readFile(__dirname + "/../client/index.html"); + const indexHTML = await fs.readFile(__dirname + "/../client_test/index.html"); this.app.get("*", (req, res) => { res.set("Cache-Control", "public, max-age=" + 60 * 60 * 24);