forked from stvlynn/EasyProfile
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
97 lines (82 loc) · 3.17 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
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
import fs from 'fs'
import path from 'path'
import { fileURLToPath } from 'url'
import express from 'express'
import { createServer as createViteServer } from 'vite'
import yaml from 'js-yaml'
const __dirname = path.dirname(fileURLToPath(import.meta.url))
async function createServer() {
const app = express()
// Create Vite server in middleware mode
const vite = await createViteServer({
server: { middlewareMode: true },
appType: 'custom'
})
// Use vite's connect instance as middleware
app.use(vite.middlewares)
app.use('*', async (req, res, next) => {
const url = req.originalUrl
try {
// 1. Read index.html
let template = fs.readFileSync(
path.resolve(__dirname, 'index.html'),
'utf-8'
)
// 2. Read config.yaml
const config = yaml.load(fs.readFileSync(
path.resolve(__dirname, 'src/config/config.yaml'),
'utf-8'
))
// 3. Apply Vite HTML transforms
template = await vite.transformIndexHtml(url, template)
// 4. Replace meta tags with config values
template = template.replace(
'<title>Personal Profile</title>',
`<title>${config.site.title}</title>`
)
template = template.replace(
'<link rel="icon" type="image/svg+xml" href="/vite.svg" />',
`<link rel="icon" href="/assets/${config.site.favicon}" />`
)
// Add Google Analytics if enabled
const gaScript = config.site.analytics?.google?.enabled && config.site.analytics?.google?.id
? `<!-- Google tag (gtag.js) -->
<script async src="https://www.googletagmanager.com/gtag/js?id=${config.site.analytics.google.id}"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', '${config.site.analytics.google.id}');
</script>`
: ''
// Insert GA script before </head>
template = template.replace('</head>', `${gaScript}</head>`)
template = template.replace(
'<meta property="og:description" content="Steven Lynn\'s About Page">',
`<meta property="og:description" content="${config.og.description}">`
)
template = template.replace(
'<meta property="og:image:width" content="1189">',
`<meta property="og:image:width" content="${config.og.image.width}">`
)
template = template.replace(
'<meta property="og:image:height" content="795">',
`<meta property="og:image:height" content="${config.og.image.height}">`
)
template = template.replace(
'<meta property="og:image" content="https://cdn.statically.io/gh/stvlynn/cloudimg@master/blog/2310/image.64v30jxjis00.webp">',
`<meta property="og:image" content="${config.og.image.url}">`
)
// 5. Send the rendered HTML back
res.status(200).set({ 'Content-Type': 'text/html' }).end(template)
} catch (e) {
// If an error is caught, let Vite fix the stack trace
vite.ssrFixStacktrace(e)
next(e)
}
})
app.listen(5173, () => {
console.log('Server running at http://localhost:5173')
})
}
createServer()