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);
|