@lvce-editor/server 0.53.4 → 0.53.6
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/ThirdPartyNotices.txt +2 -2
- package/package.json +3 -3
- package/src/server.js +89 -30
package/ThirdPartyNotices.txt
CHANGED
|
@@ -2,7 +2,7 @@ This project incorporates components from the projects listed below, that may ha
|
|
|
2
2
|
differing from this project:
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
1) License Notice for static/
|
|
5
|
+
1) License Notice for static/f429d0a/icons (from https://github.com/microsoft/vscode-icons)
|
|
6
6
|
---------------------------------------
|
|
7
7
|
|
|
8
8
|
Attribution 4.0 International
|
|
@@ -402,7 +402,7 @@ public licenses.
|
|
|
402
402
|
Creative Commons may be contacted at creativecommons.org.
|
|
403
403
|
|
|
404
404
|
|
|
405
|
-
2) License Notice for static/
|
|
405
|
+
2) License Notice for static/f429d0a/fonts/FiraCode-VariableFont.ttf (from https://github.com/tonsky/FiraCode)
|
|
406
406
|
---------------------------------------
|
|
407
407
|
|
|
408
408
|
Copyright (c) 2014, The Fira Code Project Authors (https://github.com/tonsky/FiraCode)
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lvce-editor/server",
|
|
3
|
-
"version": "0.53.
|
|
3
|
+
"version": "0.53.6",
|
|
4
4
|
"description": "Run LVCE Editor as a server.",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"bin": "bin/server.js",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
"node": ">=18"
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
|
-
"@lvce-editor/shared-process": "0.53.
|
|
24
|
-
"@lvce-editor/static-server": "0.53.
|
|
23
|
+
"@lvce-editor/shared-process": "0.53.6",
|
|
24
|
+
"@lvce-editor/static-server": "0.53.6"
|
|
25
25
|
}
|
|
26
26
|
}
|
package/src/server.js
CHANGED
|
@@ -4,6 +4,7 @@ import { ChildProcess, fork } from 'node:child_process'
|
|
|
4
4
|
import { createServer } from 'node:http'
|
|
5
5
|
import { dirname, join, resolve } from 'node:path'
|
|
6
6
|
import { fileURLToPath } from 'node:url'
|
|
7
|
+
import { Worker } from 'node:worker_threads'
|
|
7
8
|
|
|
8
9
|
const __dirname = dirname(fileURLToPath(import.meta.url))
|
|
9
10
|
const ROOT = resolve(__dirname, '../')
|
|
@@ -45,7 +46,7 @@ const isStatic = (url) => {
|
|
|
45
46
|
if(url === '/'){
|
|
46
47
|
return true
|
|
47
48
|
}
|
|
48
|
-
if (url.startsWith('/
|
|
49
|
+
if (url.startsWith('/f429d0a')) {
|
|
49
50
|
return true
|
|
50
51
|
}
|
|
51
52
|
if (url.startsWith('/favicon.ico')) {
|
|
@@ -59,7 +60,7 @@ const isStatic = (url) => {
|
|
|
59
60
|
|
|
60
61
|
const handleRequest = (req, res) => {
|
|
61
62
|
if (isStatic(req.url)) {
|
|
62
|
-
return sendHandleStaticServerProcess(req, res
|
|
63
|
+
return sendHandleStaticServerProcess(req, res, 'StaticServer.getResponse')
|
|
63
64
|
}
|
|
64
65
|
return sendHandleSharedProcess(req, res.socket, 'HandleRequest.handleRequest')
|
|
65
66
|
}
|
|
@@ -107,24 +108,55 @@ const handleSharedProcessDisconnect = () => {
|
|
|
107
108
|
console.info('[server] shared process disconnected')
|
|
108
109
|
}
|
|
109
110
|
|
|
111
|
+
const waitForProcessToBeReady = async (childProcess) => {
|
|
112
|
+
const { resolve, promise } = Promise.withResolvers()
|
|
113
|
+
childProcess.once('message', resolve)
|
|
114
|
+
const message = await promise
|
|
115
|
+
if (message !== 'ready') {
|
|
116
|
+
throw new Error('unexpected message')
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
110
120
|
/**
|
|
111
121
|
*
|
|
112
|
-
* @returns {Promise<
|
|
122
|
+
* @returns {Promise<any>}
|
|
113
123
|
*/
|
|
114
124
|
const launchProcess = async (processPath, execArgv) => {
|
|
115
|
-
const
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
125
|
+
const isWorker = execArgv.includes('--ipc-type=node-worker')
|
|
126
|
+
if (isWorker) {
|
|
127
|
+
const childProcess = new Worker(processPath, {
|
|
128
|
+
argv: execArgv,
|
|
129
|
+
env: {
|
|
130
|
+
...process.env,
|
|
131
|
+
},
|
|
132
|
+
})
|
|
133
|
+
childProcess.on('exit', handleExit)
|
|
134
|
+
childProcess.on('disconnect', handleSharedProcessDisconnect)
|
|
135
|
+
await waitForProcessToBeReady(childProcess)
|
|
136
|
+
return {
|
|
137
|
+
send(message) {
|
|
138
|
+
childProcess.postMessage(message)
|
|
139
|
+
},
|
|
140
|
+
on(event, listener) {
|
|
141
|
+
childProcess.on(event, listener)
|
|
142
|
+
},
|
|
143
|
+
off(event, listener) {
|
|
144
|
+
childProcess.off(event, listener)
|
|
145
|
+
},
|
|
146
|
+
}
|
|
147
|
+
} else {
|
|
148
|
+
const childProcess = fork(processPath, execArgv, {
|
|
149
|
+
stdio: 'inherit',
|
|
150
|
+
env: {
|
|
151
|
+
...process.env,
|
|
152
|
+
},
|
|
153
|
+
execArgv: [],
|
|
154
|
+
})
|
|
155
|
+
childProcess.on('exit', handleExit)
|
|
156
|
+
childProcess.on('disconnect', handleSharedProcessDisconnect)
|
|
157
|
+
await waitForProcessToBeReady(childProcess)
|
|
158
|
+
return childProcess
|
|
159
|
+
}
|
|
128
160
|
}
|
|
129
161
|
|
|
130
162
|
/**
|
|
@@ -153,7 +185,8 @@ const getOrCreateSharedProcess = () => {
|
|
|
153
185
|
*/
|
|
154
186
|
const launchStaticServerProcess = async () => {
|
|
155
187
|
const staticServerPath = fileURLToPath(import.meta.resolve('@lvce-editor/static-server'))
|
|
156
|
-
|
|
188
|
+
const ipc = await launchProcess(staticServerPath, ['--ipc-type=node-worker'])
|
|
189
|
+
return ipc
|
|
157
190
|
}
|
|
158
191
|
|
|
159
192
|
/**
|
|
@@ -211,21 +244,47 @@ const sendHandleSharedProcess = async (request, socket, method, ...params) => {
|
|
|
211
244
|
)
|
|
212
245
|
}
|
|
213
246
|
|
|
214
|
-
|
|
247
|
+
let id = 1
|
|
248
|
+
|
|
249
|
+
const createId = () => {
|
|
250
|
+
return ++id
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
const setHeaders = (response, headers) => {
|
|
254
|
+
for (const [key, value] of Object.entries(headers)) {
|
|
255
|
+
response.setHeader(key, value)
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
const sendHandleStaticServerProcess = async (request, res, method, ...params) => {
|
|
215
260
|
request.on('error', handleRequestError)
|
|
216
|
-
socket.on('error', handleSocketError)
|
|
261
|
+
res.socket.on('error', handleSocketError)
|
|
217
262
|
const staticServerProcess = await getOrCreateStaticServerPathProcess()
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
263
|
+
const { resolve, promise } = Promise.withResolvers()
|
|
264
|
+
const id = createId()
|
|
265
|
+
const handleMessage = (message) => {
|
|
266
|
+
if (message.id && message.id === id) {
|
|
267
|
+
resolve(message)
|
|
268
|
+
staticServerProcess.off('message', handleMessage)
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
staticServerProcess.on('message', handleMessage)
|
|
272
|
+
staticServerProcess.send({
|
|
273
|
+
jsonrpc: '2.0',
|
|
274
|
+
id,
|
|
275
|
+
method,
|
|
276
|
+
params: [getHandleMessage(request), ...params],
|
|
277
|
+
})
|
|
278
|
+
const response = await promise
|
|
279
|
+
const { result } = response
|
|
280
|
+
const { status, headers, body } = result
|
|
281
|
+
if (!status) {
|
|
282
|
+
throw new Error('invalid status')
|
|
283
|
+
}
|
|
284
|
+
res.statusCode = status
|
|
285
|
+
setHeaders(res, headers)
|
|
286
|
+
res.end(body)
|
|
287
|
+
// TODO use invoke
|
|
229
288
|
}
|
|
230
289
|
|
|
231
290
|
/**
|