extra-native-websocket 0.2.1 → 0.2.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/README.md CHANGED
@@ -59,3 +59,16 @@ class ExtraNativeWebSocket {
59
59
  ```ts
60
60
  function autoReconnect(ws: ExtraNativeWebSocket, timeout?: number): () => void
61
61
  ```
62
+
63
+ ### autoReconnectWithExponentialBackOff
64
+ ```ts
65
+ function autoReonnectWithExponentialBackOff(
66
+ ws: ExtraWebSocket
67
+ , options: {
68
+ baseTimeout: number
69
+ maxTimeout?: number
70
+ factor?: number = 2
71
+ jitter?: boolean = true
72
+ }
73
+ ): () => void
74
+ ```
@@ -0,0 +1,7 @@
1
+ import { ExtraNativeWebSocket } from "../extra-native-websocket";
2
+ export declare function autoReconnectWithExponentialBackOff(ws: ExtraNativeWebSocket, { baseTimeout, maxTimeout, factor, jitter }: {
3
+ baseTimeout: number;
4
+ maxTimeout?: number;
5
+ factor?: number;
6
+ jitter?: boolean;
7
+ }): () => void;
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.autoReconnectWithExponentialBackOff = void 0;
13
+ const extra_native_websocket_1 = require("../extra-native-websocket");
14
+ const extra_timers_1 = require("extra-timers");
15
+ const prelude_1 = require("@blackglory/prelude");
16
+ const extra_promise_1 = require("extra-promise");
17
+ const wait_for_1 = require("@blackglory/wait-for");
18
+ function autoReconnectWithExponentialBackOff(ws, { baseTimeout, maxTimeout = Infinity, factor = 2, jitter = true }) {
19
+ const controller = new AbortController();
20
+ ws.addEventListener('error', ignore);
21
+ ws.addEventListener('close', listener);
22
+ return () => {
23
+ controller.abort();
24
+ ws.removeEventListener('close', listener);
25
+ ws.removeEventListener('error', ignore);
26
+ };
27
+ function ignore() {
28
+ (0, prelude_1.pass)();
29
+ }
30
+ function listener() {
31
+ return __awaiter(this, void 0, void 0, function* () {
32
+ ws.removeEventListener('close', listener);
33
+ let retries = 0;
34
+ while (true) {
35
+ if (controller.signal.aborted)
36
+ return;
37
+ yield (0, extra_promise_1.delay)((0, extra_timers_1.calculateExponentialBackoffTimeout)({
38
+ retries,
39
+ baseTimeout,
40
+ maxTimeout,
41
+ factor,
42
+ jitter
43
+ }));
44
+ if (controller.signal.aborted)
45
+ return;
46
+ try {
47
+ yield (0, wait_for_1.waitForFunction)(() => ws.getState() === extra_native_websocket_1.State.Closed);
48
+ yield ws.connect();
49
+ if (controller.signal.aborted)
50
+ return;
51
+ ws.addEventListener('close', listener);
52
+ break;
53
+ }
54
+ catch (_a) {
55
+ retries++;
56
+ (0, prelude_1.pass)();
57
+ }
58
+ }
59
+ });
60
+ }
61
+ }
62
+ exports.autoReconnectWithExponentialBackOff = autoReconnectWithExponentialBackOff;
63
+ //# sourceMappingURL=auto-reconnect-with-exponential-back-off.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auto-reconnect-with-exponential-back-off.js","sourceRoot":"","sources":["../../../src/utils/auto-reconnect-with-exponential-back-off.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,sEAAyE;AACzE,+CAAiE;AACjE,iDAA0C;AAC1C,iDAAqC;AACrC,mDAAsD;AAEtD,SAAgB,mCAAmC,CACjD,EAAwB,EACxB,EACE,WAAW,EACX,UAAU,GAAG,QAAQ,EACrB,MAAM,GAAG,CAAC,EACV,MAAM,GAAG,IAAI,EAMd;IAED,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAA;IAGxC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;IACpC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IACtC,OAAO,GAAG,EAAE;QACV,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QACzC,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;IACzC,CAAC,CAAA;IAED,SAAS,MAAM;QACb,IAAA,cAAI,GAAE,CAAA;IACR,CAAC;IAED,SAAe,QAAQ;;YACrB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;YAEzC,IAAI,OAAO,GAAG,CAAC,CAAA;YACf,OAAO,IAAI,EAAE;gBACX,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,MAAM,IAAA,qBAAK,EAAC,IAAA,iDAAkC,EAAC;oBAC7C,OAAO;oBACP,WAAW;oBACX,UAAU;oBACV,MAAM;oBACN,MAAM;iBACP,CAAC,CAAC,CAAA;gBACH,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,IAAI;oBACF,MAAM,IAAA,0BAAe,EAAC,GAAG,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,8BAAK,CAAC,MAAM,CAAC,CAAA;oBAC3D,MAAM,EAAE,CAAC,OAAO,EAAE,CAAA;oBAClB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;wBAAE,OAAM;oBAErC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;oBACtC,MAAK;iBACN;gBAAC,WAAM;oBACN,OAAO,EAAE,CAAA;oBACT,IAAA,cAAI,GAAE,CAAA;iBACP;aACF;QACH,CAAC;KAAA;AACH,CAAC;AA1DD,kFA0DC"}
@@ -10,9 +10,11 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.autoReconnect = void 0;
13
+ const extra_native_websocket_1 = require("../extra-native-websocket");
13
14
  const extra_promise_1 = require("extra-promise");
14
15
  const extra_abort_1 = require("extra-abort");
15
16
  const prelude_1 = require("@blackglory/prelude");
17
+ const wait_for_1 = require("@blackglory/wait-for");
16
18
  function autoReconnect(ws, timeout = 0) {
17
19
  const controller = new extra_abort_1.AbortController();
18
20
  ws.addEventListener('close', listener);
@@ -30,6 +32,7 @@ function autoReconnect(ws, timeout = 0) {
30
32
  if (controller.signal.aborted)
31
33
  return;
32
34
  try {
35
+ yield (0, wait_for_1.waitForFunction)(() => ws.getState() === extra_native_websocket_1.State.Closed);
33
36
  yield ws.connect();
34
37
  if (controller.signal.aborted)
35
38
  return;
@@ -1 +1 @@
1
- {"version":3,"file":"auto-reconnect.js","sourceRoot":"","sources":["../../../src/utils/auto-reconnect.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,iDAAqC;AACrC,6CAA6C;AAC7C,iDAA0C;AAE1C,SAAgB,aAAa,CAAC,EAAwB,EAAE,UAAkB,CAAC;IACzE,MAAM,UAAU,GAAG,IAAI,6BAAe,EAAE,CAAA;IAExC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IACtC,OAAO,GAAG,EAAE;QACV,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC3C,CAAC,CAAA;IAED,SAAe,QAAQ;;YACrB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;YAEzC,OAAO,IAAI,EAAE;gBACX,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,MAAM,IAAA,qBAAK,EAAC,OAAO,CAAC,CAAA;gBACpB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,IAAI;oBACF,MAAM,EAAE,CAAC,OAAO,EAAE,CAAA;oBAClB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;wBAAE,OAAM;oBAErC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;oBACtC,MAAK;iBACN;gBAAC,WAAM;oBACN,IAAA,cAAI,GAAE,CAAA;iBACP;aACF;QACH,CAAC;KAAA;AACH,CAAC;AA7BD,sCA6BC"}
1
+ {"version":3,"file":"auto-reconnect.js","sourceRoot":"","sources":["../../../src/utils/auto-reconnect.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,sEAAyE;AACzE,iDAAqC;AACrC,6CAA6C;AAC7C,iDAA0C;AAC1C,mDAAsD;AAEtD,SAAgB,aAAa,CAAC,EAAwB,EAAE,UAAkB,CAAC;IACzE,MAAM,UAAU,GAAG,IAAI,6BAAe,EAAE,CAAA;IAExC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IACtC,OAAO,GAAG,EAAE;QACV,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC3C,CAAC,CAAA;IAED,SAAe,QAAQ;;YACrB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;YAEzC,OAAO,IAAI,EAAE;gBACX,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,MAAM,IAAA,qBAAK,EAAC,OAAO,CAAC,CAAA;gBACpB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,IAAI;oBACF,MAAM,IAAA,0BAAe,EAAC,GAAG,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,8BAAK,CAAC,MAAM,CAAC,CAAA;oBAC3D,MAAM,EAAE,CAAC,OAAO,EAAE,CAAA;oBAClB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;wBAAE,OAAM;oBAErC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;oBACtC,MAAK;iBACN;gBAAC,WAAM;oBACN,IAAA,cAAI,GAAE,CAAA;iBACP;aACF;QACH,CAAC;KAAA;AACH,CAAC;AA9BD,sCA8BC"}
@@ -1 +1,2 @@
1
1
  export * from './auto-reconnect';
2
+ export * from './auto-reconnect-with-exponential-back-off';
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./auto-reconnect"), exports);
18
+ __exportStar(require("./auto-reconnect-with-exponential-back-off"), exports);
18
19
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC;AAChC,6EAA0D"}
@@ -0,0 +1,7 @@
1
+ import { ExtraNativeWebSocket } from "../extra-native-websocket";
2
+ export declare function autoReconnectWithExponentialBackOff(ws: ExtraNativeWebSocket, { baseTimeout, maxTimeout, factor, jitter }: {
3
+ baseTimeout: number;
4
+ maxTimeout?: number;
5
+ factor?: number;
6
+ jitter?: boolean;
7
+ }): () => void;
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.autoReconnectWithExponentialBackOff = void 0;
4
+ const extra_native_websocket_1 = require("../extra-native-websocket");
5
+ const extra_timers_1 = require("extra-timers");
6
+ const prelude_1 = require("@blackglory/prelude");
7
+ const extra_promise_1 = require("extra-promise");
8
+ const wait_for_1 = require("@blackglory/wait-for");
9
+ function autoReconnectWithExponentialBackOff(ws, { baseTimeout, maxTimeout = Infinity, factor = 2, jitter = true }) {
10
+ const controller = new AbortController();
11
+ ws.addEventListener('error', ignore);
12
+ ws.addEventListener('close', listener);
13
+ return () => {
14
+ controller.abort();
15
+ ws.removeEventListener('close', listener);
16
+ ws.removeEventListener('error', ignore);
17
+ };
18
+ function ignore() {
19
+ (0, prelude_1.pass)();
20
+ }
21
+ async function listener() {
22
+ ws.removeEventListener('close', listener);
23
+ let retries = 0;
24
+ while (true) {
25
+ if (controller.signal.aborted)
26
+ return;
27
+ await (0, extra_promise_1.delay)((0, extra_timers_1.calculateExponentialBackoffTimeout)({
28
+ retries,
29
+ baseTimeout,
30
+ maxTimeout,
31
+ factor,
32
+ jitter
33
+ }));
34
+ if (controller.signal.aborted)
35
+ return;
36
+ try {
37
+ await (0, wait_for_1.waitForFunction)(() => ws.getState() === extra_native_websocket_1.State.Closed);
38
+ await ws.connect();
39
+ if (controller.signal.aborted)
40
+ return;
41
+ ws.addEventListener('close', listener);
42
+ break;
43
+ }
44
+ catch (_a) {
45
+ retries++;
46
+ (0, prelude_1.pass)();
47
+ }
48
+ }
49
+ }
50
+ }
51
+ exports.autoReconnectWithExponentialBackOff = autoReconnectWithExponentialBackOff;
52
+ //# sourceMappingURL=auto-reconnect-with-exponential-back-off.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auto-reconnect-with-exponential-back-off.js","sourceRoot":"","sources":["../../../src/utils/auto-reconnect-with-exponential-back-off.ts"],"names":[],"mappings":";;;AAAA,sEAAyE;AACzE,+CAAiE;AACjE,iDAA0C;AAC1C,iDAAqC;AACrC,mDAAsD;AAEtD,SAAgB,mCAAmC,CACjD,EAAwB,EACxB,EACE,WAAW,EACX,UAAU,GAAG,QAAQ,EACrB,MAAM,GAAG,CAAC,EACV,MAAM,GAAG,IAAI,EAMd;IAED,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAA;IAGxC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;IACpC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IACtC,OAAO,GAAG,EAAE;QACV,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QACzC,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;IACzC,CAAC,CAAA;IAED,SAAS,MAAM;QACb,IAAA,cAAI,GAAE,CAAA;IACR,CAAC;IAED,KAAK,UAAU,QAAQ;QACrB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QAEzC,IAAI,OAAO,GAAG,CAAC,CAAA;QACf,OAAO,IAAI,EAAE;YACX,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAM;YAErC,MAAM,IAAA,qBAAK,EAAC,IAAA,iDAAkC,EAAC;gBAC7C,OAAO;gBACP,WAAW;gBACX,UAAU;gBACV,MAAM;gBACN,MAAM;aACP,CAAC,CAAC,CAAA;YACH,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAM;YAErC,IAAI;gBACF,MAAM,IAAA,0BAAe,EAAC,GAAG,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,8BAAK,CAAC,MAAM,CAAC,CAAA;gBAC3D,MAAM,EAAE,CAAC,OAAO,EAAE,CAAA;gBAClB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;gBACtC,MAAK;aACN;YAAC,WAAM;gBACN,OAAO,EAAE,CAAA;gBACT,IAAA,cAAI,GAAE,CAAA;aACP;SACF;IACH,CAAC;AACH,CAAC;AA1DD,kFA0DC"}
@@ -1,9 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.autoReconnect = void 0;
4
+ const extra_native_websocket_1 = require("../extra-native-websocket");
4
5
  const extra_promise_1 = require("extra-promise");
5
6
  const extra_abort_1 = require("extra-abort");
6
7
  const prelude_1 = require("@blackglory/prelude");
8
+ const wait_for_1 = require("@blackglory/wait-for");
7
9
  function autoReconnect(ws, timeout = 0) {
8
10
  const controller = new extra_abort_1.AbortController();
9
11
  ws.addEventListener('close', listener);
@@ -20,6 +22,7 @@ function autoReconnect(ws, timeout = 0) {
20
22
  if (controller.signal.aborted)
21
23
  return;
22
24
  try {
25
+ await (0, wait_for_1.waitForFunction)(() => ws.getState() === extra_native_websocket_1.State.Closed);
23
26
  await ws.connect();
24
27
  if (controller.signal.aborted)
25
28
  return;
@@ -1 +1 @@
1
- {"version":3,"file":"auto-reconnect.js","sourceRoot":"","sources":["../../../src/utils/auto-reconnect.ts"],"names":[],"mappings":";;;AACA,iDAAqC;AACrC,6CAA6C;AAC7C,iDAA0C;AAE1C,SAAgB,aAAa,CAAC,EAAwB,EAAE,UAAkB,CAAC;IACzE,MAAM,UAAU,GAAG,IAAI,6BAAe,EAAE,CAAA;IAExC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IACtC,OAAO,GAAG,EAAE;QACV,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC3C,CAAC,CAAA;IAED,KAAK,UAAU,QAAQ;QACrB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QAEzC,OAAO,IAAI,EAAE;YACX,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAM;YAErC,MAAM,IAAA,qBAAK,EAAC,OAAO,CAAC,CAAA;YACpB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAM;YAErC,IAAI;gBACF,MAAM,EAAE,CAAC,OAAO,EAAE,CAAA;gBAClB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;gBACtC,MAAK;aACN;YAAC,WAAM;gBACN,IAAA,cAAI,GAAE,CAAA;aACP;SACF;IACH,CAAC;AACH,CAAC;AA7BD,sCA6BC"}
1
+ {"version":3,"file":"auto-reconnect.js","sourceRoot":"","sources":["../../../src/utils/auto-reconnect.ts"],"names":[],"mappings":";;;AAAA,sEAAyE;AACzE,iDAAqC;AACrC,6CAA6C;AAC7C,iDAA0C;AAC1C,mDAAsD;AAEtD,SAAgB,aAAa,CAAC,EAAwB,EAAE,UAAkB,CAAC;IACzE,MAAM,UAAU,GAAG,IAAI,6BAAe,EAAE,CAAA;IAExC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IACtC,OAAO,GAAG,EAAE;QACV,UAAU,CAAC,KAAK,EAAE,CAAA;QAClB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC3C,CAAC,CAAA;IAED,KAAK,UAAU,QAAQ;QACrB,EAAE,CAAC,mBAAmB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;QAEzC,OAAO,IAAI,EAAE;YACX,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAM;YAErC,MAAM,IAAA,qBAAK,EAAC,OAAO,CAAC,CAAA;YACpB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;gBAAE,OAAM;YAErC,IAAI;gBACF,MAAM,IAAA,0BAAe,EAAC,GAAG,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,8BAAK,CAAC,MAAM,CAAC,CAAA;gBAC3D,MAAM,EAAE,CAAC,OAAO,EAAE,CAAA;gBAClB,IAAI,UAAU,CAAC,MAAM,CAAC,OAAO;oBAAE,OAAM;gBAErC,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;gBACtC,MAAK;aACN;YAAC,WAAM;gBACN,IAAA,cAAI,GAAE,CAAA;aACP;SACF;IACH,CAAC;AACH,CAAC;AA9BD,sCA8BC"}
@@ -1 +1,2 @@
1
1
  export * from './auto-reconnect';
2
+ export * from './auto-reconnect-with-exponential-back-off';
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./auto-reconnect"), exports);
18
+ __exportStar(require("./auto-reconnect-with-exponential-back-off"), exports);
18
19
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC;AAChC,6EAA0D"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "extra-native-websocket",
3
- "version": "0.2.1",
3
+ "version": "0.2.2",
4
4
  "description": "",
5
5
  "keywords": [],
6
6
  "files": [
@@ -59,6 +59,7 @@
59
59
  "@blackglory/errors": "^2.2.1",
60
60
  "@blackglory/prelude": "^0.1.1",
61
61
  "@blackglory/structures": "^0.5.1",
62
+ "@blackglory/wait-for": "^0.4.4",
62
63
  "extra-abort": "^0.1.2",
63
64
  "extra-promise": "^2.0.0"
64
65
  }