@@ -27,6 +27,8 @@ export default class EventChannelClient {
27
27
private _ws ?: WebSocket | WebSocketBE ;
28
28
/** Whether it's connected or not. */
29
29
private _isConnected : boolean ;
30
+ /** The custom client id of the event channel. */
31
+ private _customClientId : string ;
30
32
/** The handshake timeout object. */
31
33
private _handshakeTimeout ?: ReturnType < typeof setTimeout > | null ;
32
34
/** The heartbeat timeout object. */
@@ -42,6 +44,7 @@ export default class EventChannelClient {
42
44
this . _eventCallbackManager = eventCallbackManager ;
43
45
this . _ws = undefined ;
44
46
this . _isConnected = false ;
47
+ this . _customClientId = '' ;
45
48
this . _handshakeTimeout = undefined ;
46
49
this . _heartbeatTimeout = undefined ;
47
50
}
@@ -54,9 +57,10 @@ export default class EventChannelClient {
54
57
* Opens a new event channel.
55
58
* @param {ConnectionCallback } connectionCallback The connection callback function.
56
59
* @param {DisconnectionCallback } disconnectionCallback The disconnection callback function.
60
+ * @param {string } customClientId The custom client id to set.
57
61
* @returns {Promise<void> } A promise for the connection success.
58
62
*/
59
- connect ( connectionCallback ?: ConnectionCallback , disconnectionCallback ?: DisconnectionCallback ) : Promise < any > {
63
+ connect ( connectionCallback ?: ConnectionCallback , disconnectionCallback ?: DisconnectionCallback , customClientId ?: string ) : Promise < any > {
60
64
return new Promise ( async ( resolve , reject ) => {
61
65
if ( this . isConnected ) {
62
66
reject ( new Error ( `Can't connect multiple channels` ) ) ;
@@ -139,6 +143,10 @@ export default class EventChannelClient {
139
143
}
140
144
// Heartbeat timeout
141
145
this . startHeartbeatTimer ( DEFAULT_HEARTBEAT_INTERVAL_MS ) ;
146
+ // Custom client id
147
+ if ( customClientId ) {
148
+ this . setCustomClientId ( customClientId ) ;
149
+ }
142
150
// Connection callback
143
151
if ( connectionCallback ) {
144
152
connectionCallback ( this . _ws ) ;
@@ -291,30 +299,48 @@ export default class EventChannelClient {
291
299
}
292
300
293
301
/**
294
- * Sends a register-event-filter messsage to the event channel.
302
+ * Sends a SET_CUSTOM_CLIENT_ID messsage to the event channel.
303
+ * @param {string } customClientId The custom client id to set.
304
+ */
305
+ setCustomClientId ( customClientId : string ) {
306
+ this . _customClientId = customClientId ;
307
+ const data = { customClientId } ;
308
+ const message = this . buildMessage ( EventChannelMessageTypes . SET_CUSTOM_CLIENT_ID , data ) ;
309
+ this . sendMessage ( message ) ;
310
+ }
311
+
312
+ /**
313
+ * Returns the custom client id saved on the client side.
314
+ */
315
+ getCustomClientId ( ) {
316
+ return this . _customClientId ;
317
+ }
318
+
319
+ /**
320
+ * Sends a REGISTER_FILTER messsage to the event channel.
295
321
* @param {EventFilter } filter The event filter to register.
296
322
*/
297
323
registerFilter ( filter : EventFilter ) {
298
- const filterObj = filter . toObject ( ) ;
299
- const registerMessage = this . buildMessage ( EventChannelMessageTypes . REGISTER_FILTER , filterObj ) ;
300
- this . sendMessage ( registerMessage ) ;
324
+ const data = filter . toObject ( ) ;
325
+ const message = this . buildMessage ( EventChannelMessageTypes . REGISTER_FILTER , data ) ;
326
+ this . sendMessage ( message ) ;
301
327
}
302
328
303
329
/**
304
- * Sends a deregister-event-filter messsage to the event channel.
330
+ * Sends a DEREGISTER_FILTER messsage to the event channel.
305
331
* @param {EventFilter } filter The event filter to deregister.
306
332
*/
307
333
deregisterFilter ( filter : EventFilter ) {
308
- const filterObj = filter . toObject ( ) ;
309
- const deregisterMessage = this . buildMessage ( EventChannelMessageTypes . DEREGISTER_FILTER , filterObj ) ;
310
- this . sendMessage ( deregisterMessage ) ;
334
+ const data = filter . toObject ( ) ;
335
+ const message = this . buildMessage ( EventChannelMessageTypes . DEREGISTER_FILTER , data ) ;
336
+ this . sendMessage ( message ) ;
311
337
}
312
338
313
339
/**
314
- * Sends a pong message.
340
+ * Sends a PONG message.
315
341
*/
316
342
sendPong ( ) {
317
- const pongMessage = this . buildMessage ( EventChannelMessageTypes . PONG , { } ) ;
318
- this . sendMessage ( pongMessage ) ;
343
+ const message = this . buildMessage ( EventChannelMessageTypes . PONG , { } ) ;
344
+ this . sendMessage ( message ) ;
319
345
}
320
346
}
0 commit comments