@etohq/framework 1.5.1-alpha.4 → 1.5.1-alpha.6
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/config/loader.d.ts +1 -1
- package/dist/config/loader.d.ts.map +1 -1
- package/dist/config/loader.js +3 -2
- package/dist/config/loader.js.map +1 -1
- package/dist/deps/awilix.d.ts +2 -0
- package/dist/deps/awilix.d.ts.map +1 -0
- package/dist/deps/awilix.js +18 -0
- package/dist/deps/awilix.js.map +1 -0
- package/dist/deps/mikro-orm-cli.d.ts +2 -0
- package/dist/deps/mikro-orm-cli.d.ts.map +1 -0
- package/dist/deps/mikro-orm-cli.js +18 -0
- package/dist/deps/mikro-orm-cli.js.map +1 -0
- package/dist/deps/mikro-orm-core.d.ts +2 -0
- package/dist/deps/mikro-orm-core.d.ts.map +1 -0
- package/dist/deps/mikro-orm-core.js +18 -0
- package/dist/deps/mikro-orm-core.js.map +1 -0
- package/dist/deps/mikro-orm-knex.d.ts +2 -0
- package/dist/deps/mikro-orm-knex.d.ts.map +1 -0
- package/dist/deps/mikro-orm-knex.js +18 -0
- package/dist/deps/mikro-orm-knex.js.map +1 -0
- package/dist/deps/mikro-orm-migrations.d.ts +2 -0
- package/dist/deps/mikro-orm-migrations.d.ts.map +1 -0
- package/dist/deps/mikro-orm-migrations.js +18 -0
- package/dist/deps/mikro-orm-migrations.js.map +1 -0
- package/dist/deps/mikro-orm-postgresql.d.ts +2 -0
- package/dist/deps/mikro-orm-postgresql.d.ts.map +1 -0
- package/dist/deps/mikro-orm-postgresql.js +18 -0
- package/dist/deps/mikro-orm-postgresql.js.map +1 -0
- package/dist/deps/opentelemetry-api.d.ts +2 -0
- package/dist/deps/opentelemetry-api.d.ts.map +1 -0
- package/dist/deps/opentelemetry-api.js +18 -0
- package/dist/deps/opentelemetry-api.js.map +1 -0
- package/dist/deps/opentelemetry-instrumentation-pg.d.ts +2 -0
- package/dist/deps/opentelemetry-instrumentation-pg.d.ts.map +1 -0
- package/dist/deps/opentelemetry-instrumentation-pg.js +18 -0
- package/dist/deps/opentelemetry-instrumentation-pg.js.map +1 -0
- package/dist/deps/opentelemetry-resources.d.ts +2 -0
- package/dist/deps/opentelemetry-resources.d.ts.map +1 -0
- package/dist/deps/opentelemetry-resources.js +18 -0
- package/dist/deps/opentelemetry-resources.js.map +1 -0
- package/dist/deps/opentelemetry-sdk-node.d.ts +2 -0
- package/dist/deps/opentelemetry-sdk-node.d.ts.map +1 -0
- package/dist/deps/opentelemetry-sdk-node.js +18 -0
- package/dist/deps/opentelemetry-sdk-node.js.map +1 -0
- package/dist/deps/opentelemetry-sdk-trace-node.d.ts +2 -0
- package/dist/deps/opentelemetry-sdk-trace-node.d.ts.map +1 -0
- package/dist/deps/opentelemetry-sdk-trace-node.js +18 -0
- package/dist/deps/opentelemetry-sdk-trace-node.js.map +1 -0
- package/dist/deps/pg.d.ts +2 -0
- package/dist/deps/pg.d.ts.map +1 -0
- package/dist/deps/pg.js +18 -0
- package/dist/deps/pg.js.map +1 -0
- package/dist/deps/zod.d.ts +2 -0
- package/dist/deps/zod.d.ts.map +1 -0
- package/dist/deps/zod.js +18 -0
- package/dist/deps/zod.js.map +1 -0
- package/dist/eto-app-loader.d.ts.map +1 -1
- package/dist/eto-app-loader.js +4 -2
- package/dist/eto-app-loader.js.map +1 -1
- package/dist/eto.d.ts +11 -2
- package/dist/eto.d.ts.map +1 -1
- package/dist/eto.js +29 -18
- package/dist/eto.js.map +1 -1
- package/dist/http/express-loader.d.ts +10 -0
- package/dist/http/express-loader.d.ts.map +1 -0
- package/dist/http/express-loader.js +130 -0
- package/dist/http/express-loader.js.map +1 -0
- package/dist/http/middleware-file-loader.d.ts +33 -0
- package/dist/http/middleware-file-loader.d.ts.map +1 -0
- package/dist/http/middleware-file-loader.js +186 -0
- package/dist/http/middleware-file-loader.js.map +1 -0
- package/dist/http/middlewares/apply-locale.d.ts +12 -0
- package/dist/http/middlewares/apply-locale.d.ts.map +1 -0
- package/dist/http/middlewares/apply-locale.js +31 -0
- package/dist/http/middlewares/apply-locale.js.map +1 -0
- package/dist/http/middlewares/check-permissions.d.ts +15 -0
- package/dist/http/middlewares/check-permissions.d.ts.map +1 -0
- package/dist/http/middlewares/check-permissions.js +54 -0
- package/dist/http/middlewares/check-permissions.js.map +1 -0
- package/dist/http/router.d.ts +36 -0
- package/dist/http/router.d.ts.map +1 -0
- package/dist/http/router.js +317 -0
- package/dist/http/router.js.map +1 -0
- package/dist/http/routes-finder.d.ts +22 -0
- package/dist/http/routes-finder.d.ts.map +1 -0
- package/dist/http/routes-finder.js +68 -0
- package/dist/http/routes-finder.js.map +1 -0
- package/dist/http/routes-loader.d.ts +39 -0
- package/dist/http/routes-loader.d.ts.map +1 -0
- package/dist/http/routes-loader.js +232 -0
- package/dist/http/routes-loader.js.map +1 -0
- package/dist/http/routes-sorter.d.ts +105 -0
- package/dist/http/routes-sorter.d.ts.map +1 -0
- package/dist/http/routes-sorter.js +146 -0
- package/dist/http/routes-sorter.js.map +1 -0
- package/dist/http/utils/define-middlewares.d.ts +22 -0
- package/dist/http/utils/define-middlewares.d.ts.map +1 -0
- package/dist/http/utils/define-middlewares.js +27 -0
- package/dist/http/utils/define-middlewares.js.map +1 -0
- package/dist/http/utils/field-filtering/field-parser.d.ts +32 -0
- package/dist/http/utils/field-filtering/field-parser.d.ts.map +1 -0
- package/dist/http/utils/field-filtering/field-parser.js +87 -0
- package/dist/http/utils/field-filtering/field-parser.js.map +1 -0
- package/dist/http/utils/field-filtering/field-validator.d.ts +24 -0
- package/dist/http/utils/field-filtering/field-validator.d.ts.map +1 -0
- package/dist/http/utils/field-filtering/field-validator.js +67 -0
- package/dist/http/utils/field-filtering/field-validator.js.map +1 -0
- package/dist/http/utils/field-filtering/index.d.ts +33 -0
- package/dist/http/utils/field-filtering/index.d.ts.map +1 -0
- package/dist/http/utils/field-filtering/index.js +9 -0
- package/dist/http/utils/field-filtering/index.js.map +1 -0
- package/dist/http/utils/policies/rbac-field-filter.d.ts +19 -0
- package/dist/http/utils/policies/rbac-field-filter.d.ts.map +1 -0
- package/dist/http/utils/policies/rbac-field-filter.js +348 -0
- package/dist/http/utils/policies/rbac-field-filter.js.map +1 -0
- package/dist/links/link-loader.d.ts +2 -1
- package/dist/links/link-loader.d.ts.map +1 -1
- package/dist/links/link-loader.js +9 -7
- package/dist/links/link-loader.js.map +1 -1
- package/dist/policies/has-permission.d.ts +33 -0
- package/dist/policies/has-permission.d.ts.map +1 -0
- package/dist/policies/has-permission.js +110 -0
- package/dist/policies/has-permission.js.map +1 -0
- package/dist/policies/index.d.ts +3 -0
- package/dist/policies/index.d.ts.map +1 -0
- package/dist/policies/index.js +19 -0
- package/dist/policies/index.js.map +1 -0
- package/dist/policies/policy-loader.d.ts +6 -0
- package/dist/policies/policy-loader.d.ts.map +1 -0
- package/dist/policies/policy-loader.js +17 -0
- package/dist/policies/policy-loader.js.map +1 -0
- package/dist/telemetry/index.d.ts +50 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +81 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/utils/resource-loader.d.ts +3 -1
- package/dist/utils/resource-loader.d.ts.map +1 -1
- package/dist/utils/resource-loader.js +18 -7
- package/dist/utils/resource-loader.js.map +1 -1
- package/dist/zod/index.d.ts +1 -0
- package/dist/zod/index.d.ts.map +1 -1
- package/dist/zod/index.js +1 -0
- package/dist/zod/index.js.map +1 -1
- package/package.json +21 -9
|
@@ -10,7 +10,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
10
10
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
11
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
12
|
};
|
|
13
|
-
var _LinkLoader_sourceDir, _LinkLoader_excludes;
|
|
13
|
+
var _LinkLoader_sourceDir, _LinkLoader_excludes, _LinkLoader_logger;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.LinkLoader = void 0;
|
|
16
16
|
const utils_1 = require("@etohq/utils");
|
|
@@ -18,7 +18,7 @@ const promises_1 = require("fs/promises");
|
|
|
18
18
|
const path_1 = require("path");
|
|
19
19
|
const logger_1 = require("../logger");
|
|
20
20
|
class LinkLoader {
|
|
21
|
-
constructor(sourceDir) {
|
|
21
|
+
constructor(sourceDir, logger) {
|
|
22
22
|
/**
|
|
23
23
|
* The directory from which to load the links
|
|
24
24
|
* @private
|
|
@@ -35,7 +35,9 @@ class LinkLoader {
|
|
|
35
35
|
/(\.ts\.map|\.js\.map|\.d\.ts|\.md)/,
|
|
36
36
|
/^_[^/\\]*(\.[^/\\]+)?$/,
|
|
37
37
|
]);
|
|
38
|
+
_LinkLoader_logger.set(this, void 0);
|
|
38
39
|
__classPrivateFieldSet(this, _LinkLoader_sourceDir, sourceDir, "f");
|
|
40
|
+
__classPrivateFieldSet(this, _LinkLoader_logger, logger ?? logger_1.logger, "f");
|
|
39
41
|
}
|
|
40
42
|
/**
|
|
41
43
|
* Load links from the source paths, links are registering themselves,
|
|
@@ -50,7 +52,7 @@ class LinkLoader {
|
|
|
50
52
|
await (0, promises_1.access)(sourcePath);
|
|
51
53
|
}
|
|
52
54
|
catch {
|
|
53
|
-
|
|
55
|
+
__classPrivateFieldGet(this, _LinkLoader_logger, "f").info(`No link to load from ${sourcePath}. skipped.`);
|
|
54
56
|
return;
|
|
55
57
|
}
|
|
56
58
|
return await (0, utils_1.readDirRecursive)(sourcePath).then(async (entries) => {
|
|
@@ -58,17 +60,17 @@ class LinkLoader {
|
|
|
58
60
|
return (!entry.isDirectory() &&
|
|
59
61
|
!__classPrivateFieldGet(this, _LinkLoader_excludes, "f").some((exclude) => exclude.test(entry.name)));
|
|
60
62
|
});
|
|
61
|
-
|
|
63
|
+
__classPrivateFieldGet(this, _LinkLoader_logger, "f").debug(`Registering links from ${sourcePath}.`);
|
|
62
64
|
return await (0, utils_1.promiseAll)(fileEntries.map(async (entry) => {
|
|
63
|
-
const fullPath = (0, path_1.join)(
|
|
65
|
+
const fullPath = (0, path_1.join)(entry.path, entry.name);
|
|
64
66
|
return await (0, utils_1.dynamicImport)(fullPath);
|
|
65
67
|
}));
|
|
66
68
|
});
|
|
67
69
|
});
|
|
68
70
|
await (0, utils_1.promiseAll)(promises);
|
|
69
|
-
|
|
71
|
+
__classPrivateFieldGet(this, _LinkLoader_logger, "f").debug(`Links registered.`);
|
|
70
72
|
}
|
|
71
73
|
}
|
|
72
74
|
exports.LinkLoader = LinkLoader;
|
|
73
|
-
_LinkLoader_sourceDir = new WeakMap(), _LinkLoader_excludes = new WeakMap();
|
|
75
|
+
_LinkLoader_sourceDir = new WeakMap(), _LinkLoader_excludes = new WeakMap(), _LinkLoader_logger = new WeakMap();
|
|
74
76
|
//# sourceMappingURL=link-loader.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"link-loader.js","sourceRoot":"","sources":["../../src/links/link-loader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"link-loader.js","sourceRoot":"","sources":["../../src/links/link-loader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,wCAA0E;AAE1E,0CAAoC;AACpC,+BAA2B;AAC3B,sCAAmD;AAInD,MAAa,UAAU;IAqBrB,YAAY,SAA4B,EAAE,MAAe;QApBzD;;;WAGG;QACH,wCAA6B;QAE7B;;;WAGG;QACH,+BAAsB;YACpB,WAAW;YACX,WAAW;YACX,YAAY;YACZ,oCAAoC;YACpC,wBAAwB;SACzB,EAAA;QAED,qCAAe;QAGb,uBAAA,IAAI,yBAAc,SAAS,MAAA,CAAA;QAC3B,uBAAA,IAAI,sBAAW,MAAM,IAAI,eAAa,MAAA,CAAA;IACxC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,IAAI;QACR,MAAM,oBAAoB,GAAG,KAAK,CAAC,OAAO,CAAC,uBAAA,IAAI,6BAAW,CAAC;YACzD,CAAC,CAAC,uBAAA,IAAI,6BAAW;YACjB,CAAC,CAAC,CAAC,uBAAA,IAAI,6BAAW,CAAC,CAAA;QAErB,MAAM,QAAQ,GAAG,oBAAoB,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;YAC7D,IAAI,CAAC;gBACH,MAAM,IAAA,iBAAM,EAAC,UAAU,CAAC,CAAA;YAC1B,CAAC;YAAC,MAAM,CAAC;gBACP,uBAAA,IAAI,0BAAQ,CAAC,IAAI,CAAC,wBAAwB,UAAU,YAAY,CAAC,CAAA;gBACjE,OAAM;YACR,CAAC;YAED,OAAO,MAAM,IAAA,wBAAgB,EAAC,UAAU,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;gBAC/D,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAa,EAAE,EAAE;oBACnD,OAAO,CACL,CAAC,KAAK,CAAC,WAAW,EAAE;wBACpB,CAAC,uBAAA,IAAI,4BAAU,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAC5D,CAAA;gBACH,CAAC,CAAqB,CAAA;gBAEtB,uBAAA,IAAI,0BAAQ,CAAC,KAAK,CAAC,0BAA0B,UAAU,GAAG,CAAC,CAAA;gBAE3D,OAAO,MAAM,IAAA,kBAAU,EACrB,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,KAAqB,EAAE,EAAE;oBAC9C,MAAM,QAAQ,GAAG,IAAA,WAAI,EAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;oBAC7C,OAAO,MAAM,IAAA,qBAAa,EAAC,QAAQ,CAAC,CAAA;gBACtC,CAAC,CAAC,CACH,CAAA;YACH,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,MAAM,IAAA,kBAAU,EAAC,QAAQ,CAAC,CAAA;QAE1B,uBAAA,IAAI,0BAAQ,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;IACzC,CAAC;CACF;AAlED,gCAkEC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { EtoContainer } from "@etohq/types";
|
|
2
|
+
export type PermissionAction = {
|
|
3
|
+
resource: string;
|
|
4
|
+
operation: string | string[];
|
|
5
|
+
};
|
|
6
|
+
export type HasPermissionInput = {
|
|
7
|
+
roles: string | string[];
|
|
8
|
+
actions: PermissionAction | PermissionAction[];
|
|
9
|
+
container: EtoContainer;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Checks if the given role(s) have permission to perform the specified action(s).
|
|
13
|
+
*
|
|
14
|
+
* @param input - The input containing roles, actions, and container
|
|
15
|
+
* @returns true if all actions are permitted, false otherwise
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```ts
|
|
19
|
+
* const canWrite = await hasPermission({
|
|
20
|
+
* roles: ['role_123'],
|
|
21
|
+
* actions: { resource: 'product', operation: 'write' },
|
|
22
|
+
* container
|
|
23
|
+
* })
|
|
24
|
+
*
|
|
25
|
+
* const canDeleteAndWrite = await hasPermission({
|
|
26
|
+
* roles: ['role_123'],
|
|
27
|
+
* actions: { resource: 'product', operation: ['delete', 'write'] },
|
|
28
|
+
* container
|
|
29
|
+
* })
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export declare function hasPermission(input: HasPermissionInput): Promise<boolean>;
|
|
33
|
+
//# sourceMappingURL=has-permission.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"has-permission.d.ts","sourceRoot":"","sources":["../../src/policies/has-permission.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAI3C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;CAC7B,CAAA;AASD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IACxB,OAAO,EAAE,gBAAgB,GAAG,gBAAgB,EAAE,CAAA;IAC9C,SAAS,EAAE,YAAY,CAAA;CACxB,CAAA;AAID;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAsB,aAAa,CACjC,KAAK,EAAE,kBAAkB,GACxB,OAAO,CAAC,OAAO,CAAC,CAgDlB"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.hasPermission = hasPermission;
|
|
4
|
+
const utils_1 = require("@etohq/utils");
|
|
5
|
+
/**
|
|
6
|
+
* Checks if the given role(s) have permission to perform the specified action(s).
|
|
7
|
+
*
|
|
8
|
+
* @param input - The input containing roles, actions, and container
|
|
9
|
+
* @returns true if all actions are permitted, false otherwise
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```ts
|
|
13
|
+
* const canWrite = await hasPermission({
|
|
14
|
+
* roles: ['role_123'],
|
|
15
|
+
* actions: { resource: 'product', operation: 'write' },
|
|
16
|
+
* container
|
|
17
|
+
* })
|
|
18
|
+
*
|
|
19
|
+
* const canDeleteAndWrite = await hasPermission({
|
|
20
|
+
* roles: ['role_123'],
|
|
21
|
+
* actions: { resource: 'product', operation: ['delete', 'write'] },
|
|
22
|
+
* container
|
|
23
|
+
* })
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
async function hasPermission(input) {
|
|
27
|
+
const { roles, actions, container } = input;
|
|
28
|
+
const roleIds = Array.isArray(roles) ? roles : [roles];
|
|
29
|
+
const actionList = Array.isArray(actions) ? actions : [actions];
|
|
30
|
+
const ffRouter = container.resolve(utils_1.ContainerRegistrationKeys.FEATURE_FLAG_ROUTER);
|
|
31
|
+
const isDisabled = !ffRouter.isFeatureEnabled("rbac");
|
|
32
|
+
if (isDisabled || !roleIds?.length || !actionList?.length) {
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
const rolePoliciesMap = await fetchRolePolicies(roleIds, container);
|
|
36
|
+
for (const action of actionList) {
|
|
37
|
+
// Handle multiple operations for a single resource (and)
|
|
38
|
+
const operations = Array.isArray(action.operation)
|
|
39
|
+
? action.operation
|
|
40
|
+
: [action.operation];
|
|
41
|
+
for (const op of operations) {
|
|
42
|
+
let operationHasAccess = false;
|
|
43
|
+
for (const roleId of roleIds) {
|
|
44
|
+
const resourceMap = rolePoliciesMap.get(roleId);
|
|
45
|
+
if (!resourceMap) {
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
const allowedOps = new Set([
|
|
49
|
+
...(resourceMap.get(action.resource) || []),
|
|
50
|
+
...(resourceMap.get("*") || []),
|
|
51
|
+
]);
|
|
52
|
+
if (allowedOps && (allowedOps.has(op) || allowedOps.has("*"))) {
|
|
53
|
+
operationHasAccess = true;
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
if (!operationHasAccess) {
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Fetches a single role's policies from cache or database.
|
|
66
|
+
*/
|
|
67
|
+
async function fetchSingleRolePolicies(roleId, container) {
|
|
68
|
+
const query = container.resolve(utils_1.ContainerRegistrationKeys.QUERY);
|
|
69
|
+
const tags = [];
|
|
70
|
+
return await (0, utils_1.useCache)(async () => {
|
|
71
|
+
const { data: roles } = await query.graph({
|
|
72
|
+
entity: "rbac_role",
|
|
73
|
+
fields: ["id", "policies.*"],
|
|
74
|
+
filters: { id: roleId },
|
|
75
|
+
});
|
|
76
|
+
const role = roles[0];
|
|
77
|
+
const resourceMap = new Map();
|
|
78
|
+
tags.push(`rbac_role:${roleId}`);
|
|
79
|
+
if (role?.policies && Array.isArray(role.policies)) {
|
|
80
|
+
const policyIds = [];
|
|
81
|
+
for (const policy of role.policies) {
|
|
82
|
+
policyIds.push(policy.id);
|
|
83
|
+
if (!resourceMap.has(policy.resource)) {
|
|
84
|
+
resourceMap.set(policy.resource, new Set());
|
|
85
|
+
}
|
|
86
|
+
resourceMap.get(policy.resource).add(policy.operation);
|
|
87
|
+
tags.push(`rbac_policy:${policy.id}`);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return resourceMap;
|
|
91
|
+
}, {
|
|
92
|
+
container,
|
|
93
|
+
key: roleId,
|
|
94
|
+
tags,
|
|
95
|
+
ttl: 60 * 60 * 24 * 7,
|
|
96
|
+
providers: ["cache-memory"],
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Fetches policies for multiple roles by composing individually cached role queries.
|
|
101
|
+
*/
|
|
102
|
+
async function fetchRolePolicies(roleIds, container) {
|
|
103
|
+
const rolePoliciesMap = new Map();
|
|
104
|
+
await Promise.all(roleIds.map(async (roleId) => {
|
|
105
|
+
const resourceMap = await fetchSingleRolePolicies(roleId, container);
|
|
106
|
+
rolePoliciesMap.set(roleId, resourceMap);
|
|
107
|
+
}));
|
|
108
|
+
return rolePoliciesMap;
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=has-permission.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"has-permission.js","sourceRoot":"","sources":["../../src/policies/has-permission.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/policies/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,iBAAiB,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./has-permission"), exports);
|
|
18
|
+
__exportStar(require("./policy-loader"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/policies/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC;AAChC,kDAA+B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy-loader.d.ts","sourceRoot":"","sources":["../../src/policies/policy-loader.ts"],"names":[],"mappings":"AAGA;;;GAGG;AACH,wBAAsB,cAAc,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAQvE"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.policiesLoader = policiesLoader;
|
|
4
|
+
const utils_1 = require("@etohq/utils");
|
|
5
|
+
const path_1 = require("path");
|
|
6
|
+
/**
|
|
7
|
+
* Load RBAC policies from a directory
|
|
8
|
+
* @param sourcePath - Path to scan for policies directories
|
|
9
|
+
*/
|
|
10
|
+
async function policiesLoader(sourcePath) {
|
|
11
|
+
if (!sourcePath) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
const policyDir = (0, path_1.normalize)(sourcePath);
|
|
15
|
+
await (0, utils_1.discoverPoliciesFromDir)(policyDir);
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=policy-loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy-loader.js","sourceRoot":"","sources":["../../src/policies/policy-loader.ts"],"names":[],"mappings":";;AAOA,wCAQC;AAfD,wCAAsD;AACtD,+BAAgC;AAEhC;;;GAGG;AACI,KAAK,UAAU,cAAc,CAAC,UAAmB;IACtD,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,OAAM;IACR,CAAC;IAED,MAAM,SAAS,GAAG,IAAA,gBAAS,EAAC,UAAU,CAAC,CAAA;IAEvC,MAAM,IAAA,+BAAuB,EAAC,SAAS,CAAC,CAAA;AAC1C,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Span } from "../deps/opentelemetry-api";
|
|
2
|
+
/**
|
|
3
|
+
* Tracer creates an instrumentation scope within the application
|
|
4
|
+
* code. For example: You might create a tracer for the API
|
|
5
|
+
* requests, another one for the modules, one for workflows
|
|
6
|
+
* and so on.
|
|
7
|
+
*
|
|
8
|
+
* There is no need to create a Tracer instance per HTTP
|
|
9
|
+
* call.
|
|
10
|
+
*/
|
|
11
|
+
export declare class Tracer {
|
|
12
|
+
#private;
|
|
13
|
+
name: string;
|
|
14
|
+
version?: string | undefined;
|
|
15
|
+
constructor(name: string, version?: string | undefined);
|
|
16
|
+
/**
|
|
17
|
+
* Returns the underlying tracer from open telemetry that
|
|
18
|
+
* could be used directly for certain advanced use-cases
|
|
19
|
+
*/
|
|
20
|
+
getOTTracer(): OTTracer;
|
|
21
|
+
/**
|
|
22
|
+
* Trace a function call. Using this method will create a
|
|
23
|
+
* child scope for the invocations within the callback.
|
|
24
|
+
*/
|
|
25
|
+
trace<F extends (span: Span) => unknown>(name: string, callback: F): ReturnType<F>;
|
|
26
|
+
/**
|
|
27
|
+
* Returns the active context
|
|
28
|
+
*/
|
|
29
|
+
getActiveContext(): any;
|
|
30
|
+
/**
|
|
31
|
+
* Returns the propagation state from the current active
|
|
32
|
+
* context
|
|
33
|
+
*/
|
|
34
|
+
getPropagationState(): {
|
|
35
|
+
traceparent: string;
|
|
36
|
+
tracestate?: string;
|
|
37
|
+
};
|
|
38
|
+
/**
|
|
39
|
+
* Use the existing propogation state and trace an action. This
|
|
40
|
+
* will allow the newly traced action to be part of some
|
|
41
|
+
* existing trace
|
|
42
|
+
*/
|
|
43
|
+
withPropagationState(state: {
|
|
44
|
+
traceparent: string;
|
|
45
|
+
tracestate?: string;
|
|
46
|
+
}): {
|
|
47
|
+
trace: <F extends (span: Span) => unknown>(name: string, callback: F) => ReturnType<F>;
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/telemetry/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,IAAI,EAIL,MAAM,2BAA2B,CAAA;AAElC;;;;;;;;GAQG;AACH,qBAAa,MAAM;;IAKE,IAAI,EAAE,MAAM;IAAS,OAAO,CAAC,EAAE,MAAM;gBAArC,IAAI,EAAE,MAAM,EAAS,OAAO,CAAC,EAAE,MAAM,YAAA;IAIxD;;;OAGG;IACH,WAAW;IAIX;;;OAGG;IACH,KAAK,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,KAAK,OAAO,EACrC,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,CAAC,GACV,UAAU,CAAC,CAAC,CAAC;IAIhB;;OAEG;IACH,gBAAgB;IAIhB;;;OAGG;IACH,mBAAmB,IAGA;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE;IAG/D;;;;OAIG;IACH,oBAAoB,CAAC,KAAK,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE;gBAE5D,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,KAAK,OAAO,QACjC,MAAM,YACF,CAAC,KACV,UAAU,CAAC,CAAC,CAAC;;CAMrB"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
3
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
4
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
5
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
6
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
7
|
+
};
|
|
8
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
9
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
10
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
|
+
};
|
|
13
|
+
var _Tracer_otTracer;
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.Tracer = void 0;
|
|
16
|
+
const opentelemetry_api_1 = require("../deps/opentelemetry-api");
|
|
17
|
+
/**
|
|
18
|
+
* Tracer creates an instrumentation scope within the application
|
|
19
|
+
* code. For example: You might create a tracer for the API
|
|
20
|
+
* requests, another one for the modules, one for workflows
|
|
21
|
+
* and so on.
|
|
22
|
+
*
|
|
23
|
+
* There is no need to create a Tracer instance per HTTP
|
|
24
|
+
* call.
|
|
25
|
+
*/
|
|
26
|
+
class Tracer {
|
|
27
|
+
constructor(name, version) {
|
|
28
|
+
this.name = name;
|
|
29
|
+
this.version = version;
|
|
30
|
+
/**
|
|
31
|
+
* Reference to the underlying OpenTelemetry tracer
|
|
32
|
+
*/
|
|
33
|
+
_Tracer_otTracer.set(this, void 0);
|
|
34
|
+
__classPrivateFieldSet(this, _Tracer_otTracer, opentelemetry_api_1.trace.getTracer(name, version), "f");
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Returns the underlying tracer from open telemetry that
|
|
38
|
+
* could be used directly for certain advanced use-cases
|
|
39
|
+
*/
|
|
40
|
+
getOTTracer() {
|
|
41
|
+
return __classPrivateFieldGet(this, _Tracer_otTracer, "f");
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Trace a function call. Using this method will create a
|
|
45
|
+
* child scope for the invocations within the callback.
|
|
46
|
+
*/
|
|
47
|
+
trace(name, callback) {
|
|
48
|
+
return __classPrivateFieldGet(this, _Tracer_otTracer, "f").startActiveSpan(name, callback);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Returns the active context
|
|
52
|
+
*/
|
|
53
|
+
getActiveContext() {
|
|
54
|
+
return opentelemetry_api_1.context.active();
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Returns the propagation state from the current active
|
|
58
|
+
* context
|
|
59
|
+
*/
|
|
60
|
+
getPropagationState() {
|
|
61
|
+
let output = {};
|
|
62
|
+
opentelemetry_api_1.propagation.inject(opentelemetry_api_1.context.active(), output);
|
|
63
|
+
return output;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Use the existing propogation state and trace an action. This
|
|
67
|
+
* will allow the newly traced action to be part of some
|
|
68
|
+
* existing trace
|
|
69
|
+
*/
|
|
70
|
+
withPropagationState(state) {
|
|
71
|
+
return {
|
|
72
|
+
trace: (name, callback) => {
|
|
73
|
+
const activeContext = opentelemetry_api_1.propagation.extract(opentelemetry_api_1.context.active(), state);
|
|
74
|
+
return __classPrivateFieldGet(this, _Tracer_otTracer, "f").startActiveSpan(name, {}, activeContext, callback);
|
|
75
|
+
},
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
exports.Tracer = Tracer;
|
|
80
|
+
_Tracer_otTracer = new WeakMap();
|
|
81
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/telemetry/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,iEAMkC;AAElC;;;;;;;;GAQG;AACH,MAAa,MAAM;IAKjB,YAAmB,IAAY,EAAS,OAAgB;QAArC,SAAI,GAAJ,IAAI,CAAQ;QAAS,YAAO,GAAP,OAAO,CAAS;QAJxD;;WAEG;QACH,mCAAmB;QAEjB,uBAAA,IAAI,oBAAa,yBAAK,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,CAAC,MAAA,CAAA;IACjD,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,OAAO,uBAAA,IAAI,wBAAU,CAAA;IACvB,CAAC;IAED;;;OAGG;IACH,KAAK,CACH,IAAY,EACZ,QAAW;QAEX,OAAO,uBAAA,IAAI,wBAAU,CAAC,eAAe,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;IACvD,CAAC;IAED;;OAEG;IACH,gBAAgB;QACd,OAAO,2BAAO,CAAC,MAAM,EAAE,CAAA;IACzB,CAAC;IAED;;;OAGG;IACH,mBAAmB;QACjB,IAAI,MAAM,GAAG,EAAE,CAAA;QACf,+BAAW,CAAC,MAAM,CAAC,2BAAO,CAAC,MAAM,EAAE,EAAE,MAAM,CAAC,CAAA;QAC5C,OAAO,MAAsD,CAAA;IAC/D,CAAC;IAED;;;;OAIG;IACH,oBAAoB,CAAC,KAAmD;QACtE,OAAO;YACL,KAAK,EAAE,CACL,IAAY,EACZ,QAAW,EACI,EAAE;gBACjB,MAAM,aAAa,GAAG,+BAAW,CAAC,OAAO,CAAC,2BAAO,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAA;gBAClE,OAAO,uBAAA,IAAI,wBAAU,CAAC,eAAe,CAAC,IAAI,EAAE,EAAE,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAA;YAC1E,CAAC;SACF,CAAA;IACH,CAAC;CACF;AA7DD,wBA6DC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Logger, EtoContainer } from "@etohq/types";
|
|
1
2
|
import { Dirent } from "fs";
|
|
2
3
|
export declare abstract class ResourceLoader {
|
|
3
4
|
#private;
|
|
@@ -5,7 +6,8 @@ export declare abstract class ResourceLoader {
|
|
|
5
6
|
* The name of the resource (e.g job, subscriber, workflow)
|
|
6
7
|
*/
|
|
7
8
|
protected abstract resourceName: string;
|
|
8
|
-
|
|
9
|
+
protected logger: Logger;
|
|
10
|
+
constructor(sourceDir: string | string[], container?: EtoContainer);
|
|
9
11
|
/**
|
|
10
12
|
* Discover resources from the source directory
|
|
11
13
|
* @param exclude - custom exclusion regexes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resource-loader.d.ts","sourceRoot":"","sources":["../../src/utils/resource-loader.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"resource-loader.d.ts","sourceRoot":"","sources":["../../src/utils/resource-loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAOnD,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAA;AAM3B,8BAAsB,cAAc;;IAClC;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAA;IAmBvC,SAAS,CAAC,MAAM,EAAE,MAAM,CAAA;gBAEZ,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,SAAS,CAAC,EAAE,YAAY;IAQlE;;;;;OAKG;cACa,iBAAiB,CAAC,EAChC,OAAO,EACP,eAAe,GAChB,GAAE;QACD,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;QAClB,eAAe,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAA;KACxC,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAqD3C;;;;OAIG;IACH,SAAS,CAAC,QAAQ,CAAC,YAAY,CAC7B,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACnC,OAAO,CAAC,IAAI,CAAC,GAAG,KAAK;CACzB"}
|
|
@@ -18,18 +18,27 @@ const promises_1 = require("fs/promises");
|
|
|
18
18
|
const path_1 = require("path");
|
|
19
19
|
const logger_1 = require("../logger");
|
|
20
20
|
class ResourceLoader {
|
|
21
|
-
constructor(sourceDir) {
|
|
21
|
+
constructor(sourceDir, container) {
|
|
22
22
|
/**
|
|
23
23
|
* The directory from which to load the jobs
|
|
24
24
|
* @private
|
|
25
25
|
*/
|
|
26
26
|
_ResourceLoader_sourceDir.set(this, void 0);
|
|
27
27
|
/**
|
|
28
|
-
* The list of file
|
|
28
|
+
* The list of file name patterns to exclude from resource scanning.
|
|
29
|
+
* Excludes: files starting with _, test files (.spec.ts, .test.ts)
|
|
29
30
|
* @private
|
|
30
31
|
*/
|
|
31
|
-
_ResourceLoader_excludes.set(this, [
|
|
32
|
+
_ResourceLoader_excludes.set(this, [
|
|
33
|
+
/^_[^/\\]*(\.[^/\\]+)?$/,
|
|
34
|
+
/\.spec\.[jt]s$/,
|
|
35
|
+
/\.test\.[jt]s$/,
|
|
36
|
+
]);
|
|
32
37
|
__classPrivateFieldSet(this, _ResourceLoader_sourceDir, sourceDir, "f");
|
|
38
|
+
this.logger =
|
|
39
|
+
container?.resolve?.(utils_1.ContainerRegistrationKeys.LOGGER, {
|
|
40
|
+
allowUnregistered: true,
|
|
41
|
+
}) ?? logger_1.logger;
|
|
33
42
|
}
|
|
34
43
|
/**
|
|
35
44
|
* Discover resources from the source directory
|
|
@@ -44,6 +53,7 @@ class ResourceLoader {
|
|
|
44
53
|
return (!entry.isDirectory() &&
|
|
45
54
|
parsedName.name !== "index" &&
|
|
46
55
|
!parsedName.base.endsWith(".d.ts") &&
|
|
56
|
+
!entry.parentPath.includes("__tests__") &&
|
|
47
57
|
[".js", ".ts"].includes(parsedName.ext) &&
|
|
48
58
|
!__classPrivateFieldGet(this, _ResourceLoader_excludes, "f").some((exclude) => exclude.test(parsedName.base)) &&
|
|
49
59
|
!exclude.some((exclude) => exclude.test(parsedName.base)));
|
|
@@ -56,13 +66,14 @@ class ResourceLoader {
|
|
|
56
66
|
await (0, promises_1.access)(sourcePath);
|
|
57
67
|
}
|
|
58
68
|
catch {
|
|
59
|
-
|
|
69
|
+
this.logger.info(`No ${this.resourceName} to load from ${sourcePath}. skipped.`);
|
|
60
70
|
return;
|
|
61
71
|
}
|
|
62
72
|
return await (0, utils_1.readDirRecursive)(sourcePath).then(async (entries) => {
|
|
63
|
-
const
|
|
73
|
+
const dirEntries = entries;
|
|
74
|
+
const fileEntries = dirEntries.filter((entry) => customFiltering(entry));
|
|
64
75
|
return await (0, utils_1.promiseAll)(fileEntries.map(async (entry) => {
|
|
65
|
-
const fullPath = (0, path_1.join)(
|
|
76
|
+
const fullPath = (0, path_1.join)(entry.parentPath, entry.name);
|
|
66
77
|
const module_ = await (0, utils_1.dynamicImport)(fullPath);
|
|
67
78
|
await this.onFileLoaded(fullPath, module_);
|
|
68
79
|
return module_;
|
|
@@ -70,7 +81,7 @@ class ResourceLoader {
|
|
|
70
81
|
});
|
|
71
82
|
});
|
|
72
83
|
const resources = await (0, utils_1.promiseAll)(promises);
|
|
73
|
-
return resources.flat();
|
|
84
|
+
return resources.flat().filter(Boolean);
|
|
74
85
|
}
|
|
75
86
|
}
|
|
76
87
|
exports.ResourceLoader = ResourceLoader;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resource-loader.js","sourceRoot":"","sources":["../../src/utils/resource-loader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"resource-loader.js","sourceRoot":"","sources":["../../src/utils/resource-loader.ts"],"names":[],"mappings":"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"}
|
package/dist/zod/index.d.ts
CHANGED
package/dist/zod/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/zod/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/zod/index.ts"],"names":[],"mappings":"AAAA,cAAc,KAAK,CAAA;AACnB,cAAc,eAAe,CAAA"}
|
package/dist/zod/index.js
CHANGED
|
@@ -14,5 +14,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("zod"), exports);
|
|
17
18
|
__exportStar(require("./zod-helpers"), exports);
|
|
18
19
|
//# sourceMappingURL=index.js.map
|
package/dist/zod/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/zod/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gDAA6B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/zod/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sCAAmB;AACnB,gDAA6B"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@etohq/framework",
|
|
3
|
-
"version": "1.5.1-alpha.
|
|
3
|
+
"version": "1.5.1-alpha.6",
|
|
4
4
|
"description": "Framework",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -33,7 +33,19 @@
|
|
|
33
33
|
"./workflows-sdk/composer": "./dist/workflows-sdk/composer.js",
|
|
34
34
|
"./modules-sdk": "./dist/modules-sdk/index.js",
|
|
35
35
|
"./link-modules-sdk": "./dist/link-modules-sdk/index.js",
|
|
36
|
-
"./migrations": "./dist/migrations/index.js"
|
|
36
|
+
"./migrations": "./dist/migrations/index.js",
|
|
37
|
+
"./zod": {
|
|
38
|
+
"types": "./src/zod/index.ts",
|
|
39
|
+
"default": "./dist/zod/index.js"
|
|
40
|
+
},
|
|
41
|
+
"./awilix": {
|
|
42
|
+
"types": "./src/deps/awilix.ts",
|
|
43
|
+
"default": "./dist/deps/awilix.js"
|
|
44
|
+
},
|
|
45
|
+
"./mikro-orm/core": "./dist/deps/mikro-orm-core.js",
|
|
46
|
+
"./mikro-orm/knex": "./dist/deps/mikro-orm-knex.js",
|
|
47
|
+
"./mikro-orm/migrations": "./dist/deps/mikro-orm-migrations.js",
|
|
48
|
+
"./mikro-orm/postgresql": "./dist/deps/mikro-orm-postgresql.js"
|
|
37
49
|
},
|
|
38
50
|
"engines": {
|
|
39
51
|
"node": ">=20"
|
|
@@ -89,12 +101,12 @@
|
|
|
89
101
|
"ulid": "2.3.0",
|
|
90
102
|
"stack-trace": "0.0.10",
|
|
91
103
|
"ora": "5.4.1",
|
|
92
|
-
"@etohq/
|
|
93
|
-
"@etohq/
|
|
94
|
-
"@etohq/
|
|
95
|
-
"@etohq/
|
|
96
|
-
"@etohq/
|
|
97
|
-
"@etohq/
|
|
104
|
+
"@etohq/link-modules-sdk": "1.5.1-alpha.5",
|
|
105
|
+
"@etohq/modules-sdk": "1.5.1-alpha.5",
|
|
106
|
+
"@etohq/orchestration": "1.5.1-alpha.5",
|
|
107
|
+
"@etohq/utils": "1.5.1-alpha.6",
|
|
108
|
+
"@etohq/types": "1.5.1-alpha.5",
|
|
109
|
+
"@etohq/workflows-sdk": "1.5.1-alpha.5"
|
|
98
110
|
},
|
|
99
111
|
"peerDependencies": {
|
|
100
112
|
"@mikro-orm/cli": "6.4.3",
|
|
@@ -106,7 +118,7 @@
|
|
|
106
118
|
"ioredis": "5.4.1",
|
|
107
119
|
"pg": "8.13.0",
|
|
108
120
|
"vite": "5.2.11",
|
|
109
|
-
"@etohq/cli": "1.5.1-alpha.
|
|
121
|
+
"@etohq/cli": "1.5.1-alpha.5"
|
|
110
122
|
},
|
|
111
123
|
"peerDependenciesMeta": {
|
|
112
124
|
"@mikro-orm/cli": {
|