summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--README.md50
-rw-r--r--api/src/Server.ts43
-rw-r--r--api/src/middlewares/Authentication.ts6
-rw-r--r--api/src/middlewares/Translation.ts28
-rw-r--r--bundle/src/Server.ts3
-rw-r--r--bundle/src/start.ts5
-rw-r--r--gateway/src/Server.ts8
7 files changed, 89 insertions, 54 deletions
diff --git a/README.md b/README.md

index c679e685..1c9e6cec 100644 --- a/README.md +++ b/README.md
@@ -1,15 +1,35 @@ -# Fosscord Server -Consists of: - * HTTP Rest API - * CDN - * Gateway - * RTC - -## Dev getting started -1. Install deps: `npm i` -2. TODO: Configure -3. Start the server: - * To run all at once, run `npm start` in root directory. - * To run api, do `npm start` in `api` folder - * To run cdn, do `npm start` in `cdn` folder - * To run gateway, do `npm start` in `gateway` folder +<p align="center"> + <img width="100" src="https://raw.githubusercontent.com/fosscord/fosscord/master/assets/logo_big_transparent.png" /> +</p> +<h1 align="center">Fosscord Server</h1> + +<p> + <a href="https://discord.gg/ZrnGQP6p3d"> + <img src="https://img.shields.io/discord/806142446094385153?color=7489d5&logo=discord&logoColor=ffffff" /> + </a> + <img src="https://img.shields.io/static/v1?label=Status&message=Development&color=blue"> + <a title="Crowdin" target="_blank" href="https://translate.fosscord.com/"><img src="https://badges.crowdin.net/fosscord/localized.svg"></a> + <a href="https://opencollective.com/fosscord"> + <img src="https://opencollective.com/fosscord/tiers/badge.svg"> + </a> +</p> + +## [About](https://fosscord.com) + +This repository contains: + +- [Fosscord HTTP API Server](https://github.com/fosscord/fosscord-server/tree/master/api) +- [WebSocket Gateway Server](https://github.com/fosscord/fosscord-server/tree/master/gateway) +- [HTTP CDN Server](https://github.com/fosscord/fosscord-server/tree/master/cdn) +- [Utility and Database Models](https://github.com/fosscord/fosscord-server/tree/master/util) +- [RTC Server](https://github.com/fosscord/fosscord-server/tree/master/rtc) +- [WebRTC Server](https://github.com/fosscord/fosscord-server/tree/master/webrtc) +- [Admin Dashboard](https://github.com/fosscord/fosscord-server/tree/master/dashboard) + +## [Ressources](https://docs.fosscord.com/resources/) + +- [Contributing](https://docs.fosscord.com/contributing/) + +## [Download](https://github.com/fosscord/fosscord-server/releases) + +- _is not done yet_ 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); diff --git a/api/src/middlewares/Authentication.ts b/api/src/middlewares/Authentication.ts
index 00cd9ea7..9bd2fcb7 100644 --- a/api/src/middlewares/Authentication.ts +++ b/api/src/middlewares/Authentication.ts
@@ -28,10 +28,8 @@ declare global { export async function Authentication(req: Request, res: Response, next: NextFunction) { if (req.method === "OPTIONS") return res.sendStatus(204); - if (!req.url.startsWith("/api")) return next(); - const apiPath = req.url.replace(API_PREFIX, ""); - 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.url.startsWith("/invites") && req.method === "GET") return next(); // @ts-ignore + if (NO_AUTHORIZATION_ROUTES.some((x) => req.url.startsWith(x) || x.test?.(req.url))) return next(); if (!req.headers.authorization) return next(new HTTPError("Missing Authorization Header", 401)); try { diff --git a/api/src/middlewares/Translation.ts b/api/src/middlewares/Translation.ts new file mode 100644
index 00000000..edc14707 --- /dev/null +++ b/api/src/middlewares/Translation.ts
@@ -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, {})); +} diff --git a/bundle/src/Server.ts b/bundle/src/Server.ts
index 19d9e168..68966bf4 100644 --- a/bundle/src/Server.ts +++ b/bundle/src/Server.ts
@@ -9,10 +9,9 @@ import express from "express"; import { Config } from "../../util/dist"; const app = express(); -const server = http.createServer(); +const server = http.createServer(app); const port = Number(process.env.PORT) || 8080; const production = true; -server.on("request", app); // @ts-ignore const api = new APIServer({ server, port, production, app }); diff --git a/bundle/src/start.ts b/bundle/src/start.ts
index 2bfb0069..ee012c15 100644 --- a/bundle/src/start.ts +++ b/bundle/src/start.ts
@@ -60,6 +60,11 @@ if (cluster.isMaster && !process.env.masterStarted) { console.log(`[Database] started`); console.log(`[Process] running with pid: ${process.pid}`); + if (cores === 1) { + require("./Server.js"); + return; + } + // Fork workers. for (let i = 0; i < cores; i++) { cluster.fork(); diff --git a/gateway/src/Server.ts b/gateway/src/Server.ts
index 482545f1..c2bc9c47 100644 --- a/gateway/src/Server.ts +++ b/gateway/src/Server.ts
@@ -22,9 +22,15 @@ export class Server { res.writeHead(200).end("Online"); }); + this.server.on("upgrade", (request, socket, head) => { + this.ws.handleUpgrade(request, socket, head, (socket) => { + this.ws.emit("connection", socket, request); + }); + }); + this.ws = new WebSocketServer({ maxPayload: 4096, - server: this.server, + noServer: true, }); this.ws.on("connection", Connection); this.ws.on("error", console.error);