-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathserver.js
More file actions
89 lines (73 loc) · 2.13 KB
/
server.js
File metadata and controls
89 lines (73 loc) · 2.13 KB
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
/// <reference types="node" />
/* eslint-disable */
import 'dotenv/config'
import * as path from "path";
import { createRequestHandler } from 'htmx-router';
import { renderToString } from 'react-dom/server';
import express from 'express';
import morgan from "morgan";
const port = process.env.PORT || 5173;
const app = express();
const viteDevServer =
process.env.NODE_ENV === "production"
? null
: await import("vite").then((vite) =>
vite.createServer({
server: { middlewareMode: true },
appType: 'custom'
})
);
if (viteDevServer) {
app.use(viteDevServer.middlewares)
} else {
app.use(express.static("./dist/client"));
app.use("/dist/asset", express.static("./dist/server/dist/asset",));
}
// logging
app.use(morgan("tiny"));
const build = viteDevServer
? () => viteDevServer.ssrLoadModule('./app/entry.server.ts')
: await import('./dist/server/entry.server.js');
app.use('*', createRequestHandler.http({
build, viteDevServer,
render: (res, headers) => {
if (!headers.has("Cache-Control")) headers.set("Cache-Control", "no-cache");
headers.set("Content-Type", "text/html; charset=UTF-8");
return renderToString(res);
}
}));
// Start http server
app.listen(port, () => {
console.log(`Server started at http://localhost:${port}`)
})
// Reload pages on file change
if (viteDevServer) {
const focus = path.resolve("./app");
viteDevServer.watcher.on('change', (file) => {
if (!file.startsWith(focus)) return;
console.log(`File changed: ${file}`);
console.log('Triggering full page reload');
viteDevServer.ws.send({ type: 'full-reload' });
});
}
const shutdown = () => {
console.log("Shutting down server...");
// Close the server gracefully
app.close((err) => {
if (err) {
console.error("Error during server shutdown:", err);
process.exit(1);
}
console.log("Server shut down gracefully.");
process.exit(0);
});
};
process.on('SIGTERM', shutdown);
process.on('SIGHUP', shutdown);
process .on('unhandledRejection', (reason, p) => {
console.error(reason, 'Unhandled Rejection at Promise', p);
})
.on('uncaughtException', err => {
console.error(err, 'Uncaught Exception thrown');
process.exit(1);
});