summary refs log tree commit diff
path: root/gateway/src/Server.ts
blob: 482545f15322a11919786970815b5df34ead4de3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import "missing-native-js-functions";
import dotenv from "dotenv";
dotenv.config();
import { Config, db, initEvent, RabbitMQ } from "@fosscord/util";
import { Server as WebSocketServer } from "ws";
import { Connection } from "./events/Connection";
import http from "http";

export class Server {
	public ws: WebSocketServer;
	public port: number;
	public server: http.Server;
	public production: boolean;

	constructor({ port, server, production }: { port: number; server?: http.Server; production?: boolean }) {
		this.port = port;
		this.production = production || false;

		if (server) this.server = server;
		else
			this.server = http.createServer(function (req, res) {
				res.writeHead(200).end("Online");
			});

		this.ws = new WebSocketServer({
			maxPayload: 4096,
			server: this.server,
		});
		this.ws.on("connection", Connection);
		this.ws.on("error", console.error);
	}

	async setupSchema() {
		// TODO: adjust expireAfterSeconds -> lower
		await Promise.all([db.collection("events").createIndex({ created_at: 1 }, { expireAfterSeconds: 60 })]);
	}

	async start(): Promise<void> {
		// @ts-ignore
		await (db as Promise<Connection>);
		await this.setupSchema();
		await Config.init();
		await initEvent();
		if (!this.server.listening) {
			this.server.listen(this.port);
			console.log(`[Gateway] online on 0.0.0.0:${this.port}`);
		}
	}

	async stop() {
		await db.close();
		this.server.close();
	}
}