summary refs log tree commit diff
path: root/bundle/src/start.ts
blob: f65c1db9a94b6bc2f78e3dea6f63d0f87abb4d7e (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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// process.env.MONGOMS_DEBUG = "true";
const tsConfigPaths = require("tsconfig-paths");
const path = require("path");
const baseUrl = path.join(__dirname, "..");
const cleanup = tsConfigPaths.register({
	baseUrl,
	paths: {
		"@fosscord/api": ["../api/dist/index.js"],
		"@fosscord/api/*": ["../api/dist/*"],
		"@fosscord/gateway": ["../gateway/dist/index.js"],
		"@fosscord/gateway/*": ["../gateway/dist/*"],
		"@fosscord/cdn": ["../cdn/dist/index.js"],
		"@fosscord/cdn/*": ["../cdn/dist/*"],
	},
});
console.log(require("@fosscord/gateway"));

import "reflect-metadata";
import cluster from "cluster";
import os from "os";
import { red, bold, yellow, cyan } from "nanocolors";
import { initStats } from "./stats";
import { config } from "dotenv";
config();
import { execSync } from "child_process";

// TODO: add tcp socket event transmission
const cores = 1 || Number(process.env.threads) || os.cpus().length;

function getCommitOrFail() {
	try {
		return execSync("git rev-parse HEAD").toString().trim();
	} catch (e) {
		return null;
	}
}
const commit = getCommitOrFail();

console.log(
	bold(`
███████  ██████  ███████ ███████  ██████  ██████  ██████  ██████  
██      ██    ██ ██      ██      ██      ██    ██ ██   ██ ██   ██ 
█████   ██    ██ ███████ ███████ ██      ██    ██ ██████  ██   ██ 
██      ██    ██      ██      ██ ██      ██    ██ ██   ██ ██   ██ 
██       ██████  ███████ ███████  ██████  ██████  ██   ██ ██████  
           

		fosscord-server | ${yellow(
			`Pre-relase (${
				commit !== null
					? commit.slice(0, 7)
					: "Unknown (Git cannot be found)"
			})`
		)}

Current commit: ${
		commit !== null
			? `${cyan(commit)} (${yellow(commit.slice(0, 7))})`
			: "Unknown (Git cannot be found)"
	}
`)
);

if (commit == null)
	console.log(yellow(`Warning: Git is not installed or not in PATH.`));

if (cluster.isMaster && !process.env.masterStarted) {
	process.env.masterStarted = "true";

	(async () => {
		initStats();

		if (cores === 1) {
			require("./Server");
			return;
		}

		// Fork workers.
		for (let i = 0; i < cores; i++) {
			cluster.fork();
		}

		cluster.on("exit", (worker: any, code: any, signal: any) => {
			console.log(
				`[Worker] ${red(
					`died with pid: ${worker.process.pid} , restarting ...`
				)}`
			);
			cluster.fork();
		});
	})();
} else {
	require("./Server");
}