@xelis/sdk 0.3.0 → 0.3.2

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/daemon/rpc.js CHANGED
@@ -9,6 +9,9 @@ class RPC {
9
9
  const res = await fetch(this.endpoint, { method: `POST`, body });
10
10
  if (res.ok) {
11
11
  const data = await res.json();
12
+ if (data.error) {
13
+ return Promise.reject(new Error(data.error.message));
14
+ }
12
15
  return Promise.resolve(data);
13
16
  }
14
17
  else {
package/daemon/types.d.ts CHANGED
@@ -11,7 +11,7 @@ export interface RPCError {
11
11
  export interface RPCResponse<T> {
12
12
  id: number;
13
13
  result: T;
14
- error: RPCError;
14
+ error?: RPCError;
15
15
  }
16
16
  export interface GetInfoResult {
17
17
  block_time_target: number;
@@ -7,6 +7,7 @@ declare class WS {
7
7
  socket?: WebSocket;
8
8
  timeout: number;
9
9
  connected: boolean;
10
+ unsubscribeSuspense: number;
10
11
  private events;
11
12
  constructor();
12
13
  connect(endpoint: string): Promise<unknown>;
@@ -15,6 +15,7 @@ class WS {
15
15
  this.timeout = 3000;
16
16
  this.connected = false;
17
17
  this.events = {};
18
+ this.unsubscribeSuspense = 1000;
18
19
  }
19
20
  connect(endpoint) {
20
21
  if (this.socket && this.socket.readyState !== WebSocket.CLOSED) {
@@ -92,6 +93,12 @@ class WS {
92
93
  }
93
94
  };
94
95
  if (this.events[event]) {
96
+ const { unsubscribeTimeoutId } = this.events[event];
97
+ if (unsubscribeTimeoutId) {
98
+ // clear timeout to unsubscribe
99
+ // because we got a new registered event and want to cancel the pending unsubscribe grace period
100
+ clearTimeout(unsubscribeTimeoutId);
101
+ }
95
102
  this.events[event].listeners.push(onMessage);
96
103
  }
97
104
  else {
@@ -105,13 +112,23 @@ class WS {
105
112
  this.events[event].id = res.id;
106
113
  }
107
114
  this.socket && this.socket.addEventListener(`message`, onMessage);
108
- const closeListen = async () => {
109
- if (this.events[event] && this.events[event].listeners.length === 1) {
110
- // this is the last listen callback so we unsubscribe from daemon ws
111
- const [err, _] = await to(this.call(`unsubscribe`, { notify: event }));
112
- if (err)
113
- return Promise.reject(err);
114
- Reflect.deleteProperty(this.events, event);
115
+ const closeListen = () => {
116
+ const eventData = this.events[event];
117
+ if (eventData) {
118
+ const listeners = eventData.listeners;
119
+ for (let i = 0; i < listeners.length; i++) {
120
+ if (listeners[i] === onMessage) {
121
+ listeners.splice(i, 1);
122
+ break;
123
+ }
124
+ }
125
+ if (listeners.length === 0) {
126
+ this.events[event].unsubscribeTimeoutId = setTimeout(async () => {
127
+ // no more listener so we unsubscribe from daemon websocket
128
+ this.call(`unsubscribe`, { notify: event });
129
+ Reflect.deleteProperty(this.events, event);
130
+ }, this.unsubscribeSuspense);
131
+ }
115
132
  }
116
133
  this.socket && this.socket.removeEventListener(`message`, onMessage);
117
134
  return Promise.resolve();
package/package.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "0.3.0",
2
+ "version": "0.3.2",
3
3
  "name": "@xelis/sdk",
4
4
  "description": "Xelis software development kit for JS",
5
5
  "repository": {