🐛 fix api middleware
This commit is contained in:
parent
403de3ef66
commit
213b5811c4
@ -1,19 +1,16 @@
|
|||||||
import "missing-native-js-functions";
|
import "missing-native-js-functions";
|
||||||
import fs from "fs";
|
|
||||||
import { Connection } from "mongoose";
|
import { Connection } from "mongoose";
|
||||||
import { Server, ServerOptions } from "lambert-server";
|
import { Server, ServerOptions } from "lambert-server";
|
||||||
import { Authentication, CORS } from "./middlewares/";
|
import { Authentication, CORS } from "./middlewares/";
|
||||||
import { Config, db, initEvent, RabbitMQ } from "@fosscord/util";
|
import { Config, db, initEvent } from "@fosscord/util";
|
||||||
import i18next from "i18next";
|
|
||||||
import i18nextMiddleware, { I18next } from "i18next-http-middleware";
|
|
||||||
import i18nextBackend from "i18next-node-fs-backend";
|
|
||||||
import { ErrorHandler } from "./middlewares/ErrorHandler";
|
import { ErrorHandler } from "./middlewares/ErrorHandler";
|
||||||
import { BodyParser } from "./middlewares/BodyParser";
|
import { BodyParser } from "./middlewares/BodyParser";
|
||||||
import express, { Router, Request, Response } from "express";
|
import { Router, Request, Response } from "express";
|
||||||
import mongoose from "mongoose";
|
import mongoose from "mongoose";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
import { initRateLimits } from "./middlewares/RateLimit";
|
import { initRateLimits } from "./middlewares/RateLimit";
|
||||||
import TestClient from "./middlewares/TestClient";
|
import TestClient from "./middlewares/TestClient";
|
||||||
|
import { initTranslation } from "./middlewares/Translation";
|
||||||
|
|
||||||
// this will return the new updated document for findOneAndUpdate
|
// this will return the new updated document for findOneAndUpdate
|
||||||
mongoose.set("returnOriginal", false); // https://mongoosejs.com/docs/api/model.html#model_Model.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();
|
await initEvent();
|
||||||
|
|
||||||
this.app.use(CORS);
|
this.app.use(CORS);
|
||||||
this.app.use(Authentication);
|
|
||||||
this.app.use(BodyParser({ inflate: true, limit: 1024 * 1024 * 10 })); // 2MB
|
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 app = this.app;
|
||||||
const api = Router();
|
const api = Router(); // @ts-ignore
|
||||||
// @ts-ignore
|
|
||||||
this.app = api;
|
this.app = api;
|
||||||
|
|
||||||
|
api.use(Authentication);
|
||||||
initRateLimits(api);
|
initRateLimits(api);
|
||||||
this.routes = await this.registerRoutes(path.join(__dirname, "routes", "/"));
|
await initTranslation(api);
|
||||||
app.use("/api/v8", api);
|
|
||||||
app.use("/api/v9", api);
|
|
||||||
app.use("/api", api); // allow unversioned requests
|
|
||||||
|
|
||||||
api.get("*", (req: Request, res: Response, next) => {
|
this.routes = await this.registerRoutes(path.join(__dirname, "routes", "/"));
|
||||||
|
|
||||||
|
api.use("*", (req: Request, res: Response) => {
|
||||||
res.status(404).json({
|
res.status(404).json({
|
||||||
message: "404: Not Found",
|
message: "404: Not Found",
|
||||||
code: 0
|
code: 0
|
||||||
});
|
});
|
||||||
next();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
this.app = app;
|
this.app = app;
|
||||||
|
app.use("/api/v8", api);
|
||||||
|
app.use("/api/v9", api);
|
||||||
|
app.use("/api", api); // allow unversioned requests
|
||||||
this.app.use(ErrorHandler);
|
this.app.use(ErrorHandler);
|
||||||
TestClient(this.app);
|
TestClient(this.app);
|
||||||
|
|
||||||
|
@ -28,10 +28,8 @@ declare global {
|
|||||||
|
|
||||||
export async function Authentication(req: Request, res: Response, next: NextFunction) {
|
export async function Authentication(req: Request, res: Response, next: NextFunction) {
|
||||||
if (req.method === "OPTIONS") return res.sendStatus(204);
|
if (req.method === "OPTIONS") return res.sendStatus(204);
|
||||||
if (!req.url.startsWith("/api")) return next();
|
if (req.url.startsWith("/invites") && req.method === "GET") return next(); // @ts-ignore
|
||||||
const apiPath = req.url.replace(API_PREFIX, "");
|
if (NO_AUTHORIZATION_ROUTES.some((x) => req.url.startsWith(x) || x.test?.(req.url))) return next();
|
||||||
if (apiPath.startsWith("/invites") && req.method === "GET") return next(); // @ts-ignore
|
|
||||||
if (NO_AUTHORIZATION_ROUTES.some((x) => apiPath.startsWith(x) || x.test?.(req.url))) return next();
|
|
||||||
if (!req.headers.authorization) return next(new HTTPError("Missing Authorization Header", 401));
|
if (!req.headers.authorization) return next(new HTTPError("Missing Authorization Header", 401));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
28
api/src/middlewares/Translation.ts
Normal file
28
api/src/middlewares/Translation.ts
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
import fs from "fs";
|
||||||
|
import path from "path";
|
||||||
|
import i18next from "i18next";
|
||||||
|
import i18nextMiddleware from "i18next-http-middleware";
|
||||||
|
import i18nextBackend from "i18next-node-fs-backend";
|
||||||
|
import { Router } from "express";
|
||||||
|
|
||||||
|
export async function initTranslation(router: Router) {
|
||||||
|
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"
|
||||||
|
});
|
||||||
|
|
||||||
|
router.use(i18nextMiddleware.handle(i18next, {}));
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user