ag-common 0.0.875 → 0.0.876
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.
|
@@ -22,6 +22,7 @@ __exportStar(require("./cosmos"), exports);
|
|
|
22
22
|
__exportStar(require("./dynamo"), exports);
|
|
23
23
|
__exportStar(require("./enforceDynamoProvisionCap"), exports);
|
|
24
24
|
__exportStar(require("./google"), exports);
|
|
25
|
+
__exportStar(require("./retryOnError"), exports);
|
|
25
26
|
__exportStar(require("./s3"), exports);
|
|
26
27
|
__exportStar(require("./ses"), exports);
|
|
27
28
|
__exportStar(require("./sqs"), exports);
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function retryOnError<T>(
|
|
2
|
+
/** so we can log retries with useful info */
|
|
3
|
+
debugIdent: string, fn: () => Promise<T>, retries?: number, errorDelay?: number, errorCheck?: (error: Error) => boolean): Promise<T>;
|
|
4
|
+
export declare const sleep: (ms: number) => Promise<unknown>;
|
|
@@ -0,0 +1,43 @@
|
|
|
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.sleep = void 0;
|
|
13
|
+
exports.retryOnError = retryOnError;
|
|
14
|
+
const log_1 = require("../../common/helpers/log");
|
|
15
|
+
function retryOnError(debugIdent_1, fn_1) {
|
|
16
|
+
return __awaiter(this, arguments, void 0, function* (
|
|
17
|
+
/** so we can log retries with useful info */
|
|
18
|
+
debugIdent, fn, retries = 1, errorDelay = 2000, errorCheck = (s) => s.message.includes('429') ||
|
|
19
|
+
s.message.includes('500') ||
|
|
20
|
+
s.message.includes('503') ||
|
|
21
|
+
s.message.includes('SAFETY') ||
|
|
22
|
+
s.message.includes('"invalid_type"') ||
|
|
23
|
+
s.message.includes('overloaded') ||
|
|
24
|
+
s.message.includes('Expected') ||
|
|
25
|
+
s.message.includes('is not valid JSON') ||
|
|
26
|
+
s.message.includes('Unexpected token')) {
|
|
27
|
+
try {
|
|
28
|
+
return yield fn();
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
const e = error;
|
|
32
|
+
const em = e.message;
|
|
33
|
+
if (retries > 0 && errorCheck(e)) {
|
|
34
|
+
(0, log_1.info)(`Operation ${debugIdent} failed. Retrying after ${errorDelay}ms...`, em);
|
|
35
|
+
yield (0, exports.sleep)(errorDelay);
|
|
36
|
+
return retryOnError(debugIdent, fn, retries - 1, errorDelay, errorCheck);
|
|
37
|
+
}
|
|
38
|
+
throw error;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
43
|
+
exports.sleep = sleep;
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -15,6 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./api"), exports);
|
|
18
|
-
__exportStar(require("./common"), exports);
|
|
19
18
|
__exportStar(require("./node"), exports);
|
|
20
19
|
__exportStar(require("./ui"), exports);
|
package/package.json
CHANGED