tadis-analyzer 2.4.0 → 2.4.2
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/build/src/app/code-pattern/main.d.ts +1 -0
- package/build/src/app/code-pattern/main.js +14 -0
- package/build/src/app/code-pattern/main.js.map +1 -0
- package/build/src/app/default/main.d.ts +1 -0
- package/build/src/app/default/main.js +15 -0
- package/build/src/app/default/main.js.map +1 -0
- package/build/src/app/error.d.ts +3 -0
- package/build/src/app/error.js +10 -0
- package/build/src/app/error.js.map +1 -0
- package/build/src/config/Config.module.d.ts +4 -0
- package/build/src/config/Config.module.js +28 -0
- package/build/src/config/Config.module.js.map +1 -0
- package/build/src/config/Config.service.d.ts +19 -0
- package/build/src/config/Config.service.js +105 -0
- package/build/src/config/Config.service.js.map +1 -0
- package/build/src/config/Config.service.test.d.ts +1 -0
- package/build/src/config/Config.service.test.js +33 -0
- package/build/src/config/Config.service.test.js.map +1 -0
- package/build/src/deprecated-modules/CommonTransformers.module.d.ts +5 -0
- package/build/src/deprecated-modules/CommonTransformers.module.js +34 -0
- package/build/src/deprecated-modules/CommonTransformers.module.js.map +1 -0
- package/build/src/deprecated-modules/Msa.module.d.ts +13 -0
- package/build/src/deprecated-modules/Msa.module.js +63 -0
- package/build/src/deprecated-modules/Msa.module.js.map +1 -0
- package/build/src/deprecated-modules/SourceCodeAnalysis.module.d.ts +6 -0
- package/build/src/deprecated-modules/SourceCodeAnalysis.module.js +60 -0
- package/build/src/deprecated-modules/SourceCodeAnalysis.module.js.map +1 -0
- package/build/src/git/Git.module.d.ts +5 -0
- package/build/src/git/Git.module.js +28 -0
- package/build/src/git/Git.module.js.map +1 -0
- package/build/src/git/GitStorage.controller.d.ts +17 -0
- package/build/src/git/GitStorage.controller.js +88 -0
- package/build/src/git/GitStorage.controller.js.map +1 -0
- package/build/src/git/GitStorage.controller.test.d.ts +1 -0
- package/build/src/git/GitStorage.controller.test.js +30 -0
- package/build/src/git/GitStorage.controller.test.js.map +1 -0
- package/build/src/git/GitStorage.d.ts +23 -0
- package/build/src/git/GitStorage.js +153 -0
- package/build/src/git/GitStorage.js.map +1 -0
- package/build/src/git/GitStorage.service.d.ts +10 -0
- package/build/src/git/GitStorage.service.js +36 -0
- package/build/src/git/GitStorage.service.js.map +1 -0
- package/build/src/git/SourceLocationDecorator.d.ts +12 -0
- package/build/src/git/SourceLocationDecorator.js +46 -0
- package/build/src/git/SourceLocationDecorator.js.map +1 -0
- package/build/src/git/SourceLocationDecorator.test.d.ts +1 -0
- package/build/src/git/SourceLocationDecorator.test.js +35 -0
- package/build/src/git/SourceLocationDecorator.test.js.map +1 -0
- package/build/src/lib.d.ts +21 -0
- package/build/src/lib.js +57 -0
- package/build/src/lib.js.map +1 -0
- package/build/src/model/core-typed.d.ts +21 -0
- package/build/src/model/core-typed.js +89 -0
- package/build/src/model/core-typed.js.map +1 -0
- package/build/src/model/core-typed.test.d.ts +1 -0
- package/build/src/model/core-typed.test.js +29 -0
- package/build/src/model/core-typed.test.js.map +1 -0
- package/build/src/model/core.d.ts +33 -0
- package/build/src/model/core.js +117 -0
- package/build/src/model/core.js.map +1 -0
- package/build/src/model/ms.d.ts +58 -0
- package/build/src/model/ms.js +83 -0
- package/build/src/model/ms.js.map +1 -0
- package/build/src/model/transport.d.ts +17 -0
- package/build/src/model/transport.js +20 -0
- package/build/src/model/transport.js.map +1 -0
- package/build/src/model/v1-legacy/model.d.ts +53 -0
- package/build/src/model/v1-legacy/model.js +85 -0
- package/build/src/model/v1-legacy/model.js.map +1 -0
- package/build/src/model/v1-legacy/v1-adapter.d.ts +3 -0
- package/build/src/model/v1-legacy/v1-adapter.js +68 -0
- package/build/src/model/v1-legacy/v1-adapter.js.map +1 -0
- package/build/src/model/v1-legacy/v1-adapter.test.d.ts +1 -0
- package/build/src/model/v1-legacy/v1-adapter.test.js +66 -0
- package/build/src/model/v1-legacy/v1-adapter.test.js.map +1 -0
- package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.d.ts +12 -0
- package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.js +107 -0
- package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.js.map +1 -0
- package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.d.ts +1 -0
- package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.js +111 -0
- package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.js.map +1 -0
- package/build/src/post-processors/PostProcessors.module.d.ts +6 -0
- package/build/src/post-processors/PostProcessors.module.js +37 -0
- package/build/src/post-processors/PostProcessors.module.js.map +1 -0
- package/build/src/post-processors/PostProcessors.module.test.d.ts +1 -0
- package/build/src/post-processors/PostProcessors.module.test.js +23 -0
- package/build/src/post-processors/PostProcessors.module.test.js.map +1 -0
- package/build/src/post-processors/StaticNodeFilter.d.ts +9 -0
- package/build/src/post-processors/StaticNodeFilter.js +91 -0
- package/build/src/post-processors/StaticNodeFilter.js.map +1 -0
- package/build/src/post-processors/StaticNodeFilter.test.d.ts +1 -0
- package/build/src/post-processors/StaticNodeFilter.test.js +36 -0
- package/build/src/post-processors/StaticNodeFilter.test.js.map +1 -0
- package/build/src/post-processors/SubSystemFromPayloadTransformer.d.ts +13 -0
- package/build/src/post-processors/SubSystemFromPayloadTransformer.js +103 -0
- package/build/src/post-processors/SubSystemFromPayloadTransformer.js.map +1 -0
- package/build/src/post-processors/SubSystemFromPayloadTransformer.test.d.ts +1 -0
- package/build/src/post-processors/SubSystemFromPayloadTransformer.test.js +56 -0
- package/build/src/post-processors/SubSystemFromPayloadTransformer.test.js.map +1 -0
- package/build/src/system-assemblers/controllers/ISystemAssembler.d.ts +5 -0
- package/build/src/system-assemblers/controllers/ISystemAssembler.js +3 -0
- package/build/src/system-assemblers/controllers/ISystemAssembler.js.map +1 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.controller.d.ts +19 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.controller.js +95 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.controller.js.map +1 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.controller.test.d.ts +1 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.controller.test.js +54 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.controller.test.js.map +1 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.module.d.ts +6 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.module.js +28 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.module.js.map +1 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.service.d.ts +6 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.service.js +24 -0
- package/build/src/system-assemblers/controllers/SystemAssembler.service.js.map +1 -0
- package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.d.ts +4 -0
- package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.js +46 -0
- package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.js.map +1 -0
- package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.d.ts +16 -0
- package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.js +53 -0
- package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.js.map +1 -0
- package/build/src/system-element-extractors/env-variables/EnvVariables.module.d.ts +4 -0
- package/build/src/system-element-extractors/env-variables/EnvVariables.module.js +25 -0
- package/build/src/system-element-extractors/env-variables/EnvVariables.module.js.map +1 -0
- package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.d.ts +13 -0
- package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.js +64 -0
- package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.js.map +1 -0
- package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.d.ts +1 -0
- package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.js +56 -0
- package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/CodePattern.module.d.ts +4 -0
- package/build/src/system-element-extractors/experimental/code-pattern/CodePattern.module.js +26 -0
- package/build/src/system-element-extractors/experimental/code-pattern/CodePattern.module.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.controller.d.ts +8 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.controller.js +54 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.controller.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.d.ts +10 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.js +345 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.multiFile.test.d.ts +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.multiFile.test.js +130 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.multiFile.test.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.service.d.ts +16 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.service.js +47 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.service.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.singleFile.test.d.ts +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.singleFile.test.js +177 -0
- package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.singleFile.test.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/behavior-model.d.ts +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/behavior-model.js +3 -0
- package/build/src/system-element-extractors/experimental/code-pattern/behavior-model.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/model.d.ts +116 -0
- package/build/src/system-element-extractors/experimental/code-pattern/model.js +23 -0
- package/build/src/system-element-extractors/experimental/code-pattern/model.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/prototyping/pattern-dsl.d.ts +8 -0
- package/build/src/system-element-extractors/experimental/code-pattern/prototyping/pattern-dsl.js +26 -0
- package/build/src/system-element-extractors/experimental/code-pattern/prototyping/pattern-dsl.js.map +1 -0
- package/build/src/system-element-extractors/experimental/code-pattern/prototyping/regexp-test.d.ts +0 -0
- package/build/src/system-element-extractors/experimental/code-pattern/prototyping/regexp-test.js +18 -0
- package/build/src/system-element-extractors/experimental/code-pattern/prototyping/regexp-test.js.map +1 -0
- package/build/src/system-element-extractors/java/Java.module.d.ts +4 -0
- package/build/src/system-element-extractors/java/Java.module.js +26 -0
- package/build/src/system-element-extractors/java/Java.module.js.map +1 -0
- package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.d.ts +35 -0
- package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.js +155 -0
- package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.js.map +1 -0
- package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.test.d.ts +1 -0
- package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.test.js +85 -0
- package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.test.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/Kubernetes.module.d.ts +7 -0
- package/build/src/system-element-extractors/kubernetes/Kubernetes.module.js +43 -0
- package/build/src/system-element-extractors/kubernetes/Kubernetes.module.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/api/api.service.d.ts +9 -0
- package/build/src/system-element-extractors/kubernetes/api/api.service.js +78 -0
- package/build/src/system-element-extractors/kubernetes/api/api.service.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.d.ts +10 -0
- package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.js +80 -0
- package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.test.d.ts +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.test.js +32 -0
- package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.test.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.d.ts +12 -0
- package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.js +82 -0
- package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.test.d.ts +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.test.js +30 -0
- package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.test.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.d.ts +12 -0
- package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.js +67 -0
- package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.test.d.ts +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.test.js +38 -0
- package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.test.js.map +1 -0
- package/build/src/system-element-extractors/kubernetes/transformer/testdata/api/deployments.json +256 -0
- package/build/src/system-element-extractors/kubernetes/transformer/testdata/api/pods.json +101 -0
- package/build/src/system-element-extractors/kubernetes/transformer/testdata/api/services.json +75 -0
- package/build/src/system-element-extractors/rabbitmq/RabbitMq.module.d.ts +6 -0
- package/build/src/system-element-extractors/rabbitmq/RabbitMq.module.js +38 -0
- package/build/src/system-element-extractors/rabbitmq/RabbitMq.module.js.map +1 -0
- package/build/src/system-element-extractors/rabbitmq/api/api.service.d.ts +11 -0
- package/build/src/system-element-extractors/rabbitmq/api/api.service.js +63 -0
- package/build/src/system-element-extractors/rabbitmq/api/api.service.js.map +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.d.ts +9 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.js +117 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.js.map +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.test.d.ts +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.test.js +43 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.test.js.map +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.d.ts +14 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.js +117 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.js.map +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.test.d.ts +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.test.js +121 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.test.js.map +1 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/testdata/api/bindings.json +20 -0
- package/build/src/system-element-extractors/rabbitmq/transformer/testdata/api/queues.json +5 -0
- package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.d.ts +15 -0
- package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.js +131 -0
- package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.js.map +1 -0
- package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.test.d.ts +1 -0
- package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.test.js +54 -0
- package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.test.js.map +1 -0
- package/build/src/system-element-extractors/spring-boot/SpringBoot.module.d.ts +4 -0
- package/build/src/system-element-extractors/spring-boot/SpringBoot.module.js +25 -0
- package/build/src/system-element-extractors/spring-boot/SpringBoot.module.js.map +1 -0
- package/build/src/test/expect-extensions.d.ts +7 -0
- package/build/src/test/expect-extensions.js +20 -0
- package/build/src/test/expect-extensions.js.map +1 -0
- package/build/src/test/verifiers.d.ts +4 -0
- package/build/src/test/verifiers.js +19 -0
- package/build/src/test/verifiers.js.map +1 -0
- package/build/src/utils/files/analysis.d.ts +30 -0
- package/build/src/utils/files/analysis.js +109 -0
- package/build/src/utils/files/analysis.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const CommonTransformers_module_1 = require("../deprecated-modules/CommonTransformers.module");
|
|
4
|
+
const ms_1 = require("../model/ms");
|
|
5
|
+
const core_1 = require("../model/core");
|
|
6
|
+
jest.mock('../config/Config.service');
|
|
7
|
+
describe(CommonTransformers_module_1.SubSystemFromPayloadTransformer.name, () => {
|
|
8
|
+
it('moves each microservice which defines a cabinet label to its sub-system', async () => {
|
|
9
|
+
const inputSystem = new ms_1.System('system');
|
|
10
|
+
const serviceA = inputSystem.addMicroService('A');
|
|
11
|
+
serviceA.getPayload().labels = { cabinet: 'X' };
|
|
12
|
+
const serviceB = inputSystem.addMicroService('B');
|
|
13
|
+
const transformer = new CommonTransformers_module_1.SubSystemFromPayloadTransformer();
|
|
14
|
+
const system = await transformer.transform(inputSystem, CommonTransformers_module_1.SubSystemFromPayloadTransformer.getSubSystemNameFromCabinetLabel);
|
|
15
|
+
expect(system.nodes).toHaveLength(2);
|
|
16
|
+
expect(system.nodes[0].content.payload.name).toEqual('X');
|
|
17
|
+
expect(system.nodes[0].content.type).toEqual('System');
|
|
18
|
+
expect(system.nodes[0].nodes).toHaveLength(1);
|
|
19
|
+
expect(system.nodes[0].nodes[0].content.payload.name).toEqual('A');
|
|
20
|
+
expect(system.nodes[1].content.payload.name).toEqual('B');
|
|
21
|
+
});
|
|
22
|
+
it('moves edges that connect nodes of the same cabinet to this cabinet', async () => {
|
|
23
|
+
const inputSystem = new ms_1.System('system');
|
|
24
|
+
const serviceA = inputSystem.addMicroService('A');
|
|
25
|
+
serviceA.getPayload().labels = { cabinet: 'X' };
|
|
26
|
+
const serviceC = inputSystem.addMicroService('C');
|
|
27
|
+
serviceC.getPayload().labels = { cabinet: 'X' };
|
|
28
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceA, serviceC));
|
|
29
|
+
const transformer = new CommonTransformers_module_1.SubSystemFromPayloadTransformer();
|
|
30
|
+
const system = await transformer.transform(inputSystem, CommonTransformers_module_1.SubSystemFromPayloadTransformer.getSubSystemNameFromCabinetLabel);
|
|
31
|
+
expect(system.edges).toHaveLength(0);
|
|
32
|
+
const cabinetX = system.findTypedNodeWithName(ms_1.System, 'X');
|
|
33
|
+
expect(cabinetX.edges).toHaveLength(1);
|
|
34
|
+
expect(cabinetX.edges[0].source.id).toEqual(serviceA.id);
|
|
35
|
+
expect(cabinetX.edges[0].target.id).toEqual(serviceC.id);
|
|
36
|
+
});
|
|
37
|
+
it('moves outgoing nodes of microservices contained in a cabinet to the cabinet', async () => {
|
|
38
|
+
const inputSystem = new ms_1.System('system');
|
|
39
|
+
const nodeA = new core_1.Node('A', new core_1.Content('T', undefined, { name: 'A' }));
|
|
40
|
+
inputSystem.nodes.push(nodeA);
|
|
41
|
+
const serviceB = inputSystem.addMicroService('B');
|
|
42
|
+
serviceB.getPayload().labels = { cabinet: 'X' };
|
|
43
|
+
const nodeC = new core_1.Node('C', new core_1.Content('T', undefined, { name: 'C' }));
|
|
44
|
+
inputSystem.nodes.push(nodeC);
|
|
45
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(nodeA, serviceB));
|
|
46
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceB, nodeC));
|
|
47
|
+
const transformer = new CommonTransformers_module_1.SubSystemFromPayloadTransformer();
|
|
48
|
+
const system = await transformer.transform(inputSystem, CommonTransformers_module_1.SubSystemFromPayloadTransformer.getSubSystemNameFromCabinetLabel);
|
|
49
|
+
expect(system.findNodeOfTypeWithName('T', 'A')).toBeDefined();
|
|
50
|
+
const cabinetX = system.nodes.find((node) => node.getName() === 'X');
|
|
51
|
+
expect(cabinetX.nodes.find((node) => node.getName() === 'C'));
|
|
52
|
+
expect(cabinetX.edges[0].source.id).toEqual(serviceB.id);
|
|
53
|
+
expect(cabinetX.edges[0].target.id).toEqual(nodeC.id);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=SubSystemFromPayloadTransformer.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubSystemFromPayloadTransformer.test.js","sourceRoot":"","sources":["../../../src/post-processors/SubSystemFromPayloadTransformer.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ISystemAssembler.js","sourceRoot":"","sources":["../../../../src/system-assemblers/controllers/ISystemAssembler.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { GitStorageService } from '../../git/GitStorage.service';
|
|
2
|
+
import { SystemAssembler } from './SystemAssembler.service';
|
|
3
|
+
export declare class SystemAssemblerController {
|
|
4
|
+
private readonly assembler;
|
|
5
|
+
private readonly gitStorage;
|
|
6
|
+
private readonly logger;
|
|
7
|
+
constructor(assembler: SystemAssembler, gitStorage: GitStorageService);
|
|
8
|
+
/**
|
|
9
|
+
* @deprecated use GET /system
|
|
10
|
+
*/
|
|
11
|
+
getSystemDeprecated(version: string): Promise<any>;
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated use GET /system/import_source
|
|
14
|
+
*/
|
|
15
|
+
importSourceDeprecated(): Promise<string>;
|
|
16
|
+
getSystem(version: string): Promise<any>;
|
|
17
|
+
importSource(): Promise<string>;
|
|
18
|
+
importSourceInBackground(): Promise<void>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,95 @@
|
|
|
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
|
+
var SystemAssemblerController_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.SystemAssemblerController = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const GitStorage_service_1 = require("../../git/GitStorage.service");
|
|
19
|
+
const v1_adapter_1 = require("../../model/v1-legacy/v1-adapter");
|
|
20
|
+
const transport_1 = require("../../model/transport");
|
|
21
|
+
const SystemAssembler_service_1 = require("./SystemAssembler.service");
|
|
22
|
+
let SystemAssemblerController = SystemAssemblerController_1 = class SystemAssemblerController {
|
|
23
|
+
constructor(assembler, gitStorage) {
|
|
24
|
+
this.assembler = assembler;
|
|
25
|
+
this.gitStorage = gitStorage;
|
|
26
|
+
this.logger = new common_1.Logger(SystemAssemblerController_1.name);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* @deprecated use GET /system
|
|
30
|
+
*/
|
|
31
|
+
async getSystemDeprecated(version) {
|
|
32
|
+
return this.getSystem(version);
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* @deprecated use GET /system/import_source
|
|
36
|
+
*/
|
|
37
|
+
async importSourceDeprecated() {
|
|
38
|
+
return this.importSource();
|
|
39
|
+
}
|
|
40
|
+
async getSystem(version) {
|
|
41
|
+
const system = await this.assembler.getSystem();
|
|
42
|
+
if (version === '1') {
|
|
43
|
+
return (0, v1_adapter_1.adaptToV1)(system);
|
|
44
|
+
}
|
|
45
|
+
return (0, transport_1.convertCoreToTransportNode)(system);
|
|
46
|
+
}
|
|
47
|
+
async importSource() {
|
|
48
|
+
// tslint:disable-next-line: no-floating-promises
|
|
49
|
+
this.importSourceInBackground();
|
|
50
|
+
return 'started storing in background ...';
|
|
51
|
+
}
|
|
52
|
+
async importSourceInBackground() {
|
|
53
|
+
var _a;
|
|
54
|
+
const microservices = await this.assembler.getAllMicroservices();
|
|
55
|
+
for (const microservice of microservices) {
|
|
56
|
+
// TODO: this could be faster when we let store be executed in parallel until a certain limit is reached.
|
|
57
|
+
// see https://stackoverflow.com/questions/53144401/limit-the-number-of-concurrent-child-processes-spawned-in-a-loop-in-node-js
|
|
58
|
+
await this.gitStorage.storeRepository(microservice.getName(), (_a = microservice.getPayload().labels) === null || _a === void 0 ? void 0 : _a.repositoryName);
|
|
59
|
+
}
|
|
60
|
+
this.logger.log('finished storing system source');
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
__decorate([
|
|
64
|
+
(0, common_1.Get)('collect/system'),
|
|
65
|
+
__param(0, (0, common_1.Query)('version')),
|
|
66
|
+
__metadata("design:type", Function),
|
|
67
|
+
__metadata("design:paramtypes", [String]),
|
|
68
|
+
__metadata("design:returntype", Promise)
|
|
69
|
+
], SystemAssemblerController.prototype, "getSystemDeprecated", null);
|
|
70
|
+
__decorate([
|
|
71
|
+
(0, common_1.Get)('collect/source'),
|
|
72
|
+
__metadata("design:type", Function),
|
|
73
|
+
__metadata("design:paramtypes", []),
|
|
74
|
+
__metadata("design:returntype", Promise)
|
|
75
|
+
], SystemAssemblerController.prototype, "importSourceDeprecated", null);
|
|
76
|
+
__decorate([
|
|
77
|
+
(0, common_1.Get)('system'),
|
|
78
|
+
__param(0, (0, common_1.Query)('version')),
|
|
79
|
+
__metadata("design:type", Function),
|
|
80
|
+
__metadata("design:paramtypes", [String]),
|
|
81
|
+
__metadata("design:returntype", Promise)
|
|
82
|
+
], SystemAssemblerController.prototype, "getSystem", null);
|
|
83
|
+
__decorate([
|
|
84
|
+
(0, common_1.Get)('system/import_source'),
|
|
85
|
+
__metadata("design:type", Function),
|
|
86
|
+
__metadata("design:paramtypes", []),
|
|
87
|
+
__metadata("design:returntype", Promise)
|
|
88
|
+
], SystemAssemblerController.prototype, "importSource", null);
|
|
89
|
+
SystemAssemblerController = SystemAssemblerController_1 = __decorate([
|
|
90
|
+
(0, common_1.Controller)(),
|
|
91
|
+
__metadata("design:paramtypes", [SystemAssembler_service_1.SystemAssembler,
|
|
92
|
+
GitStorage_service_1.GitStorageService])
|
|
93
|
+
], SystemAssemblerController);
|
|
94
|
+
exports.SystemAssemblerController = SystemAssemblerController;
|
|
95
|
+
//# sourceMappingURL=SystemAssembler.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SystemAssembler.controller.js","sourceRoot":"","sources":["../../../../src/system-assemblers/controllers/SystemAssembler.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA+D;AAE/D,qEAAgE;AAEhE,iEAA4D;AAC5D,qDAAkE;AAClE,uEAA2D;AAGpD,IAAM,yBAAyB,iCAA/B,MAAM,yBAAyB;IAGpC,YACmB,SAA0B,EAC1B,UAA6B;QAD7B,cAAS,GAAT,SAAS,CAAiB;QAC1B,eAAU,GAAV,UAAU,CAAmB;QAJ/B,WAAM,GAAG,IAAI,eAAM,CAAC,2BAAyB,CAAC,IAAI,CAAC,CAAA;IAKjE,CAAC;IAEJ;;OAEG;IAEG,AAAN,KAAK,CAAC,mBAAmB,CAAmB,OAAe;QACzD,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;IAChC,CAAC;IAED;;OAEG;IAEG,AAAN,KAAK,CAAC,sBAAsB;QAC1B,OAAO,IAAI,CAAC,YAAY,EAAE,CAAA;IAC5B,CAAC;IAGK,AAAN,KAAK,CAAC,SAAS,CAAmB,OAAe;QAC/C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,CAAA;QAE/C,IAAI,OAAO,KAAK,GAAG,EAAE;YACnB,OAAO,IAAA,sBAAS,EAAC,MAAM,CAAC,CAAA;SACzB;QAED,OAAO,IAAA,sCAA0B,EAAC,MAAM,CAAC,CAAA;IAC3C,CAAC;IAGK,AAAN,KAAK,CAAC,YAAY;QAChB,iDAAiD;QACjD,IAAI,CAAC,wBAAwB,EAAE,CAAA;QAC/B,OAAO,mCAAmC,CAAA;IAC5C,CAAC;IAED,KAAK,CAAC,wBAAwB;;QAC5B,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,mBAAmB,EAAE,CAAA;QAChE,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE;YACxC,yGAAyG;YACzG,+HAA+H;YAC/H,MAAM,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,YAAY,CAAC,OAAO,EAAE,EAC1D,MAAA,YAAY,CAAC,UAAU,EAAE,CAAC,MAAM,0CAAE,cAAc,CAAC,CAAA;SACpD;QACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,gCAAgC,CAAC,CAAA;IACnD,CAAC;CACF,CAAA;AAxCO;IADL,IAAA,YAAG,EAAC,gBAAgB,CAAC;IACK,WAAA,IAAA,cAAK,EAAC,SAAS,CAAC,CAAA;;;;oEAE1C;AAMK;IADL,IAAA,YAAG,EAAC,gBAAgB,CAAC;;;;uEAGrB;AAGK;IADL,IAAA,YAAG,EAAC,QAAQ,CAAC;IACG,WAAA,IAAA,cAAK,EAAC,SAAS,CAAC,CAAA;;;;0DAQhC;AAGK;IADL,IAAA,YAAG,EAAC,sBAAsB,CAAC;;;;6DAK3B;AAxCU,yBAAyB;IADrC,IAAA,mBAAU,GAAE;qCAKmB,yCAAe;QACd,sCAAiB;GALrC,yBAAyB,CAoDrC;AApDY,8DAAyB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,54 @@
|
|
|
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
|
+
const testing_1 = require("@nestjs/testing");
|
|
7
|
+
const supertest_1 = __importDefault(require("supertest"));
|
|
8
|
+
const ms_1 = require("../../model/ms");
|
|
9
|
+
const SystemAssembler_controller_1 = require("./SystemAssembler.controller");
|
|
10
|
+
const SystemAssembler_service_1 = require("./SystemAssembler.service");
|
|
11
|
+
const SystemAssembler_module_1 = require("./SystemAssembler.module");
|
|
12
|
+
describe(SystemAssembler_controller_1.SystemAssemblerController.name, () => {
|
|
13
|
+
let app;
|
|
14
|
+
beforeAll(async () => {
|
|
15
|
+
const testingModule = await testing_1.Test.createTestingModule({
|
|
16
|
+
imports: [SystemAssembler_module_1.SystemAssemblerModule]
|
|
17
|
+
}).compile();
|
|
18
|
+
app = testingModule.createNestApplication();
|
|
19
|
+
await app.init();
|
|
20
|
+
});
|
|
21
|
+
it('collects the system and provides it with the transport model', async () => {
|
|
22
|
+
const system = new ms_1.System('test');
|
|
23
|
+
const serviceA = system.addMicroService('A');
|
|
24
|
+
const serviceB = system.addMicroService('B');
|
|
25
|
+
system.edges.push(new ms_1.SyncDataFlow(serviceA, serviceB));
|
|
26
|
+
const orchestrator = app.get(SystemAssembler_service_1.SystemAssembler);
|
|
27
|
+
jest.spyOn(orchestrator, 'getSystem').mockImplementation(async () => system);
|
|
28
|
+
return (0, supertest_1.default)(app.getHttpServer())
|
|
29
|
+
.get('/system')
|
|
30
|
+
.expect(200)
|
|
31
|
+
.then((response) => {
|
|
32
|
+
const result = JSON.parse(response.text);
|
|
33
|
+
expect(result.nodes).toHaveLength(2);
|
|
34
|
+
expect(result.edges[0].sourceId).toBeDefined();
|
|
35
|
+
expect(result.edges[0].source).toBeUndefined();
|
|
36
|
+
expect(result.edges[0].targetId).toBeDefined();
|
|
37
|
+
expect(result.edges[0].target).toBeUndefined();
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
it('collects the system and adapts it a v1 model', async () => {
|
|
41
|
+
const system = new ms_1.System('test');
|
|
42
|
+
const orchestrator = app.get(SystemAssembler_service_1.SystemAssembler);
|
|
43
|
+
jest.spyOn(orchestrator, 'getSystem').mockImplementation(async () => system);
|
|
44
|
+
return (0, supertest_1.default)(app.getHttpServer())
|
|
45
|
+
.get('/system?version=1')
|
|
46
|
+
.expect(200)
|
|
47
|
+
.then((response) => {
|
|
48
|
+
const result = JSON.parse(response.text);
|
|
49
|
+
expect(result.name).toEqual('test');
|
|
50
|
+
expect(result.type).toEqual('System');
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=SystemAssembler.controller.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SystemAssembler.controller.test.js","sourceRoot":"","sources":["../../../../src/system-assemblers/controllers/SystemAssembler.controller.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { SystemAssemblerController } from './SystemAssembler.controller';
|
|
2
|
+
import { SystemAssembler } from './SystemAssembler.service';
|
|
3
|
+
import { ISystemAssembler } from './ISystemAssembler';
|
|
4
|
+
declare class SystemAssemblerModule {
|
|
5
|
+
}
|
|
6
|
+
export { SystemAssemblerModule, SystemAssembler, SystemAssemblerController, ISystemAssembler };
|
|
@@ -0,0 +1,28 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.SystemAssemblerController = exports.SystemAssembler = exports.SystemAssemblerModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const Config_module_1 = require("../../config/Config.module");
|
|
12
|
+
const SystemAssembler_controller_1 = require("./SystemAssembler.controller");
|
|
13
|
+
Object.defineProperty(exports, "SystemAssemblerController", { enumerable: true, get: function () { return SystemAssembler_controller_1.SystemAssemblerController; } });
|
|
14
|
+
const SystemAssembler_service_1 = require("./SystemAssembler.service");
|
|
15
|
+
Object.defineProperty(exports, "SystemAssembler", { enumerable: true, get: function () { return SystemAssembler_service_1.SystemAssembler; } });
|
|
16
|
+
const Git_module_1 = require("../../git/Git.module");
|
|
17
|
+
let SystemAssemblerModule = class SystemAssemblerModule {
|
|
18
|
+
};
|
|
19
|
+
SystemAssemblerModule = __decorate([
|
|
20
|
+
(0, common_1.Module)({
|
|
21
|
+
imports: [Config_module_1.ConfigModule, Git_module_1.GitModule],
|
|
22
|
+
controllers: [SystemAssembler_controller_1.SystemAssemblerController],
|
|
23
|
+
providers: [SystemAssembler_service_1.SystemAssembler],
|
|
24
|
+
exports: [SystemAssembler_service_1.SystemAssembler]
|
|
25
|
+
})
|
|
26
|
+
], SystemAssemblerModule);
|
|
27
|
+
exports.SystemAssemblerModule = SystemAssemblerModule;
|
|
28
|
+
//# sourceMappingURL=SystemAssembler.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SystemAssembler.module.js","sourceRoot":"","sources":["../../../../src/system-assemblers/controllers/SystemAssembler.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AAEvC,8DAAyD;AACzD,6EAAwE;AAgBtE,0GAhBO,sDAAyB,OAgBP;AAf3B,uEAA2D;AAczD,gGAdO,yCAAe,OAcP;AAZjB,qDAAgD;AAQhD,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;CAAG,CAAA;AAAxB,qBAAqB;IAN1B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,4BAAY,EAAE,sBAAS,CAAC;QAClC,WAAW,EAAE,CAAC,sDAAyB,CAAC;QACxC,SAAS,EAAE,CAAC,yCAAe,CAAC;QAC5B,OAAO,EAAE,CAAC,yCAAe,CAAC;KAC3B,CAAC;GACI,qBAAqB,CAAG;AAG5B,sDAAqB"}
|
|
@@ -0,0 +1,24 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.SystemAssembler = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const ms_1 = require("../../model/ms");
|
|
12
|
+
let SystemAssembler = class SystemAssembler {
|
|
13
|
+
async getAllMicroservices() {
|
|
14
|
+
return [];
|
|
15
|
+
}
|
|
16
|
+
async getSystem() {
|
|
17
|
+
return new ms_1.System('');
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
SystemAssembler = __decorate([
|
|
21
|
+
(0, common_1.Injectable)()
|
|
22
|
+
], SystemAssembler);
|
|
23
|
+
exports.SystemAssembler = SystemAssembler;
|
|
24
|
+
//# sourceMappingURL=SystemAssembler.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SystemAssembler.service.js","sourceRoot":"","sources":["../../../../src/system-assemblers/controllers/SystemAssembler.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA2C;AAE3C,uCAAqD;AAI9C,IAAM,eAAe,GAArB,MAAM,eAAe;IACnB,KAAK,CAAC,mBAAmB;QAC9B,OAAO,EAAE,CAAA;IACX,CAAC;IAEM,KAAK,CAAC,SAAS;QACpB,OAAO,IAAI,WAAM,CAAC,EAAE,CAAC,CAAA;IACvB,CAAC;CACF,CAAA;AARY,eAAe;IAD3B,IAAA,mBAAU,GAAE;GACA,eAAe,CAQ3B;AARY,0CAAe"}
|
|
@@ -0,0 +1,46 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.KubernetesRabbitMqAssembler = exports.KubernetesRabbitMqAssemblerModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const Config_module_1 = require("../../config/Config.module");
|
|
12
|
+
const Kubernetes_module_1 = require("../../system-element-extractors/kubernetes/Kubernetes.module");
|
|
13
|
+
const RabbitMq_module_1 = require("../../system-element-extractors/rabbitmq/RabbitMq.module");
|
|
14
|
+
const SystemAssembler_controller_1 = require("../controllers/SystemAssembler.controller");
|
|
15
|
+
const KubernetesRabbitMqAssembler_service_1 = require("./KubernetesRabbitMqAssembler.service");
|
|
16
|
+
Object.defineProperty(exports, "KubernetesRabbitMqAssembler", { enumerable: true, get: function () { return KubernetesRabbitMqAssembler_service_1.KubernetesRabbitMqAssembler; } });
|
|
17
|
+
const Git_module_1 = require("../../git/Git.module");
|
|
18
|
+
const SystemAssembler_service_1 = require("../controllers/SystemAssembler.service");
|
|
19
|
+
const SpringBoot_module_1 = require("../../system-element-extractors/spring-boot/SpringBoot.module");
|
|
20
|
+
const PostProcessors_module_1 = require("../../post-processors/PostProcessors.module");
|
|
21
|
+
let KubernetesRabbitMqAssemblerModule = class KubernetesRabbitMqAssemblerModule {
|
|
22
|
+
};
|
|
23
|
+
KubernetesRabbitMqAssemblerModule = __decorate([
|
|
24
|
+
(0, common_1.Module)({
|
|
25
|
+
imports: [
|
|
26
|
+
Config_module_1.ConfigModule,
|
|
27
|
+
Git_module_1.GitModule,
|
|
28
|
+
Kubernetes_module_1.KubernetesModule,
|
|
29
|
+
RabbitMq_module_1.RabbitMqModule,
|
|
30
|
+
SpringBoot_module_1.SpringBootModule,
|
|
31
|
+
PostProcessors_module_1.PostProcessorsModule
|
|
32
|
+
],
|
|
33
|
+
controllers: [SystemAssembler_controller_1.SystemAssemblerController],
|
|
34
|
+
providers: [
|
|
35
|
+
KubernetesRabbitMqAssembler_service_1.KubernetesRabbitMqAssembler,
|
|
36
|
+
{
|
|
37
|
+
provide: SystemAssembler_service_1.SystemAssembler,
|
|
38
|
+
useClass: KubernetesRabbitMqAssembler_service_1.KubernetesRabbitMqAssembler
|
|
39
|
+
},
|
|
40
|
+
Config_module_1.ConfigService
|
|
41
|
+
],
|
|
42
|
+
exports: [KubernetesRabbitMqAssembler_service_1.KubernetesRabbitMqAssembler, Config_module_1.ConfigService]
|
|
43
|
+
})
|
|
44
|
+
], KubernetesRabbitMqAssemblerModule);
|
|
45
|
+
exports.KubernetesRabbitMqAssemblerModule = KubernetesRabbitMqAssemblerModule;
|
|
46
|
+
//# sourceMappingURL=KubernetesRabbitMqAssembler.module.js.map
|
package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KubernetesRabbitMqAssembler.module.js","sourceRoot":"","sources":["../../../../src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AAEvC,8DAAwE;AACxE,oGAA+F;AAC/F,8FAAyF;AACzF,0FAAqF;AACrF,+FAAmF;AA4BvC,4GA5BnC,iEAA2B,OA4BmC;AA3BvE,qDAAgD;AAChD,oFAAwE;AACxE,qGAAgG;AAChG,uFAAkF;AAsBlF,IAAM,iCAAiC,GAAvC,MAAM,iCAAiC;CAAG,CAAA;AAApC,iCAAiC;IApBtC,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,4BAAY;YACZ,sBAAS;YACT,oCAAgB;YAChB,gCAAc;YACd,oCAAgB;YAChB,4CAAoB;SACrB;QACD,WAAW,EAAE,CAAC,sDAAyB,CAAC;QACxC,SAAS,EAAE;YACT,iEAA2B;YAC3B;gBACE,OAAO,EAAE,yCAAe;gBACxB,QAAQ,EAAE,iEAA2B;aACtC;YACD,6BAAa;SACd;QACD,OAAO,EAAE,CAAC,iEAA2B,EAAE,6BAAa,CAAC;KACtD,CAAC;GACI,iCAAiC,CAAG;AAEjC,8EAAiC"}
|
package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.d.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ModuleRef } from '@nestjs/core';
|
|
2
|
+
import { System, MicroService } from '../../model/ms';
|
|
3
|
+
import { SourceLocationDecorator } from '../../git/SourceLocationDecorator';
|
|
4
|
+
import { ISystemAssembler } from '../controllers/ISystemAssembler';
|
|
5
|
+
import { RabbitMqBindingsFromApiAnalyzer } from '../../system-element-extractors/rabbitmq/RabbitMq.module';
|
|
6
|
+
import { MicroservicesFromKubernetesCreator } from '../../system-element-extractors/kubernetes/Kubernetes.module';
|
|
7
|
+
export declare class KubernetesRabbitMqAssembler implements ISystemAssembler {
|
|
8
|
+
private readonly moduleRef;
|
|
9
|
+
private readonly microservicesCreator;
|
|
10
|
+
private readonly rabbitMqApiAnalyzer;
|
|
11
|
+
private readonly sourceLocationDecorator;
|
|
12
|
+
constructor(moduleRef: ModuleRef, microservicesCreator: MicroservicesFromKubernetesCreator, rabbitMqApiAnalyzer: RabbitMqBindingsFromApiAnalyzer, sourceLocationDecorator: SourceLocationDecorator);
|
|
13
|
+
getAllMicroservices(): Promise<MicroService[]>;
|
|
14
|
+
getSystem(): Promise<System>;
|
|
15
|
+
private getProvider;
|
|
16
|
+
}
|
package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.js
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.KubernetesRabbitMqAssembler = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const core_1 = require("@nestjs/core");
|
|
15
|
+
const ms_1 = require("../../model/ms");
|
|
16
|
+
const SourceLocationDecorator_1 = require("../../git/SourceLocationDecorator");
|
|
17
|
+
const RabbitMq_module_1 = require("../../system-element-extractors/rabbitmq/RabbitMq.module");
|
|
18
|
+
const Kubernetes_module_1 = require("../../system-element-extractors/kubernetes/Kubernetes.module");
|
|
19
|
+
let KubernetesRabbitMqAssembler = class KubernetesRabbitMqAssembler {
|
|
20
|
+
constructor(moduleRef, microservicesCreator, rabbitMqApiAnalyzer, sourceLocationDecorator) {
|
|
21
|
+
this.moduleRef = moduleRef;
|
|
22
|
+
this.microservicesCreator = microservicesCreator;
|
|
23
|
+
this.rabbitMqApiAnalyzer = rabbitMqApiAnalyzer;
|
|
24
|
+
this.sourceLocationDecorator = sourceLocationDecorator;
|
|
25
|
+
}
|
|
26
|
+
async getAllMicroservices() {
|
|
27
|
+
const system = await this.microservicesCreator.transform(new ms_1.System(''));
|
|
28
|
+
return system.getMicroServices();
|
|
29
|
+
}
|
|
30
|
+
async getSystem() {
|
|
31
|
+
let system = new ms_1.System('');
|
|
32
|
+
system = await this.microservicesCreator.transform(system);
|
|
33
|
+
system = await this.rabbitMqApiAnalyzer.transform(system);
|
|
34
|
+
system = await this.sourceLocationDecorator.transform(system);
|
|
35
|
+
// INFO: this just shows how providers can be accessed dynamic
|
|
36
|
+
system = await this.getProvider('StaticNodeFilter').transform(system);
|
|
37
|
+
return system;
|
|
38
|
+
}
|
|
39
|
+
getProvider(className) {
|
|
40
|
+
return this.moduleRef.get(className,
|
|
41
|
+
// gets provider from any module in the system
|
|
42
|
+
{ strict: false });
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
KubernetesRabbitMqAssembler = __decorate([
|
|
46
|
+
(0, common_1.Injectable)(),
|
|
47
|
+
__metadata("design:paramtypes", [core_1.ModuleRef,
|
|
48
|
+
Kubernetes_module_1.MicroservicesFromKubernetesCreator,
|
|
49
|
+
RabbitMq_module_1.RabbitMqBindingsFromApiAnalyzer,
|
|
50
|
+
SourceLocationDecorator_1.SourceLocationDecorator])
|
|
51
|
+
], KubernetesRabbitMqAssembler);
|
|
52
|
+
exports.KubernetesRabbitMqAssembler = KubernetesRabbitMqAssembler;
|
|
53
|
+
//# sourceMappingURL=KubernetesRabbitMqAssembler.service.js.map
|
package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KubernetesRabbitMqAssembler.service.js","sourceRoot":"","sources":["../../../../src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA2C;AAC3C,uCAAwC;AAExC,uCAAqD;AACrD,+EAA2E;AAE3E,8FAA0G;AAC1G,oGAAiH;AAG1G,IAAM,2BAA2B,GAAjC,MAAM,2BAA2B;IACtC,YACmB,SAAoB,EACpB,oBAAwD,EACxD,mBAAoD,EACpD,uBAAgD;QAHhD,cAAS,GAAT,SAAS,CAAW;QACpB,yBAAoB,GAApB,oBAAoB,CAAoC;QACxD,wBAAmB,GAAnB,mBAAmB,CAAiC;QACpD,4BAAuB,GAAvB,uBAAuB,CAAyB;IAChE,CAAC;IAEG,KAAK,CAAC,mBAAmB;QAC9B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,IAAI,WAAM,CAAC,EAAE,CAAC,CAAC,CAAA;QACxE,OAAO,MAAM,CAAC,gBAAgB,EAAE,CAAA;IAClC,CAAC;IAEM,KAAK,CAAC,SAAS;QACpB,IAAI,MAAM,GAAG,IAAI,WAAM,CAAC,EAAE,CAAC,CAAA;QAE3B,MAAM,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;QAC1D,MAAM,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;QAEzD,MAAM,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;QAE7D,8DAA8D;QAC9D,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;QAErE,OAAO,MAAM,CAAA;IACf,CAAC;IAEO,WAAW,CAAC,SAAiB;QACnC,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CACvB,SAAS;QACT,8CAA8C;QAC9C,EAAE,MAAM,EAAE,KAAK,EAAE,CAClB,CAAA;IACH,CAAC;CACF,CAAA;AAlCY,2BAA2B;IADvC,IAAA,mBAAU,GAAE;qCAGmB,gBAAS;QACE,sDAAkC;QACnC,iDAA+B;QAC3B,iDAAuB;GALxD,2BAA2B,CAkCvC;AAlCY,kEAA2B"}
|
|
@@ -0,0 +1,25 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.ExchangesFromEnvPayloadCreator = exports.EnvVariablesModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const Config_module_1 = require("../../config/Config.module");
|
|
12
|
+
const ExchangesFromEnvPayloadCreator_1 = require("./ExchangesFromEnvPayloadCreator");
|
|
13
|
+
Object.defineProperty(exports, "ExchangesFromEnvPayloadCreator", { enumerable: true, get: function () { return ExchangesFromEnvPayloadCreator_1.ExchangesFromEnvPayloadCreator; } });
|
|
14
|
+
let EnvVariablesModule = class EnvVariablesModule {
|
|
15
|
+
};
|
|
16
|
+
EnvVariablesModule = __decorate([
|
|
17
|
+
(0, common_1.Module)({
|
|
18
|
+
imports: [Config_module_1.ConfigModule],
|
|
19
|
+
controllers: [],
|
|
20
|
+
providers: [ExchangesFromEnvPayloadCreator_1.ExchangesFromEnvPayloadCreator],
|
|
21
|
+
exports: [ExchangesFromEnvPayloadCreator_1.ExchangesFromEnvPayloadCreator]
|
|
22
|
+
})
|
|
23
|
+
], EnvVariablesModule);
|
|
24
|
+
exports.EnvVariablesModule = EnvVariablesModule;
|
|
25
|
+
//# sourceMappingURL=EnvVariables.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EnvVariables.module.js","sourceRoot":"","sources":["../../../../src/system-element-extractors/env-variables/EnvVariables.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AAEvC,8DAAyD;AACzD,qFAAiF;AAUpD,+GAVpB,+DAA8B,OAUoB;AAF3D,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;CAAG,CAAA;AAArB,kBAAkB;IANvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,4BAAY,CAAC;QACvB,WAAW,EAAE,EAAE;QACf,SAAS,EAAE,CAAC,+DAA8B,CAAC;QAC3C,OAAO,EAAE,CAAC,+DAA8B,CAAC;KAC1C,CAAC;GACI,kBAAkB,CAAG;AAElB,gDAAkB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ConfigService } from '../../config/Config.service';
|
|
2
|
+
import { System } from '../../model/ms';
|
|
3
|
+
export declare class ExchangesFromEnvPayloadCreator {
|
|
4
|
+
private readonly config;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(config: ConfigService);
|
|
7
|
+
/**
|
|
8
|
+
* looks for env vars that configure an exchange and adds corresponding system nodes.
|
|
9
|
+
*
|
|
10
|
+
* @param system: requires nodes to have payloads of type NodePayload
|
|
11
|
+
*/
|
|
12
|
+
transform(system: System): Promise<System>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
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 ExchangesFromEnvPayloadCreator_1;
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.ExchangesFromEnvPayloadCreator = void 0;
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const Config_service_1 = require("../../config/Config.service");
|
|
16
|
+
const ms_1 = require("../../model/ms");
|
|
17
|
+
const exchangeEnvNameMustInclude = 'EXCHANGE';
|
|
18
|
+
const outgoingEnvNameMustInclude = 'OUTGOING';
|
|
19
|
+
const incomingEnvNameMustInclude = 'INCOMING';
|
|
20
|
+
let ExchangesFromEnvPayloadCreator = ExchangesFromEnvPayloadCreator_1 = class ExchangesFromEnvPayloadCreator {
|
|
21
|
+
constructor(config) {
|
|
22
|
+
this.config = config;
|
|
23
|
+
this.logger = new common_1.Logger(ExchangesFromEnvPayloadCreator_1.name);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* looks for env vars that configure an exchange and adds corresponding system nodes.
|
|
27
|
+
*
|
|
28
|
+
* @param system: requires nodes to have payloads of type NodePayload
|
|
29
|
+
*/
|
|
30
|
+
async transform(system) {
|
|
31
|
+
system.getMicroServices().forEach((service) => {
|
|
32
|
+
const env = service.getPayload().env;
|
|
33
|
+
if (env) {
|
|
34
|
+
env
|
|
35
|
+
.filter((envEntry) => envEntry.name.includes(exchangeEnvNameMustInclude))
|
|
36
|
+
.forEach((envEntry) => {
|
|
37
|
+
const metadata = {
|
|
38
|
+
transformer: ExchangesFromEnvPayloadCreator_1.name,
|
|
39
|
+
context: 'env variable ' + envEntry.name
|
|
40
|
+
};
|
|
41
|
+
if (envEntry.name.includes(outgoingEnvNameMustInclude)) {
|
|
42
|
+
const outgoingExchange = system.addMessageExchange(envEntry.value, undefined, metadata);
|
|
43
|
+
const edge = new ms_1.AsyncEventFlow(service, outgoingExchange, undefined, metadata);
|
|
44
|
+
system.edges.push(edge);
|
|
45
|
+
this.logger.log(`added outgoing exchange ${envEntry.value} for service ${service.getPayload().name}`);
|
|
46
|
+
}
|
|
47
|
+
if (envEntry.name.includes(incomingEnvNameMustInclude)) {
|
|
48
|
+
const incomingExchange = system.addMessageExchange(envEntry.value, undefined, metadata);
|
|
49
|
+
const eventFlow = new ms_1.AsyncEventFlow(incomingExchange, service, undefined, metadata);
|
|
50
|
+
system.edges.push(eventFlow);
|
|
51
|
+
this.logger.log(`added incoming exchange ${envEntry.value} for service ${service.getPayload().name}`);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
return system;
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
ExchangesFromEnvPayloadCreator = ExchangesFromEnvPayloadCreator_1 = __decorate([
|
|
60
|
+
(0, common_1.Injectable)(),
|
|
61
|
+
__metadata("design:paramtypes", [Config_service_1.ConfigService])
|
|
62
|
+
], ExchangesFromEnvPayloadCreator);
|
|
63
|
+
exports.ExchangesFromEnvPayloadCreator = ExchangesFromEnvPayloadCreator;
|
|
64
|
+
//# sourceMappingURL=ExchangesFromEnvPayloadCreator.js.map
|
package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExchangesFromEnvPayloadCreator.js","sourceRoot":"","sources":["../../../../src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,2CAAmD;AAEnD,gEAA2D;AAC3D,uCAAuD;AAGvD,MAAM,0BAA0B,GAAG,UAAU,CAAA;AAC7C,MAAM,0BAA0B,GAAG,UAAU,CAAA;AAC7C,MAAM,0BAA0B,GAAG,UAAU,CAAA;AAGtC,IAAM,8BAA8B,sCAApC,MAAM,8BAA8B;IAGzC,YAA6B,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;QAFjC,WAAM,GAAG,IAAI,eAAM,CAAC,gCAA8B,CAAC,IAAI,CAAC,CAAA;IAEpB,CAAC;IAEtD;;;;OAIG;IACI,KAAK,CAAC,SAAS,CAAC,MAAc;QACnC,MAAM,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC5C,MAAM,GAAG,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,GAAG,CAAA;YACpC,IAAI,GAAG,EAAE;gBACP,GAAG;qBACA,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CACnB,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,0BAA0B,CAAC,CACnD;qBACA,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;oBACpB,MAAM,QAAQ,GAAa;wBACzB,WAAW,EAAE,gCAA8B,CAAC,IAAI;wBAChD,OAAO,EAAE,eAAe,GAAG,QAAQ,CAAC,IAAI;qBACzC,CAAA;oBAED,IAAI,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,0BAA0B,CAAC,EAAE;wBACtD,MAAM,gBAAgB,GAAG,MAAM,CAAC,kBAAkB,CAChD,QAAQ,CAAC,KAAK,EACd,SAAS,EACT,QAAQ,CACT,CAAA;wBACD,MAAM,IAAI,GAAG,IAAI,mBAAc,CAC7B,OAAO,EACP,gBAAgB,EAChB,SAAS,EACT,QAAQ,CACT,CAAA;wBACD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;wBACvB,IAAI,CAAC,MAAM,CAAC,GAAG,CACb,2BAA2B,QAAQ,CAAC,KAAK,gBACvC,OAAO,CAAC,UAAU,EAAE,CAAC,IACvB,EAAE,CACH,CAAA;qBACF;oBACD,IAAI,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,0BAA0B,CAAC,EAAE;wBACtD,MAAM,gBAAgB,GAAG,MAAM,CAAC,kBAAkB,CAChD,QAAQ,CAAC,KAAK,EACd,SAAS,EACT,QAAQ,CACT,CAAA;wBACD,MAAM,SAAS,GAAG,IAAI,mBAAc,CAClC,gBAAgB,EAChB,OAAO,EACP,SAAS,EACT,QAAQ,CACT,CAAA;wBACD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;wBAC5B,IAAI,CAAC,MAAM,CAAC,GAAG,CACb,2BAA2B,QAAQ,CAAC,KAAK,gBACvC,OAAO,CAAC,UAAU,EAAE,CAAC,IACvB,EAAE,CACH,CAAA;qBACF;gBACH,CAAC,CAAC,CAAA;aACL;QACH,CAAC,CAAC,CAAA;QACF,OAAO,MAAM,CAAA;IACf,CAAC;CACF,CAAA;AAnEY,8BAA8B;IAD1C,IAAA,mBAAU,GAAE;qCAI0B,8BAAa;GAHvC,8BAA8B,CAmE1C;AAnEY,wEAA8B"}
|
package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import '../../test/expect-extensions';
|