-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.ts
114 lines (90 loc) · 3.17 KB
/
server.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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import 'zone.js/node'
import { APP_BASE_HREF } from '@angular/common'
import { CommonEngine } from '@angular/ssr'
import * as express from 'express'
import { existsSync } from 'node:fs'
import { join } from 'node:path'
import bootstrap from './src/main.server'
import { REQUEST, RESPONSE } from './src/express.tokens'
import * as fs from 'fs'
// The Express app is exported so that it can be used by serverless Functions.
export function app(): express.Express {
const server = express()
const distFolder = join(process.cwd(), 'dist/browser')
const indexHtml = existsSync(join(distFolder, 'index.original.html'))
? join(distFolder, 'index.original.html')
: join(distFolder, 'index.html')
const commonEngine = new CommonEngine()
server.set('view engine', 'html')
server.set('views', distFolder)
// Example Express Rest API endpoints
// server.get('/api/**', (req, res) => { })
// Serve static files from /browser
server.get('*.*', express.static(distFolder, {
maxAge: '1y'
}))
const ngApp = (req: any, res: any, next: any) => {
const { protocol, originalUrl, baseUrl, headers } = req
commonEngine
.render({
bootstrap,
documentFilePath: indexHtml,
url: `${protocol}://${headers.host}${originalUrl}`,
publicPath: distFolder,
providers: [
{ provide: APP_BASE_HREF, useValue: baseUrl },
{ provide: RESPONSE, useValue: res },
{ provide: REQUEST, useValue: req }
],
})
.then((html) => {
let status = 200
if (html && html.includes('404-error')) {
status = 404
}
if (html && html.includes('401-error')) {
status = 401
}
if (!html) {
status = 500
}
return res.status(status).send(html)
})
.catch((err) => next(err))
}
let data: any = JSON.parse(fs.readFileSync(`dist/browser/assets/locales.json`, 'utf8'))
// Default route with accept-language redirect
server.get('/', (req: any, res: any) => {
const defaultLang = 'nl'
const lang = req.acceptsLanguages('nl', 'fr', 'en')
const definedLang = lang || defaultLang
res.redirect(301, `/${definedLang}`)
})
// oad translated routes used by LocalizeRouter
data.forEach((route: string) => {
console.log('registering', `/${route}`)
server.get(`/${route}`, ngApp)
server.get(`/${route}/*`, ngApp)
})
// All regular routes use the Angular engine
server.get('*', ngApp)
return server
}
function run(): void {
const port = process.env['PORT'] || 80
// Start up the Node server
const server = app()
server.listen(port, () => {
console.log(`Node Express server listening on http://localhost:${port}`)
})
}
// Webpack will replace 'require' with '__webpack_require__'
// '__non_webpack_require__' is a proxy to Node 'require'
// The below code is to ensure that the server is run only when not requiring the bundle.
declare const __non_webpack_require__: NodeRequire
const mainModule = __non_webpack_require__.main
const moduleFilename = mainModule && mainModule.filename || ''
if (moduleFilename === __filename || moduleFilename.includes('iisnode')) {
run()
}
export default bootstrap