-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.ts
96 lines (82 loc) · 2.47 KB
/
index.ts
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
95
96
import chokidar from "chokidar";
import { Server, createServer } from "http";
import { Socket } from "net";
import next from "next";
import path from "path";
import { parse } from "url";
const state = {
backendServer: undefined as Server | undefined,
backendSockets: [] as Socket[],
};
const dev = process.env.NODE_ENV !== "production";
const NEXT_PORT = 3001; // Port for the Next.js app
const BACKEND_PORT = 3002; // Port for the Express server
const app = next({ dev });
const handle = app.getRequestHandler();
app.prepare().then(() => {
const nextServer = createServer(async (req, res) => {
try {
const parsedUrl = parse(req.url ?? "", true);
await handle(req, res, parsedUrl);
} catch (err) {
console.error("Error occurred handling", req.url, err);
res.statusCode = 500;
res.end("internal server error");
}
});
nextServer.once("error", (err) => {
console.error(err);
process.exit(1);
});
nextServer.listen(NEXT_PORT, () => {
console.log(`🔥 [next server]: running at http://localhost:${NEXT_PORT}`);
});
function startBackendServer() {
state.backendServer = (require("./backend") as unknown as Server).listen(
BACKEND_PORT,
() => {
console.log(
`🔥 [backend server]: running at http://localhost:${BACKEND_PORT}`
);
}
);
state.backendServer.on("connection", (socket) => {
console.log("Add socket", state.backendSockets.length + 1);
state.backendSockets.push(socket);
});
}
function pathCheck(id: string) {
return id.startsWith(path.join(__dirname, "backend"));
}
function restartBackendServer() {
// clean the cache
Object.keys(require.cache).forEach((id) => {
if (pathCheck(id)) {
console.log("Reloading", id);
delete require.cache[id];
}
});
state.backendSockets.forEach((socket, index) => {
console.log("Destroying socket", index + 1);
if (socket.destroyed === false) {
socket.destroy();
}
});
state.backendSockets = [];
state.backendServer?.close(() => {
console.log("Server is closed");
console.log("\n----------------- restarting -------------");
startBackendServer();
});
}
startBackendServer();
chokidar.watch("./backend").on("all", (event, at) => {
if (event === "add") {
console.log("Watching for", at);
}
if (event === "change") {
console.log("Changes at", at);
restartBackendServer();
}
});
});