@live-change/server 0.8.10 → 0.8.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/Renderer.js +11 -8
- package/lib/Services.js +10 -0
- package/lib/SsrServer.js +66 -36
- package/lib/createLoopbackDao.js +8 -0
- package/package.json +7 -7
package/lib/Renderer.js
CHANGED
|
@@ -128,7 +128,7 @@ class Renderer {
|
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
130
|
|
|
131
|
-
async
|
|
131
|
+
async getSitemapRenderFunction() {
|
|
132
132
|
if(this.settings.dev) {
|
|
133
133
|
/// Reload every request
|
|
134
134
|
const entryPath = path.resolve(this.root, this.settings.serverEntry || 'src/entry-server.js')
|
|
@@ -138,19 +138,22 @@ class Renderer {
|
|
|
138
138
|
}
|
|
139
139
|
}
|
|
140
140
|
|
|
141
|
-
async renderSitemap(
|
|
141
|
+
async renderSitemap(params, res) {
|
|
142
142
|
try {
|
|
143
|
+
const { url, headers, dao, clientIp, credentials, windowId, version, now } = params
|
|
144
|
+
|
|
143
145
|
res.header('Content-Type', 'application/xml')
|
|
144
146
|
res.status(200)
|
|
145
147
|
const smStream = new SitemapStream({ hostname: (process.env.BASE_HREF || "https://sitemap.com")+'/' })
|
|
146
148
|
smStream.pipe(res)
|
|
147
|
-
const sitemapFunction = await this.
|
|
148
|
-
|
|
149
|
-
function
|
|
150
|
-
|
|
149
|
+
const sitemapFunction = await this.getSitemapRenderFunction()
|
|
150
|
+
|
|
151
|
+
function write(routeInfo) {
|
|
152
|
+
console.log("SM WRITE", routeInfo)
|
|
153
|
+
smStream.write(routeInfo)
|
|
151
154
|
}
|
|
152
|
-
|
|
153
|
-
await
|
|
155
|
+
|
|
156
|
+
await sitemapFunction(params, write)
|
|
154
157
|
//route({ name: 'index' })
|
|
155
158
|
smStream.end()
|
|
156
159
|
} catch(err) {
|
package/lib/Services.js
CHANGED
|
@@ -86,6 +86,16 @@ class Services {
|
|
|
86
86
|
}
|
|
87
87
|
}
|
|
88
88
|
}
|
|
89
|
+
// push validators from services to other services
|
|
90
|
+
for(const sourceServiceDefinition of this.serviceDefinitions) {
|
|
91
|
+
for(const validatorName in sourceServiceDefinition.validators) {
|
|
92
|
+
for(const destinationServiceDefinition of this.serviceDefinitions) {
|
|
93
|
+
if(!destinationServiceDefinition.validators[validatorName]) {
|
|
94
|
+
destinationServiceDefinition.validators[validatorName] = sourceServiceDefinition.validators[validatorName]
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
89
99
|
|
|
90
100
|
/// TODO: load dependent services!!!
|
|
91
101
|
}
|
package/lib/SsrServer.js
CHANGED
|
@@ -100,10 +100,33 @@ class SsrServer {
|
|
|
100
100
|
})
|
|
101
101
|
|
|
102
102
|
this.express.get('/sitemap.xml', async (req, res) => {
|
|
103
|
-
|
|
103
|
+
if(this.settings.spa) {
|
|
104
|
+
res.status(404).end()
|
|
105
|
+
return
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const url = req.originalUrl
|
|
104
109
|
const clientIp = getIp(req)
|
|
105
|
-
const
|
|
106
|
-
this.
|
|
110
|
+
const credentials = readCredentials(req)
|
|
111
|
+
const windowId = this.uidGenerator()
|
|
112
|
+
const now = Date.now()
|
|
113
|
+
|
|
114
|
+
try {
|
|
115
|
+
const dao = await this.createDao({ sessionKey: 'sitemap' }, clientIp)
|
|
116
|
+
try {
|
|
117
|
+
const version = this.version
|
|
118
|
+
await this.renderer.renderSitemap({
|
|
119
|
+
url, headers: req.headers, dao, clientIp, credentials, windowId, version, now
|
|
120
|
+
}, res)
|
|
121
|
+
} catch (e) {
|
|
122
|
+
console.error("SITEMAP RENDERING ERROR", e.stack || e)
|
|
123
|
+
res.status(500).end(e.stack || e)
|
|
124
|
+
}
|
|
125
|
+
dao.dispose()
|
|
126
|
+
} catch (e) {
|
|
127
|
+
console.error("SITEMAP DAO ERROR", e.stack || e)
|
|
128
|
+
res.status(500).end(e.stack || e)
|
|
129
|
+
}
|
|
107
130
|
})
|
|
108
131
|
this.express.use('*', async (req, res) => {
|
|
109
132
|
if(fbRedirect(req, res)) return
|
|
@@ -120,48 +143,55 @@ class SsrServer {
|
|
|
120
143
|
|
|
121
144
|
const credentials = readCredentials(req)
|
|
122
145
|
const windowId = this.uidGenerator()
|
|
123
|
-
|
|
124
|
-
try {
|
|
125
|
-
dao = await this.createDao(credentials, clientIp)
|
|
126
|
-
} catch (e) {
|
|
127
|
-
console.error("DAO ERROR", e.stack || e)
|
|
128
|
-
res.status(500).end(e.stack || e)
|
|
129
|
-
}
|
|
146
|
+
|
|
130
147
|
try {
|
|
131
|
-
const
|
|
148
|
+
const dao = await this.createDao(credentials, clientIp)
|
|
149
|
+
|
|
150
|
+
//dao.dispose(); return res.end('dao test!!\n')
|
|
151
|
+
|
|
152
|
+
try {
|
|
153
|
+
const version = this.version
|
|
154
|
+
|
|
155
|
+
let result
|
|
156
|
+
let error
|
|
157
|
+
|
|
158
|
+
for(let retry = 0; retry < 3; retry ++) {
|
|
159
|
+
try {
|
|
160
|
+
const now = Date.now()
|
|
161
|
+
result = await this.renderer.renderPage({
|
|
162
|
+
url, headers: req.headers, dao, clientIp, credentials, windowId, version, now
|
|
163
|
+
})
|
|
164
|
+
break
|
|
165
|
+
} catch(e) {
|
|
166
|
+
error = e
|
|
167
|
+
}
|
|
168
|
+
}
|
|
132
169
|
|
|
133
|
-
|
|
134
|
-
let error
|
|
170
|
+
//dao.dispose(); return res.end('render page test!!\n')
|
|
135
171
|
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
172
|
+
if(result) {
|
|
173
|
+
const { html, response } = result
|
|
174
|
+
res.status(response?.status || 200)
|
|
175
|
+
writeCredentials(res, credentials)
|
|
176
|
+
res.set(response?.headers ?? {
|
|
177
|
+
'Content-Type': 'text/html'
|
|
141
178
|
})
|
|
142
|
-
|
|
143
|
-
}
|
|
144
|
-
error
|
|
179
|
+
res.end(html)
|
|
180
|
+
} else {
|
|
181
|
+
if(error.stack) this.renderer.fixStackTrace(error)
|
|
182
|
+
console.error("RENDERING ERROR", error.stack || error)
|
|
183
|
+
res.status(500).end(error.stack || error)
|
|
145
184
|
}
|
|
185
|
+
} catch (e) {
|
|
186
|
+
console.error("ERROR", e.stack || e)
|
|
187
|
+
res.status(500).end(e.stack || e)
|
|
146
188
|
}
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
res.status(response?.status || 200)
|
|
150
|
-
writeCredentials(res, credentials)
|
|
151
|
-
res.set(response?.headers ?? {
|
|
152
|
-
'Content-Type': 'text/html'
|
|
153
|
-
})
|
|
154
|
-
res.end(html)
|
|
155
|
-
} else {
|
|
156
|
-
if(error.stack) this.renderer.fixStackTrace(error)
|
|
157
|
-
console.error("RENDERING ERROR", error.stack || error)
|
|
158
|
-
res.status(500).end(error.stack || error)
|
|
159
|
-
}
|
|
189
|
+
|
|
190
|
+
dao.dispose()
|
|
160
191
|
} catch (e) {
|
|
161
|
-
console.error("ERROR", e.stack || e)
|
|
192
|
+
console.error("DAO ERROR", e.stack || e)
|
|
162
193
|
res.status(500).end(e.stack || e)
|
|
163
194
|
}
|
|
164
|
-
dao.dispose()
|
|
165
195
|
})
|
|
166
196
|
}
|
|
167
197
|
|
package/lib/createLoopbackDao.js
CHANGED
|
@@ -3,6 +3,7 @@ import Dao from "@live-change/dao"
|
|
|
3
3
|
async function createLoopbackDao(credentials, daoFactory) {
|
|
4
4
|
const server = new Dao.ReactiveServer(daoFactory)
|
|
5
5
|
const loopback = new Dao.LoopbackConnection(credentials, server, {})
|
|
6
|
+
|
|
6
7
|
const dao = new Dao(credentials, {
|
|
7
8
|
remoteUrl: 'dao',
|
|
8
9
|
protocols: { local: null },
|
|
@@ -15,13 +16,20 @@ async function createLoopbackDao(credentials, daoFactory) {
|
|
|
15
16
|
logLevel: 10,
|
|
16
17
|
},
|
|
17
18
|
})
|
|
19
|
+
|
|
18
20
|
dao.connections.set('local:dao', loopback)
|
|
21
|
+
|
|
19
22
|
await loopback.initialize()
|
|
23
|
+
|
|
24
|
+
//dao.dispose(); return null
|
|
25
|
+
|
|
20
26
|
if(!loopback.connected) {
|
|
21
27
|
console.error("LOOPBACK NOT CONNECTED?!")
|
|
22
28
|
process.exit(1)
|
|
23
29
|
}
|
|
30
|
+
|
|
24
31
|
return dao
|
|
32
|
+
|
|
25
33
|
}
|
|
26
34
|
|
|
27
35
|
export default createLoopbackDao
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@live-change/server",
|
|
3
|
-
"version": "0.8.
|
|
3
|
+
"version": "0.8.12",
|
|
4
4
|
"description": "Live Change Framework - server",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -22,12 +22,12 @@
|
|
|
22
22
|
"type": "module",
|
|
23
23
|
"homepage": "https://github.com/live-change/live-change-framework",
|
|
24
24
|
"dependencies": {
|
|
25
|
-
"@live-change/dao": "^0.8.
|
|
26
|
-
"@live-change/dao-sockjs": "^0.8.
|
|
27
|
-
"@live-change/db-server": "^0.8.
|
|
28
|
-
"@live-change/framework": "^0.8.
|
|
25
|
+
"@live-change/dao": "^0.8.12",
|
|
26
|
+
"@live-change/dao-sockjs": "^0.8.12",
|
|
27
|
+
"@live-change/db-server": "^0.8.12",
|
|
28
|
+
"@live-change/framework": "^0.8.12",
|
|
29
29
|
"@live-change/sockjs": "0.4.1",
|
|
30
|
-
"@live-change/uid": "^0.8.
|
|
30
|
+
"@live-change/uid": "^0.8.12",
|
|
31
31
|
"dotenv": "^16.4.4",
|
|
32
32
|
"express": "^4.18.2",
|
|
33
33
|
"express-static-gzip": "2.1.7",
|
|
@@ -39,5 +39,5 @@
|
|
|
39
39
|
"websocket": "^1.0.34",
|
|
40
40
|
"yargs": "^17.7.2"
|
|
41
41
|
},
|
|
42
|
-
"gitHead": "
|
|
42
|
+
"gitHead": "5c93162184742550bf6a5e7b37a5537c69f8a3c4"
|
|
43
43
|
}
|