summary refs log tree commit diff
path: root/api/src/Server.ts
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-08-13 20:53:50 +0200
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-08-13 20:53:50 +0200
commit49da9769439b1618e178928e889cdf583e0e973b (patch)
treeab7ce3d433d5c6a624f329217bd0fcc2f336e78d /api/src/Server.ts
parent:pencil: updated links to fosscord-server (diff)
downloadserver-49da9769439b1618e178928e889cdf583e0e973b.tar.xz
:bug: fix api middleware
Diffstat (limited to 'api/src/Server.ts')
-rw-r--r--api/src/Server.ts43
1 files changed, 11 insertions, 32 deletions
diff --git a/api/src/Server.ts b/api/src/Server.ts
index a60c5e4d..5c5d5fc0 100644
--- a/api/src/Server.ts
+++ b/api/src/Server.ts
@@ -1,19 +1,16 @@
 import "missing-native-js-functions";
-import fs from "fs";
 import { Connection } from "mongoose";
 import { Server, ServerOptions } from "lambert-server";
 import { Authentication, CORS } from "./middlewares/";
-import { Config, db, initEvent, RabbitMQ } from "@fosscord/util";
-import i18next from "i18next";
-import i18nextMiddleware, { I18next } from "i18next-http-middleware";
-import i18nextBackend from "i18next-node-fs-backend";
+import { Config, db, initEvent } from "@fosscord/util";
 import { ErrorHandler } from "./middlewares/ErrorHandler";
 import { BodyParser } from "./middlewares/BodyParser";
-import express, { Router, Request, Response } from "express";
+import { Router, Request, Response } from "express";
 import mongoose from "mongoose";
 import path from "path";
 import { initRateLimits } from "./middlewares/RateLimit";
 import TestClient from "./middlewares/TestClient";
+import { initTranslation } from "./middlewares/Translation";
 
 // this will return the new updated document for findOneAndUpdate
 mongoose.set("returnOriginal", false); // https://mongoosejs.com/docs/api/model.html#model_Model.findOneAndUpdate
@@ -60,47 +57,29 @@ export class FosscordServer extends Server {
 		await initEvent();
 
 		this.app.use(CORS);
-		this.app.use(Authentication);
 		this.app.use(BodyParser({ inflate: true, limit: 1024 * 1024 * 10 })); // 2MB
-		const languages = fs.readdirSync(path.join(__dirname, "..", "locales"));
-		const namespaces = fs.readdirSync(path.join(__dirname, "..", "locales", "en"));
-		const ns = namespaces.filter((x) => x.endsWith(".json")).map((x) => x.slice(0, x.length - 5));
-
-		await i18next
-			.use(i18nextBackend)
-			.use(i18nextMiddleware.LanguageDetector)
-			.init({
-				preload: languages,
-				// debug: true,
-				fallbackLng: "en",
-				ns,
-				backend: {
-					loadPath: __dirname + "/../locales/{{lng}}/{{ns}}.json"
-				},
-				load: "all"
-			});
-		this.app.use(i18nextMiddleware.handle(i18next, {}));
 
 		const app = this.app;
-		const api = Router();
-		// @ts-ignore
+		const api = Router(); // @ts-ignore
 		this.app = api;
 
+		api.use(Authentication);
 		initRateLimits(api);
+		await initTranslation(api);
+
 		this.routes = await this.registerRoutes(path.join(__dirname, "routes", "/"));
-		app.use("/api/v8", api);
-		app.use("/api/v9", api);
-		app.use("/api", api); // allow unversioned requests
 
-		api.get("*", (req: Request, res: Response, next) => {
+		api.use("*", (req: Request, res: Response) => {
 			res.status(404).json({
 				message: "404: Not Found",
 				code: 0
 			});
-			next();
 		});
 
 		this.app = app;
+		app.use("/api/v8", api);
+		app.use("/api/v9", api);
+		app.use("/api", api); // allow unversioned requests
 		this.app.use(ErrorHandler);
 		TestClient(this.app);