@metriport/shared 0.1.3 → 0.1.5-alpha.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/__tests__/env-setup.d.ts +2 -0
- package/dist/__tests__/env-setup.d.ts.map +1 -0
- package/dist/__tests__/env-setup.js +35 -0
- package/dist/__tests__/env-setup.js.map +1 -0
- package/dist/common/__tests__/normalize-oid.test.d.ts +2 -0
- package/dist/common/__tests__/normalize-oid.test.d.ts.map +1 -0
- package/dist/common/__tests__/normalize-oid.test.js +24 -0
- package/dist/common/__tests__/normalize-oid.test.js.map +1 -0
- package/dist/common/__tests__/retry.test.d.ts +2 -0
- package/dist/common/__tests__/retry.test.d.ts.map +1 -0
- package/dist/common/__tests__/retry.test.js +31 -0
- package/dist/common/__tests__/retry.test.js.map +1 -0
- package/dist/common/date.d.ts +5 -0
- package/dist/common/date.d.ts.map +1 -0
- package/dist/common/date.js +20 -0
- package/dist/common/date.js.map +1 -0
- package/dist/common/general.d.ts +2 -0
- package/dist/common/general.d.ts.map +1 -0
- package/dist/common/general.js +9 -0
- package/dist/common/general.js.map +1 -0
- package/dist/common/normalize-oid.d.ts +2 -0
- package/dist/common/normalize-oid.d.ts.map +1 -0
- package/dist/common/normalize-oid.js +13 -0
- package/dist/common/normalize-oid.js.map +1 -0
- package/dist/common/retry.d.ts +19 -0
- package/dist/common/retry.d.ts.map +1 -0
- package/dist/common/retry.js +37 -0
- package/dist/common/retry.js.map +1 -0
- package/dist/common/sleep.d.ts +2 -0
- package/dist/common/sleep.d.ts.map +1 -0
- package/dist/common/sleep.js +8 -0
- package/dist/common/sleep.js.map +1 -0
- package/dist/common/validate-npi.d.ts +10 -0
- package/dist/common/validate-npi.d.ts.map +1 -0
- package/dist/common/validate-npi.js +41 -0
- package/dist/common/validate-npi.js.map +1 -0
- package/dist/index.d.ts +6 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +12 -6
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"env-setup.d.ts","sourceRoot":"","sources":["../../src/__tests__/env-setup.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const dotenv = __importStar(require("dotenv"));
|
|
30
|
+
const path_1 = __importDefault(require("path"));
|
|
31
|
+
const cwd = process.cwd();
|
|
32
|
+
const paths = [cwd, ...(cwd.includes("packages") ? [] : ["packages", "shared"])];
|
|
33
|
+
dotenv.config({ path: path_1.default.resolve(...paths, ".env.test") });
|
|
34
|
+
// Keep dotenv import and config before everything else
|
|
35
|
+
//# sourceMappingURL=env-setup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"env-setup.js","sourceRoot":"","sources":["../../src/__tests__/env-setup.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAiC;AACjC,gDAAwB;AACxB,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;AAC1B,MAAM,KAAK,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;AACjF,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,cAAI,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,WAAW,CAAC,EAAE,CAAC,CAAC;AAC7D,uDAAuD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize-oid.test.d.ts","sourceRoot":"","sources":["../../../src/common/__tests__/normalize-oid.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const normalize_oid_1 = require("../normalize-oid");
|
|
4
|
+
const shorterValidOid = "1";
|
|
5
|
+
const validOid = "1.22.333.444";
|
|
6
|
+
const longerValidOid = "1.22.33.444.555.6677.889999.0001";
|
|
7
|
+
const validOidWithPrefix = "urn:oid:1.22.333.444";
|
|
8
|
+
const invalidOid = "notAnOid";
|
|
9
|
+
const consecutiveDotsInvalidOid = "1.22.333..444";
|
|
10
|
+
describe("normalizeOid", () => {
|
|
11
|
+
it("should return the same oid if it is already valid", () => {
|
|
12
|
+
expect((0, normalize_oid_1.normalizeOid)(validOid)).toBe(validOid);
|
|
13
|
+
expect((0, normalize_oid_1.normalizeOid)(shorterValidOid)).toBe(shorterValidOid);
|
|
14
|
+
expect((0, normalize_oid_1.normalizeOid)(longerValidOid)).toBe(longerValidOid);
|
|
15
|
+
});
|
|
16
|
+
it("should return the oid without the urn:oid: prefix", () => {
|
|
17
|
+
expect((0, normalize_oid_1.normalizeOid)(validOidWithPrefix)).toBe(validOid);
|
|
18
|
+
});
|
|
19
|
+
it("should throw an error if oid does not conform to the format", () => {
|
|
20
|
+
expect(() => (0, normalize_oid_1.normalizeOid)(invalidOid)).toThrow("OID is not valid");
|
|
21
|
+
expect(() => (0, normalize_oid_1.normalizeOid)(consecutiveDotsInvalidOid)).toThrow("OID is not valid");
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=normalize-oid.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize-oid.test.js","sourceRoot":"","sources":["../../../src/common/__tests__/normalize-oid.test.ts"],"names":[],"mappings":";;AAAA,oDAAgD;AAEhD,MAAM,eAAe,GAAG,GAAG,CAAC;AAC5B,MAAM,QAAQ,GAAG,cAAc,CAAC;AAChC,MAAM,cAAc,GAAG,kCAAkC,CAAC;AAC1D,MAAM,kBAAkB,GAAG,sBAAsB,CAAC;AAClD,MAAM,UAAU,GAAG,UAAU,CAAC;AAC9B,MAAM,yBAAyB,GAAG,eAAe,CAAC;AAElD,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,CAAC,IAAA,4BAAY,EAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAA,4BAAY,EAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC5D,MAAM,CAAC,IAAA,4BAAY,EAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,CAAC,IAAA,4BAAY,EAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,4BAAY,EAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;QACnE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,4BAAY,EAAC,yBAAyB,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;IACpF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.test.d.ts","sourceRoot":"","sources":["../../../src/common/__tests__/retry.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const faker_1 = require("@faker-js/faker");
|
|
4
|
+
const retry_1 = require("../retry");
|
|
5
|
+
describe("executeWithRetries", () => {
|
|
6
|
+
it("returns the first successful execution", async () => {
|
|
7
|
+
const fn = jest.fn();
|
|
8
|
+
await (0, retry_1.executeWithRetries)(fn, undefined, 1);
|
|
9
|
+
expect(fn).toHaveBeenCalledTimes(1);
|
|
10
|
+
});
|
|
11
|
+
it("keeps trying on error and returns the first successful execution", async () => {
|
|
12
|
+
const expectedResponse = faker_1.faker.lorem.sentence();
|
|
13
|
+
const fn = jest.fn(async () => expectedResponse);
|
|
14
|
+
fn.mockImplementationOnce(() => {
|
|
15
|
+
throw new Error("test error");
|
|
16
|
+
});
|
|
17
|
+
const resp = await (0, retry_1.executeWithRetries)(fn, undefined, 1);
|
|
18
|
+
expect(resp).toBeTruthy();
|
|
19
|
+
expect(resp).toEqual(expectedResponse);
|
|
20
|
+
expect(fn).toHaveBeenCalledTimes(2);
|
|
21
|
+
});
|
|
22
|
+
it("throws after maxxed out retries", async () => {
|
|
23
|
+
const fn = jest.fn();
|
|
24
|
+
const errorMsg = "test error";
|
|
25
|
+
fn.mockImplementation(() => {
|
|
26
|
+
throw new Error(errorMsg);
|
|
27
|
+
});
|
|
28
|
+
await expect((0, retry_1.executeWithRetries)(fn, undefined, 1)).rejects.toThrow(errorMsg);
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=retry.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.test.js","sourceRoot":"","sources":["../../../src/common/__tests__/retry.test.ts"],"names":[],"mappings":";;AAAA,2CAAwC;AACxC,oCAA8C;AAE9C,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QACrB,MAAM,IAAA,0BAAkB,EAAC,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,EAAE,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kEAAkE,EAAE,KAAK,IAAI,EAAE;QAChF,MAAM,gBAAgB,GAAG,aAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QAChD,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,gBAAgB,CAAC,CAAC;QACjD,EAAE,CAAC,sBAAsB,CAAC,GAAG,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,MAAM,IAAA,0BAAkB,EAAS,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAChE,MAAM,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC;QAC1B,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QACvC,MAAM,CAAC,EAAE,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QACrB,MAAM,QAAQ,GAAG,YAAY,CAAC;QAC9B,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE;YACzB,MAAM,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,MAAM,MAAM,CAAC,IAAA,0BAAkB,EAAS,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACvF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
export declare const ISO_DATE = "YYYY-MM-DD";
|
|
3
|
+
export declare function isValidISODate(date: string): boolean;
|
|
4
|
+
export declare const optionalDateSchema: z.ZodEffects<z.ZodOptional<z.ZodNullable<z.ZodString>>, string | null | undefined, string | null | undefined>;
|
|
5
|
+
//# sourceMappingURL=date.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date.d.ts","sourceRoot":"","sources":["../../src/common/date.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,eAAO,MAAM,QAAQ,eAAe,CAAC;AAErC,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAEpD;AAKD,eAAO,MAAM,kBAAkB,+GAImC,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.optionalDateSchema = exports.isValidISODate = exports.ISO_DATE = void 0;
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
const dayjs_1 = __importDefault(require("dayjs"));
|
|
9
|
+
exports.ISO_DATE = "YYYY-MM-DD";
|
|
10
|
+
function isValidISODate(date) {
|
|
11
|
+
return (0, dayjs_1.default)(date, exports.ISO_DATE, true).isValid();
|
|
12
|
+
}
|
|
13
|
+
exports.isValidISODate = isValidISODate;
|
|
14
|
+
const isValidISODateOptional = (date) => date ? isValidISODate(date) : true;
|
|
15
|
+
exports.optionalDateSchema = zod_1.z
|
|
16
|
+
.string()
|
|
17
|
+
.trim()
|
|
18
|
+
.nullish()
|
|
19
|
+
.refine(isValidISODateOptional, { message: "Invalid ISO date" });
|
|
20
|
+
//# sourceMappingURL=date.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date.js","sourceRoot":"","sources":["../../src/common/date.ts"],"names":[],"mappings":";;;;;;AAAA,6BAAwB;AACxB,kDAA0B;AAEb,QAAA,QAAQ,GAAG,YAAY,CAAC;AAErC,SAAgB,cAAc,CAAC,IAAY;IACzC,OAAO,IAAA,eAAK,EAAC,IAAI,EAAE,gBAAQ,EAAE,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC;AAC/C,CAAC;AAFD,wCAEC;AAED,MAAM,sBAAsB,GAAG,CAAC,IAA+B,EAAW,EAAE,CAC1E,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AAExB,QAAA,kBAAkB,GAAG,OAAC;KAChC,MAAM,EAAE;KACR,IAAI,EAAE;KACN,OAAO,EAAE;KACT,MAAM,CAAC,sBAAsB,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"general.d.ts","sourceRoot":"","sources":["../../src/common/general.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,aAAa,YAAW,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.emptyFunction = void 0;
|
|
4
|
+
// Useful as catch handler for asynchonous promises so we don't get an unhandled promise rejection,
|
|
5
|
+
// or just to have a function that does nothing without having the warning below on the code.
|
|
6
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
7
|
+
const emptyFunction = () => { };
|
|
8
|
+
exports.emptyFunction = emptyFunction;
|
|
9
|
+
//# sourceMappingURL=general.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"general.js","sourceRoot":"","sources":["../../src/common/general.ts"],"names":[],"mappings":";;;AAAA,mGAAmG;AACnG,6FAA6F;AAC7F,gEAAgE;AACzD,MAAM,aAAa,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;AAAzB,QAAA,aAAa,iBAAY"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize-oid.d.ts","sourceRoot":"","sources":["../../src/common/normalize-oid.ts"],"names":[],"mappings":"AAEA,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAOhD"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.normalizeOid = void 0;
|
|
4
|
+
const OID_REGEX = /^(urn:oid:)?([0-9]+(\.[0-9]+)*)$/;
|
|
5
|
+
function normalizeOid(oid) {
|
|
6
|
+
const match = OID_REGEX.exec(oid);
|
|
7
|
+
if (match && match[2]) {
|
|
8
|
+
return match[2];
|
|
9
|
+
}
|
|
10
|
+
throw new Error("OID is not valid");
|
|
11
|
+
}
|
|
12
|
+
exports.normalizeOid = normalizeOid;
|
|
13
|
+
//# sourceMappingURL=normalize-oid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize-oid.js","sourceRoot":"","sources":["../../src/common/normalize-oid.ts"],"names":[],"mappings":";;;AAAA,MAAM,SAAS,GAAG,kCAAkC,CAAC;AAErD,SAAgB,YAAY,CAAC,GAAW;IACtC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClC,IAAI,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE;QACrB,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC;KACjB;IAED,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;AACtC,CAAC;AAPD,oCAOC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Executes a function with retries. If the function throws an error, it will retry
|
|
3
|
+
* up to maxRetries times, waiting waitTime between each retry.
|
|
4
|
+
* If the function throws an error on the last retry, it will throw the error.
|
|
5
|
+
* If the function succeeds, it will return the result.
|
|
6
|
+
*
|
|
7
|
+
* @param fn the function to be executed
|
|
8
|
+
* @param maxRetries the maximum number of retries, defaults to 3
|
|
9
|
+
* @param waitTime the time to wait between retries, defaults to 3000ms
|
|
10
|
+
* @param log the logger to use, defaults to console.log
|
|
11
|
+
* @returns
|
|
12
|
+
*/
|
|
13
|
+
export declare function executeWithRetries<K>(fn: () => Promise<K>, maxRetries?: number, waitTime?: number, log?: {
|
|
14
|
+
(...data: any[]): void;
|
|
15
|
+
(message?: any, ...optionalParams: any[]): void;
|
|
16
|
+
(message?: any, ...optionalParams: any[]): void;
|
|
17
|
+
(message?: any, ...optionalParams: any[]): void;
|
|
18
|
+
}): Promise<K>;
|
|
19
|
+
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/common/retry.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;GAWG;AACH,wBAAsB,kBAAkB,CAAC,CAAC,EACxC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,UAAU,SAAI,EACd,QAAQ,SAAO,EACf,GAAG;;;;;CAAc,GAChB,OAAO,CAAC,CAAC,CAAC,CAiBZ"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.executeWithRetries = void 0;
|
|
4
|
+
const sleep_1 = require("./sleep");
|
|
5
|
+
/**
|
|
6
|
+
* Executes a function with retries. If the function throws an error, it will retry
|
|
7
|
+
* up to maxRetries times, waiting waitTime between each retry.
|
|
8
|
+
* If the function throws an error on the last retry, it will throw the error.
|
|
9
|
+
* If the function succeeds, it will return the result.
|
|
10
|
+
*
|
|
11
|
+
* @param fn the function to be executed
|
|
12
|
+
* @param maxRetries the maximum number of retries, defaults to 3
|
|
13
|
+
* @param waitTime the time to wait between retries, defaults to 3000ms
|
|
14
|
+
* @param log the logger to use, defaults to console.log
|
|
15
|
+
* @returns
|
|
16
|
+
*/
|
|
17
|
+
async function executeWithRetries(fn, maxRetries = 3, waitTime = 3000, log = console.log) {
|
|
18
|
+
let count = 0;
|
|
19
|
+
while (count <= maxRetries) {
|
|
20
|
+
try {
|
|
21
|
+
return await fn();
|
|
22
|
+
}
|
|
23
|
+
catch (e) {
|
|
24
|
+
const msg = `Error on executeWithRetries: ${e}, re`;
|
|
25
|
+
if (count++ < maxRetries) {
|
|
26
|
+
log(`${msg}, retrying...`);
|
|
27
|
+
await (0, sleep_1.sleep)(waitTime);
|
|
28
|
+
continue;
|
|
29
|
+
}
|
|
30
|
+
log(`${msg}, gave up.`);
|
|
31
|
+
throw e;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
throw new Error(`Should never get here`);
|
|
35
|
+
}
|
|
36
|
+
exports.executeWithRetries = executeWithRetries;
|
|
37
|
+
//# sourceMappingURL=retry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.js","sourceRoot":"","sources":["../../src/common/retry.ts"],"names":[],"mappings":";;;AAAA,mCAAgC;AAEhC;;;;;;;;;;;GAWG;AACI,KAAK,UAAU,kBAAkB,CACtC,EAAoB,EACpB,UAAU,GAAG,CAAC,EACd,QAAQ,GAAG,IAAI,EACf,GAAG,GAAG,OAAO,CAAC,GAAG;IAEjB,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,OAAO,KAAK,IAAI,UAAU,EAAE;QAC1B,IAAI;YACF,OAAO,MAAM,EAAE,EAAE,CAAC;SACnB;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,GAAG,GAAG,gCAAgC,CAAC,MAAM,CAAC;YACpD,IAAI,KAAK,EAAE,GAAG,UAAU,EAAE;gBACxB,GAAG,CAAC,GAAG,GAAG,eAAe,CAAC,CAAC;gBAC3B,MAAM,IAAA,aAAK,EAAC,QAAQ,CAAC,CAAC;gBACtB,SAAS;aACV;YACD,GAAG,CAAC,GAAG,GAAG,YAAY,CAAC,CAAC;YACxB,MAAM,CAAC,CAAC;SACT;KACF;IACD,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;AAC3C,CAAC;AAtBD,gDAsBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sleep.d.ts","sourceRoot":"","sources":["../../src/common/sleep.ts"],"names":[],"mappings":"AAAA,wBAAgB,KAAK,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAErD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sleep.js","sourceRoot":"","sources":["../../src/common/sleep.ts"],"names":[],"mappings":";;;AAAA,SAAgB,KAAK,CAAC,QAAgB;IACpC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;AAC/D,CAAC;AAFD,sBAEC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Checks if the specified 10 digit NPI is valid as per ISO standard mod 10 Luhn algorithm.
|
|
3
|
+
*
|
|
4
|
+
* See: https://www.cms.gov/Regulations-and-Guidance/Administrative-Simplification/NationalProvIdentStand/Downloads/NPIcheckdigit.pdf
|
|
5
|
+
*
|
|
6
|
+
* @param npi The npi number to validate, must be 10 digits.
|
|
7
|
+
* @returns true if valid; false otherwise.
|
|
8
|
+
*/
|
|
9
|
+
export declare function validateNPI(npi: string): boolean;
|
|
10
|
+
//# sourceMappingURL=validate-npi.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-npi.d.ts","sourceRoot":"","sources":["../../src/common/validate-npi.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAiChD"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateNPI = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Checks if the specified 10 digit NPI is valid as per ISO standard mod 10 Luhn algorithm.
|
|
6
|
+
*
|
|
7
|
+
* See: https://www.cms.gov/Regulations-and-Guidance/Administrative-Simplification/NationalProvIdentStand/Downloads/NPIcheckdigit.pdf
|
|
8
|
+
*
|
|
9
|
+
* @param npi The npi number to validate, must be 10 digits.
|
|
10
|
+
* @returns true if valid; false otherwise.
|
|
11
|
+
*/
|
|
12
|
+
function validateNPI(npi) {
|
|
13
|
+
if (!npi || npi.length !== 10) {
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
const firstNPIDigit = parseInt(npi.charAt(0), 10);
|
|
17
|
+
if (firstNPIDigit !== 1 && firstNPIDigit !== 2) {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
let sum = 0;
|
|
21
|
+
let shouldDouble = true;
|
|
22
|
+
for (let i = 0; i < npi.length - 1; i++) {
|
|
23
|
+
let digit = parseInt(npi.charAt(i), 10);
|
|
24
|
+
if (shouldDouble) {
|
|
25
|
+
digit *= 2;
|
|
26
|
+
if (digit > 9) {
|
|
27
|
+
digit -= 9;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
sum += digit;
|
|
31
|
+
shouldDouble = !shouldDouble;
|
|
32
|
+
}
|
|
33
|
+
// account for NPI prefix
|
|
34
|
+
sum += 24;
|
|
35
|
+
const diffFromNextTens = 10 - (sum % 10);
|
|
36
|
+
const checkDigit = diffFromNextTens % 10;
|
|
37
|
+
const lastNPIDigit = parseInt(npi.charAt(npi.length - 1), 10);
|
|
38
|
+
return checkDigit === lastNPIDigit;
|
|
39
|
+
}
|
|
40
|
+
exports.validateNPI = validateNPI;
|
|
41
|
+
//# sourceMappingURL=validate-npi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-npi.js","sourceRoot":"","sources":["../../src/common/validate-npi.ts"],"names":[],"mappings":";;;AAAA;;;;;;;GAOG;AACH,SAAgB,WAAW,CAAC,GAAW;IACrC,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,EAAE;QAC7B,OAAO,KAAK,CAAC;KACd;IACD,MAAM,aAAa,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAClD,IAAI,aAAa,KAAK,CAAC,IAAI,aAAa,KAAK,CAAC,EAAE;QAC9C,OAAO,KAAK,CAAC;KACd;IAED,IAAI,GAAG,GAAG,CAAC,CAAC;IACZ,IAAI,YAAY,GAAG,IAAI,CAAC;IACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;QACvC,IAAI,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAExC,IAAI,YAAY,EAAE;YAChB,KAAK,IAAI,CAAC,CAAC;YACX,IAAI,KAAK,GAAG,CAAC,EAAE;gBACb,KAAK,IAAI,CAAC,CAAC;aACZ;SACF;QAED,GAAG,IAAI,KAAK,CAAC;QACb,YAAY,GAAG,CAAC,YAAY,CAAC;KAC9B;IAED,yBAAyB;IACzB,GAAG,IAAI,EAAE,CAAC;IAEV,MAAM,gBAAgB,GAAG,EAAE,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC;IACzC,MAAM,UAAU,GAAG,gBAAgB,GAAG,EAAE,CAAC;IAEzC,MAAM,YAAY,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC9D,OAAO,UAAU,KAAK,YAAY,CAAC;AACrC,CAAC;AAjCD,kCAiCC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export {
|
|
3
|
-
export {
|
|
1
|
+
export { optionalDateSchema } from "./common/date";
|
|
2
|
+
export { emptyFunction } from "./common/general";
|
|
3
|
+
export { normalizeOid } from "./common/normalize-oid";
|
|
4
|
+
export { executeWithRetries } from "./common/retry";
|
|
5
|
+
export { sleep } from "./common/sleep";
|
|
6
|
+
export { validateNPI } from "./common/validate-npi";
|
|
4
7
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,10 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
var
|
|
5
|
-
Object.defineProperty(exports, "validateNPI", { enumerable: true, get: function () { return validate_npi_1.validateNPI; } });
|
|
6
|
-
var normalize_oid_1 = require("./src/common/normalize-oid");
|
|
7
|
-
Object.defineProperty(exports, "normalizeOid", { enumerable: true, get: function () { return normalize_oid_1.normalizeOid; } });
|
|
8
|
-
var date_1 = require("./src/common/date");
|
|
3
|
+
exports.validateNPI = exports.sleep = exports.executeWithRetries = exports.normalizeOid = exports.emptyFunction = exports.optionalDateSchema = void 0;
|
|
4
|
+
var date_1 = require("./common/date");
|
|
9
5
|
Object.defineProperty(exports, "optionalDateSchema", { enumerable: true, get: function () { return date_1.optionalDateSchema; } });
|
|
6
|
+
var general_1 = require("./common/general");
|
|
7
|
+
Object.defineProperty(exports, "emptyFunction", { enumerable: true, get: function () { return general_1.emptyFunction; } });
|
|
8
|
+
var normalize_oid_1 = require("./common/normalize-oid");
|
|
9
|
+
Object.defineProperty(exports, "normalizeOid", { enumerable: true, get: function () { return normalize_oid_1.normalizeOid; } });
|
|
10
|
+
var retry_1 = require("./common/retry");
|
|
11
|
+
Object.defineProperty(exports, "executeWithRetries", { enumerable: true, get: function () { return retry_1.executeWithRetries; } });
|
|
12
|
+
var sleep_1 = require("./common/sleep");
|
|
13
|
+
Object.defineProperty(exports, "sleep", { enumerable: true, get: function () { return sleep_1.sleep; } });
|
|
14
|
+
var validate_npi_1 = require("./common/validate-npi");
|
|
15
|
+
Object.defineProperty(exports, "validateNPI", { enumerable: true, get: function () { return validate_npi_1.validateNPI; } });
|
|
10
16
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,sCAAmD;AAA1C,0GAAA,kBAAkB,OAAA;AAC3B,4CAAiD;AAAxC,wGAAA,aAAa,OAAA;AACtB,wDAAsD;AAA7C,6GAAA,YAAY,OAAA;AACrB,wCAAoD;AAA3C,2GAAA,kBAAkB,OAAA;AAC3B,wCAAuC;AAA9B,8FAAA,KAAK,OAAA;AACd,sDAAoD;AAA3C,2GAAA,WAAW,OAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@metriport/shared",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.5-alpha.0",
|
|
4
4
|
"description": "Common code shared across packages - by Metriport Inc.",
|
|
5
5
|
"author": "Metriport Inc. <contact@metriport.com>",
|
|
6
6
|
"homepage": "https://metriport.com/",
|
|
@@ -51,5 +51,5 @@
|
|
|
51
51
|
"test": "jest --runInBand --detectOpenHandles --passWithNoTests",
|
|
52
52
|
"test:e2e": "E2E=true jest --runInBand --detectOpenHandles --passWithNoTests"
|
|
53
53
|
},
|
|
54
|
-
"gitHead": "
|
|
54
|
+
"gitHead": "337f2a29b04f3447b889acc49adb0058c9b06046"
|
|
55
55
|
}
|