@xylabs/retry 3.6.11 → 4.0.0
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/neutral/index.d.ts +13 -2
- package/package.json +8 -15
- package/xy.config.ts +12 -0
- package/dist/browser/index.cjs +0 -41
- package/dist/browser/index.cjs.map +0 -1
- package/dist/browser/index.d.cts +0 -2
- package/dist/browser/index.d.cts.map +0 -1
- package/dist/browser/index.d.mts +0 -2
- package/dist/browser/index.d.mts.map +0 -1
- package/dist/browser/index.d.ts +0 -2
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/index.mjs +0 -18
- package/dist/browser/index.mjs.map +0 -1
- package/dist/browser/retry.d.cts +0 -11
- package/dist/browser/retry.d.cts.map +0 -1
- package/dist/browser/retry.d.mts +0 -11
- package/dist/browser/retry.d.mts.map +0 -1
- package/dist/browser/retry.d.ts +0 -11
- package/dist/browser/retry.d.ts.map +0 -1
- package/dist/neutral/index.cjs +0 -41
- package/dist/neutral/index.cjs.map +0 -1
- package/dist/neutral/index.d.cts +0 -2
- package/dist/neutral/index.d.cts.map +0 -1
- package/dist/neutral/index.d.mts +0 -2
- package/dist/neutral/index.d.mts.map +0 -1
- package/dist/neutral/index.d.ts.map +0 -1
- package/dist/neutral/retry.d.cts +0 -11
- package/dist/neutral/retry.d.cts.map +0 -1
- package/dist/neutral/retry.d.mts +0 -11
- package/dist/neutral/retry.d.mts.map +0 -1
- package/dist/neutral/retry.d.ts +0 -11
- package/dist/neutral/retry.d.ts.map +0 -1
- package/dist/node/index.cjs +0 -45
- package/dist/node/index.cjs.map +0 -1
- package/dist/node/index.d.cts +0 -2
- package/dist/node/index.d.cts.map +0 -1
- package/dist/node/index.d.mts +0 -2
- package/dist/node/index.d.mts.map +0 -1
- package/dist/node/index.d.ts +0 -2
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/index.mjs +0 -18
- package/dist/node/index.mjs.map +0 -1
- package/dist/node/retry.d.cts +0 -11
- package/dist/node/retry.d.cts.map +0 -1
- package/dist/node/retry.d.mts +0 -11
- package/dist/node/retry.d.mts.map +0 -1
- package/dist/node/retry.d.ts +0 -11
- package/dist/node/retry.d.ts.map +0 -1
package/dist/neutral/index.d.ts
CHANGED
|
@@ -1,2 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { Promisable } from '@xylabs/promise';
|
|
2
|
+
|
|
3
|
+
interface RetryConfig {
|
|
4
|
+
backoff?: number;
|
|
5
|
+
interval?: number;
|
|
6
|
+
retries?: number;
|
|
7
|
+
}
|
|
8
|
+
interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
9
|
+
complete?: (result?: T) => boolean;
|
|
10
|
+
}
|
|
11
|
+
declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
12
|
+
|
|
13
|
+
export { type RetryConfig, type RetryConfigWithComplete, retry };
|
package/package.json
CHANGED
|
@@ -13,18 +13,11 @@
|
|
|
13
13
|
"description": "Base functionality used throughout XY Labs TypeScript/JavaScript libraries",
|
|
14
14
|
"exports": {
|
|
15
15
|
".": {
|
|
16
|
-
"
|
|
17
|
-
|
|
18
|
-
"default": "./dist/neutral/index.cjs"
|
|
19
|
-
},
|
|
20
|
-
"import": {
|
|
21
|
-
"types": "./dist/neutral/index.d.ts",
|
|
22
|
-
"default": "./dist/neutral/index.mjs"
|
|
23
|
-
}
|
|
16
|
+
"types": "./dist/neutral/index.d.ts",
|
|
17
|
+
"default": "./dist/neutral/index.mjs"
|
|
24
18
|
},
|
|
25
19
|
"./package.json": "./package.json"
|
|
26
20
|
},
|
|
27
|
-
"main": "./dist/neutral/index.cjs",
|
|
28
21
|
"types": "./dist/neutral/index.d.ts",
|
|
29
22
|
"module": "./dist/neutral/index.mjs",
|
|
30
23
|
"homepage": "https://xylabs.com",
|
|
@@ -36,13 +29,13 @@
|
|
|
36
29
|
"esm"
|
|
37
30
|
],
|
|
38
31
|
"dependencies": {
|
|
39
|
-
"@xylabs/delay": "^
|
|
40
|
-
"@xylabs/promise": "^
|
|
32
|
+
"@xylabs/delay": "^4.0.0",
|
|
33
|
+
"@xylabs/promise": "^4.0.0"
|
|
41
34
|
},
|
|
42
35
|
"devDependencies": {
|
|
43
|
-
"@xylabs/ts-scripts-yarn3": "^
|
|
44
|
-
"@xylabs/tsconfig": "^
|
|
45
|
-
"@xylabs/tsconfig-dom": "^
|
|
36
|
+
"@xylabs/ts-scripts-yarn3": "^4.0.0-rc.15",
|
|
37
|
+
"@xylabs/tsconfig": "^4.0.0-rc.15",
|
|
38
|
+
"@xylabs/tsconfig-dom": "^4.0.0-rc.15",
|
|
46
39
|
"typescript": "^5.5.4"
|
|
47
40
|
},
|
|
48
41
|
"engines": {
|
|
@@ -56,6 +49,6 @@
|
|
|
56
49
|
"url": "https://github.com/xylabs/sdk-js.git"
|
|
57
50
|
},
|
|
58
51
|
"sideEffects": false,
|
|
59
|
-
"version": "
|
|
52
|
+
"version": "4.0.0",
|
|
60
53
|
"type": "module"
|
|
61
54
|
}
|
package/xy.config.ts
ADDED
package/dist/browser/index.cjs
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
retry: () => retry
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
// src/retry.ts
|
|
28
|
-
var import_delay = require("@xylabs/delay");
|
|
29
|
-
var retry = async (func, config) => {
|
|
30
|
-
const { complete = (value) => value !== void 0, retries = 0, interval = 100, backoff = 2 } = config ?? {};
|
|
31
|
-
const result = await func();
|
|
32
|
-
if (complete(result)) {
|
|
33
|
-
return result;
|
|
34
|
-
}
|
|
35
|
-
if (retries <= 0) {
|
|
36
|
-
return void 0;
|
|
37
|
-
}
|
|
38
|
-
await (0, import_delay.delay)(interval);
|
|
39
|
-
return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 });
|
|
40
|
-
};
|
|
41
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/retry.ts"],"sourcesContent":["export * from './retry.ts'\n","import { delay } from '@xylabs/delay'\nimport { Promisable } from '@xylabs/promise'\n\nexport interface RetryConfig {\n backoff?: number\n interval?: number\n retries?: number\n}\n\nexport interface RetryConfigWithComplete<T = unknown> extends RetryConfig {\n complete?: (result?: T) => boolean\n}\n\nexport const retry = async <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>): Promise<T | undefined> => {\n const { complete = (value: T | undefined) => value !== undefined, retries = 0, interval = 100, backoff = 2 } = config ?? {}\n const result = await func()\n if (complete(result)) {\n return result\n }\n if (retries <= 0) {\n return undefined\n }\n await delay(interval)\n return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 })\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,mBAAsB;AAaf,IAAM,QAAQ,OAAoB,MAAuC,WAAgE;AAC9I,QAAM,EAAE,WAAW,CAAC,UAAyB,UAAU,QAAW,UAAU,GAAG,WAAW,KAAK,UAAU,EAAE,IAAI,UAAU,CAAC;AAC1H,QAAM,SAAS,MAAM,KAAK;AAC1B,MAAI,SAAS,MAAM,GAAG;AACpB,WAAO;AAAA,EACT;AACA,MAAI,WAAW,GAAG;AAChB,WAAO;AAAA,EACT;AACA,YAAM,oBAAM,QAAQ;AACpB,SAAO,MAAM,MAAM,EAAE,SAAS,UAAU,UAAU,WAAW,SAAS,SAAS,UAAU,EAAE,CAAC;AAC9F;","names":[]}
|
package/dist/browser/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/browser/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/browser/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/browser/index.mjs
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// src/retry.ts
|
|
2
|
-
import { delay } from "@xylabs/delay";
|
|
3
|
-
var retry = async (func, config) => {
|
|
4
|
-
const { complete = (value) => value !== void 0, retries = 0, interval = 100, backoff = 2 } = config ?? {};
|
|
5
|
-
const result = await func();
|
|
6
|
-
if (complete(result)) {
|
|
7
|
-
return result;
|
|
8
|
-
}
|
|
9
|
-
if (retries <= 0) {
|
|
10
|
-
return void 0;
|
|
11
|
-
}
|
|
12
|
-
await delay(interval);
|
|
13
|
-
return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 });
|
|
14
|
-
};
|
|
15
|
-
export {
|
|
16
|
-
retry
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/retry.ts"],"sourcesContent":["import { delay } from '@xylabs/delay'\nimport { Promisable } from '@xylabs/promise'\n\nexport interface RetryConfig {\n backoff?: number\n interval?: number\n retries?: number\n}\n\nexport interface RetryConfigWithComplete<T = unknown> extends RetryConfig {\n complete?: (result?: T) => boolean\n}\n\nexport const retry = async <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>): Promise<T | undefined> => {\n const { complete = (value: T | undefined) => value !== undefined, retries = 0, interval = 100, backoff = 2 } = config ?? {}\n const result = await func()\n if (complete(result)) {\n return result\n }\n if (retries <= 0) {\n return undefined\n }\n await delay(interval)\n return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 })\n}\n"],"mappings":";AAAA,SAAS,aAAa;AAaf,IAAM,QAAQ,OAAoB,MAAuC,WAAgE;AAC9I,QAAM,EAAE,WAAW,CAAC,UAAyB,UAAU,QAAW,UAAU,GAAG,WAAW,KAAK,UAAU,EAAE,IAAI,UAAU,CAAC;AAC1H,QAAM,SAAS,MAAM,KAAK;AAC1B,MAAI,SAAS,MAAM,GAAG;AACpB,WAAO;AAAA,EACT;AACA,MAAI,WAAW,GAAG;AAChB,WAAO;AAAA,EACT;AACA,QAAM,MAAM,QAAQ;AACpB,SAAO,MAAM,MAAM,EAAE,SAAS,UAAU,UAAU,WAAW,SAAS,SAAS,UAAU,EAAE,CAAC;AAC9F;","names":[]}
|
package/dist/browser/retry.d.cts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/browser/retry.d.mts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/browser/retry.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/neutral/index.cjs
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
retry: () => retry
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
// src/retry.ts
|
|
28
|
-
var import_delay = require("@xylabs/delay");
|
|
29
|
-
var retry = async (func, config) => {
|
|
30
|
-
const { complete = (value) => value !== void 0, retries = 0, interval = 100, backoff = 2 } = config ?? {};
|
|
31
|
-
const result = await func();
|
|
32
|
-
if (complete(result)) {
|
|
33
|
-
return result;
|
|
34
|
-
}
|
|
35
|
-
if (retries <= 0) {
|
|
36
|
-
return void 0;
|
|
37
|
-
}
|
|
38
|
-
await (0, import_delay.delay)(interval);
|
|
39
|
-
return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 });
|
|
40
|
-
};
|
|
41
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/retry.ts"],"sourcesContent":["export * from './retry.ts'\n","import { delay } from '@xylabs/delay'\nimport { Promisable } from '@xylabs/promise'\n\nexport interface RetryConfig {\n backoff?: number\n interval?: number\n retries?: number\n}\n\nexport interface RetryConfigWithComplete<T = unknown> extends RetryConfig {\n complete?: (result?: T) => boolean\n}\n\nexport const retry = async <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>): Promise<T | undefined> => {\n const { complete = (value: T | undefined) => value !== undefined, retries = 0, interval = 100, backoff = 2 } = config ?? {}\n const result = await func()\n if (complete(result)) {\n return result\n }\n if (retries <= 0) {\n return undefined\n }\n await delay(interval)\n return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 })\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,mBAAsB;AAaf,IAAM,QAAQ,OAAoB,MAAuC,WAAgE;AAC9I,QAAM,EAAE,WAAW,CAAC,UAAyB,UAAU,QAAW,UAAU,GAAG,WAAW,KAAK,UAAU,EAAE,IAAI,UAAU,CAAC;AAC1H,QAAM,SAAS,MAAM,KAAK;AAC1B,MAAI,SAAS,MAAM,GAAG;AACpB,WAAO;AAAA,EACT;AACA,MAAI,WAAW,GAAG;AAChB,WAAO;AAAA,EACT;AACA,YAAM,oBAAM,QAAQ;AACpB,SAAO,MAAM,MAAM,EAAE,SAAS,UAAU,UAAU,WAAW,SAAS,SAAS,UAAU,EAAE,CAAC;AAC9F;","names":[]}
|
package/dist/neutral/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/neutral/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/neutral/retry.d.cts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/neutral/retry.d.mts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/neutral/retry.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/node/index.cjs
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
retry: () => retry
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
// src/retry.ts
|
|
28
|
-
var import_delay = require("@xylabs/delay");
|
|
29
|
-
var retry = async (func, config) => {
|
|
30
|
-
const { complete = (value) => value !== void 0, retries = 0, interval = 100, backoff = 2 } = config ?? {};
|
|
31
|
-
const result = await func();
|
|
32
|
-
if (complete(result)) {
|
|
33
|
-
return result;
|
|
34
|
-
}
|
|
35
|
-
if (retries <= 0) {
|
|
36
|
-
return void 0;
|
|
37
|
-
}
|
|
38
|
-
await (0, import_delay.delay)(interval);
|
|
39
|
-
return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 });
|
|
40
|
-
};
|
|
41
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
42
|
-
0 && (module.exports = {
|
|
43
|
-
retry
|
|
44
|
-
});
|
|
45
|
-
//# sourceMappingURL=index.cjs.map
|
package/dist/node/index.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/retry.ts"],"sourcesContent":["export * from './retry.ts'\n","import { delay } from '@xylabs/delay'\nimport { Promisable } from '@xylabs/promise'\n\nexport interface RetryConfig {\n backoff?: number\n interval?: number\n retries?: number\n}\n\nexport interface RetryConfigWithComplete<T = unknown> extends RetryConfig {\n complete?: (result?: T) => boolean\n}\n\nexport const retry = async <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>): Promise<T | undefined> => {\n const { complete = (value: T | undefined) => value !== undefined, retries = 0, interval = 100, backoff = 2 } = config ?? {}\n const result = await func()\n if (complete(result)) {\n return result\n }\n if (retries <= 0) {\n return undefined\n }\n await delay(interval)\n return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 })\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,mBAAsB;AAaf,IAAM,QAAQ,OAAoB,MAAuC,WAAgE;AAC9I,QAAM,EAAE,WAAW,CAAC,UAAyB,UAAU,QAAW,UAAU,GAAG,WAAW,KAAK,UAAU,EAAE,IAAI,UAAU,CAAC;AAC1H,QAAM,SAAS,MAAM,KAAK;AAC1B,MAAI,SAAS,MAAM,GAAG;AACpB,WAAO;AAAA,EACT;AACA,MAAI,WAAW,GAAG;AAChB,WAAO;AAAA,EACT;AACA,YAAM,oBAAM,QAAQ;AACpB,SAAO,MAAM,MAAM,EAAE,SAAS,UAAU,UAAU,WAAW,SAAS,SAAS,UAAU,EAAE,CAAC;AAC9F;","names":[]}
|
package/dist/node/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/node/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/node/index.d.ts
DELETED
package/dist/node/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
|
package/dist/node/index.mjs
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// src/retry.ts
|
|
2
|
-
import { delay } from "@xylabs/delay";
|
|
3
|
-
var retry = async (func, config) => {
|
|
4
|
-
const { complete = (value) => value !== void 0, retries = 0, interval = 100, backoff = 2 } = config ?? {};
|
|
5
|
-
const result = await func();
|
|
6
|
-
if (complete(result)) {
|
|
7
|
-
return result;
|
|
8
|
-
}
|
|
9
|
-
if (retries <= 0) {
|
|
10
|
-
return void 0;
|
|
11
|
-
}
|
|
12
|
-
await delay(interval);
|
|
13
|
-
return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 });
|
|
14
|
-
};
|
|
15
|
-
export {
|
|
16
|
-
retry
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/node/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/retry.ts"],"sourcesContent":["import { delay } from '@xylabs/delay'\nimport { Promisable } from '@xylabs/promise'\n\nexport interface RetryConfig {\n backoff?: number\n interval?: number\n retries?: number\n}\n\nexport interface RetryConfigWithComplete<T = unknown> extends RetryConfig {\n complete?: (result?: T) => boolean\n}\n\nexport const retry = async <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>): Promise<T | undefined> => {\n const { complete = (value: T | undefined) => value !== undefined, retries = 0, interval = 100, backoff = 2 } = config ?? {}\n const result = await func()\n if (complete(result)) {\n return result\n }\n if (retries <= 0) {\n return undefined\n }\n await delay(interval)\n return retry(func, { backoff, complete, interval: interval * backoff, retries: retries - 1 })\n}\n"],"mappings":";AAAA,SAAS,aAAa;AAaf,IAAM,QAAQ,OAAoB,MAAuC,WAAgE;AAC9I,QAAM,EAAE,WAAW,CAAC,UAAyB,UAAU,QAAW,UAAU,GAAG,WAAW,KAAK,UAAU,EAAE,IAAI,UAAU,CAAC;AAC1H,QAAM,SAAS,MAAM,KAAK;AAC1B,MAAI,SAAS,MAAM,GAAG;AACpB,WAAO;AAAA,EACT;AACA,MAAI,WAAW,GAAG;AAChB,WAAO;AAAA,EACT;AACA,QAAM,MAAM,QAAQ;AACpB,SAAO,MAAM,MAAM,EAAE,SAAS,UAAU,UAAU,WAAW,SAAS,SAAS,UAAU,EAAE,CAAC;AAC9F;","names":[]}
|
package/dist/node/retry.d.cts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/node/retry.d.mts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|
package/dist/node/retry.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Promisable } from '@xylabs/promise';
|
|
2
|
-
export interface RetryConfig {
|
|
3
|
-
backoff?: number;
|
|
4
|
-
interval?: number;
|
|
5
|
-
retries?: number;
|
|
6
|
-
}
|
|
7
|
-
export interface RetryConfigWithComplete<T = unknown> extends RetryConfig {
|
|
8
|
-
complete?: (result?: T) => boolean;
|
|
9
|
-
}
|
|
10
|
-
export declare const retry: <T = unknown>(func: () => Promisable<T | undefined>, config?: RetryConfigWithComplete<T>) => Promise<T | undefined>;
|
|
11
|
-
//# sourceMappingURL=retry.d.ts.map
|
package/dist/node/retry.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/retry.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE5C,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,GAAG,OAAO,CAAE,SAAQ,WAAW;IACvE,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;CACnC;AAED,eAAO,MAAM,KAAK,GAAU,CAAC,kBAAkB,MAAM,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,WAAW,uBAAuB,CAAC,CAAC,CAAC,KAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAW1I,CAAA"}
|