@cardano-sdk/util-rxjs 0.4.16 → 0.5.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/dist/cjs/coldObservableProvider.d.ts +14 -0
- package/dist/cjs/coldObservableProvider.d.ts.map +1 -0
- package/dist/cjs/coldObservableProvider.js +33 -0
- package/dist/cjs/coldObservableProvider.js.map +1 -0
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/coldObservableProvider.d.ts +14 -0
- package/dist/esm/coldObservableProvider.d.ts.map +1 -0
- package/dist/esm/coldObservableProvider.js +29 -0
- package/dist/esm/coldObservableProvider.js.map +1 -0
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -4
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Observable, switchMap } from 'rxjs';
|
|
2
|
+
import { RetryBackoffConfig } from 'backoff-rxjs';
|
|
3
|
+
export interface ColdObservableProviderProps<T> {
|
|
4
|
+
provider: () => Promise<T>;
|
|
5
|
+
retryBackoffConfig: RetryBackoffConfig;
|
|
6
|
+
onFatalError?: (value: unknown) => void;
|
|
7
|
+
trigger$?: Observable<unknown>;
|
|
8
|
+
equals?: (t1: T, t2: T) => boolean;
|
|
9
|
+
combinator?: typeof switchMap;
|
|
10
|
+
cancel$?: Observable<unknown>;
|
|
11
|
+
pollUntil?: (v: T) => boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare const coldObservableProvider: <T>({ provider, retryBackoffConfig, onFatalError, trigger$, equals, combinator, cancel$, pollUntil }: ColdObservableProviderProps<T>) => Observable<T>;
|
|
14
|
+
//# sourceMappingURL=coldObservableProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coldObservableProvider.d.ts","sourceRoot":"","sources":["../../src/coldObservableProvider.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,UAAU,EASV,SAAS,EAGV,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,kBAAkB,EAAgB,MAAM,cAAc,CAAC;AAEhE,MAAM,WAAW,2BAA2B,CAAC,CAAC;IAC5C,QAAQ,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3B,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IACxC,QAAQ,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC/B,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,OAAO,CAAC;IACnC,UAAU,CAAC,EAAE,OAAO,SAAS,CAAC;IAC9B,OAAO,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IAC9B,SAAS,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,OAAO,CAAC;CAC/B;AAED,eAAO,MAAM,sBAAsB,wJAqD/B,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.coldObservableProvider = void 0;
|
|
4
|
+
const util_1 = require("@cardano-sdk/util");
|
|
5
|
+
const rxjs_1 = require("rxjs");
|
|
6
|
+
const backoff_rxjs_1 = require("backoff-rxjs");
|
|
7
|
+
const coldObservableProvider = ({ provider, retryBackoffConfig, onFatalError, trigger$ = (0, rxjs_1.of)(true), equals = util_1.strictEquals, combinator = rxjs_1.switchMap, cancel$ = rxjs_1.NEVER, pollUntil = () => true }) => new rxjs_1.Observable((subscriber) => {
|
|
8
|
+
const cancelOnFatalError$ = new rxjs_1.Subject();
|
|
9
|
+
const internalCancel$ = (0, rxjs_1.merge)(cancel$, cancelOnFatalError$);
|
|
10
|
+
const sub = trigger$
|
|
11
|
+
.pipe(combinator(() => (0, rxjs_1.defer)(() => (0, rxjs_1.from)(provider()).pipe((0, rxjs_1.mergeMap)((v) => pollUntil(v)
|
|
12
|
+
? (0, rxjs_1.of)(v)
|
|
13
|
+
:
|
|
14
|
+
(0, rxjs_1.concat)((0, rxjs_1.of)(v), (0, rxjs_1.throwError)(() => new Error('polling')))))).pipe((0, backoff_rxjs_1.retryBackoff)({
|
|
15
|
+
...retryBackoffConfig,
|
|
16
|
+
shouldRetry: (error) => {
|
|
17
|
+
if (retryBackoffConfig.shouldRetry && !retryBackoffConfig.shouldRetry(error))
|
|
18
|
+
return false;
|
|
19
|
+
if (error instanceof util_1.InvalidStringError) {
|
|
20
|
+
onFatalError?.(error);
|
|
21
|
+
cancelOnFatalError$.next(true);
|
|
22
|
+
}
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
}))), (0, rxjs_1.distinctUntilChanged)(equals), (0, rxjs_1.takeUntil)(internalCancel$))
|
|
26
|
+
.subscribe(subscriber);
|
|
27
|
+
return () => {
|
|
28
|
+
sub.unsubscribe();
|
|
29
|
+
cancelOnFatalError$.complete();
|
|
30
|
+
};
|
|
31
|
+
});
|
|
32
|
+
exports.coldObservableProvider = coldObservableProvider;
|
|
33
|
+
//# sourceMappingURL=coldObservableProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coldObservableProvider.js","sourceRoot":"","sources":["../../src/coldObservableProvider.ts"],"names":[],"mappings":";;;AAAA,4CAAqE;AACrE,+BAcc;AACd,+CAAgE;AAazD,MAAM,sBAAsB,GAAG,CAAI,EACxC,QAAQ,EACR,kBAAkB,EAClB,YAAY,EACZ,QAAQ,GAAG,IAAA,SAAE,EAAC,IAAI,CAAC,EACnB,MAAM,GAAG,mBAAY,EACrB,UAAU,GAAG,gBAAS,EACtB,OAAO,GAAG,YAAK,EACf,SAAS,GAAG,GAAG,EAAE,CAAC,IAAI,EACS,EAAE,EAAE,CACnC,IAAI,iBAAU,CAAI,CAAC,UAAU,EAAE,EAAE;IAC/B,MAAM,mBAAmB,GAAG,IAAI,cAAO,EAAW,CAAC;IACnD,MAAM,eAAe,GAAG,IAAA,YAAK,EAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;IAC5D,MAAM,GAAG,GAAG,QAAQ;SACjB,IAAI,CACH,UAAU,CAAC,GAAG,EAAE,CACd,IAAA,YAAK,EAAC,GAAG,EAAE,CACT,IAAA,WAAI,EAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CACnB,IAAA,eAAQ,EAAC,CAAC,CAAC,EAAE,EAAE,CACb,SAAS,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,IAAA,SAAE,EAAC,CAAC,CAAC;QACP,CAAC;YACC,IAAA,aAAM,EACJ,IAAA,SAAE,EAAC,CAAC,CAAC,EACL,IAAA,iBAAU,EAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC,CACvC,CACN,CACF,CACF,CAAC,IAAI,CACJ,IAAA,2BAAY,EAAC;QACX,GAAG,kBAAkB;QACrB,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE;YACrB,IAAI,kBAAkB,CAAC,WAAW,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,KAAK,CAAC;gBAAE,OAAO,KAAK,CAAC;YAE3F,IAAI,KAAK,YAAY,yBAAkB,EAAE;gBACvC,YAAY,EAAE,CAAC,KAAK,CAAC,CAAC;gBACtB,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAChC;YAED,OAAO,IAAI,CAAC;QACd,CAAC;KACF,CAAC,CACH,CACF,EACD,IAAA,2BAAoB,EAAC,MAAM,CAAC,EAC5B,IAAA,gBAAS,EAAC,eAAe,CAAC,CAC3B;SACA,SAAS,CAAC,UAAU,CAAC,CAAC;IAEzB,OAAO,GAAG,EAAE;QACV,GAAG,CAAC,WAAW,EAAE,CAAC;QAClB,mBAAmB,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC;AArDQ,QAAA,sBAAsB,0BAqD9B"}
|
package/dist/cjs/index.d.ts
CHANGED
package/dist/cjs/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,0BAA0B,CAAC;AACzC,cAAc,qBAAqB,CAAC;AACpC,cAAc,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,sBAAsB,CAAC;AACrC,cAAc,0BAA0B,CAAC;AACzC,cAAc,qBAAqB,CAAC;AACpC,cAAc,0BAA0B,CAAC;AACzC,cAAc,SAAS,CAAC"}
|
package/dist/cjs/index.js
CHANGED
|
@@ -21,5 +21,6 @@ __exportStar(require("./passthrough"), exports);
|
|
|
21
21
|
__exportStar(require("./finalizeWithLatest"), exports);
|
|
22
22
|
__exportStar(require("./concatAndCombineLatest"), exports);
|
|
23
23
|
__exportStar(require("./shareRetryBackoff"), exports);
|
|
24
|
+
__exportStar(require("./coldObservableProvider"), exports);
|
|
24
25
|
__exportStar(require("./types"), exports);
|
|
25
26
|
//# sourceMappingURL=index.js.map
|
package/dist/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,2DAAyC;AACzC,4CAA0B;AAC1B,gDAA8B;AAC9B,uDAAqC;AACrC,2DAAyC;AACzC,sDAAoC;AACpC,0CAAwB"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,2DAAyC;AACzC,4CAA0B;AAC1B,gDAA8B;AAC9B,uDAAqC;AACrC,2DAAyC;AACzC,sDAAoC;AACpC,2DAAyC;AACzC,0CAAwB"}
|