tadis-analyzer 2.4.1 → 2.4.3
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,12 @@
|
|
|
1
|
+
import { System } from '../model/ms';
|
|
2
|
+
export declare class MicroserviceWithOutgoingExchangeMerger {
|
|
3
|
+
private readonly logger;
|
|
4
|
+
transform(system: System): Promise<System>;
|
|
5
|
+
private merge;
|
|
6
|
+
private getEdgesNotConnectedToMergedExchanges;
|
|
7
|
+
private getOtherExchangeEdgesRedirectedToService;
|
|
8
|
+
private getNonMessageExchanges;
|
|
9
|
+
private extendPayloadOfMicroService;
|
|
10
|
+
private extendMetadataOfMicroService;
|
|
11
|
+
private findEdgeTargetingSameNameMicroService;
|
|
12
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
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 MicroserviceWithOutgoingExchangeMerger_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.MicroserviceWithOutgoingExchangeMerger = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const ms_1 = require("../model/ms");
|
|
13
|
+
let MicroserviceWithOutgoingExchangeMerger = MicroserviceWithOutgoingExchangeMerger_1 = class MicroserviceWithOutgoingExchangeMerger {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.logger = new common_1.Logger(MicroserviceWithOutgoingExchangeMerger_1.name);
|
|
16
|
+
}
|
|
17
|
+
async transform(system) {
|
|
18
|
+
return this.merge(system);
|
|
19
|
+
}
|
|
20
|
+
merge(system) {
|
|
21
|
+
const result = new ms_1.System(system.id);
|
|
22
|
+
result.content = system.content;
|
|
23
|
+
this.getNonMessageExchanges(system).forEach((node) => {
|
|
24
|
+
result.nodes.push(node);
|
|
25
|
+
});
|
|
26
|
+
const mergedExchanges = [];
|
|
27
|
+
system.nodes.forEach((node) => {
|
|
28
|
+
var _a;
|
|
29
|
+
if (node.content.type === ms_1.MessageExchange.name) {
|
|
30
|
+
const exchange = node;
|
|
31
|
+
const exchangeName = exchange.getName();
|
|
32
|
+
if (!exchangeName)
|
|
33
|
+
return;
|
|
34
|
+
const edgeTargetingSameNameMicroService = this.findEdgeTargetingSameNameMicroService(exchange, system);
|
|
35
|
+
if (edgeTargetingSameNameMicroService) {
|
|
36
|
+
const service = system.findMicroService(exchangeName);
|
|
37
|
+
if (service) {
|
|
38
|
+
this.extendPayloadOfMicroService(service, exchange.content.payload);
|
|
39
|
+
this.extendMetadataOfMicroService(service, exchange.content.metadata);
|
|
40
|
+
this.extendMetadataOfMicroService(service, (_a = edgeTargetingSameNameMicroService.content) === null || _a === void 0 ? void 0 : _a.metadata);
|
|
41
|
+
this.getOtherExchangeEdgesRedirectedToService(system, exchange, service).forEach((edge) => result.edges.push(edge));
|
|
42
|
+
mergedExchanges.push(exchange);
|
|
43
|
+
this.logger.log(`merged exchange ${exchange.id} with service ${service.id}`);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
result.nodes.push(exchange);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
this.getEdgesNotConnectedToMergedExchanges(mergedExchanges, system).forEach((edge) => {
|
|
52
|
+
result.edges.push(edge);
|
|
53
|
+
});
|
|
54
|
+
return result;
|
|
55
|
+
}
|
|
56
|
+
getEdgesNotConnectedToMergedExchanges(nodes, system) {
|
|
57
|
+
return system.edges.filter((edge) => !nodes.includes(edge.source) && !nodes.includes(edge.target));
|
|
58
|
+
}
|
|
59
|
+
getOtherExchangeEdgesRedirectedToService(system, exchange, service) {
|
|
60
|
+
return system.edges
|
|
61
|
+
.filter((edge) => (edge.source === exchange || edge.target === exchange) &&
|
|
62
|
+
edge.source !== edge.target &&
|
|
63
|
+
!(edge.source.content.type === ms_1.MicroService.name &&
|
|
64
|
+
edge.source.hasSameNameAs(exchange)) &&
|
|
65
|
+
!(edge.target.content.type === ms_1.MicroService.name &&
|
|
66
|
+
edge.target.hasSameNameAs(exchange)))
|
|
67
|
+
.map((exchangeEdge) => {
|
|
68
|
+
var _a, _b;
|
|
69
|
+
const source = exchangeEdge.source === exchange ? service : exchangeEdge.source;
|
|
70
|
+
const target = exchangeEdge.target === exchange ? service : exchangeEdge.target;
|
|
71
|
+
const newEdge = new ms_1.AsyncEventFlow(source, target, (_a = exchangeEdge.content) === null || _a === void 0 ? void 0 : _a.payload, (_b = exchangeEdge.content) === null || _b === void 0 ? void 0 : _b.metadata);
|
|
72
|
+
this.logger.log(`redirected ${exchangeEdge.source.id} -> ${exchangeEdge.target.id}` +
|
|
73
|
+
` to ${newEdge.source.id} -> ${newEdge.target.id}`);
|
|
74
|
+
return newEdge;
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
getNonMessageExchanges(system) {
|
|
78
|
+
return system.nodes.filter((node) => node.content.type !== ms_1.MessageExchange.name);
|
|
79
|
+
}
|
|
80
|
+
extendPayloadOfMicroService(service, extraPayload) {
|
|
81
|
+
service.content.payload.reduced = true;
|
|
82
|
+
Object.getOwnPropertyNames(extraPayload).forEach((payloadPropertyName) => (service.content.payload[payloadPropertyName] =
|
|
83
|
+
extraPayload[payloadPropertyName]));
|
|
84
|
+
}
|
|
85
|
+
extendMetadataOfMicroService(service, metadata) {
|
|
86
|
+
if (!metadata)
|
|
87
|
+
return;
|
|
88
|
+
if (service.content.metadata) {
|
|
89
|
+
service.content.metadata.transformer += '; ' + metadata.transformer;
|
|
90
|
+
service.content.metadata.context += '; ' + metadata.context;
|
|
91
|
+
service.content.metadata.info += '; ' + metadata.info;
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
service.content.metadata = metadata;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
findEdgeTargetingSameNameMicroService(exchange, system) {
|
|
98
|
+
return system.edges.find((edge) => edge.target.id === exchange.id &&
|
|
99
|
+
edge.source.hasSameNameAs(exchange) &&
|
|
100
|
+
edge.source.content.type === ms_1.MicroService.name);
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
MicroserviceWithOutgoingExchangeMerger = MicroserviceWithOutgoingExchangeMerger_1 = __decorate([
|
|
104
|
+
(0, common_1.Injectable)()
|
|
105
|
+
], MicroserviceWithOutgoingExchangeMerger);
|
|
106
|
+
exports.MicroserviceWithOutgoingExchangeMerger = MicroserviceWithOutgoingExchangeMerger;
|
|
107
|
+
//# sourceMappingURL=MicroserviceWithOutgoingExchangeMerger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MicroserviceWithOutgoingExchangeMerger.js","sourceRoot":"","sources":["../../../src/post-processors/MicroserviceWithOutgoingExchangeMerger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const MicroserviceWithOutgoingExchangeMerger_1 = require("./MicroserviceWithOutgoingExchangeMerger");
|
|
4
|
+
const ms_1 = require("../model/ms");
|
|
5
|
+
describe(MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger.name, () => {
|
|
6
|
+
it('can merge in standard case', async () => {
|
|
7
|
+
const inputSystem = new ms_1.System('system');
|
|
8
|
+
const serviceA = inputSystem.addMicroService('A');
|
|
9
|
+
const serviceB = inputSystem.addMicroService('B');
|
|
10
|
+
const exchangeB = inputSystem.addMessageExchange('B');
|
|
11
|
+
const serviceC = inputSystem.addMicroService('C');
|
|
12
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceA, serviceB));
|
|
13
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceB, exchangeB));
|
|
14
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(exchangeB, serviceC));
|
|
15
|
+
const merger = new MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger();
|
|
16
|
+
const system = await merger.transform(inputSystem);
|
|
17
|
+
expect(system.nodes).toHaveLength(3);
|
|
18
|
+
const mergedServiceB = system.nodes.find((node) => node.content.payload.name === 'B' &&
|
|
19
|
+
node.content.type === ms_1.MicroService.name);
|
|
20
|
+
expect(mergedServiceB).toBeDefined();
|
|
21
|
+
expect(mergedServiceB.content.payload.reduced).toEqual(true);
|
|
22
|
+
expect(system.edges).toHaveLength(2);
|
|
23
|
+
expect(system.edges.find((edge) => edge.source.hasName('A') && edge.target.hasName('B'))).toBeDefined();
|
|
24
|
+
expect(system.edges.find((edge) => edge.source.hasName('B') && edge.target.hasName('C'))).toBeDefined();
|
|
25
|
+
});
|
|
26
|
+
it('can redirect other nodes connected to the exchange to the corresponding service', async () => {
|
|
27
|
+
const inputSystem = new ms_1.System('system');
|
|
28
|
+
const serviceX = inputSystem.addMicroService('X');
|
|
29
|
+
const serviceB = inputSystem.addMicroService('B');
|
|
30
|
+
const exchangeB = inputSystem.addMessageExchange('B');
|
|
31
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceB, exchangeB));
|
|
32
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceX, exchangeB));
|
|
33
|
+
const merger = new MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger();
|
|
34
|
+
const system = await merger.transform(inputSystem);
|
|
35
|
+
expect(system.nodes).toHaveLength(2);
|
|
36
|
+
const mergedServiceB = system.nodes.find((node) => node.content.payload.name === 'B' &&
|
|
37
|
+
node.content.type === ms_1.MicroService.name);
|
|
38
|
+
expect(mergedServiceB).toBeDefined();
|
|
39
|
+
expect(mergedServiceB.content.payload.reduced).toEqual(true);
|
|
40
|
+
expect(system.edges).toHaveLength(1);
|
|
41
|
+
expect(system.edges.find((edge) => edge.source.hasName('X') && edge.target.hasName('B'))).toBeDefined();
|
|
42
|
+
});
|
|
43
|
+
it('can merge and keeps unconnected nodes', async () => {
|
|
44
|
+
const inputSystem = new ms_1.System('system');
|
|
45
|
+
inputSystem.addMicroService('A');
|
|
46
|
+
const serviceB = inputSystem.addMicroService('B');
|
|
47
|
+
const exchangeB = inputSystem.addMessageExchange('B');
|
|
48
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceB, exchangeB));
|
|
49
|
+
const merger = new MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger();
|
|
50
|
+
const system = await merger.transform(inputSystem);
|
|
51
|
+
expect(system.nodes).toHaveLength(2);
|
|
52
|
+
});
|
|
53
|
+
it('does not merge exchanges which are connected to differently named services', async () => {
|
|
54
|
+
const inputSystem = new ms_1.System('system');
|
|
55
|
+
const serviceA = inputSystem.addMicroService('A');
|
|
56
|
+
const exchangeB = inputSystem.addMessageExchange('B');
|
|
57
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceA, exchangeB));
|
|
58
|
+
const merger = new MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger();
|
|
59
|
+
const system = await merger.transform(inputSystem);
|
|
60
|
+
expect(system.nodes).toHaveLength(2);
|
|
61
|
+
expect(system.nodes).toContain(serviceA);
|
|
62
|
+
expect(system.nodes).toContain(exchangeB);
|
|
63
|
+
});
|
|
64
|
+
it('does not merge exchanges which are connected to nodes of same name but of a type different from MicroService', async () => {
|
|
65
|
+
const inputSystem = new ms_1.System('system');
|
|
66
|
+
const exchangeA = inputSystem.addMessageExchange('A');
|
|
67
|
+
const queueA = inputSystem.addMessageQueue('A');
|
|
68
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(exchangeA, queueA));
|
|
69
|
+
const merger = new MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger();
|
|
70
|
+
const system = await merger.transform(inputSystem);
|
|
71
|
+
expect(system.nodes).toHaveLength(2);
|
|
72
|
+
expect(system.nodes).toContain(exchangeA);
|
|
73
|
+
expect(system.nodes).toContain(queueA);
|
|
74
|
+
});
|
|
75
|
+
it('merges payload and metadata of service and exchange and the edge between them', async () => {
|
|
76
|
+
var _a, _b, _c, _d, _e, _f;
|
|
77
|
+
const inputSystem = new ms_1.System('system');
|
|
78
|
+
const metadataOfServiceB = {
|
|
79
|
+
transformer: 't1',
|
|
80
|
+
context: 'c1'
|
|
81
|
+
};
|
|
82
|
+
const serviceB = inputSystem.addMicroService('B', { p: 1 }, metadataOfServiceB);
|
|
83
|
+
const metadataOfExchangeB = {
|
|
84
|
+
transformer: 't2',
|
|
85
|
+
context: 'c2'
|
|
86
|
+
};
|
|
87
|
+
const exchangeB = inputSystem.addMessageExchange('B', { q: 2 }, metadataOfExchangeB);
|
|
88
|
+
const metadataOfEdgeAtoB = {
|
|
89
|
+
transformer: 't3',
|
|
90
|
+
context: 'c3'
|
|
91
|
+
};
|
|
92
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceB, exchangeB, { routingKey: 'r' }, metadataOfEdgeAtoB));
|
|
93
|
+
const serviceC = inputSystem.addMicroService('C');
|
|
94
|
+
const metadataOfEdgeBtoC = {
|
|
95
|
+
transformer: 't4',
|
|
96
|
+
context: 'c4'
|
|
97
|
+
};
|
|
98
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(exchangeB, serviceC, { routingKey: 'r' }, metadataOfEdgeBtoC));
|
|
99
|
+
const merger = new MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger();
|
|
100
|
+
const system = await merger.transform(inputSystem);
|
|
101
|
+
expect(system.nodes).toHaveLength(2);
|
|
102
|
+
expect(system.nodes[0].content.payload.p).toEqual(1);
|
|
103
|
+
expect(system.nodes[0].content.payload.q).toEqual(2);
|
|
104
|
+
expect((_b = (_a = system.nodes[0].content) === null || _a === void 0 ? void 0 : _a.metadata) === null || _b === void 0 ? void 0 : _b.transformer).toEqual('t1; t2; t3');
|
|
105
|
+
expect((_d = (_c = system.nodes[0].content) === null || _c === void 0 ? void 0 : _c.metadata) === null || _d === void 0 ? void 0 : _d.context).toEqual('c1; c2; c3');
|
|
106
|
+
expect(system.edges).toHaveLength(1);
|
|
107
|
+
expect((_e = system.edges[0].content) === null || _e === void 0 ? void 0 : _e.payload).toEqual({ routingKey: 'r' });
|
|
108
|
+
expect((_f = system.edges[0].content) === null || _f === void 0 ? void 0 : _f.metadata).toEqual(metadataOfEdgeBtoC);
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=MicroserviceWithOutgoingExchangeMerger.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MicroserviceWithOutgoingExchangeMerger.test.js","sourceRoot":"","sources":["../../../src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { StaticNodeFilter } from './StaticNodeFilter';
|
|
2
|
+
import { SubSystemFromPayloadTransformer } from './SubSystemFromPayloadTransformer';
|
|
3
|
+
import { MicroserviceWithOutgoingExchangeMerger } from './MicroserviceWithOutgoingExchangeMerger';
|
|
4
|
+
declare class PostProcessorsModule {
|
|
5
|
+
}
|
|
6
|
+
export { PostProcessorsModule, StaticNodeFilter, SubSystemFromPayloadTransformer, MicroserviceWithOutgoingExchangeMerger };
|
|
@@ -0,0 +1,37 @@
|
|
|
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.MicroserviceWithOutgoingExchangeMerger = exports.SubSystemFromPayloadTransformer = exports.StaticNodeFilter = exports.PostProcessorsModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const Config_module_1 = require("../config/Config.module");
|
|
12
|
+
const StaticNodeFilter_1 = require("./StaticNodeFilter");
|
|
13
|
+
Object.defineProperty(exports, "StaticNodeFilter", { enumerable: true, get: function () { return StaticNodeFilter_1.StaticNodeFilter; } });
|
|
14
|
+
const SubSystemFromPayloadTransformer_1 = require("./SubSystemFromPayloadTransformer");
|
|
15
|
+
Object.defineProperty(exports, "SubSystemFromPayloadTransformer", { enumerable: true, get: function () { return SubSystemFromPayloadTransformer_1.SubSystemFromPayloadTransformer; } });
|
|
16
|
+
const MicroserviceWithOutgoingExchangeMerger_1 = require("./MicroserviceWithOutgoingExchangeMerger");
|
|
17
|
+
Object.defineProperty(exports, "MicroserviceWithOutgoingExchangeMerger", { enumerable: true, get: function () { return MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger; } });
|
|
18
|
+
let PostProcessorsModule = class PostProcessorsModule {
|
|
19
|
+
};
|
|
20
|
+
PostProcessorsModule = __decorate([
|
|
21
|
+
(0, common_1.Module)({
|
|
22
|
+
imports: [Config_module_1.ConfigModule],
|
|
23
|
+
controllers: [],
|
|
24
|
+
providers: [
|
|
25
|
+
StaticNodeFilter_1.StaticNodeFilter,
|
|
26
|
+
SubSystemFromPayloadTransformer_1.SubSystemFromPayloadTransformer,
|
|
27
|
+
MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger
|
|
28
|
+
],
|
|
29
|
+
exports: [
|
|
30
|
+
StaticNodeFilter_1.StaticNodeFilter,
|
|
31
|
+
SubSystemFromPayloadTransformer_1.SubSystemFromPayloadTransformer,
|
|
32
|
+
MicroserviceWithOutgoingExchangeMerger_1.MicroserviceWithOutgoingExchangeMerger
|
|
33
|
+
]
|
|
34
|
+
})
|
|
35
|
+
], PostProcessorsModule);
|
|
36
|
+
exports.PostProcessorsModule = PostProcessorsModule;
|
|
37
|
+
//# sourceMappingURL=PostProcessors.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostProcessors.module.js","sourceRoot":"","sources":["../../../src/post-processors/PostProcessors.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AAEvC,2DAAsD;AACtD,yDAAqD;AAsBnD,iGAtBO,mCAAgB,OAsBP;AArBlB,uFAAmF;AAsBjF,gHAtBO,iEAA+B,OAsBP;AArBjC,qGAAiG;AAsB/F,uHAtBO,+EAAsC,OAsBP;AANxC,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;CAAG,CAAA;AAAvB,oBAAoB;IAdzB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,4BAAY,CAAC;QACvB,WAAW,EAAE,EAAE;QACf,SAAS,EAAE;YACT,mCAAgB;YAChB,iEAA+B;YAC/B,+EAAsC;SACvC;QACD,OAAO,EAAE;YACP,mCAAgB;YAChB,iEAA+B;YAC/B,+EAAsC;SACvC;KACF,CAAC;GACI,oBAAoB,CAAG;AAG3B,oDAAoB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const testing_1 = require("@nestjs/testing");
|
|
4
|
+
const ms_1 = require("../model/ms");
|
|
5
|
+
const PostProcessors_module_1 = require("./PostProcessors.module");
|
|
6
|
+
jest.mock('../config/Config.service');
|
|
7
|
+
describe(PostProcessors_module_1.PostProcessorsModule.name, () => {
|
|
8
|
+
let app;
|
|
9
|
+
beforeAll(async () => {
|
|
10
|
+
const testingModule = await testing_1.Test.createTestingModule({
|
|
11
|
+
imports: [PostProcessors_module_1.PostProcessorsModule]
|
|
12
|
+
}).compile();
|
|
13
|
+
app = testingModule.createNestApplication();
|
|
14
|
+
await app.init();
|
|
15
|
+
});
|
|
16
|
+
it('supports backward-compatible use of SubSystemFromPayloadTransformer', async () => {
|
|
17
|
+
const inputSystem = new ms_1.System('system');
|
|
18
|
+
const transformer = app.get(PostProcessors_module_1.SubSystemFromPayloadTransformer);
|
|
19
|
+
const system = await transformer.transform(inputSystem, PostProcessors_module_1.SubSystemFromPayloadTransformer.getSubSystemNameFromCabinetLabel);
|
|
20
|
+
expect(system.nodes).toHaveLength(0);
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=PostProcessors.module.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostProcessors.module.test.js","sourceRoot":"","sources":["../../../src/post-processors/PostProcessors.module.test.ts"],"names":[],"mappings":";;AACA,6CAAsC;AAEtC,oCAAoC;AACpC,mEAGgC;AAEhC,IAAI,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAA;AAErC,QAAQ,CAAC,4CAAoB,CAAC,IAAI,EAAE,GAAG,EAAE;IACvC,IAAI,GAAqB,CAAA;IAEzB,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,aAAa,GAAG,MAAM,cAAI,CAAC,mBAAmB,CAAC;YACnD,OAAO,EAAE,CAAC,4CAAoB,CAAC;SAChC,CAAC,CAAC,OAAO,EAAE,CAAA;QACZ,GAAG,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAA;QAC3C,MAAM,GAAG,CAAC,IAAI,EAAE,CAAA;IAClB,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,qEAAqE,EAAE,KAAK,IAAI,EAAE;QACnF,MAAM,WAAW,GAAG,IAAI,WAAM,CAAC,QAAQ,CAAC,CAAA;QAExC,MAAM,WAAW,GAAG,GAAG,CAAC,GAAG,CACzB,uDAA+B,CAChC,CAAA;QACD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,SAAS,CACxC,WAAW,EACX,uDAA+B,CAAC,gCAAgC,CACjE,CAAA;QAED,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;IACtC,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ConfigService } from '../config/Config.service';
|
|
2
|
+
import { System } from '../model/ms';
|
|
3
|
+
export declare class StaticNodeFilter {
|
|
4
|
+
private readonly config;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(config: ConfigService);
|
|
7
|
+
transform(system: System): Promise<System>;
|
|
8
|
+
private shouldBeRemoved;
|
|
9
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
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;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
};
|
|
24
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
25
|
+
if (mod && mod.__esModule) return mod;
|
|
26
|
+
var result = {};
|
|
27
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
28
|
+
__setModuleDefault(result, mod);
|
|
29
|
+
return result;
|
|
30
|
+
};
|
|
31
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
32
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
33
|
+
};
|
|
34
|
+
var StaticNodeFilter_1;
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.StaticNodeFilter = void 0;
|
|
37
|
+
const common_1 = require("@nestjs/common");
|
|
38
|
+
const _ = __importStar(require("lodash"));
|
|
39
|
+
const Config_service_1 = require("../config/Config.service");
|
|
40
|
+
let StaticNodeFilter = StaticNodeFilter_1 = class StaticNodeFilter {
|
|
41
|
+
constructor(config) {
|
|
42
|
+
this.config = config;
|
|
43
|
+
this.logger = new common_1.Logger(StaticNodeFilter_1.name);
|
|
44
|
+
}
|
|
45
|
+
async transform(system) {
|
|
46
|
+
const namesToRemove = this.config.getExcludedNodeNames();
|
|
47
|
+
system.edges = system.edges
|
|
48
|
+
.filter(edge => {
|
|
49
|
+
const sourceNodeName = edge.source.content.payload.name;
|
|
50
|
+
const targetNodeName = edge.target.content.payload.name;
|
|
51
|
+
if (this.shouldBeRemoved(namesToRemove, sourceNodeName)
|
|
52
|
+
|| this.shouldBeRemoved(namesToRemove, targetNodeName)) {
|
|
53
|
+
this.logger.log(`removing edge ${sourceNodeName} -> ${targetNodeName} of excluded node`);
|
|
54
|
+
return false;
|
|
55
|
+
}
|
|
56
|
+
return true;
|
|
57
|
+
});
|
|
58
|
+
const nodesRemoved = [];
|
|
59
|
+
system.nodes = system.nodes
|
|
60
|
+
.filter(node => {
|
|
61
|
+
const nodeName = node.content.payload.name;
|
|
62
|
+
if (this.shouldBeRemoved(namesToRemove, nodeName)) {
|
|
63
|
+
nodesRemoved.push(nodeName);
|
|
64
|
+
this.logger.log('removing excluded node named ' + nodeName);
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
return true;
|
|
68
|
+
});
|
|
69
|
+
system.content.metadata = {
|
|
70
|
+
transformer: StaticNodeFilter_1.name,
|
|
71
|
+
context: 'system.nodes',
|
|
72
|
+
info: _.uniq(nodesRemoved).join(', ')
|
|
73
|
+
};
|
|
74
|
+
return system;
|
|
75
|
+
}
|
|
76
|
+
shouldBeRemoved(namesToRemove, nodeName) {
|
|
77
|
+
for (const nameToRemove of namesToRemove) {
|
|
78
|
+
const regexp = new RegExp(nameToRemove);
|
|
79
|
+
if (nodeName.match(regexp)) {
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return false;
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
StaticNodeFilter = StaticNodeFilter_1 = __decorate([
|
|
87
|
+
(0, common_1.Injectable)(),
|
|
88
|
+
__metadata("design:paramtypes", [Config_service_1.ConfigService])
|
|
89
|
+
], StaticNodeFilter);
|
|
90
|
+
exports.StaticNodeFilter = StaticNodeFilter;
|
|
91
|
+
//# sourceMappingURL=StaticNodeFilter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StaticNodeFilter.js","sourceRoot":"","sources":["../../../src/post-processors/StaticNodeFilter.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAAmD;AACnD,0CAA2B;AAE3B,6DAAwD;AAIjD,IAAM,gBAAgB,wBAAtB,MAAM,gBAAgB;IAG3B,YACmB,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;QAHvB,WAAM,GAAG,IAAI,eAAM,CAAC,kBAAgB,CAAC,IAAI,CAAC,CAAA;IAIvD,CAAC;IAEE,KAAK,CAAC,SAAS,CAAC,MAAc;QACnC,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAA;QAExD,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK;aACxB,MAAM,CAAC,IAAI,CAAC,EAAE;YACb,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAA;YACvD,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAA;YACvD,IAAI,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,cAAc,CAAC;mBAClD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,cAAc,CAAC,EAAE;gBACxD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,iBAAiB,cAAc,OAAO,cAAc,mBAAmB,CAAC,CAAA;gBACxF,OAAO,KAAK,CAAA;aACb;YACD,OAAO,IAAI,CAAA;QACb,CAAC,CAAC,CAAA;QAEJ,MAAM,YAAY,GAAa,EAAE,CAAA;QACjC,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK;aACxB,MAAM,CAAC,IAAI,CAAC,EAAE;YACb,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAA;YAC1C,IAAI,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,QAAQ,CAAC,EAAE;gBACjD,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;gBAC3B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,+BAA+B,GAAG,QAAQ,CAAC,CAAA;gBAC3D,OAAO,KAAK,CAAA;aACb;YACD,OAAO,IAAI,CAAA;QACb,CAAC,CAAC,CAAA;QACJ,MAAM,CAAC,OAAO,CAAC,QAAQ,GAAG;YACxB,WAAW,EAAE,kBAAgB,CAAC,IAAI;YAClC,OAAO,EAAE,cAAc;YACvB,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;SACtC,CAAA;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAEO,eAAe,CAAC,aAAuB,EAAE,QAAgB;QAC/D,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE;YACxC,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,YAAY,CAAC,CAAA;YACvC,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;gBAC1B,OAAO,IAAI,CAAA;aACZ;SACF;QACD,OAAO,KAAK,CAAA;IACd,CAAC;CAEF,CAAA;AApDY,gBAAgB;IAD5B,IAAA,mBAAU,GAAE;qCAKgB,8BAAa;GAJ7B,gBAAgB,CAoD5B;AApDY,4CAAgB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const Config_service_1 = require("../config/Config.service");
|
|
4
|
+
const StaticNodeFilter_1 = require("./StaticNodeFilter");
|
|
5
|
+
const ms_1 = require("../model/ms");
|
|
6
|
+
jest.mock('../config/Config.service');
|
|
7
|
+
describe(StaticNodeFilter_1.StaticNodeFilter.name, () => {
|
|
8
|
+
it('removes nodes to be excluded', async () => {
|
|
9
|
+
const inputSystem = new ms_1.System('system');
|
|
10
|
+
const serviceAAA = inputSystem.addMicroService('AAA');
|
|
11
|
+
inputSystem.addMessageExchange('AAA');
|
|
12
|
+
const exchangeC = inputSystem.addMessageExchange('C');
|
|
13
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceAAA, exchangeC));
|
|
14
|
+
const serviceD = inputSystem.addMicroService('D');
|
|
15
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(exchangeC, serviceD));
|
|
16
|
+
const serviceE = inputSystem.addMicroService('E');
|
|
17
|
+
inputSystem.edges.push(new ms_1.AsyncEventFlow(serviceD, serviceE));
|
|
18
|
+
Config_service_1.ConfigService.prototype.getExcludedNodeNames = jest.fn().mockImplementation(() => {
|
|
19
|
+
return ['A.*', 'C'];
|
|
20
|
+
});
|
|
21
|
+
const config = new Config_service_1.ConfigService();
|
|
22
|
+
const nodeRemover = new StaticNodeFilter_1.StaticNodeFilter(config);
|
|
23
|
+
const system = await nodeRemover.transform(inputSystem);
|
|
24
|
+
expect(system.findMicroService('A')).toBeUndefined();
|
|
25
|
+
expect(system.findMessageExchange('C')).toBeUndefined();
|
|
26
|
+
expect(system.findMicroService('D')).toBeDefined();
|
|
27
|
+
expect(system.findMicroService('E')).toBeDefined();
|
|
28
|
+
expect(system.nodes).toHaveLength(2);
|
|
29
|
+
expect(system.edges).toHaveLength(1);
|
|
30
|
+
expect(system.edges[0].source.id).toEqual(serviceD.id);
|
|
31
|
+
expect(system.edges[0].target.id).toEqual(serviceE.id);
|
|
32
|
+
expect(system.content.metadata.transformer).toEqual(StaticNodeFilter_1.StaticNodeFilter.name);
|
|
33
|
+
expect(system.content.metadata.info).toEqual('AAA, C');
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
//# sourceMappingURL=StaticNodeFilter.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StaticNodeFilter.test.js","sourceRoot":"","sources":["../../../src/post-processors/StaticNodeFilter.test.ts"],"names":[],"mappings":";;AAAA,6DAAwD;AAExD,yDAAqD;AACrD,oCAAoD;AAEpD,IAAI,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAA;AAErC,QAAQ,CAAC,mCAAgB,CAAC,IAAI,EAAE,GAAG,EAAE;IAEnC,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAG,EAAE;QAC3C,MAAM,WAAW,GAAG,IAAI,WAAM,CAAC,QAAQ,CAAC,CAAA;QAExC,MAAM,UAAU,GAAG,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,CAAA;QACrD,WAAW,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;QACrC,MAAM,SAAS,GAAG,WAAW,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAA;QACrD,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,mBAAc,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAA;QAEjE,MAAM,QAAQ,GAAG,WAAW,CAAC,eAAe,CAAC,GAAG,CAAC,CAAA;QACjD,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,mBAAc,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAA;QAE/D,MAAM,QAAQ,GAAG,WAAW,CAAC,eAAe,CAAC,GAAG,CAAC,CAAA;QACjD,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,mBAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAA;QAE9D,8BAAa,CAAC,SAAS,CAAC,oBAAoB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE;YAC/E,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;QACrB,CAAC,CAAC,CAAA;QAEF,MAAM,MAAM,GAAG,IAAI,8BAAa,EAAE,CAAA;QAClC,MAAM,WAAW,GAAG,IAAI,mCAAgB,CAAC,MAAM,CAAC,CAAA;QAChD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,SAAS,CAAC,WAAW,CAAC,CAAA;QAEvD,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,CAAA;QACpD,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,CAAA;QACvD,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;QAClD,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;QAClD,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QAEpC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QACpC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QACtD,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAEtD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,mCAAgB,CAAC,IAAI,CAAC,CAAA;QAC1E,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IACxD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { System } from '../model/ms';
|
|
2
|
+
import { Node } from '../model/core';
|
|
3
|
+
type mapNodeToSubSystemNameFunction = (node: Node) => string;
|
|
4
|
+
/**
|
|
5
|
+
* Transforms a flat system to a system of sub-systems where each node
|
|
6
|
+
* is moved to its sub-system.
|
|
7
|
+
* The associated sub-system of a node is derived from its payload.
|
|
8
|
+
*/
|
|
9
|
+
export declare class SubSystemFromPayloadTransformer {
|
|
10
|
+
static readonly getSubSystemNameFromCabinetLabel: (node: Node) => string;
|
|
11
|
+
transform(system: System, getSubSystemName: mapNodeToSubSystemNameFunction): Promise<System>;
|
|
12
|
+
}
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,103 @@
|
|
|
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.SubSystemFromPayloadTransformer = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const ms_1 = require("../model/ms");
|
|
12
|
+
/**
|
|
13
|
+
* Transforms a flat system to a system of sub-systems where each node
|
|
14
|
+
* is moved to its sub-system.
|
|
15
|
+
* The associated sub-system of a node is derived from its payload.
|
|
16
|
+
*/
|
|
17
|
+
let SubSystemFromPayloadTransformer = class SubSystemFromPayloadTransformer {
|
|
18
|
+
// TODO: the transformer could be made more generic by transforming nodes of any kind instead of just systems
|
|
19
|
+
async transform(system, getSubSystemName) {
|
|
20
|
+
const transformer = new SubSystemTransformer(getSubSystemName);
|
|
21
|
+
return transformer.moveNodesToTheirSubSystems(system);
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
SubSystemFromPayloadTransformer.getSubSystemNameFromCabinetLabel = (node) => {
|
|
25
|
+
if (node.content.payload.labels) {
|
|
26
|
+
return node.content.payload.labels.cabinet;
|
|
27
|
+
}
|
|
28
|
+
return undefined;
|
|
29
|
+
};
|
|
30
|
+
SubSystemFromPayloadTransformer = __decorate([
|
|
31
|
+
(0, common_1.Injectable)()
|
|
32
|
+
], SubSystemFromPayloadTransformer);
|
|
33
|
+
exports.SubSystemFromPayloadTransformer = SubSystemFromPayloadTransformer;
|
|
34
|
+
class SubSystemTransformer {
|
|
35
|
+
constructor(getSubSystemName) {
|
|
36
|
+
this.getSubSystemName = getSubSystemName;
|
|
37
|
+
this.logger = new common_1.Logger(SubSystemTransformer.name);
|
|
38
|
+
}
|
|
39
|
+
moveNodesToTheirSubSystems(system) {
|
|
40
|
+
const transformedSystem = new ms_1.System(system.id);
|
|
41
|
+
transformedSystem.content = system.content;
|
|
42
|
+
system.nodes.forEach((childNode) => {
|
|
43
|
+
const subSystemName = this.computeSubSystemName(system, childNode);
|
|
44
|
+
if (subSystemName) {
|
|
45
|
+
const subSystem = this.getOrElseCreateSubSystem(transformedSystem, subSystemName);
|
|
46
|
+
subSystem.nodes.push(childNode);
|
|
47
|
+
this.logger.log(`added node ${childNode.id} to sub-system ${subSystemName}`);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
transformedSystem.nodes.push(childNode);
|
|
51
|
+
this.logger.log(`added node ${childNode.id} to root system`);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
system.edges.forEach((edge) => {
|
|
55
|
+
const sourceSubSystem = this.computeSubSystemName(system, edge.source);
|
|
56
|
+
const targetSubSystem = this.computeSubSystemName(system, edge.target);
|
|
57
|
+
if (sourceSubSystem &&
|
|
58
|
+
targetSubSystem &&
|
|
59
|
+
sourceSubSystem === targetSubSystem) {
|
|
60
|
+
const subSystem = this.getOrElseCreateSubSystem(transformedSystem, sourceSubSystem);
|
|
61
|
+
subSystem.edges.push(edge);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
transformedSystem.edges.push(edge);
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
return transformedSystem;
|
|
68
|
+
}
|
|
69
|
+
computeSubSystemName(system, node) {
|
|
70
|
+
const subSystemName = this.getSubSystemName(node);
|
|
71
|
+
if (subSystemName) {
|
|
72
|
+
return subSystemName;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
return this.deriveSubSystemFromIncomingNode(system, node);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
getOrElseCreateSubSystem(system, subSystemName) {
|
|
79
|
+
const existingNode = system.findTypedNodeWithName(ms_1.System, subSystemName);
|
|
80
|
+
if (existingNode)
|
|
81
|
+
return existingNode;
|
|
82
|
+
const newNode = new ms_1.System(subSystemName);
|
|
83
|
+
system.nodes.push(newNode);
|
|
84
|
+
this.logger.log(`added sub-system ${subSystemName}`);
|
|
85
|
+
return newNode;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* derives the sub-system of a node from its incoming node if there is just one
|
|
89
|
+
* and if it defines a sub-system.
|
|
90
|
+
*
|
|
91
|
+
* @param system
|
|
92
|
+
* @param node which is inspected for an incoming node
|
|
93
|
+
*/
|
|
94
|
+
deriveSubSystemFromIncomingNode(system, node) {
|
|
95
|
+
const incomingEdges = system.edges.filter((edge) => edge.target.id === node.id);
|
|
96
|
+
if (incomingEdges.length === 1) {
|
|
97
|
+
const singleIncomingNode = incomingEdges[0].source;
|
|
98
|
+
return this.getSubSystemName(singleIncomingNode);
|
|
99
|
+
}
|
|
100
|
+
return undefined;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=SubSystemFromPayloadTransformer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubSystemFromPayloadTransformer.js","sourceRoot":"","sources":["../../../src/post-processors/SubSystemFromPayloadTransformer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|