-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
106 lines (80 loc) · 2.97 KB
/
server.js
File metadata and controls
106 lines (80 loc) · 2.97 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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
// @ts-check
import fs from 'fs';
import path from 'path';
import express from 'express';
import { fileURLToPath } from 'url';
import compression from 'compression';
import serveStatic from 'serve-static';
import { createServer as createViteServer } from 'vite';
import { generateMetaInfo } from './seoData.js';
import { getHeader } from './html-template.js';
import { promises } from "fs";
import cors from 'cors';
const PORT = process.env.PORT || 3000;
// Get __dirname equivalent in ES6 modules
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const isTest = process.env.NODE_ENV === 'test' || !!process.env.VITE_TEST_BUILD;
process.env.MY_CUSTOM_SECRET = 'API_KEY_qwertyuiop';
async function createServer(root = process.cwd(), isProd = process.env.NODE_ENV === 'production') {
const resolve = (p) => path.resolve(__dirname, p);
console.log("this is resolve", resolve)
const indexProd = isProd ? fs.readFileSync(resolve('./dist/client/index.html'), 'utf-8') : '';
const app = express();
app.use(cors({ origin: 'https://your-netlify-app.netlify.app' })); // Replace with your actual Netlify URL
let vite;
if (!isProd) {
vite = await createViteServer({
root,
logLevel: isTest ? 'error' : 'info',
server: {
middlewareMode: true, // Change 'ssr' to true
},
appType: "custom",
});
app.use(vite.middlewares);
} else {
app.use(compression());
app.use(serveStatic(resolve('./dist/client'), { index: false }));
}
app.use('*', async (req, res) => {
try {
const url = req.originalUrl;
let template, render;
if (!isProd) {
template = await promises.readFile("../index.html", "utf-8");
const metaData = generateMetaInfo({ path: url });
const metaTags = getHeader(metaData);
// 🚀 REPLACING `<!--meta-tags-->` IN HTML FILE 🚀
template = template.replace("<!--meta-tags-->", metaTags);
res.status(200).set({ "Content-Type": "text/html" }).end(template);
} else {
template = indexProd;
render = (await import(resolve('./dist/server/entry-server.js'))).render;
const context = {};
const appHtml = await render(url, context);
if (context.url) {
return res.redirect(301, context.url);
}
const metaData = generateMetaInfo({ path: url });
const metaTags = getHeader(metaData);
template = template.replace("<!--meta-tags-->", metaTags);
const html = template.replace(`<!--app-html-->`, appHtml);
res.status(200).set({ 'Content-Type': 'text/html' }).end(html);
}
} catch (e) {
if (!isProd) vite.ssrFixStacktrace(e);
console.log(e.stack);
res.status(500).end(e.stack);
}
});
return { app, vite };
}
if (!isTest) {
createServer().then(({ app }) =>
app.listen(PORT, () => {
console.log('http://localhost:3000');
})
);
}
export { createServer };