@carlonicora/nestjs-neo4jsonapi 1.62.7 → 1.64.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/agents/agents.modules.d.ts.map +1 -1
- package/dist/agents/agents.modules.js +3 -0
- package/dist/agents/agents.modules.js.map +1 -1
- package/dist/agents/chatbot/chatbot.module.d.ts +3 -0
- package/dist/agents/chatbot/chatbot.module.d.ts.map +1 -0
- package/dist/agents/chatbot/chatbot.module.js +65 -0
- package/dist/agents/chatbot/chatbot.module.js.map +1 -0
- package/dist/agents/chatbot/interfaces/chatbot.response.interface.d.ts +25 -0
- package/dist/agents/chatbot/interfaces/chatbot.response.interface.d.ts.map +1 -0
- package/dist/agents/chatbot/interfaces/chatbot.response.interface.js +3 -0
- package/dist/agents/chatbot/interfaces/chatbot.response.interface.js.map +1 -0
- package/dist/agents/chatbot/interfaces/graph.catalog.interface.d.ts +50 -0
- package/dist/agents/chatbot/interfaces/graph.catalog.interface.d.ts.map +1 -0
- package/dist/agents/chatbot/interfaces/graph.catalog.interface.js +3 -0
- package/dist/agents/chatbot/interfaces/graph.catalog.interface.js.map +1 -0
- package/dist/agents/chatbot/prompts/chatbot.system.prompt.d.ts +3 -0
- package/dist/agents/chatbot/prompts/chatbot.system.prompt.d.ts.map +1 -0
- package/dist/agents/chatbot/prompts/chatbot.system.prompt.js +60 -0
- package/dist/agents/chatbot/prompts/chatbot.system.prompt.js.map +1 -0
- package/dist/agents/chatbot/repositories/user-modules.repository.d.ts +28 -0
- package/dist/agents/chatbot/repositories/user-modules.repository.d.ts.map +1 -0
- package/dist/agents/chatbot/repositories/user-modules.repository.js +76 -0
- package/dist/agents/chatbot/repositories/user-modules.repository.js.map +1 -0
- package/dist/agents/chatbot/services/chatbot.index.manager.d.ts +17 -0
- package/dist/agents/chatbot/services/chatbot.index.manager.d.ts.map +1 -0
- package/dist/agents/chatbot/services/chatbot.index.manager.js +84 -0
- package/dist/agents/chatbot/services/chatbot.index.manager.js.map +1 -0
- package/dist/agents/chatbot/services/chatbot.search.service.d.ts +46 -0
- package/dist/agents/chatbot/services/chatbot.search.service.d.ts.map +1 -0
- package/dist/agents/chatbot/services/chatbot.search.service.js +148 -0
- package/dist/agents/chatbot/services/chatbot.search.service.js.map +1 -0
- package/dist/agents/chatbot/services/chatbot.service.d.ts +36 -0
- package/dist/agents/chatbot/services/chatbot.service.d.ts.map +1 -0
- package/dist/agents/chatbot/services/chatbot.service.js +220 -0
- package/dist/agents/chatbot/services/chatbot.service.js.map +1 -0
- package/dist/agents/chatbot/services/descriptor.source.d.ts +18 -0
- package/dist/agents/chatbot/services/descriptor.source.d.ts.map +1 -0
- package/dist/agents/chatbot/services/descriptor.source.js +41 -0
- package/dist/agents/chatbot/services/descriptor.source.js.map +1 -0
- package/dist/agents/chatbot/services/field-formatting.d.ts +18 -0
- package/dist/agents/chatbot/services/field-formatting.d.ts.map +1 -0
- package/dist/agents/chatbot/services/field-formatting.js +43 -0
- package/dist/agents/chatbot/services/field-formatting.js.map +1 -0
- package/dist/agents/chatbot/services/graph.catalog.service.d.ts +60 -0
- package/dist/agents/chatbot/services/graph.catalog.service.d.ts.map +1 -0
- package/dist/agents/chatbot/services/graph.catalog.service.js +217 -0
- package/dist/agents/chatbot/services/graph.catalog.service.js.map +1 -0
- package/dist/agents/chatbot/services/humanize-tool.d.ts +9 -0
- package/dist/agents/chatbot/services/humanize-tool.d.ts.map +1 -0
- package/dist/agents/chatbot/services/humanize-tool.js +35 -0
- package/dist/agents/chatbot/services/humanize-tool.js.map +1 -0
- package/dist/agents/chatbot/tools/describe-entity.tool.d.ts +14 -0
- package/dist/agents/chatbot/tools/describe-entity.tool.d.ts.map +1 -0
- package/dist/agents/chatbot/tools/describe-entity.tool.js +63 -0
- package/dist/agents/chatbot/tools/describe-entity.tool.js.map +1 -0
- package/dist/agents/chatbot/tools/read-entity.tool.d.ts +16 -0
- package/dist/agents/chatbot/tools/read-entity.tool.d.ts.map +1 -0
- package/dist/agents/chatbot/tools/read-entity.tool.js +102 -0
- package/dist/agents/chatbot/tools/read-entity.tool.js.map +1 -0
- package/dist/agents/chatbot/tools/resolve-entity.tool.d.ts +16 -0
- package/dist/agents/chatbot/tools/resolve-entity.tool.d.ts.map +1 -0
- package/dist/agents/chatbot/tools/resolve-entity.tool.js +48 -0
- package/dist/agents/chatbot/tools/resolve-entity.tool.js.map +1 -0
- package/dist/agents/chatbot/tools/search-entities.tool.d.ts +20 -0
- package/dist/agents/chatbot/tools/search-entities.tool.d.ts.map +1 -0
- package/dist/agents/chatbot/tools/search-entities.tool.js +122 -0
- package/dist/agents/chatbot/tools/search-entities.tool.js.map +1 -0
- package/dist/agents/chatbot/tools/tool.factory.d.ts +29 -0
- package/dist/agents/chatbot/tools/tool.factory.d.ts.map +1 -0
- package/dist/agents/chatbot/tools/tool.factory.js +72 -0
- package/dist/agents/chatbot/tools/tool.factory.js.map +1 -0
- package/dist/agents/chatbot/tools/traverse.tool.d.ts +58 -0
- package/dist/agents/chatbot/tools/traverse.tool.d.ts.map +1 -0
- package/dist/agents/chatbot/tools/traverse.tool.js +212 -0
- package/dist/agents/chatbot/tools/traverse.tool.js.map +1 -0
- package/dist/agents/index.d.ts +9 -0
- package/dist/agents/index.d.ts.map +1 -1
- package/dist/agents/index.js +17 -1
- package/dist/agents/index.js.map +1 -1
- package/dist/bootstrap/bootstrap.options.d.ts +7 -0
- package/dist/bootstrap/bootstrap.options.d.ts.map +1 -1
- package/dist/common/helpers/define-entity.d.ts.map +1 -1
- package/dist/common/helpers/define-entity.js +5 -1
- package/dist/common/helpers/define-entity.js.map +1 -1
- package/dist/common/interfaces/datamodel.interface.d.ts +10 -0
- package/dist/common/interfaces/datamodel.interface.d.ts.map +1 -1
- package/dist/common/interfaces/datamodel.interface.js.map +1 -1
- package/dist/common/interfaces/entity.descriptor.interface.d.ts +1 -1
- package/dist/common/interfaces/entity.descriptor.interface.d.ts.map +1 -1
- package/dist/common/interfaces/entity.descriptor.interface.js.map +1 -1
- package/dist/common/interfaces/entity.schema.interface.d.ts +48 -0
- package/dist/common/interfaces/entity.schema.interface.d.ts.map +1 -1
- package/dist/common/registries/entity.service.registry.d.ts +13 -0
- package/dist/common/registries/entity.service.registry.d.ts.map +1 -0
- package/dist/common/registries/entity.service.registry.js +52 -0
- package/dist/common/registries/entity.service.registry.js.map +1 -0
- package/dist/common/registries/index.d.ts +1 -0
- package/dist/common/registries/index.d.ts.map +1 -1
- package/dist/common/registries/index.js +1 -0
- package/dist/common/registries/index.js.map +1 -1
- package/dist/core/core.module.d.ts.map +1 -1
- package/dist/core/core.module.js +6 -2
- package/dist/core/core.module.js.map +1 -1
- package/dist/core/llm/services/llm.service.d.ts.map +1 -1
- package/dist/core/llm/services/llm.service.js +8 -0
- package/dist/core/llm/services/llm.service.js.map +1 -1
- package/dist/core/neo4j/abstracts/abstract.repository.d.ts +48 -1
- package/dist/core/neo4j/abstracts/abstract.repository.d.ts.map +1 -1
- package/dist/core/neo4j/abstracts/abstract.repository.js +147 -9
- package/dist/core/neo4j/abstracts/abstract.repository.js.map +1 -1
- package/dist/core/neo4j/abstracts/abstract.service.d.ts +47 -0
- package/dist/core/neo4j/abstracts/abstract.service.d.ts.map +1 -1
- package/dist/core/neo4j/abstracts/abstract.service.js +57 -0
- package/dist/core/neo4j/abstracts/abstract.service.js.map +1 -1
- package/dist/core/neo4j/factories/entity.factory.d.ts.map +1 -1
- package/dist/core/neo4j/factories/entity.factory.js +27 -6
- package/dist/core/neo4j/factories/entity.factory.js.map +1 -1
- package/dist/core/neo4j/helpers/build-filter-clauses.d.ts +11 -0
- package/dist/core/neo4j/helpers/build-filter-clauses.d.ts.map +1 -0
- package/dist/core/neo4j/helpers/build-filter-clauses.js +69 -0
- package/dist/core/neo4j/helpers/build-filter-clauses.js.map +1 -0
- package/dist/core/neo4j/helpers/build-order-by.d.ts +6 -0
- package/dist/core/neo4j/helpers/build-order-by.d.ts.map +1 -0
- package/dist/core/neo4j/helpers/build-order-by.js +20 -0
- package/dist/core/neo4j/helpers/build-order-by.js.map +1 -0
- package/dist/core/neo4j/index.d.ts +1 -0
- package/dist/core/neo4j/index.d.ts.map +1 -1
- package/dist/core/neo4j/index.js +2 -0
- package/dist/core/neo4j/index.js.map +1 -1
- package/dist/core/neo4j/types/filter.criterion.d.ts +20 -0
- package/dist/core/neo4j/types/filter.criterion.d.ts.map +1 -0
- package/dist/core/neo4j/types/filter.criterion.js +3 -0
- package/dist/core/neo4j/types/filter.criterion.js.map +1 -0
- package/dist/core/neo4j/types/index.d.ts +2 -0
- package/dist/core/neo4j/types/index.d.ts.map +1 -0
- package/dist/core/neo4j/types/index.js +3 -0
- package/dist/core/neo4j/types/index.js.map +1 -0
- package/dist/foundations/assistant/assistant.module.d.ts +5 -0
- package/dist/foundations/assistant/assistant.module.d.ts.map +1 -0
- package/dist/foundations/assistant/assistant.module.js +32 -0
- package/dist/foundations/assistant/assistant.module.js.map +1 -0
- package/dist/foundations/assistant/controllers/assistant.controller.d.ts +67 -0
- package/dist/foundations/assistant/controllers/assistant.controller.d.ts.map +1 -0
- package/dist/foundations/assistant/controllers/assistant.controller.js +226 -0
- package/dist/foundations/assistant/controllers/assistant.controller.js.map +1 -0
- package/dist/foundations/assistant/dtos/assistant-append.dto.d.ts +11 -0
- package/dist/foundations/assistant/dtos/assistant-append.dto.d.ts.map +1 -0
- package/dist/foundations/assistant/dtos/assistant-append.dto.js +44 -0
- package/dist/foundations/assistant/dtos/assistant-append.dto.js.map +1 -0
- package/dist/foundations/assistant/dtos/assistant-patch.dto.d.ts +12 -0
- package/dist/foundations/assistant/dtos/assistant-patch.dto.d.ts.map +1 -0
- package/dist/foundations/assistant/dtos/assistant-patch.dto.js +52 -0
- package/dist/foundations/assistant/dtos/assistant-patch.dto.js.map +1 -0
- package/dist/foundations/assistant/dtos/assistant-post.dto.d.ts +12 -0
- package/dist/foundations/assistant/dtos/assistant-post.dto.d.ts.map +1 -0
- package/dist/foundations/assistant/dtos/assistant-post.dto.js +51 -0
- package/dist/foundations/assistant/dtos/assistant-post.dto.js.map +1 -0
- package/dist/foundations/assistant/entities/assistant.d.ts +48 -0
- package/dist/foundations/assistant/entities/assistant.d.ts.map +1 -0
- package/dist/foundations/assistant/entities/assistant.js +44 -0
- package/dist/foundations/assistant/entities/assistant.js.map +1 -0
- package/dist/foundations/assistant/entities/assistant.meta.d.ts +3 -0
- package/dist/foundations/assistant/entities/assistant.meta.d.ts.map +1 -0
- package/dist/foundations/assistant/entities/assistant.meta.js +10 -0
- package/dist/foundations/assistant/entities/assistant.meta.js.map +1 -0
- package/dist/foundations/assistant/index.d.ts +7 -0
- package/dist/foundations/assistant/index.d.ts.map +1 -0
- package/dist/foundations/assistant/index.js +12 -0
- package/dist/foundations/assistant/index.js.map +1 -0
- package/dist/foundations/assistant/repositories/assistant.repository.d.ts +50 -0
- package/dist/foundations/assistant/repositories/assistant.repository.d.ts.map +1 -0
- package/dist/foundations/assistant/repositories/assistant.repository.js +65 -0
- package/dist/foundations/assistant/repositories/assistant.repository.js.map +1 -0
- package/dist/foundations/assistant/services/assistant.service.d.ts +113 -0
- package/dist/foundations/assistant/services/assistant.service.d.ts.map +1 -0
- package/dist/foundations/assistant/services/assistant.service.js +395 -0
- package/dist/foundations/assistant/services/assistant.service.js.map +1 -0
- package/dist/foundations/assistant-message/assistant-message.module.d.ts +6 -0
- package/dist/foundations/assistant-message/assistant-message.module.d.ts.map +1 -0
- package/dist/foundations/assistant-message/assistant-message.module.js +36 -0
- package/dist/foundations/assistant-message/assistant-message.module.js.map +1 -0
- package/dist/foundations/assistant-message/controllers/assistant-message.controller.d.ts +16 -0
- package/dist/foundations/assistant-message/controllers/assistant-message.controller.d.ts.map +1 -0
- package/dist/foundations/assistant-message/controllers/assistant-message.controller.js +84 -0
- package/dist/foundations/assistant-message/controllers/assistant-message.controller.js.map +1 -0
- package/dist/foundations/assistant-message/dtos/assistant-message.dto.d.ts +11 -0
- package/dist/foundations/assistant-message/dtos/assistant-message.dto.d.ts.map +1 -0
- package/dist/foundations/assistant-message/dtos/assistant-message.dto.js +45 -0
- package/dist/foundations/assistant-message/dtos/assistant-message.dto.js.map +1 -0
- package/dist/foundations/assistant-message/entities/assistant-message.d.ts +49 -0
- package/dist/foundations/assistant-message/entities/assistant-message.d.ts.map +1 -0
- package/dist/foundations/assistant-message/entities/assistant-message.js +52 -0
- package/dist/foundations/assistant-message/entities/assistant-message.js.map +1 -0
- package/dist/foundations/assistant-message/entities/assistant-message.meta.d.ts +3 -0
- package/dist/foundations/assistant-message/entities/assistant-message.meta.d.ts.map +1 -0
- package/dist/foundations/assistant-message/entities/assistant-message.meta.js +10 -0
- package/dist/foundations/assistant-message/entities/assistant-message.meta.js.map +1 -0
- package/dist/foundations/assistant-message/index.d.ts +8 -0
- package/dist/foundations/assistant-message/index.d.ts.map +1 -0
- package/dist/foundations/assistant-message/index.js +24 -0
- package/dist/foundations/assistant-message/index.js.map +1 -0
- package/dist/foundations/assistant-message/repositories/assistant-message.repository.d.ts +70 -0
- package/dist/foundations/assistant-message/repositories/assistant-message.repository.d.ts.map +1 -0
- package/dist/foundations/assistant-message/repositories/assistant-message.repository.js +119 -0
- package/dist/foundations/assistant-message/repositories/assistant-message.repository.js.map +1 -0
- package/dist/foundations/assistant-message/services/assistant-message.service.d.ts +31 -0
- package/dist/foundations/assistant-message/services/assistant-message.service.d.ts.map +1 -0
- package/dist/foundations/assistant-message/services/assistant-message.service.js +32 -0
- package/dist/foundations/assistant-message/services/assistant-message.service.js.map +1 -0
- package/dist/foundations/foundations.modules.d.ts.map +1 -1
- package/dist/foundations/foundations.modules.js +2 -0
- package/dist/foundations/foundations.modules.js.map +1 -1
- package/dist/foundations/index.d.ts +2 -0
- package/dist/foundations/index.d.ts.map +1 -1
- package/dist/foundations/index.js +2 -0
- package/dist/foundations/index.js.map +1 -1
- package/dist/foundations/rbac/controllers/rbac-dev.controller.d.ts +50 -0
- package/dist/foundations/rbac/controllers/rbac-dev.controller.d.ts.map +1 -0
- package/dist/foundations/rbac/controllers/rbac-dev.controller.js +172 -0
- package/dist/foundations/rbac/controllers/rbac-dev.controller.js.map +1 -0
- package/dist/foundations/rbac/dsl/define-rbac.d.ts +15 -0
- package/dist/foundations/rbac/dsl/define-rbac.d.ts.map +1 -0
- package/dist/foundations/rbac/dsl/define-rbac.js +19 -0
- package/dist/foundations/rbac/dsl/define-rbac.js.map +1 -0
- package/dist/foundations/rbac/dsl/index.d.ts +6 -0
- package/dist/foundations/rbac/dsl/index.d.ts.map +1 -0
- package/dist/foundations/rbac/dsl/index.js +30 -0
- package/dist/foundations/rbac/dsl/index.js.map +1 -0
- package/dist/foundations/rbac/dsl/perm.d.ts +15 -0
- package/dist/foundations/rbac/dsl/perm.d.ts.map +1 -0
- package/dist/foundations/rbac/dsl/perm.js +24 -0
- package/dist/foundations/rbac/dsl/perm.js.map +1 -0
- package/dist/foundations/rbac/dsl/resolver.d.ts +24 -0
- package/dist/foundations/rbac/dsl/resolver.d.ts.map +1 -0
- package/dist/foundations/rbac/dsl/resolver.js +55 -0
- package/dist/foundations/rbac/dsl/resolver.js.map +1 -0
- package/dist/foundations/rbac/dsl/to-permissions-json.d.ts +13 -0
- package/dist/foundations/rbac/dsl/to-permissions-json.d.ts.map +1 -0
- package/dist/foundations/rbac/dsl/to-permissions-json.js +43 -0
- package/dist/foundations/rbac/dsl/to-permissions-json.js.map +1 -0
- package/dist/foundations/rbac/dsl/types.d.ts +55 -0
- package/dist/foundations/rbac/dsl/types.d.ts.map +1 -0
- package/dist/foundations/rbac/dsl/types.js +6 -0
- package/dist/foundations/rbac/dsl/types.js.map +1 -0
- package/dist/foundations/rbac/dump.d.ts +116 -0
- package/dist/foundations/rbac/dump.d.ts.map +1 -0
- package/dist/foundations/rbac/dump.js +154 -0
- package/dist/foundations/rbac/dump.js.map +1 -0
- package/dist/foundations/rbac/index.d.ts +6 -0
- package/dist/foundations/rbac/index.d.ts.map +1 -1
- package/dist/foundations/rbac/index.js +23 -1
- package/dist/foundations/rbac/index.js.map +1 -1
- package/dist/foundations/rbac/rbac.module.d.ts +4 -1
- package/dist/foundations/rbac/rbac.module.d.ts.map +1 -1
- package/dist/foundations/rbac/rbac.module.js +25 -11
- package/dist/foundations/rbac/rbac.module.js.map +1 -1
- package/dist/foundations/rbac/rbac.tokens.d.ts +11 -0
- package/dist/foundations/rbac/rbac.tokens.d.ts.map +1 -0
- package/dist/foundations/rbac/rbac.tokens.js +14 -0
- package/dist/foundations/rbac/rbac.tokens.js.map +1 -0
- package/dist/foundations/rbac/serializer/matrix-to-ts.d.ts +13 -0
- package/dist/foundations/rbac/serializer/matrix-to-ts.d.ts.map +1 -0
- package/dist/foundations/rbac/serializer/matrix-to-ts.js +74 -0
- package/dist/foundations/rbac/serializer/matrix-to-ts.js.map +1 -0
- package/dist/foundations/rbac/services/rbac-reconciler.service.d.ts +30 -0
- package/dist/foundations/rbac/services/rbac-reconciler.service.d.ts.map +1 -0
- package/dist/foundations/rbac/services/rbac-reconciler.service.js +192 -0
- package/dist/foundations/rbac/services/rbac-reconciler.service.js.map +1 -0
- package/dist/foundations/stripe/__tests__/mocks/stripe.mock.d.ts +62 -62
- package/dist/tools/generate-rbac-paths/index.js +24 -19
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rbac.module.js","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"rbac.module.js","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAuE;AACvE,mEAA+D;AAC/D,6FAAuF;AACvF,oEAAgE;AAChE,0DAAsD;AACtD,gFAA2E;AAC3E,+FAA0F;AAC1F,mFAA8E;AAC9E,qDAA2D;AAC3D,+CAAkD;AAElD,2EAAsE;AACtE,yGAA6F;AAGtF,IAAM,UAAU,kBAAhB,MAAM,UAAU;IACrB,MAAM,CAAC,QAAQ,CAAC,OAIf;QACC,MAAM,SAAS,GAAe;YAC5B,gCAAc;YACd,0BAAW;YACX,2DAA2B;YAC3B,+CAAqB;YACrB,IAAA,oDAAoB,EAAC,+CAAqB,CAAC;YAC3C;gBACE,OAAO,EAAE,wCAAuB;gBAChC,QAAQ,EAAE,OAAO,CAAC,eAAe;aAClC;YACD;gBACE,OAAO,EAAE,+BAAiB;gBAC1B,QAAQ,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI;aAC/B;SACF,CAAC;QAEF,MAAM,WAAW,GAAgB,CAAC,gCAAc,EAAE,wDAAyB,CAAC,CAAC;QAC7E,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,WAAW,CAAC,IAAI,CAAC,uCAAiB,CAAC,CAAC;QACtC,CAAC;QAED,OAAO;YACL,MAAM,EAAE,YAAU;YAClB,WAAW;YACX,SAAS;YACT,OAAO,EAAE,CAAC,0BAAW,CAAC;SACvB,CAAC;IACJ,CAAC;CACF,CAAA;AAlCY,gCAAU;qBAAV,UAAU;IADtB,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,UAAU,CAkCtB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DI token for the declarative RBAC matrix.
|
|
3
|
+
*
|
|
4
|
+
* Applications provide an `RbacMatrix` under this token; `RbacReconcilerService`
|
|
5
|
+
* reads it at bootstrap and reconciles Neo4j against it.
|
|
6
|
+
*
|
|
7
|
+
* Note: `MODULE_USER_PATHS_TOKEN` already lives in `rbac.constants.ts` — import
|
|
8
|
+
* it from there rather than duplicating it here.
|
|
9
|
+
*/
|
|
10
|
+
export declare const RBAC_MATRIX_TOKEN: unique symbol;
|
|
11
|
+
//# sourceMappingURL=rbac.tokens.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rbac.tokens.d.ts","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.tokens.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,eAAO,MAAM,iBAAiB,eAA8B,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RBAC_MATRIX_TOKEN = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* DI token for the declarative RBAC matrix.
|
|
6
|
+
*
|
|
7
|
+
* Applications provide an `RbacMatrix` under this token; `RbacReconcilerService`
|
|
8
|
+
* reads it at bootstrap and reconciles Neo4j against it.
|
|
9
|
+
*
|
|
10
|
+
* Note: `MODULE_USER_PATHS_TOKEN` already lives in `rbac.constants.ts` — import
|
|
11
|
+
* it from there rather than duplicating it here.
|
|
12
|
+
*/
|
|
13
|
+
exports.RBAC_MATRIX_TOKEN = Symbol("RBAC_MATRIX_TOKEN");
|
|
14
|
+
//# sourceMappingURL=rbac.tokens.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rbac.tokens.js","sourceRoot":"","sources":["../../../src/foundations/rbac/rbac.tokens.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;GAQG;AACU,QAAA,iBAAiB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { RbacMatrix } from "../dsl/types";
|
|
2
|
+
interface Options {
|
|
3
|
+
roleNames: Record<string, string>;
|
|
4
|
+
moduleNames: Record<string, string>;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Serialise an RbacMatrix to formatted TypeScript source.
|
|
8
|
+
* Deterministic: module and role keys are sorted by UUID; tokens are
|
|
9
|
+
* normalised per action.
|
|
10
|
+
*/
|
|
11
|
+
export declare function serializeMatrixToTs(matrix: RbacMatrix, opts: Options): Promise<string>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=matrix-to-ts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"matrix-to-ts.d.ts","sourceRoot":"","sources":["../../../../src/foundations/rbac/serializer/matrix-to-ts.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAa,MAAM,cAAc,CAAC;AAE1D,UAAU,OAAO;IACf,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAClC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACrC;AAED;;;;GAIG;AACH,wBAAsB,mBAAmB,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAmC5F"}
|
|
@@ -0,0 +1,74 @@
|
|
|
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.serializeMatrixToTs = serializeMatrixToTs;
|
|
7
|
+
// packages/nestjs-neo4jsonapi/src/foundations/rbac/serializer/matrix-to-ts.ts
|
|
8
|
+
const prettier_1 = __importDefault(require("prettier"));
|
|
9
|
+
/**
|
|
10
|
+
* Serialise an RbacMatrix to formatted TypeScript source.
|
|
11
|
+
* Deterministic: module and role keys are sorted by UUID; tokens are
|
|
12
|
+
* normalised per action.
|
|
13
|
+
*/
|
|
14
|
+
async function serializeMatrixToTs(matrix, opts) {
|
|
15
|
+
const moduleIds = Object.keys(matrix).sort();
|
|
16
|
+
const lines = [];
|
|
17
|
+
lines.push(`// Auto-maintained by the RBAC UI. Edit via \`pnpm dev\` + UI, or by hand.`);
|
|
18
|
+
lines.push(``);
|
|
19
|
+
lines.push(`import { RoleId, ModuleId } from "@neural-erp/shared";`);
|
|
20
|
+
lines.push(`import { perm, defineRbac } from "@carlonicora/nestjs-neo4jsonapi";`);
|
|
21
|
+
lines.push(`import { MODULE_USER_PATHS } from "../features/rbac/module-relationships.map";`);
|
|
22
|
+
lines.push(``);
|
|
23
|
+
lines.push(`export const rbac = defineRbac<typeof MODULE_USER_PATHS>({`);
|
|
24
|
+
for (const moduleId of moduleIds) {
|
|
25
|
+
const block = matrix[moduleId];
|
|
26
|
+
if (!block)
|
|
27
|
+
continue;
|
|
28
|
+
const moduleName = opts.moduleNames[moduleId];
|
|
29
|
+
if (!moduleName) {
|
|
30
|
+
throw new Error(`Unknown module UUID: ${moduleId}. Check module-id.map.json.`);
|
|
31
|
+
}
|
|
32
|
+
lines.push(` [ModuleId.${moduleName}]: {`);
|
|
33
|
+
lines.push(` default: ${renderTokens(block.default)},`);
|
|
34
|
+
const roleIds = Object.keys(block)
|
|
35
|
+
.filter((k) => k !== "default")
|
|
36
|
+
.sort();
|
|
37
|
+
for (const roleId of roleIds) {
|
|
38
|
+
const roleName = opts.roleNames[roleId];
|
|
39
|
+
if (!roleName)
|
|
40
|
+
throw new Error(`Unknown role UUID: ${roleId}`);
|
|
41
|
+
lines.push(` [RoleId.${roleName}]: ${renderTokens(block[roleId])},`);
|
|
42
|
+
}
|
|
43
|
+
lines.push(` },`);
|
|
44
|
+
}
|
|
45
|
+
lines.push(`});`);
|
|
46
|
+
lines.push(``);
|
|
47
|
+
const raw = lines.join("\n");
|
|
48
|
+
return prettier_1.default.format(raw, { parser: "typescript" });
|
|
49
|
+
}
|
|
50
|
+
function renderTokens(tokens) {
|
|
51
|
+
// `scope === false` has no emission (absence of a token is the "deny"
|
|
52
|
+
// semantics). Drop defensively before any shape-checking so malformed state
|
|
53
|
+
// never leaks to disk as `perm.X("false")`.
|
|
54
|
+
const valid = tokens.filter((t) => t.scope === true || (typeof t.scope === "string" && t.scope.length > 0));
|
|
55
|
+
// perm.full collapse
|
|
56
|
+
const isFull = valid.length === 4 && valid.every((t) => t.scope === true) && new Set(valid.map((t) => t.action)).size === 4;
|
|
57
|
+
if (isFull)
|
|
58
|
+
return "perm.full";
|
|
59
|
+
if (valid.length === 0)
|
|
60
|
+
return "[]";
|
|
61
|
+
// Render each token
|
|
62
|
+
const parts = [...valid]
|
|
63
|
+
.sort((a, b) => {
|
|
64
|
+
const order = { read: 0, create: 1, update: 2, delete: 3 };
|
|
65
|
+
return order[a.action] - order[b.action];
|
|
66
|
+
})
|
|
67
|
+
.map((t) => {
|
|
68
|
+
if (t.scope === true)
|
|
69
|
+
return `perm.${t.action}`;
|
|
70
|
+
return `perm.${t.action}("${t.scope}")`;
|
|
71
|
+
});
|
|
72
|
+
return `[${parts.join(", ")}]`;
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=matrix-to-ts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"matrix-to-ts.js","sourceRoot":"","sources":["../../../../src/foundations/rbac/serializer/matrix-to-ts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { OnApplicationBootstrap } from "@nestjs/common";
|
|
2
|
+
import { Neo4jService } from "../../../core/neo4j/services/neo4j.service";
|
|
3
|
+
import { AppLoggingService } from "../../../core/logging/services/logging.service";
|
|
4
|
+
import type { RbacMatrix } from "../dsl/types";
|
|
5
|
+
/**
|
|
6
|
+
* Applies the declared `RbacMatrix` to Neo4j at application bootstrap.
|
|
7
|
+
*
|
|
8
|
+
* Behaviour (per spec §6.3):
|
|
9
|
+
* - Administrator role is never written as an HAS_PERMISSIONS edge — the
|
|
10
|
+
* security layer short-circuits for it.
|
|
11
|
+
* - Module defaults are stored on `Module.permissions`.
|
|
12
|
+
* - Role-specific permissions are stored on `(Role)-[:HAS_PERMISSIONS]->(Module)`.
|
|
13
|
+
* - Deletions are scoped to modules declared in the matrix: edges for
|
|
14
|
+
* undeclared modules are left untouched.
|
|
15
|
+
* - Preflight aborts with a clear error if any referenced role or module is
|
|
16
|
+
* missing from the DB (seed migrations must run first).
|
|
17
|
+
*/
|
|
18
|
+
export declare class RbacReconcilerService implements OnApplicationBootstrap {
|
|
19
|
+
private readonly neo4j;
|
|
20
|
+
private readonly matrix;
|
|
21
|
+
private readonly logger;
|
|
22
|
+
constructor(neo4j: Neo4jService, matrix: RbacMatrix | null, logger: AppLoggingService);
|
|
23
|
+
onApplicationBootstrap(): Promise<void>;
|
|
24
|
+
private preflight;
|
|
25
|
+
private findMissing;
|
|
26
|
+
private readActualState;
|
|
27
|
+
private computeDiff;
|
|
28
|
+
private apply;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=rbac-reconciler.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rbac-reconciler.service.d.ts","sourceRoot":"","sources":["../../../../src/foundations/rbac/services/rbac-reconciler.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,MAAM,4CAA4C,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AAGnF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAe/C;;;;;;;;;;;;GAYG;AACH,qBACa,qBAAsB,YAAW,sBAAsB;IAEhE,OAAO,CAAC,QAAQ,CAAC,KAAK;IACiB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAC9D,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAFN,KAAK,EAAE,YAAY,EACoB,MAAM,EAAE,UAAU,GAAG,IAAI,EAChE,MAAM,EAAE,iBAAiB;IAGtC,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;YAsB/B,SAAS;YAyBT,WAAW;YAOX,eAAe;IAsB7B,OAAO,CAAC,WAAW;YAkEL,KAAK;CA4BpB"}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.RbacReconcilerService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const neo4j_service_1 = require("../../../core/neo4j/services/neo4j.service");
|
|
18
|
+
const logging_service_1 = require("../../../core/logging/services/logging.service");
|
|
19
|
+
const system_roles_1 = require("../../../common/constants/system.roles");
|
|
20
|
+
const rbac_tokens_1 = require("../rbac.tokens");
|
|
21
|
+
const resolver_1 = require("../dsl/resolver");
|
|
22
|
+
const ADMINISTRATOR_ID = system_roles_1.SystemRoles.Administrator;
|
|
23
|
+
/**
|
|
24
|
+
* Applies the declared `RbacMatrix` to Neo4j at application bootstrap.
|
|
25
|
+
*
|
|
26
|
+
* Behaviour (per spec §6.3):
|
|
27
|
+
* - Administrator role is never written as an HAS_PERMISSIONS edge — the
|
|
28
|
+
* security layer short-circuits for it.
|
|
29
|
+
* - Module defaults are stored on `Module.permissions`.
|
|
30
|
+
* - Role-specific permissions are stored on `(Role)-[:HAS_PERMISSIONS]->(Module)`.
|
|
31
|
+
* - Deletions are scoped to modules declared in the matrix: edges for
|
|
32
|
+
* undeclared modules are left untouched.
|
|
33
|
+
* - Preflight aborts with a clear error if any referenced role or module is
|
|
34
|
+
* missing from the DB (seed migrations must run first).
|
|
35
|
+
*/
|
|
36
|
+
let RbacReconcilerService = class RbacReconcilerService {
|
|
37
|
+
constructor(neo4j, matrix, logger) {
|
|
38
|
+
this.neo4j = neo4j;
|
|
39
|
+
this.matrix = matrix;
|
|
40
|
+
this.logger = logger;
|
|
41
|
+
}
|
|
42
|
+
async onApplicationBootstrap() {
|
|
43
|
+
if (!this.matrix) {
|
|
44
|
+
this.logger.log("RBAC reconciler: no matrix configured, skipping");
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
await this.preflight();
|
|
48
|
+
const actual = await this.readActualState();
|
|
49
|
+
const diff = this.computeDiff(actual);
|
|
50
|
+
if (diff.operations.length === 0) {
|
|
51
|
+
this.logger.log("RBAC reconcile: no changes");
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
await this.apply(diff.operations);
|
|
55
|
+
this.logger.log(`RBAC reconcile: ${diff.defaultsChanged} defaults changed, ${diff.edgesUpserted} edges upserted, ${diff.edgesRemoved} edges removed`);
|
|
56
|
+
}
|
|
57
|
+
async preflight() {
|
|
58
|
+
const moduleIds = new Set();
|
|
59
|
+
const roleIds = new Set();
|
|
60
|
+
for (const moduleId of (0, resolver_1.iterateDeclaredModules)(this.matrix)) {
|
|
61
|
+
moduleIds.add(moduleId);
|
|
62
|
+
}
|
|
63
|
+
for (const { roleId } of (0, resolver_1.iterateDeclaredEdges)(this.matrix)) {
|
|
64
|
+
if (roleId === ADMINISTRATOR_ID)
|
|
65
|
+
continue;
|
|
66
|
+
roleIds.add(roleId);
|
|
67
|
+
}
|
|
68
|
+
const missingRoles = await this.findMissing("Role", Array.from(roleIds));
|
|
69
|
+
const missingModules = await this.findMissing("Module", Array.from(moduleIds));
|
|
70
|
+
if (missingRoles.length > 0 || missingModules.length > 0) {
|
|
71
|
+
throw new Error(`RBAC reconcile aborted - referenced entities not found in DB. ` +
|
|
72
|
+
`Roles missing: ${missingRoles.join(", ") || "none"}. ` +
|
|
73
|
+
`Modules missing: ${missingModules.join(", ") || "none"}. ` +
|
|
74
|
+
`Apply seed migrations before declaring these in the matrix.`);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
async findMissing(label, ids) {
|
|
78
|
+
if (ids.length === 0)
|
|
79
|
+
return [];
|
|
80
|
+
const result = await this.neo4j.read(`MATCH (n:${label}) WHERE n.id IN $ids RETURN n.id AS id`, { ids });
|
|
81
|
+
const found = new Set(result.records.map((r) => r.get("id")));
|
|
82
|
+
return ids.filter((id) => !found.has(id));
|
|
83
|
+
}
|
|
84
|
+
async readActualState() {
|
|
85
|
+
const modulesResult = await this.neo4j.read(`MATCH (m:Module) RETURN m.id AS id, m.permissions AS permissions`, {});
|
|
86
|
+
const edgesResult = await this.neo4j.read(`MATCH (r:Role)-[p:HAS_PERMISSIONS]->(m:Module) RETURN r.id AS roleId, m.id AS moduleId, p.permissions AS permissions`, {});
|
|
87
|
+
const moduleDefaults = {};
|
|
88
|
+
for (const rec of modulesResult.records) {
|
|
89
|
+
moduleDefaults[rec.get("id")] = rec.get("permissions");
|
|
90
|
+
}
|
|
91
|
+
const edges = [];
|
|
92
|
+
for (const rec of edgesResult.records) {
|
|
93
|
+
edges.push({
|
|
94
|
+
roleId: rec.get("roleId"),
|
|
95
|
+
moduleId: rec.get("moduleId"),
|
|
96
|
+
permissions: rec.get("permissions"),
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
return { moduleDefaults, edges };
|
|
100
|
+
}
|
|
101
|
+
computeDiff(actual) {
|
|
102
|
+
const operations = [];
|
|
103
|
+
let defaultsChanged = 0;
|
|
104
|
+
let edgesUpserted = 0;
|
|
105
|
+
let edgesRemoved = 0;
|
|
106
|
+
const declaredModules = new Set(Array.from((0, resolver_1.iterateDeclaredModules)(this.matrix)));
|
|
107
|
+
const sortedModules = Array.from(declaredModules).sort();
|
|
108
|
+
// Defaults
|
|
109
|
+
for (const moduleId of sortedModules) {
|
|
110
|
+
const expected = (0, resolver_1.resolveDefault)(this.matrix, moduleId);
|
|
111
|
+
if (expected === undefined)
|
|
112
|
+
continue;
|
|
113
|
+
if (actual.moduleDefaults[moduleId] !== expected) {
|
|
114
|
+
operations.push({ kind: "setDefault", params: { moduleId, permissions: expected } });
|
|
115
|
+
defaultsChanged++;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
// Edges — expected (Administrator excluded)
|
|
119
|
+
const expectedEdgeKeys = new Set();
|
|
120
|
+
const sortedEdges = Array.from((0, resolver_1.iterateDeclaredEdges)(this.matrix))
|
|
121
|
+
.filter((e) => e.roleId !== ADMINISTRATOR_ID)
|
|
122
|
+
.sort((a, b) => (a.moduleId + a.roleId).localeCompare(b.moduleId + b.roleId));
|
|
123
|
+
const actualByKey = new Map();
|
|
124
|
+
for (const edge of actual.edges) {
|
|
125
|
+
actualByKey.set(`${edge.roleId}|${edge.moduleId}`, edge.permissions);
|
|
126
|
+
}
|
|
127
|
+
for (const { roleId, moduleId } of sortedEdges) {
|
|
128
|
+
const expected = (0, resolver_1.resolveForRole)(this.matrix, roleId, moduleId);
|
|
129
|
+
if (expected === undefined)
|
|
130
|
+
continue;
|
|
131
|
+
const key = `${roleId}|${moduleId}`;
|
|
132
|
+
expectedEdgeKeys.add(key);
|
|
133
|
+
if (actualByKey.get(key) !== expected) {
|
|
134
|
+
operations.push({
|
|
135
|
+
kind: "upsertEdge",
|
|
136
|
+
params: { roleId, moduleId, permissions: expected },
|
|
137
|
+
});
|
|
138
|
+
edgesUpserted++;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
// Edges — to delete (scoped to declared modules only; Administrator never managed)
|
|
142
|
+
for (const edge of actual.edges) {
|
|
143
|
+
if (!declaredModules.has(edge.moduleId))
|
|
144
|
+
continue;
|
|
145
|
+
if (edge.roleId === ADMINISTRATOR_ID)
|
|
146
|
+
continue;
|
|
147
|
+
const key = `${edge.roleId}|${edge.moduleId}`;
|
|
148
|
+
if (!expectedEdgeKeys.has(key)) {
|
|
149
|
+
operations.push({
|
|
150
|
+
kind: "deleteEdge",
|
|
151
|
+
params: { roleId: edge.roleId, moduleId: edge.moduleId },
|
|
152
|
+
});
|
|
153
|
+
edgesRemoved++;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
return { operations, defaultsChanged, edgesUpserted, edgesRemoved };
|
|
157
|
+
}
|
|
158
|
+
async apply(operations) {
|
|
159
|
+
const queries = operations.map((op) => {
|
|
160
|
+
if (op.kind === "setDefault") {
|
|
161
|
+
return {
|
|
162
|
+
query: `MATCH (m:Module {id: $moduleId}) SET m.permissions = $permissions`,
|
|
163
|
+
params: op.params,
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
if (op.kind === "upsertEdge") {
|
|
167
|
+
return {
|
|
168
|
+
query: `MATCH (role:Role {id: $roleId}) ` +
|
|
169
|
+
`MATCH (module:Module {id: $moduleId}) ` +
|
|
170
|
+
`MERGE (role)-[permissions:HAS_PERMISSIONS]->(module) ` +
|
|
171
|
+
`ON CREATE SET permissions.permissions = $permissions ` +
|
|
172
|
+
`ON MATCH SET permissions.permissions = $permissions`,
|
|
173
|
+
params: op.params,
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
// deleteEdge
|
|
177
|
+
return {
|
|
178
|
+
query: `MATCH (role:Role {id: $roleId})-[p:HAS_PERMISSIONS]->(module:Module {id: $moduleId}) DELETE p`,
|
|
179
|
+
params: op.params,
|
|
180
|
+
};
|
|
181
|
+
});
|
|
182
|
+
await this.neo4j.executeInTransaction(queries);
|
|
183
|
+
}
|
|
184
|
+
};
|
|
185
|
+
exports.RbacReconcilerService = RbacReconcilerService;
|
|
186
|
+
exports.RbacReconcilerService = RbacReconcilerService = __decorate([
|
|
187
|
+
(0, common_1.Injectable)(),
|
|
188
|
+
__param(1, (0, common_1.Optional)()),
|
|
189
|
+
__param(1, (0, common_1.Inject)(rbac_tokens_1.RBAC_MATRIX_TOKEN)),
|
|
190
|
+
__metadata("design:paramtypes", [neo4j_service_1.Neo4jService, Object, logging_service_1.AppLoggingService])
|
|
191
|
+
], RbacReconcilerService);
|
|
192
|
+
//# sourceMappingURL=rbac-reconciler.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rbac-reconciler.service.js","sourceRoot":"","sources":["../../../../src/foundations/rbac/services/rbac-reconciler.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,112 +6,112 @@
|
|
|
6
6
|
*/
|
|
7
7
|
export declare const createMockStripeClient: () => {
|
|
8
8
|
customers: {
|
|
9
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
10
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
11
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
12
|
-
del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
13
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
9
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
10
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
11
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
12
|
+
del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
13
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
14
14
|
};
|
|
15
15
|
subscriptions: {
|
|
16
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
17
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
18
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
19
|
-
cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
20
|
-
pause: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
21
|
-
resume: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
22
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
16
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
17
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
18
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
19
|
+
cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
20
|
+
pause: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
21
|
+
resume: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
22
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
23
23
|
};
|
|
24
24
|
products: {
|
|
25
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
26
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
27
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
28
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
25
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
26
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
27
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
28
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
29
29
|
};
|
|
30
30
|
prices: {
|
|
31
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
32
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
33
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
34
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
31
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
32
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
33
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
34
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
35
35
|
};
|
|
36
36
|
paymentIntents: {
|
|
37
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
38
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
39
|
-
confirm: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
40
|
-
cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
37
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
38
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
39
|
+
confirm: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
40
|
+
cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
41
41
|
};
|
|
42
42
|
setupIntents: {
|
|
43
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
44
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
43
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
44
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
45
45
|
};
|
|
46
46
|
paymentMethods: {
|
|
47
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
48
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
49
|
-
attach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
50
|
-
detach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
47
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
48
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
49
|
+
attach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
50
|
+
detach: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
51
51
|
};
|
|
52
52
|
invoices: {
|
|
53
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
54
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
55
|
-
pay: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
56
|
-
voidInvoice: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
57
|
-
retrieveUpcoming: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
58
|
-
createPreview: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
53
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
54
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
55
|
+
pay: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
56
|
+
voidInvoice: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
57
|
+
retrieveUpcoming: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
58
|
+
createPreview: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
59
59
|
};
|
|
60
60
|
billingPortal: {
|
|
61
61
|
sessions: {
|
|
62
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
62
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
63
63
|
};
|
|
64
64
|
};
|
|
65
65
|
webhooks: {
|
|
66
|
-
constructEvent: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
66
|
+
constructEvent: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
67
67
|
};
|
|
68
68
|
v2: {
|
|
69
69
|
billing: {
|
|
70
70
|
meterEvents: {
|
|
71
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
71
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
72
72
|
};
|
|
73
73
|
meterEventSummaries: {
|
|
74
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
74
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
75
75
|
};
|
|
76
76
|
};
|
|
77
77
|
};
|
|
78
78
|
billing: {
|
|
79
79
|
meters: {
|
|
80
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
81
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
82
|
-
listEventSummaries: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
80
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
81
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
82
|
+
listEventSummaries: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
83
83
|
};
|
|
84
84
|
};
|
|
85
85
|
coupons: {
|
|
86
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
87
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
88
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
89
|
-
del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
90
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
86
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
87
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
88
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
89
|
+
del: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
90
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
91
91
|
};
|
|
92
92
|
refunds: {
|
|
93
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
94
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
95
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
96
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
97
|
-
cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
93
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
94
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
95
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
96
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
97
|
+
cancel: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
98
98
|
};
|
|
99
99
|
taxRates: {
|
|
100
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
101
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
102
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
103
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
100
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
101
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
102
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
103
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
104
104
|
};
|
|
105
105
|
tax: {
|
|
106
106
|
calculations: {
|
|
107
|
-
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
107
|
+
create: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
108
108
|
};
|
|
109
109
|
};
|
|
110
110
|
disputes: {
|
|
111
|
-
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
112
|
-
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
113
|
-
close: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
114
|
-
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.
|
|
111
|
+
retrieve: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
112
|
+
update: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
113
|
+
close: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
114
|
+
list: import("vitest").Mock<import(".pnpm/@vitest+spy@4.1.5/node_modules/@vitest/spy", { with: { "resolution-mode": "import" } }).Procedure>;
|
|
115
115
|
};
|
|
116
116
|
};
|
|
117
117
|
/**
|