/
server.js
62 lines (50 loc) · 1.82 KB
/
server.js
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
import { wrapExpressCreateRequestHandler } from "@sentry/remix";
import { createRequestHandler } from "@remix-run/express";
import compression from "compression";
import express from "express";
const sentryCreateRequestHandler =
wrapExpressCreateRequestHandler(createRequestHandler);
const shouldStartDevServer = process.env.NODE_ENV !== "production";
const isStagingOrPreviewEnvironment = process.env.ENVIRONMENT !== "production";
const viteDevServer = shouldStartDevServer
? await import("vite").then((vite) =>
vite.createServer({
server: { middlewareMode: true },
}),
)
: undefined;
const remixHandler = sentryCreateRequestHandler({
build: viteDevServer
? () => viteDevServer.ssrLoadModule("virtual:remix/server-build")
: await import("./build/server/index.js"),
});
const app = express();
app.use(compression());
// http://expressjs.com/en/advanced/best-practice-security.html#at-a-minimum-disable-x-powered-by-header
app.disable("x-powered-by");
// handle asset requests
if (viteDevServer) {
app.use(viteDevServer.middlewares);
} else {
// Vite fingerprints its assets so we can cache forever.
app.use(
"/assets",
express.static("build/client/assets", { immutable: true, maxAge: "1y" }),
);
}
// Everything else (like favicon.ico) is cached for an hour. You may want to be
// more aggressive with this caching.
const staticFileServer = express.static("build/client", { maxAge: "1h" });
const mountPathWithoutStorybook = [
/^\/build\/client\/storybook($|\/)/,
"/build/client",
];
isStagingOrPreviewEnvironment
? app.use(staticFileServer)
: app.use(mountPathWithoutStorybook, staticFileServer);
// handle SSR requests
app.all("*", remixHandler);
const port = process.env.PORT || 3000;
app.listen(port, () =>
console.log(`Express server listening at http://localhost:${port}`),
);