@jcbuisson/express-x-client 2.1.8 → 2.2.1
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/package.json +1 -1
- package/src/index.mjs +40 -19
package/package.json
CHANGED
package/src/index.mjs
CHANGED
|
@@ -17,34 +17,50 @@ export default function expressXClient(socket, options={}) {
|
|
|
17
17
|
const waitingPromisesByUid = {}
|
|
18
18
|
const action2service2handlers = {}
|
|
19
19
|
const type2appHandler = {}
|
|
20
|
-
let
|
|
21
|
-
let
|
|
22
|
-
let
|
|
20
|
+
let connectListeners = []
|
|
21
|
+
let disconnectListeners = []
|
|
22
|
+
let errorListeners = []
|
|
23
23
|
|
|
24
24
|
socket.on("connect", async () => {
|
|
25
25
|
console.log("socket connected", socket.id)
|
|
26
|
-
|
|
26
|
+
for (const func of connectListeners) {
|
|
27
|
+
func(socket)
|
|
28
|
+
}
|
|
27
29
|
})
|
|
28
30
|
|
|
29
31
|
socket.on("connect_error", async (err) => {
|
|
30
32
|
console.log("socket connection error", socket.id)
|
|
31
|
-
|
|
33
|
+
for (const func of errorListeners) {
|
|
34
|
+
func(socket)
|
|
35
|
+
}
|
|
32
36
|
})
|
|
33
37
|
|
|
34
38
|
socket.on("disconnect", async () => {
|
|
35
|
-
|
|
39
|
+
console.log("socket disconnected", socket.id)
|
|
40
|
+
for (const func of disconnectListeners) {
|
|
41
|
+
func(socket)
|
|
42
|
+
}
|
|
36
43
|
})
|
|
37
44
|
|
|
38
|
-
function
|
|
39
|
-
|
|
45
|
+
function addConnectListener(func) {
|
|
46
|
+
connectListeners.push(func)
|
|
47
|
+
}
|
|
48
|
+
function removeConnectListener(func) {
|
|
49
|
+
connectListeners = connectListeners.filter(f !== func)
|
|
40
50
|
}
|
|
41
51
|
|
|
42
|
-
function
|
|
43
|
-
|
|
52
|
+
function addDisconnectListener(func) {
|
|
53
|
+
disconnectListeners.push(func)
|
|
54
|
+
}
|
|
55
|
+
function removeDisonnectListener(func) {
|
|
56
|
+
disconnectListeners = disconnectListeners.filter(f !== func)
|
|
44
57
|
}
|
|
45
58
|
|
|
46
|
-
function
|
|
47
|
-
|
|
59
|
+
function addErrorListener(func) {
|
|
60
|
+
errorListeners.push(func)
|
|
61
|
+
}
|
|
62
|
+
function removeErrorListener(func) {
|
|
63
|
+
errorListeners = errorListeners.filter(f !== func)
|
|
48
64
|
}
|
|
49
65
|
|
|
50
66
|
// on receiving response from service request
|
|
@@ -75,10 +91,12 @@ export default function expressXClient(socket, options={}) {
|
|
|
75
91
|
const promise = new Promise((resolve, reject) => {
|
|
76
92
|
waitingPromisesByUid[uid] = [resolve, reject]
|
|
77
93
|
// a timeout may also reject the promise
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
94
|
+
if (serviceOptions.timeout && !serviceOptions.volatile) {
|
|
95
|
+
setTimeout(() => {
|
|
96
|
+
delete waitingPromisesByUid[uid]
|
|
97
|
+
reject(`Error: timeout on service '${name}', action '${action}', args: ${JSON.stringify(args)}`)
|
|
98
|
+
}, serviceOptions.timeout)
|
|
99
|
+
}
|
|
82
100
|
})
|
|
83
101
|
// send request to server through websocket
|
|
84
102
|
if (options.debug) console.log('client-request', uid, name, action, args)
|
|
@@ -134,9 +152,12 @@ export default function expressXClient(socket, options={}) {
|
|
|
134
152
|
}
|
|
135
153
|
|
|
136
154
|
return {
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
155
|
+
addConnectListener,
|
|
156
|
+
removeConnectListener,
|
|
157
|
+
addDisconnectListener,
|
|
158
|
+
removeDisonnectListener,
|
|
159
|
+
addErrorListener,
|
|
160
|
+
removeErrorListener,
|
|
140
161
|
|
|
141
162
|
service,
|
|
142
163
|
on,
|