softkave-node-utils 0.1.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/README.md +3 -0
- package/build/src/contexts/SessionContext.d.ts +15 -0
- package/build/src/contexts/SessionContext.js +70 -0
- package/build/src/contexts/SessionContext.js.map +1 -0
- package/build/src/contexts/asyncLocalStorage.d.ts +27 -0
- package/build/src/contexts/asyncLocalStorage.js +115 -0
- package/build/src/contexts/asyncLocalStorage.js.map +1 -0
- package/build/src/contexts/config.d.ts +49 -0
- package/build/src/contexts/config.js +25 -0
- package/build/src/contexts/config.js.map +1 -0
- package/build/src/contexts/data/BaseMongoDataProvider.d.ts +21 -0
- package/build/src/contexts/data/BaseMongoDataProvider.js +157 -0
- package/build/src/contexts/data/BaseMongoDataProvider.js.map +1 -0
- package/build/src/contexts/data/MongoDataProviderUtils.d.ts +6 -0
- package/build/src/contexts/data/MongoDataProviderUtils.js +35 -0
- package/build/src/contexts/data/MongoDataProviderUtils.js.map +1 -0
- package/build/src/contexts/data/dataQueryToMongoQuery.d.ts +3 -0
- package/build/src/contexts/data/dataQueryToMongoQuery.js +85 -0
- package/build/src/contexts/data/dataQueryToMongoQuery.js.map +1 -0
- package/build/src/contexts/data/types.d.ts +114 -0
- package/build/src/contexts/data/types.js +15 -0
- package/build/src/contexts/data/types.js.map +1 -0
- package/build/src/contexts/data/utils.d.ts +2 -0
- package/build/src/contexts/data/utils.js +24 -0
- package/build/src/contexts/data/utils.js.map +1 -0
- package/build/src/contexts/email/SESEmailProviderContext.d.ts +9 -0
- package/build/src/contexts/email/SESEmailProviderContext.js +49 -0
- package/build/src/contexts/email/SESEmailProviderContext.js.map +1 -0
- package/build/src/contexts/email/types.d.ts +13 -0
- package/build/src/contexts/email/types.js +3 -0
- package/build/src/contexts/email/types.js.map +1 -0
- package/build/src/contexts/encryption/AWSSecretsManagerProvider.d.ts +12 -0
- package/build/src/contexts/encryption/AWSSecretsManagerProvider.js +51 -0
- package/build/src/contexts/encryption/AWSSecretsManagerProvider.js.map +1 -0
- package/build/src/contexts/encryption/MemorySecretsManagerProvider.d.ts +12 -0
- package/build/src/contexts/encryption/MemorySecretsManagerProvider.js +35 -0
- package/build/src/contexts/encryption/MemorySecretsManagerProvider.js.map +1 -0
- package/build/src/contexts/encryption/types.d.ts +29 -0
- package/build/src/contexts/encryption/types.js +3 -0
- package/build/src/contexts/encryption/types.js.map +1 -0
- package/build/src/contexts/globalUtils.d.ts +2 -0
- package/build/src/contexts/globalUtils.js +17 -0
- package/build/src/contexts/globalUtils.js.map +1 -0
- package/build/src/contexts/injection/injectables.d.ts +56 -0
- package/build/src/contexts/injection/injectables.js +26 -0
- package/build/src/contexts/injection/injectables.js.map +1 -0
- package/build/src/contexts/injection/keys.d.ts +22 -0
- package/build/src/contexts/injection/keys.js +33 -0
- package/build/src/contexts/injection/keys.js.map +1 -0
- package/build/src/contexts/injection/register.d.ts +33 -0
- package/build/src/contexts/injection/register.js +107 -0
- package/build/src/contexts/injection/register.js.map +1 -0
- package/build/src/contexts/logger/noop.d.ts +5 -0
- package/build/src/contexts/logger/noop.js +12 -0
- package/build/src/contexts/logger/noop.js.map +1 -0
- package/build/src/contexts/logger/types.d.ts +11 -0
- package/build/src/contexts/logger/types.js +8 -0
- package/build/src/contexts/logger/types.js.map +1 -0
- package/build/src/contexts/logger/utils.d.ts +2 -0
- package/build/src/contexts/logger/utils.js +15 -0
- package/build/src/contexts/logger/utils.js.map +1 -0
- package/build/src/contexts/semantic/DataSemanticDataAccessBaseProvider.d.ts +28 -0
- package/build/src/contexts/semantic/DataSemanticDataAccessBaseProvider.js +115 -0
- package/build/src/contexts/semantic/DataSemanticDataAccessBaseProvider.js.map +1 -0
- package/build/src/contexts/semantic/types.d.ts +48 -0
- package/build/src/contexts/semantic/types.js +3 -0
- package/build/src/contexts/semantic/types.js.map +1 -0
- package/build/src/contexts/semantic/utils.d.ts +16 -0
- package/build/src/contexts/semantic/utils.js +68 -0
- package/build/src/contexts/semantic/utils.js.map +1 -0
- package/build/src/contexts/types.d.ts +6 -0
- package/build/src/contexts/types.js +3 -0
- package/build/src/contexts/types.js.map +1 -0
- package/build/src/definitions/agent.d.ts +10 -0
- package/build/src/definitions/agent.js +3 -0
- package/build/src/definitions/agent.js.map +1 -0
- package/build/src/definitions/resource.d.ts +17 -0
- package/build/src/definitions/resource.js +3 -0
- package/build/src/definitions/resource.js.map +1 -0
- package/build/src/definitions/resourceTypes.d.ts +10 -0
- package/build/src/definitions/resourceTypes.js +19 -0
- package/build/src/definitions/resourceTypes.js.map +1 -0
- package/build/src/definitions/token.d.ts +17 -0
- package/build/src/definitions/token.js +10 -0
- package/build/src/definitions/token.js.map +1 -0
- package/build/src/endpoints/RequestData.d.ts +20 -0
- package/build/src/endpoints/RequestData.js +52 -0
- package/build/src/endpoints/RequestData.js.map +1 -0
- package/build/src/endpoints/constants.d.ts +20 -0
- package/build/src/endpoints/constants.js +24 -0
- package/build/src/endpoints/constants.js.map +1 -0
- package/build/src/endpoints/endpoints.d.ts +7 -0
- package/build/src/endpoints/endpoints.js +33 -0
- package/build/src/endpoints/endpoints.js.map +1 -0
- package/build/src/endpoints/endpoints.mddoc.d.ts +62 -0
- package/build/src/endpoints/endpoints.mddoc.js +437 -0
- package/build/src/endpoints/endpoints.mddoc.js.map +1 -0
- package/build/src/endpoints/extractors.d.ts +9 -0
- package/build/src/endpoints/extractors.js +24 -0
- package/build/src/endpoints/extractors.js.map +1 -0
- package/build/src/endpoints/jobs/types.d.ts +6 -0
- package/build/src/endpoints/jobs/types.js +3 -0
- package/build/src/endpoints/jobs/types.js.map +1 -0
- package/build/src/endpoints/pagination.d.ts +3 -0
- package/build/src/endpoints/pagination.js +27 -0
- package/build/src/endpoints/pagination.js.map +1 -0
- package/build/src/endpoints/types.d.ts +68 -0
- package/build/src/endpoints/types.js +13 -0
- package/build/src/endpoints/types.js.map +1 -0
- package/build/src/endpoints/utils.d.ts +23 -0
- package/build/src/endpoints/utils.js +131 -0
- package/build/src/endpoints/utils.js.map +1 -0
- package/build/src/endpoints/validation.d.ts +47 -0
- package/build/src/endpoints/validation.js +73 -0
- package/build/src/endpoints/validation.js.map +1 -0
- package/build/src/errors/OperationError.d.ts +20 -0
- package/build/src/errors/OperationError.js +38 -0
- package/build/src/errors/OperationError.js.map +1 -0
- package/build/src/errors/commonErrors.d.ts +24 -0
- package/build/src/errors/commonErrors.js +72 -0
- package/build/src/errors/commonErrors.js.map +1 -0
- package/build/src/errors/endpointErrors.d.ts +31 -0
- package/build/src/errors/endpointErrors.js +83 -0
- package/build/src/errors/endpointErrors.js.map +1 -0
- package/build/src/errors/messages.d.ts +11 -0
- package/build/src/errors/messages.js +27 -0
- package/build/src/errors/messages.js.map +1 -0
- package/build/src/errors/reusableErrors.d.ts +12 -0
- package/build/src/errors/reusableErrors.js +25 -0
- package/build/src/errors/reusableErrors.js.map +1 -0
- package/build/src/errors/sessionErrors.d.ts +18 -0
- package/build/src/errors/sessionErrors.js +60 -0
- package/build/src/errors/sessionErrors.js.map +1 -0
- package/build/src/index.d.ts +0 -0
- package/build/src/index.js +2 -0
- package/build/src/index.js.map +1 -0
- package/build/src/mddoc/jsSdkCodeGen.d.ts +7 -0
- package/build/src/mddoc/jsSdkCodeGen.js +546 -0
- package/build/src/mddoc/jsSdkCodeGen.js.map +1 -0
- package/build/src/mddoc/mddoc.d.ts +206 -0
- package/build/src/mddoc/mddoc.js +142 -0
- package/build/src/mddoc/mddoc.js.map +1 -0
- package/build/src/mddoc/restApiEndpointsInfoGen.d.ts +10 -0
- package/build/src/mddoc/restApiEndpointsInfoGen.js +92 -0
- package/build/src/mddoc/restApiEndpointsInfoGen.js.map +1 -0
- package/build/src/mddoc/restApiTableOfContentGen.d.ts +2 -0
- package/build/src/mddoc/restApiTableOfContentGen.js +51 -0
- package/build/src/mddoc/restApiTableOfContentGen.js.map +1 -0
- package/build/src/mongodb/connection.d.ts +26 -0
- package/build/src/mongodb/connection.js +50 -0
- package/build/src/mongodb/connection.js.map +1 -0
- package/build/src/mongodb/constants.d.ts +4 -0
- package/build/src/mongodb/constants.js +7 -0
- package/build/src/mongodb/constants.js.map +1 -0
- package/build/src/mongodb/utils.d.ts +20 -0
- package/build/src/mongodb/utils.js +26 -0
- package/build/src/mongodb/utils.js.map +1 -0
- package/build/src/testUtils/context/email/MockTestEmailProviderContext.d.ts +6 -0
- package/build/src/testUtils/context/email/MockTestEmailProviderContext.js +10 -0
- package/build/src/testUtils/context/email/MockTestEmailProviderContext.js.map +1 -0
- package/build/src/testUtils/context/email/NoopEmailProviderContext.d.ts +6 -0
- package/build/src/testUtils/context/email/NoopEmailProviderContext.js +11 -0
- package/build/src/testUtils/context/email/NoopEmailProviderContext.js.map +1 -0
- package/build/src/testUtils/context/email/TestSESEmailProviderContext.d.ts +8 -0
- package/build/src/testUtils/context/email/TestSESEmailProviderContext.js +14 -0
- package/build/src/testUtils/context/email/TestSESEmailProviderContext.js.map +1 -0
- package/build/src/testUtils/context/types.d.ts +9 -0
- package/build/src/testUtils/context/types.js +3 -0
- package/build/src/testUtils/context/types.js.map +1 -0
- package/build/src/testUtils/generate/utils.d.ts +37 -0
- package/build/src/testUtils/generate/utils.js +79 -0
- package/build/src/testUtils/generate/utils.js.map +1 -0
- package/build/src/testUtils/helpers/assertion.d.ts +25 -0
- package/build/src/testUtils/helpers/assertion.js +63 -0
- package/build/src/testUtils/helpers/assertion.js.map +1 -0
- package/build/src/testUtils/helpers/binary.d.ts +4 -0
- package/build/src/testUtils/helpers/binary.js +19 -0
- package/build/src/testUtils/helpers/binary.js.map +1 -0
- package/build/src/testUtils/helpers/error.d.ts +3 -0
- package/build/src/testUtils/helpers/error.js +43 -0
- package/build/src/testUtils/helpers/error.js.map +1 -0
- package/build/src/testUtils/helpers/mock.d.ts +2 -0
- package/build/src/testUtils/helpers/mock.js +15 -0
- package/build/src/testUtils/helpers/mock.js.map +1 -0
- package/build/src/testUtils/helpers/mongodb.d.ts +3 -0
- package/build/src/testUtils/helpers/mongodb.js +17 -0
- package/build/src/testUtils/helpers/mongodb.js.map +1 -0
- package/build/src/testUtils/helpers/testFns.d.ts +30 -0
- package/build/src/testUtils/helpers/testFns.js +96 -0
- package/build/src/testUtils/helpers/testFns.js.map +1 -0
- package/build/src/testUtils/testUtils.d.ts +13 -0
- package/build/src/testUtils/testUtils.js +50 -0
- package/build/src/testUtils/testUtils.js.map +1 -0
- package/build/src/utils/assertion.d.ts +2 -0
- package/build/src/utils/assertion.js +31 -0
- package/build/src/utils/assertion.js.map +1 -0
- package/build/src/utils/aws.d.ts +5 -0
- package/build/src/utils/aws.js +3 -0
- package/build/src/utils/aws.js.map +1 -0
- package/build/src/utils/streamToBuffer.d.ts +4 -0
- package/build/src/utils/streamToBuffer.js +19 -0
- package/build/src/utils/streamToBuffer.js.map +1 -0
- package/package.json +72 -0
|
@@ -0,0 +1,96 @@
|
|
|
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.testCombinations = exports.matchExpects = exports.expectFields = exports.performPaginationTest = exports.softkaveTest = exports.startTesting = exports.completeTests = exports.mutationTest = void 0;
|
|
7
|
+
const assert_1 = __importDefault(require("assert"));
|
|
8
|
+
const lodash_1 = require("lodash");
|
|
9
|
+
const softkave_js_utils_1 = require("softkave-js-utils");
|
|
10
|
+
const globalUtils_1 = require("../../contexts/globalUtils");
|
|
11
|
+
const injectables_1 = require("../../contexts/injection/injectables");
|
|
12
|
+
const RequestData_1 = __importDefault(require("../../endpoints/RequestData"));
|
|
13
|
+
const testUtils_1 = require("../testUtils");
|
|
14
|
+
function mutationTest(name, fn, timeout) {
|
|
15
|
+
injectables_1.kSemanticModels.utils().withTxn(async (options) => {
|
|
16
|
+
await test(name, () => fn(options), timeout);
|
|
17
|
+
}, /** reuseAsyncLocalTxn */ false);
|
|
18
|
+
}
|
|
19
|
+
exports.mutationTest = mutationTest;
|
|
20
|
+
async function completeTests() {
|
|
21
|
+
await (0, globalUtils_1.globalDispose)();
|
|
22
|
+
}
|
|
23
|
+
exports.completeTests = completeTests;
|
|
24
|
+
function startTesting() {
|
|
25
|
+
beforeAll(async () => {
|
|
26
|
+
await (0, globalUtils_1.globalSetup)();
|
|
27
|
+
});
|
|
28
|
+
afterAll(async () => {
|
|
29
|
+
await (0, globalUtils_1.globalDispose)();
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
exports.startTesting = startTesting;
|
|
33
|
+
exports.softkaveTest = {
|
|
34
|
+
run: (name, fn, timeout) => {
|
|
35
|
+
test(name, async () => {
|
|
36
|
+
await injectables_1.kUtilsInjectables.asyncLocalStorage().run(fn);
|
|
37
|
+
}, timeout);
|
|
38
|
+
},
|
|
39
|
+
only: (name, fn, timeout) => {
|
|
40
|
+
test.only(name, async () => {
|
|
41
|
+
await injectables_1.kUtilsInjectables.asyncLocalStorage().run(fn);
|
|
42
|
+
}, timeout);
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
46
|
+
async function performPaginationTest(endpoint, props) {
|
|
47
|
+
const { params, req, count, fields, otherTestsFn = lodash_1.noop } = props;
|
|
48
|
+
(0, assert_1.default)(params);
|
|
49
|
+
const pageSize = props.pageSize || (0, softkave_js_utils_1.getRandomInt)(1, count);
|
|
50
|
+
const maxPages = (0, softkave_js_utils_1.calculateMaxPages)(count, pageSize);
|
|
51
|
+
// Add an extra page to test that final page returns 0 items
|
|
52
|
+
for (let page = 0; page <= maxPages; page++) {
|
|
53
|
+
const instData = RequestData_1.default.fromExpressRequest(req, {
|
|
54
|
+
page,
|
|
55
|
+
pageSize,
|
|
56
|
+
...params,
|
|
57
|
+
});
|
|
58
|
+
const result = await endpoint(instData);
|
|
59
|
+
(0, testUtils_1.assertEndpointResultOk)(result);
|
|
60
|
+
// Seeing page is 0-based, when page === maxPages, expectedPageSize should
|
|
61
|
+
// be 0
|
|
62
|
+
const expectedPageSize = page < maxPages ? (0, softkave_js_utils_1.calculatePageSize)(count, pageSize, page) : 0;
|
|
63
|
+
expect(result.page).toBe(page);
|
|
64
|
+
(0, softkave_js_utils_1.convertToArray)(fields).forEach(field => {
|
|
65
|
+
expect((0, lodash_1.get)(result, field)).toHaveLength(expectedPageSize);
|
|
66
|
+
});
|
|
67
|
+
otherTestsFn(result);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
exports.performPaginationTest = performPaginationTest;
|
|
71
|
+
function expectFields(resources, fields) {
|
|
72
|
+
resources.forEach(resource => {
|
|
73
|
+
for (const key in fields) {
|
|
74
|
+
const expectedValue = fields[key];
|
|
75
|
+
const receivedValue = resource[key];
|
|
76
|
+
expect({ [key]: expectedValue }).toEqual({ [key]: receivedValue });
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
exports.expectFields = expectFields;
|
|
81
|
+
async function matchExpects(expects, ...args) {
|
|
82
|
+
for (const { matcher, expect } of expects) {
|
|
83
|
+
const matches = await matcher(...args);
|
|
84
|
+
if (matches) {
|
|
85
|
+
await expect(...args);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
exports.matchExpects = matchExpects;
|
|
90
|
+
async function testCombinations(combinations, fn) {
|
|
91
|
+
for (const combination of combinations) {
|
|
92
|
+
await fn(combination);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
exports.testCombinations = testCombinations;
|
|
96
|
+
//# sourceMappingURL=testFns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testFns.js","sourceRoot":"","sources":["../../../../src/testUtils/helpers/testFns.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ServerRequest } from '../contexts/types';
|
|
2
|
+
import { Resource } from '../definitions/resource';
|
|
3
|
+
import { BaseTokenData } from '../definitions/token';
|
|
4
|
+
import { BaseEndpointResult } from '../endpoints/types';
|
|
5
|
+
import MockTestEmailProviderContext from './context/email/MockTestEmailProviderContext';
|
|
6
|
+
export declare function getTestEmailProvider(): MockTestEmailProviderContext;
|
|
7
|
+
export declare function initTests(): Promise<void>;
|
|
8
|
+
export declare function assertEndpointResultOk(result?: BaseEndpointResult | void): boolean;
|
|
9
|
+
export declare function mockExpressRequest(token?: BaseTokenData): ServerRequest;
|
|
10
|
+
export declare function mockExpressRequestWithAgentToken(token: Pick<Resource, 'resourceId' | 'createdAt'> & {
|
|
11
|
+
expiresAt?: number;
|
|
12
|
+
}): ServerRequest;
|
|
13
|
+
export declare function mockExpressRequestForPublicAgent(): ServerRequest;
|
|
@@ -0,0 +1,50 @@
|
|
|
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.mockExpressRequestForPublicAgent = exports.mockExpressRequestWithAgentToken = exports.mockExpressRequest = exports.assertEndpointResultOk = exports.initTests = exports.getTestEmailProvider = void 0;
|
|
7
|
+
const globalUtils_1 = require("../contexts/globalUtils");
|
|
8
|
+
const token_1 = require("../definitions/token");
|
|
9
|
+
const MockTestEmailProviderContext_1 = __importDefault(require("./context/email/MockTestEmailProviderContext"));
|
|
10
|
+
function getTestEmailProvider() {
|
|
11
|
+
return new MockTestEmailProviderContext_1.default();
|
|
12
|
+
}
|
|
13
|
+
exports.getTestEmailProvider = getTestEmailProvider;
|
|
14
|
+
async function initTests() {
|
|
15
|
+
await (0, globalUtils_1.globalSetup)();
|
|
16
|
+
}
|
|
17
|
+
exports.initTests = initTests;
|
|
18
|
+
function assertEndpointResultOk(result) {
|
|
19
|
+
var _a;
|
|
20
|
+
if ((_a = result === null || result === void 0 ? void 0 : result.errors) === null || _a === void 0 ? void 0 : _a.length) {
|
|
21
|
+
throw result.errors;
|
|
22
|
+
}
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
exports.assertEndpointResultOk = assertEndpointResultOk;
|
|
26
|
+
function mockExpressRequest(token) {
|
|
27
|
+
const req = { auth: token };
|
|
28
|
+
return req;
|
|
29
|
+
}
|
|
30
|
+
exports.mockExpressRequest = mockExpressRequest;
|
|
31
|
+
function mockExpressRequestWithAgentToken(token) {
|
|
32
|
+
const req = {
|
|
33
|
+
auth: {
|
|
34
|
+
version: token_1.kCurrentJWTTokenVersion,
|
|
35
|
+
sub: { id: token.resourceId },
|
|
36
|
+
iat: token.createdAt,
|
|
37
|
+
exp: token.expiresAt,
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
return req;
|
|
41
|
+
}
|
|
42
|
+
exports.mockExpressRequestWithAgentToken = mockExpressRequestWithAgentToken;
|
|
43
|
+
function mockExpressRequestForPublicAgent() {
|
|
44
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
45
|
+
// @ts-ignore
|
|
46
|
+
const req = {};
|
|
47
|
+
return req;
|
|
48
|
+
}
|
|
49
|
+
exports.mockExpressRequestForPublicAgent = mockExpressRequestForPublicAgent;
|
|
50
|
+
//# sourceMappingURL=testUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testUtils.js","sourceRoot":"","sources":["../../../src/testUtils/testUtils.ts"],"names":[],"mappings":";;;;;;AAAA,yDAAoD;AAGpD,gDAA4E;AAE5E,gHAAwF;AAExF,SAAgB,oBAAoB;IAClC,OAAO,IAAI,sCAA4B,EAAE,CAAC;AAC5C,CAAC;AAFD,oDAEC;AAEM,KAAK,UAAU,SAAS;IAC7B,MAAM,IAAA,yBAAW,GAAE,CAAC;AACtB,CAAC;AAFD,8BAEC;AAED,SAAgB,sBAAsB,CAAC,MAAkC;;IACvE,IAAI,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,0CAAE,MAAM,EAAE;QAC1B,MAAM,MAAM,CAAC,MAAM,CAAC;KACrB;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAND,wDAMC;AAED,SAAgB,kBAAkB,CAAC,KAAqB;IACtD,MAAM,GAAG,GAAkB,EAAC,IAAI,EAAE,KAAK,EAA6B,CAAC;IACrE,OAAO,GAAG,CAAC;AACb,CAAC;AAHD,gDAGC;AAED,SAAgB,gCAAgC,CAC9C,KAAwE;IAExE,MAAM,GAAG,GAAkB;QACzB,IAAI,EAAE;YACJ,OAAO,EAAE,+BAAuB;YAChC,GAAG,EAAE,EAAC,EAAE,EAAE,KAAK,CAAC,UAAU,EAAC;YAC3B,GAAG,EAAE,KAAK,CAAC,SAAS;YACpB,GAAG,EAAE,KAAK,CAAC,SAAS;SACrB;KAC0B,CAAC;IAC9B,OAAO,GAAG,CAAC;AACb,CAAC;AAZD,4EAYC;AAED,SAAgB,gCAAgC;IAC9C,6DAA6D;IAC7D,aAAa;IACb,MAAM,GAAG,GAAkB,EAAE,CAAC;IAC9B,OAAO,GAAG,CAAC;AACb,CAAC;AALD,4EAKC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
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.appAssert = void 0;
|
|
7
|
+
const lodash_1 = require("lodash");
|
|
8
|
+
const injectables_1 = require("../contexts/injection/injectables");
|
|
9
|
+
const commonErrors_1 = require("../errors/commonErrors");
|
|
10
|
+
const OperationError_1 = __importDefault(require("../errors/OperationError"));
|
|
11
|
+
function appAssert(value, response = new commonErrors_1.ServerError(), logMessage) {
|
|
12
|
+
if (!value) {
|
|
13
|
+
if (logMessage) {
|
|
14
|
+
injectables_1.kUtilsInjectables.logger().error(logMessage);
|
|
15
|
+
}
|
|
16
|
+
if ((0, lodash_1.isString)(response)) {
|
|
17
|
+
throw new OperationError_1.default(response);
|
|
18
|
+
}
|
|
19
|
+
else if (response instanceof Error) {
|
|
20
|
+
throw response;
|
|
21
|
+
}
|
|
22
|
+
else if (response) {
|
|
23
|
+
response();
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
throw new Error('Assertion failed');
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.appAssert = appAssert;
|
|
31
|
+
//# sourceMappingURL=assertion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"assertion.js","sourceRoot":"","sources":["../../../src/utils/assertion.ts"],"names":[],"mappings":";;;;;;AAAA,mCAAgC;AAEhC,mEAAoE;AACpE,yDAAmD;AACnD,8EAAsD;AAEtD,SAAgB,SAAS,CACvB,KAAc,EACd,WAAmC,IAAI,0BAAW,EAAE,EACpD,UAAmB;IAEnB,IAAI,CAAC,KAAK,EAAE;QACV,IAAI,UAAU,EAAE;YACd,+BAAiB,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;SAC9C;QAED,IAAI,IAAA,iBAAQ,EAAC,QAAQ,CAAC,EAAE;YACtB,MAAM,IAAI,wBAAc,CAAC,QAAQ,CAAC,CAAC;SACpC;aAAM,IAAI,QAAQ,YAAY,KAAK,EAAE;YACpC,MAAM,QAAQ,CAAC;SAChB;aAAM,IAAI,QAAQ,EAAE;YACnB,QAAQ,EAAE,CAAC;SACZ;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;SACrC;KACF;AACH,CAAC;AApBD,8BAoBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../../src/utils/aws.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.streamToBuffer = void 0;
|
|
4
|
+
function streamToBuffer(stream) {
|
|
5
|
+
const chunks = [];
|
|
6
|
+
return new Promise((resolve, reject) => {
|
|
7
|
+
stream.on('data', chunk => {
|
|
8
|
+
chunks.push(Buffer.from(chunk));
|
|
9
|
+
});
|
|
10
|
+
stream.on('error', err => {
|
|
11
|
+
reject(err);
|
|
12
|
+
});
|
|
13
|
+
stream.on('end', () => {
|
|
14
|
+
resolve(Buffer.concat(chunks));
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
exports.streamToBuffer = streamToBuffer;
|
|
19
|
+
//# sourceMappingURL=streamToBuffer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streamToBuffer.js","sourceRoot":"","sources":["../../../src/utils/streamToBuffer.ts"],"names":[],"mappings":";;;AAEA,SAAgB,cAAc,CAAC,MAAgB;IAC7C,MAAM,MAAM,GAAa,EAAE,CAAC;IAC5B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE;YACxB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE;YACvB,MAAM,CAAC,GAAG,CAAC,CAAC;QACd,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE;YACpB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAbD,wCAaC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "softkave-node-utils",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Compilation of Node.js utils",
|
|
5
|
+
"author": {
|
|
6
|
+
"email": "ywordk@gmail.com",
|
|
7
|
+
"name": "softkave"
|
|
8
|
+
},
|
|
9
|
+
"license": "MIT",
|
|
10
|
+
"keywords": [],
|
|
11
|
+
"repository": {
|
|
12
|
+
"type": "git",
|
|
13
|
+
"url": "https://github.com/softkave/softkave-js-utils.git"
|
|
14
|
+
},
|
|
15
|
+
"bugs": {
|
|
16
|
+
"url": "https://github.com/softkave/softkave-js-utils/issues"
|
|
17
|
+
},
|
|
18
|
+
"homepage": "https://github.com/softkave/softkave-js-utils",
|
|
19
|
+
"main": "build/src/index.js",
|
|
20
|
+
"types": "build/src/index.d.ts",
|
|
21
|
+
"files": [
|
|
22
|
+
"build/src/{*.js,**/*.js}",
|
|
23
|
+
"build/src/{*.js.map,**/*.js.map}",
|
|
24
|
+
"build/src/{*.d.ts,**/*.d.ts}",
|
|
25
|
+
"!build/src/**/__tests__/**/*",
|
|
26
|
+
"!build/src/**/__test__/**/*"
|
|
27
|
+
],
|
|
28
|
+
"scripts": {
|
|
29
|
+
"test": "echo \"Error: no test specified\" && exit 1",
|
|
30
|
+
"lint": "gts lint",
|
|
31
|
+
"clean": "gts clean",
|
|
32
|
+
"compile": "tsc",
|
|
33
|
+
"fix": "gts fix",
|
|
34
|
+
"prepare": "npm run compile",
|
|
35
|
+
"pretest": "npm run compile",
|
|
36
|
+
"posttest": "npm run lint",
|
|
37
|
+
"check-circular-deps": "npx dpdm --no-warning --no-tree ./src/index.ts",
|
|
38
|
+
"publish-to-npm": "npm run compile && npm publish",
|
|
39
|
+
"show-packlist": "npm run compile && npm pack --dry-run"
|
|
40
|
+
},
|
|
41
|
+
"devDependencies": {
|
|
42
|
+
"@faker-js/faker": "^8.4.1",
|
|
43
|
+
"@types/config": "^3.3.4",
|
|
44
|
+
"@types/express": "^4.17.21",
|
|
45
|
+
"@types/fs-extra": "^11.0.4",
|
|
46
|
+
"@types/jest": "^29.5.12",
|
|
47
|
+
"@types/jsonwebtoken": "^9.0.6",
|
|
48
|
+
"@types/lodash": "^4.17.0",
|
|
49
|
+
"@types/node": "20.8.2",
|
|
50
|
+
"gts": "^5.2.0",
|
|
51
|
+
"jest": "^29.7.0",
|
|
52
|
+
"ts-jest": "^29.1.2",
|
|
53
|
+
"typescript": "~5.2.0"
|
|
54
|
+
},
|
|
55
|
+
"dependencies": {
|
|
56
|
+
"@aws-sdk/client-secrets-manager": "^3.549.0",
|
|
57
|
+
"@aws-sdk/client-sesv2": "^3.549.0",
|
|
58
|
+
"config": "^3.3.11",
|
|
59
|
+
"date-fns": "^3.6.0",
|
|
60
|
+
"express": "^4.19.2",
|
|
61
|
+
"fs-extra": "^11.2.0",
|
|
62
|
+
"joi": "^17.12.3",
|
|
63
|
+
"js-accessor": "^1.1.0",
|
|
64
|
+
"jsonwebtoken": "^9.0.2",
|
|
65
|
+
"lodash": "^4.17.21",
|
|
66
|
+
"mongoose": "^8.1.1",
|
|
67
|
+
"nanoid": "^5.0.7",
|
|
68
|
+
"softkave-js-utils": "^0.3.1",
|
|
69
|
+
"tsyringe": "^4.8.0",
|
|
70
|
+
"type-fest": "^4.15.0"
|
|
71
|
+
}
|
|
72
|
+
}
|