tadis-analyzer 2.4.1 → 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 @@
|
|
|
1
|
+
{"version":3,"file":"GitStorage.controller.js","sourceRoot":"","sources":["../../../src/git/GitStorage.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA8D;AAC9D,6DAAwD;AAIjD,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAC/B,YAA6B,UAA6B;QAA7B,eAAU,GAAV,UAAU,CAAmB;IAAG,CAAC;IAE9D;;OAEG;IAEG,AAAN,KAAK,CAAC,0BAA0B;QAC9B,OAAO,IAAI,CAAC,gBAAgB,EAAE,CAAA;IAChC,CAAC;IAED;;OAEG;IAEG,AAAN,KAAK,CAAC,+BAA+B,CACV,cAAsB,EAChC,IAAY;QAE3B,OAAO,IAAI,CAAC,qBAAqB,CAAC,cAAc,EAAE,IAAI,CAAC,CAAA;IACzD,CAAC;IAED,gGAAgG;IAChG,wEAAwE;IAGlE,AAAN,KAAK,CAAC,gBAAgB;QACpB,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC;IAGK,AAAN,KAAK,CAAC,qBAAqB,CACA,cAAsB,EAChC,IAAY;QAE3B,IAAI,IAAI,KAAK,SAAS,EAAE;YACtB,OAAO,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,CAAA;SAChD;QAED,iDAAiD;QACjD,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAA;QAC/C,OAAO,mCAAmC,CAAA;IAC5C,CAAC;IAEO,KAAK,CAAC,mBAAmB,CAAC,cAAsB;QACtD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,cAAc,CAAC,CAAA;QACvE,IAAI,CAAC,SAAS,EAAE;YACd,OAAO,iBAAiB,CAAA;SACzB;QAED,OAAO,uBAAuB,GAAG,SAAS,CAAA;IAC5C,CAAC;CACF,CAAA;AA7CO;IADL,IAAA,YAAG,EAAC,eAAe,CAAC;;;;sEAGpB;AAMK;IADL,IAAA,YAAG,EAAC,yCAAyC,CAAC;IAE5C,WAAA,IAAA,cAAK,EAAC,gBAAgB,CAAC,CAAA;IACvB,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;;;;2EAGf;AAMK;IADL,IAAA,YAAG,EAAC,KAAK,CAAC;;;;4DAGV;AAGK;IADL,IAAA,YAAG,EAAC,4BAA4B,CAAC;IAE/B,WAAA,IAAA,cAAK,EAAC,gBAAgB,CAAC,CAAA;IACvB,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;;;;iEASf;AA1CU,oBAAoB;IADhC,IAAA,mBAAU,GAAE;qCAE8B,sCAAiB;GAD/C,oBAAoB,CAoDhC;AApDY,oDAAoB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const testing_1 = require("@nestjs/testing");
|
|
4
|
+
const GitStorage_controller_1 = require("./GitStorage.controller");
|
|
5
|
+
const GitStorage_service_1 = require("./GitStorage.service");
|
|
6
|
+
const Config_service_1 = require("../config/Config.service");
|
|
7
|
+
describe('SourceStorageController', () => {
|
|
8
|
+
let app;
|
|
9
|
+
beforeAll(async () => {
|
|
10
|
+
const configService = new Config_service_1.ConfigService();
|
|
11
|
+
jest
|
|
12
|
+
.spyOn(configService, 'getSourceFolder')
|
|
13
|
+
.mockImplementation(() => process.cwd() + '/src/git/testdata/source-folder');
|
|
14
|
+
app = await testing_1.Test.createTestingModule({
|
|
15
|
+
controllers: [GitStorage_controller_1.GitStorageController],
|
|
16
|
+
providers: [GitStorage_service_1.GitStorageService, Config_service_1.ConfigService]
|
|
17
|
+
})
|
|
18
|
+
.overrideProvider(Config_service_1.ConfigService)
|
|
19
|
+
.useValue(configService)
|
|
20
|
+
.compile();
|
|
21
|
+
});
|
|
22
|
+
describe('getStorageStatus', () => {
|
|
23
|
+
it('returns something', async () => {
|
|
24
|
+
const controller = app.get(GitStorage_controller_1.GitStorageController);
|
|
25
|
+
const status = await controller.getStorageStatus();
|
|
26
|
+
expect(status).not.toBeNull();
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
//# sourceMappingURL=GitStorage.controller.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GitStorage.controller.test.js","sourceRoot":"","sources":["../../../src/git/GitStorage.controller.test.ts"],"names":[],"mappings":";;AAAA,6CAAqD;AACrD,mEAA8D;AAC9D,6DAAwD;AACxD,6DAAwD;AAExD,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,IAAI,GAAkB,CAAA;IAEtB,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,aAAa,GAAG,IAAI,8BAAa,EAAE,CAAA;QACzC,IAAI;aACD,KAAK,CAAC,aAAa,EAAE,iBAAiB,CAAC;aACvC,kBAAkB,CACjB,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,iCAAiC,CACxD,CAAA;QAEH,GAAG,GAAG,MAAM,cAAI,CAAC,mBAAmB,CAAC;YACnC,WAAW,EAAE,CAAC,4CAAoB,CAAC;YACnC,SAAS,EAAE,CAAC,sCAAiB,EAAE,8BAAa,CAAC;SAC9C,CAAC;aACC,gBAAgB,CAAC,8BAAa,CAAC;aAC/B,QAAQ,CAAC,aAAa,CAAC;aACvB,OAAO,EAAE,CAAA;IACd,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAChC,EAAE,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE;YACjC,MAAM,UAAU,GAAG,GAAG,CAAC,GAAG,CAAuB,4CAAoB,CAAC,CAAA;YACtE,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,gBAAgB,EAAE,CAAA;YAClD,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAA;QAC/B,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export type StorageStatus = {
|
|
2
|
+
name: string;
|
|
3
|
+
location: string;
|
|
4
|
+
lastModified: Date;
|
|
5
|
+
};
|
|
6
|
+
export declare class GitStorage {
|
|
7
|
+
private sourceFolder;
|
|
8
|
+
private gitBaseUrls;
|
|
9
|
+
private readonly logger;
|
|
10
|
+
private readonly childProcessOptions;
|
|
11
|
+
constructor(sourceFolder: string, gitBaseUrls: string[]);
|
|
12
|
+
storeRepository(localRepositoryName: string, remoteRepositoryName: string): Promise<string | undefined>;
|
|
13
|
+
clearRepository(directoryName: string): void;
|
|
14
|
+
getStorageStatus(): Promise<StorageStatus[]>;
|
|
15
|
+
private storeRepositoryFromUrl;
|
|
16
|
+
private isRepositoryValid;
|
|
17
|
+
private isCloned;
|
|
18
|
+
private getGitPath;
|
|
19
|
+
private getLocalPath;
|
|
20
|
+
private updateRepository;
|
|
21
|
+
private cloneRepository;
|
|
22
|
+
private getChildExitCode;
|
|
23
|
+
}
|
|
@@ -0,0 +1,153 @@
|
|
|
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 __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.GitStorage = void 0;
|
|
27
|
+
const common_1 = require("@nestjs/common");
|
|
28
|
+
const cp = __importStar(require("child_process"));
|
|
29
|
+
const fs = __importStar(require("fs"));
|
|
30
|
+
const path = __importStar(require("path"));
|
|
31
|
+
const util_1 = require("util");
|
|
32
|
+
const rimraf = __importStar(require("rimraf"));
|
|
33
|
+
class GitStorage {
|
|
34
|
+
constructor(sourceFolder, gitBaseUrls) {
|
|
35
|
+
this.sourceFolder = sourceFolder;
|
|
36
|
+
this.gitBaseUrls = gitBaseUrls;
|
|
37
|
+
this.logger = new common_1.Logger(GitStorage.name);
|
|
38
|
+
this.childProcessOptions = {
|
|
39
|
+
cwd: process.cwd(),
|
|
40
|
+
env: process.env,
|
|
41
|
+
stdio: [process.stdin, process.stdout, process.stderr],
|
|
42
|
+
encoding: 'utf-8'
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
// TODO: improve error handling when ssh key is missing or not authorized
|
|
46
|
+
async storeRepository(localRepositoryName, remoteRepositoryName) {
|
|
47
|
+
for (const baseUrl of this.gitBaseUrls) {
|
|
48
|
+
const url = baseUrl + '/' + remoteRepositoryName;
|
|
49
|
+
const localPath = await this.storeRepositoryFromUrl(localRepositoryName, url);
|
|
50
|
+
if (localPath) {
|
|
51
|
+
return localPath;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
// TODO: maybe there is some way to check if a repository should be stored?
|
|
55
|
+
this.logger.warn('could not store repository ' + localRepositoryName +
|
|
56
|
+
(remoteRepositoryName !== localRepositoryName ? ' (remoteRepositoryName: ' + remoteRepositoryName + ') ' : '') +
|
|
57
|
+
' from any base URL!');
|
|
58
|
+
}
|
|
59
|
+
clearRepository(directoryName) {
|
|
60
|
+
rimraf.sync(this.getLocalPath(directoryName));
|
|
61
|
+
}
|
|
62
|
+
async getStorageStatus() {
|
|
63
|
+
const readdir = (0, util_1.promisify)(fs.readdir);
|
|
64
|
+
const repositories = await readdir(this.sourceFolder);
|
|
65
|
+
const repositoriesStatus = repositories.map(async (repository) => {
|
|
66
|
+
const stat = (0, util_1.promisify)(fs.stat);
|
|
67
|
+
const location = this.sourceFolder + '/' + repository;
|
|
68
|
+
const stats = await stat(location);
|
|
69
|
+
return {
|
|
70
|
+
name: repository,
|
|
71
|
+
location,
|
|
72
|
+
lastModified: stats.mtime
|
|
73
|
+
};
|
|
74
|
+
});
|
|
75
|
+
return Promise.all(repositoriesStatus);
|
|
76
|
+
}
|
|
77
|
+
async storeRepositoryFromUrl(repositoryName, repositoryUrl) {
|
|
78
|
+
const valid = await this.isRepositoryValid(repositoryUrl);
|
|
79
|
+
if (!valid) {
|
|
80
|
+
this.logger.log('could not read repository ' + repositoryUrl);
|
|
81
|
+
return undefined;
|
|
82
|
+
}
|
|
83
|
+
this.logger.log('storing repository ' + repositoryUrl);
|
|
84
|
+
if (this.isCloned(repositoryName)) {
|
|
85
|
+
return this.updateRepository(repositoryName);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
return this.cloneRepository(repositoryName, repositoryUrl);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
async isRepositoryValid(repositoryUrl) {
|
|
92
|
+
const child = cp.spawn('git', ['ls-remote', repositoryUrl], this.childProcessOptions);
|
|
93
|
+
const exitCode = await this.getChildExitCode(child);
|
|
94
|
+
return exitCode === 0;
|
|
95
|
+
}
|
|
96
|
+
isCloned(repositoryName) {
|
|
97
|
+
return fs.existsSync(this.getGitPath(repositoryName));
|
|
98
|
+
}
|
|
99
|
+
getGitPath(repositoryName) {
|
|
100
|
+
return path.resolve(this.getLocalPath(repositoryName), '.git');
|
|
101
|
+
}
|
|
102
|
+
getLocalPath(repositoryName) {
|
|
103
|
+
return path.resolve(this.sourceFolder, repositoryName);
|
|
104
|
+
}
|
|
105
|
+
async updateRepository(repositoryName) {
|
|
106
|
+
this.logger.log('pulling ' + repositoryName);
|
|
107
|
+
const gitPath = this.getGitPath(repositoryName);
|
|
108
|
+
const localPath = this.getLocalPath(repositoryName);
|
|
109
|
+
const child = cp.spawn('git', [
|
|
110
|
+
'--git-dir=' + gitPath,
|
|
111
|
+
'--work-tree=' + localPath,
|
|
112
|
+
'pull'
|
|
113
|
+
], this.childProcessOptions);
|
|
114
|
+
const exitCode = await this.getChildExitCode(child);
|
|
115
|
+
if (exitCode === 0) {
|
|
116
|
+
return localPath;
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
this.logger.error('failed to pull repository ', repositoryName);
|
|
120
|
+
return undefined;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
async cloneRepository(repositoryName, repositoryUrl) {
|
|
124
|
+
// INFO: using sync calls in an async call stack is an anti-pattern because it blocks the event processing loop.
|
|
125
|
+
if (!fs.existsSync(this.sourceFolder)) {
|
|
126
|
+
fs.mkdirSync(this.sourceFolder);
|
|
127
|
+
}
|
|
128
|
+
const localPath = this.getLocalPath(repositoryName);
|
|
129
|
+
if (!fs.existsSync(localPath)) {
|
|
130
|
+
fs.mkdirSync(localPath);
|
|
131
|
+
}
|
|
132
|
+
this.logger.log('cloning repository ' + repositoryUrl);
|
|
133
|
+
const child = cp.spawn('git', [
|
|
134
|
+
'clone',
|
|
135
|
+
'--depth', '1', repositoryUrl, localPath
|
|
136
|
+
], this.childProcessOptions);
|
|
137
|
+
const exitCode = await this.getChildExitCode(child);
|
|
138
|
+
if (exitCode === 0) {
|
|
139
|
+
return localPath;
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
this.logger.error('failed to clone repository from url ' + repositoryUrl);
|
|
143
|
+
return undefined;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
async getChildExitCode(child) {
|
|
147
|
+
return new Promise((resolve) => {
|
|
148
|
+
child.on('exit', (code) => resolve(code));
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
exports.GitStorage = GitStorage;
|
|
153
|
+
//# sourceMappingURL=GitStorage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GitStorage.js","sourceRoot":"","sources":["../../../src/git/GitStorage.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAAuC;AAEvC,kDAAmC;AACnC,uCAAwB;AACxB,2CAA4B;AAC5B,+BAAgC;AAChC,+CAAgC;AAQhC,MAAa,UAAU;IAUrB,YAAoB,YAAoB,EAAU,WAAqB;QAAnD,iBAAY,GAAZ,YAAY,CAAQ;QAAU,gBAAW,GAAX,WAAW,CAAU;QATtD,WAAM,GAAG,IAAI,eAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QAEpC,wBAAmB,GAAG;YACrC,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE;YAClB,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,KAAK,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC;YACtD,QAAQ,EAAE,OAAO;SAClB,CAAA;IAE0E,CAAC;IAE5E,yEAAyE;IACzE,KAAK,CAAC,eAAe,CAAC,mBAA2B,EAAE,oBAA4B;QAC7E,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,WAAW,EAAE;YACtC,MAAM,GAAG,GAAG,OAAO,GAAG,GAAG,GAAG,oBAAoB,CAAA;YAChD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,sBAAsB,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAA;YAC7E,IAAI,SAAS,EAAE;gBACb,OAAO,SAAS,CAAA;aACjB;SACF;QACD,2EAA2E;QAC3E,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6BAA6B,GAAG,mBAAmB;YAClE,CAAC,oBAAoB,KAAK,mBAAmB,CAAC,CAAC,CAAC,0BAA0B,GAAG,oBAAoB,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YAC9G,qBAAqB,CAAC,CAAA;IAC1B,CAAC;IAED,eAAe,CAAC,aAAqB;QACnC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAA;IAC/C,CAAC;IAED,KAAK,CAAC,gBAAgB;QACpB,MAAM,OAAO,GAAG,IAAA,gBAAS,EAAC,EAAE,CAAC,OAAO,CAAC,CAAA;QACrC,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;QAErD,MAAM,kBAAkB,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,EAAC,UAAU,EAAC,EAAE;YAC7D,MAAM,IAAI,GAAG,IAAA,gBAAS,EAAC,EAAE,CAAC,IAAI,CAAC,CAAA;YAC/B,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,GAAG,GAAG,GAAG,UAAU,CAAA;YACrD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAA;YAClC,OAAO;gBACL,IAAI,EAAE,UAAU;gBAChB,QAAQ;gBACR,YAAY,EAAE,KAAK,CAAC,KAAK;aAC1B,CAAA;QACH,CAAC,CAAC,CAAA;QAEF,OAAO,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;IACxC,CAAC;IAEO,KAAK,CAAC,sBAAsB,CAAC,cAAsB,EAAE,aAAqB;QAChF,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAA;QACzD,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,4BAA4B,GAAG,aAAa,CAAC,CAAA;YAC7D,OAAO,SAAS,CAAA;SACjB;QAED,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,qBAAqB,GAAG,aAAa,CAAC,CAAA;QACtD,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE;YACjC,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAA;SAC7C;aAAM;YACL,OAAO,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,aAAa,CAAC,CAAA;SAC3D;IACH,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAAC,aAAqB;QACnD,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,WAAW,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAA;QAErF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAA;QACnD,OAAO,QAAQ,KAAK,CAAC,CAAA;IACvB,CAAC;IAEO,QAAQ,CAAC,cAAsB;QACrC,OAAO,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,CAAA;IACvD,CAAC;IAEO,UAAU,CAAC,cAAsB;QACvC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,CAAA;IAChE,CAAC;IAEO,YAAY,CAAC,cAAsB;QACzC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC,CAAA;IACxD,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAAC,cAAsB;QACnD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,GAAG,cAAc,CAAC,CAAA;QAE5C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,CAAA;QAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAA;QAEnD,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE;YAC5B,YAAY,GAAG,OAAO;YACtB,cAAc,GAAG,SAAS;YAC1B,MAAM;SACP,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAA;QAE5B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAA;QACnD,IAAI,QAAQ,KAAK,CAAC,EAAE;YAClB,OAAO,SAAS,CAAA;SACjB;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,4BAA4B,EAAE,cAAc,CAAC,CAAA;YAC/D,OAAO,SAAS,CAAA;SACjB;IACH,CAAC;IAEO,KAAK,CAAC,eAAe,CAAC,cAAsB,EAAE,aAAqB;QACzE,gHAAgH;QAChH,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;YACrC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;SAChC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAA;QACnD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;YAC7B,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAA;SACxB;QAED,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,qBAAqB,GAAG,aAAa,CAAC,CAAA;QAEtD,MAAM,KAAK,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE;YAC5B,OAAO;YACP,SAAS,EAAE,GAAG,EAAE,aAAa,EAAE,SAAS;SACzC,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAA;QAE5B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAA;QACnD,IAAI,QAAQ,KAAK,CAAC,EAAE;YAClB,OAAO,SAAS,CAAA;SACjB;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,GAAG,aAAa,CAAC,CAAA;YACzE,OAAO,SAAS,CAAA;SACjB;IACH,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAAC,KAAsB;QACnD,OAAO,IAAI,OAAO,CAChB,CAAC,OAAO,EAAE,EAAE;YACV,KAAK,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA;QAC3C,CAAC,CAAC,CAAA;IACN,CAAC;CAEF;AA1ID,gCA0IC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ConfigService } from '../config/Config.service';
|
|
2
|
+
import { StorageStatus } from './GitStorage';
|
|
3
|
+
export declare class GitStorageService {
|
|
4
|
+
private config;
|
|
5
|
+
private readonly gitStorage;
|
|
6
|
+
constructor(config: ConfigService);
|
|
7
|
+
storeRepository(repositoryName: string, remoteRepositoryName?: string): Promise<string | undefined>;
|
|
8
|
+
getStorageStatus(): Promise<StorageStatus[]>;
|
|
9
|
+
clearRepository(directoryName: string): void;
|
|
10
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
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.GitStorageService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const Config_service_1 = require("../config/Config.service");
|
|
15
|
+
const GitStorage_1 = require("./GitStorage");
|
|
16
|
+
let GitStorageService = class GitStorageService {
|
|
17
|
+
constructor(config) {
|
|
18
|
+
this.config = config;
|
|
19
|
+
this.gitStorage = new GitStorage_1.GitStorage(config.getSourceFolder(), config.getGitBaseUrls());
|
|
20
|
+
}
|
|
21
|
+
async storeRepository(repositoryName, remoteRepositoryName) {
|
|
22
|
+
return this.gitStorage.storeRepository(repositoryName, remoteRepositoryName !== null && remoteRepositoryName !== void 0 ? remoteRepositoryName : repositoryName);
|
|
23
|
+
}
|
|
24
|
+
async getStorageStatus() {
|
|
25
|
+
return this.gitStorage.getStorageStatus();
|
|
26
|
+
}
|
|
27
|
+
clearRepository(directoryName) {
|
|
28
|
+
this.gitStorage.clearRepository(directoryName);
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
GitStorageService = __decorate([
|
|
32
|
+
(0, common_1.Injectable)(),
|
|
33
|
+
__metadata("design:paramtypes", [Config_service_1.ConfigService])
|
|
34
|
+
], GitStorageService);
|
|
35
|
+
exports.GitStorageService = GitStorageService;
|
|
36
|
+
//# sourceMappingURL=GitStorage.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GitStorage.service.js","sourceRoot":"","sources":["../../../src/git/GitStorage.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA2C;AAE3C,6DAAwD;AACxD,6CAAwD;AAGjD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAG5B,YAAoB,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;QACvC,IAAI,CAAC,UAAU,GAAG,IAAI,uBAAU,CAC9B,MAAM,CAAC,eAAe,EAAE,EACxB,MAAM,CAAC,cAAc,EAAE,CACxB,CAAA;IACH,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,cAAsB,EAAE,oBAA6B;QACzE,OAAO,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,cAAc,EAAE,oBAAoB,aAApB,oBAAoB,cAApB,oBAAoB,GAAI,cAAc,CAAC,CAAA;IAChG,CAAC;IAED,KAAK,CAAC,gBAAgB;QACpB,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAA;IAC3C,CAAC;IAED,eAAe,CAAC,aAAqB;QACnC,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,aAAa,CAAC,CAAA;IAChD,CAAC;CACF,CAAA;AArBY,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAIiB,8BAAa;GAH9B,iBAAiB,CAqB7B;AArBY,8CAAiB"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { GitStorageService } from './GitStorage.service';
|
|
2
|
+
import { System } from '../model/ms';
|
|
3
|
+
/**
|
|
4
|
+
* Decorates each microservice of the system for which source code was stored.
|
|
5
|
+
* Adds the local source location of the source code.
|
|
6
|
+
*/
|
|
7
|
+
export declare class SourceLocationDecorator {
|
|
8
|
+
private gitStorage;
|
|
9
|
+
constructor(gitStorage: GitStorageService);
|
|
10
|
+
transform(system: System): Promise<System>;
|
|
11
|
+
private setLocationUnknownForServicesWithoutSource;
|
|
12
|
+
}
|
|
@@ -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
|
+
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.SourceLocationDecorator = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const GitStorage_service_1 = require("./GitStorage.service");
|
|
15
|
+
/**
|
|
16
|
+
* Decorates each microservice of the system for which source code was stored.
|
|
17
|
+
* Adds the local source location of the source code.
|
|
18
|
+
*/
|
|
19
|
+
let SourceLocationDecorator = class SourceLocationDecorator {
|
|
20
|
+
constructor(gitStorage) {
|
|
21
|
+
this.gitStorage = gitStorage;
|
|
22
|
+
}
|
|
23
|
+
async transform(system) {
|
|
24
|
+
const storageStatus = await this.gitStorage.getStorageStatus();
|
|
25
|
+
storageStatus.forEach((status) => {
|
|
26
|
+
const service = system.findMicroService(status.name);
|
|
27
|
+
if (service) {
|
|
28
|
+
service.getPayload().sourceLocation = status.location;
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
this.setLocationUnknownForServicesWithoutSource(system);
|
|
32
|
+
return system;
|
|
33
|
+
}
|
|
34
|
+
setLocationUnknownForServicesWithoutSource(system) {
|
|
35
|
+
system
|
|
36
|
+
.getMicroServices()
|
|
37
|
+
.filter((service) => service.getPayload().sourceLocation === undefined)
|
|
38
|
+
.forEach((service) => (service.getPayload().sourceLocation = ''));
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
SourceLocationDecorator = __decorate([
|
|
42
|
+
(0, common_1.Injectable)(),
|
|
43
|
+
__metadata("design:paramtypes", [GitStorage_service_1.GitStorageService])
|
|
44
|
+
], SourceLocationDecorator);
|
|
45
|
+
exports.SourceLocationDecorator = SourceLocationDecorator;
|
|
46
|
+
//# sourceMappingURL=SourceLocationDecorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SourceLocationDecorator.js","sourceRoot":"","sources":["../../../src/git/SourceLocationDecorator.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA2C;AAE3C,6DAAwD;AAGxD;;;GAGG;AAEI,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAClC,YAAoB,UAA6B;QAA7B,eAAU,GAAV,UAAU,CAAmB;IAAG,CAAC;IAE9C,KAAK,CAAC,SAAS,CAAC,MAAc;QACnC,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAA;QAC9D,aAAa,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC/B,MAAM,OAAO,GAAG,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YACpD,IAAI,OAAO,EAAE;gBACX,OAAO,CAAC,UAAU,EAAE,CAAC,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAA;aACtD;QACH,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,0CAA0C,CAAC,MAAM,CAAC,CAAA;QACvD,OAAO,MAAM,CAAA;IACf,CAAC;IAEO,0CAA0C,CAAC,MAAc;QAC/D,MAAM;aACH,gBAAgB,EAAE;aAClB,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC,cAAc,KAAK,SAAS,CAAC;aACtE,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC,cAAc,GAAG,EAAE,CAAC,CAAC,CAAA;IACrE,CAAC;CACF,CAAA;AArBY,uBAAuB;IADnC,IAAA,mBAAU,GAAE;qCAEqB,sCAAiB;GADtC,uBAAuB,CAqBnC;AArBY,0DAAuB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const testing_1 = require("@nestjs/testing");
|
|
4
|
+
const SourceLocationDecorator_1 = require("./SourceLocationDecorator");
|
|
5
|
+
const GitStorage_service_1 = require("./GitStorage.service");
|
|
6
|
+
const ms_1 = require("../model/ms");
|
|
7
|
+
const Config_service_1 = require("../config/Config.service");
|
|
8
|
+
describe(SourceLocationDecorator_1.SourceLocationDecorator.name, () => {
|
|
9
|
+
let app;
|
|
10
|
+
beforeAll(async () => {
|
|
11
|
+
app = await testing_1.Test.createTestingModule({
|
|
12
|
+
providers: [GitStorage_service_1.GitStorageService, Config_service_1.ConfigService, SourceLocationDecorator_1.SourceLocationDecorator]
|
|
13
|
+
}).compile();
|
|
14
|
+
});
|
|
15
|
+
it('decorates', async () => {
|
|
16
|
+
const inputSystem = new ms_1.System('test');
|
|
17
|
+
inputSystem.addMicroService('service1');
|
|
18
|
+
inputSystem.addMicroService('service2');
|
|
19
|
+
const testStorageStatus = [
|
|
20
|
+
{
|
|
21
|
+
name: 'service1',
|
|
22
|
+
location: '/source/service1',
|
|
23
|
+
lastModified: new Date()
|
|
24
|
+
}
|
|
25
|
+
];
|
|
26
|
+
const gitStorage = app.get(GitStorage_service_1.GitStorageService);
|
|
27
|
+
const gitStorageSpy = jest.spyOn(gitStorage, 'getStorageStatus');
|
|
28
|
+
gitStorageSpy.mockImplementation(async () => testStorageStatus);
|
|
29
|
+
const decorator = app.get(SourceLocationDecorator_1.SourceLocationDecorator);
|
|
30
|
+
const system = await decorator.transform(inputSystem);
|
|
31
|
+
expect(system.findMicroService('service1').getPayload().sourceLocation).toEqual('/source/service1');
|
|
32
|
+
expect(system.findMicroService('service2').getPayload().sourceLocation).toEqual('');
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=SourceLocationDecorator.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SourceLocationDecorator.test.js","sourceRoot":"","sources":["../../../src/git/SourceLocationDecorator.test.ts"],"names":[],"mappings":";;AAAA,6CAAqD;AAErD,uEAAmE;AACnE,6DAAwD;AAExD,oCAAoC;AACpC,6DAAwD;AAExD,QAAQ,CAAC,iDAAuB,CAAC,IAAI,EAAE,GAAG,EAAE;IAC1C,IAAI,GAAkB,CAAA;IAEtB,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,GAAG,GAAG,MAAM,cAAI,CAAC,mBAAmB,CAAC;YACnC,SAAS,EAAE,CAAC,sCAAiB,EAAE,8BAAa,EAAE,iDAAuB,CAAC;SACvE,CAAC,CAAC,OAAO,EAAE,CAAA;IACd,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,WAAW,EAAE,KAAK,IAAI,EAAE;QACzB,MAAM,WAAW,GAAG,IAAI,WAAM,CAAC,MAAM,CAAC,CAAA;QACtC,WAAW,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;QACvC,WAAW,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;QAEvC,MAAM,iBAAiB,GAAoB;YACzC;gBACE,IAAI,EAAE,UAAU;gBAChB,QAAQ,EAAE,kBAAkB;gBAC5B,YAAY,EAAE,IAAI,IAAI,EAAE;aACzB;SACF,CAAA;QACD,MAAM,UAAU,GAAG,GAAG,CAAC,GAAG,CAAoB,sCAAiB,CAAC,CAAA;QAChE,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAA;QAChE,aAAa,CAAC,kBAAkB,CAAC,KAAK,IAAI,EAAE,CAAC,iBAAiB,CAAC,CAAA;QAE/D,MAAM,SAAS,GAAG,GAAG,CAAC,GAAG,CAA0B,iDAAuB,CAAC,CAAA;QAC3E,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,SAAS,CAAC,WAAW,CAAC,CAAA;QAErD,MAAM,CACJ,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,UAAU,EAAE,CAAC,cAAc,CAChE,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAA;QAC7B,MAAM,CACJ,MAAM,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,UAAU,EAAE,CAAC,cAAc,CAChE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;IACf,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import * as core from './model/core';
|
|
2
|
+
import * as ms from './model/ms';
|
|
3
|
+
import * as transport from './model/transport';
|
|
4
|
+
export { ms, core, transport };
|
|
5
|
+
export * from './model/core';
|
|
6
|
+
export * from './model/ms';
|
|
7
|
+
export * from './config/Config.module';
|
|
8
|
+
export * from './git/Git.module';
|
|
9
|
+
export * from './system-element-extractors/java/Java.module';
|
|
10
|
+
export * from './system-element-extractors/env-variables/EnvVariables.module';
|
|
11
|
+
export * from './system-element-extractors/kubernetes/Kubernetes.module';
|
|
12
|
+
export * from './system-element-extractors/rabbitmq/RabbitMq.module';
|
|
13
|
+
export * from './system-element-extractors/spring-boot/SpringBoot.module';
|
|
14
|
+
export * from './system-assemblers/controllers/SystemAssembler.module';
|
|
15
|
+
export * from './system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module';
|
|
16
|
+
export * from './post-processors/PostProcessors.module';
|
|
17
|
+
import * as fileAnalysis from './utils/files/analysis';
|
|
18
|
+
export { fileAnalysis };
|
|
19
|
+
export * from './deprecated-modules/SourceCodeAnalysis.module';
|
|
20
|
+
export * from './deprecated-modules/CommonTransformers.module';
|
|
21
|
+
export * from './deprecated-modules/Msa.module';
|
package/build/src/lib.js
ADDED
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// don't use typescript path alias here. imported types won't be available
|
|
3
|
+
// in other typescript projects which depend on this one.
|
|
4
|
+
// it's ok to use path alias in tests.
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
17
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
18
|
+
}) : function(o, v) {
|
|
19
|
+
o["default"] = v;
|
|
20
|
+
});
|
|
21
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
22
|
+
if (mod && mod.__esModule) return mod;
|
|
23
|
+
var result = {};
|
|
24
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
25
|
+
__setModuleDefault(result, mod);
|
|
26
|
+
return result;
|
|
27
|
+
};
|
|
28
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
29
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
30
|
+
};
|
|
31
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
32
|
+
exports.fileAnalysis = exports.transport = exports.core = exports.ms = void 0;
|
|
33
|
+
const core = __importStar(require("./model/core"));
|
|
34
|
+
exports.core = core;
|
|
35
|
+
const ms = __importStar(require("./model/ms"));
|
|
36
|
+
exports.ms = ms;
|
|
37
|
+
const transport = __importStar(require("./model/transport"));
|
|
38
|
+
exports.transport = transport;
|
|
39
|
+
__exportStar(require("./model/core"), exports);
|
|
40
|
+
__exportStar(require("./model/ms"), exports);
|
|
41
|
+
__exportStar(require("./config/Config.module"), exports);
|
|
42
|
+
__exportStar(require("./git/Git.module"), exports);
|
|
43
|
+
__exportStar(require("./system-element-extractors/java/Java.module"), exports);
|
|
44
|
+
__exportStar(require("./system-element-extractors/env-variables/EnvVariables.module"), exports);
|
|
45
|
+
__exportStar(require("./system-element-extractors/kubernetes/Kubernetes.module"), exports);
|
|
46
|
+
__exportStar(require("./system-element-extractors/rabbitmq/RabbitMq.module"), exports);
|
|
47
|
+
__exportStar(require("./system-element-extractors/spring-boot/SpringBoot.module"), exports);
|
|
48
|
+
__exportStar(require("./system-assemblers/controllers/SystemAssembler.module"), exports);
|
|
49
|
+
__exportStar(require("./system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module"), exports);
|
|
50
|
+
__exportStar(require("./post-processors/PostProcessors.module"), exports);
|
|
51
|
+
const fileAnalysis = __importStar(require("./utils/files/analysis"));
|
|
52
|
+
exports.fileAnalysis = fileAnalysis;
|
|
53
|
+
// deprecated exports
|
|
54
|
+
__exportStar(require("./deprecated-modules/SourceCodeAnalysis.module"), exports);
|
|
55
|
+
__exportStar(require("./deprecated-modules/CommonTransformers.module"), exports);
|
|
56
|
+
__exportStar(require("./deprecated-modules/Msa.module"), exports);
|
|
57
|
+
//# sourceMappingURL=lib.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../../src/lib.ts"],"names":[],"mappings":";AAAA,0EAA0E;AAC1E,yDAAyD;AACzD,sCAAsC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtC,mDAAoC;AAGvB,oBAAI;AAFjB,+CAAgC;AAEvB,gBAAE;AADX,6DAA8C;AAC3B,8BAAS;AAE5B,+CAA4B;AAC5B,6CAA0B;AAE1B,yDAAsC;AACtC,mDAAgC;AAEhC,+EAA4D;AAC5D,gGAA6E;AAC7E,2FAAwE;AACxE,uFAAoE;AACpE,4FAAyE;AAEzE,yFAAsE;AACtE,6GAA0F;AAE1F,0EAAuD;AAEvD,qEAAsD;AAC7C,oCAAY;AAErB,qBAAqB;AACrB,iFAA8D;AAC9D,iFAA8D;AAC9D,kEAA+C"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Node, Edge, Metadata } from './core';
|
|
2
|
+
export declare class TypedNode<Payload> extends Node {
|
|
3
|
+
constructor(id: string, payload: Payload, metadata: Metadata | undefined, typeName: string);
|
|
4
|
+
getNodes<NodeType extends Node>(type: Type<NodeType>): NodeType[];
|
|
5
|
+
addOrExtendTypedNode(type: string, name: string, extraPayload?: any, metadata?: Metadata): Node;
|
|
6
|
+
addOrExtendNamedNode<NodeType extends TypedNode<Payload>>(type: TypeExtendsTypedNode<NodeType, Payload>, name: string, extraPayload?: any, metadata?: Metadata): NodeType;
|
|
7
|
+
findTypedNodeWithName<NodeType extends TypedNode<Payload>>(type: Type<NodeType>, name: string): NodeType;
|
|
8
|
+
getEdges<EdgeType extends Edge>(type: Type<EdgeType>): EdgeType[];
|
|
9
|
+
getPayload(): Payload;
|
|
10
|
+
}
|
|
11
|
+
export declare class TypedEdge<Payload> extends Edge {
|
|
12
|
+
constructor(source: Node, target: Node, payload: Payload, metadata: Metadata | undefined, typeName: string);
|
|
13
|
+
getPayload(): Payload | undefined;
|
|
14
|
+
}
|
|
15
|
+
interface Type<T> extends Function {
|
|
16
|
+
new (...args: any[]): T;
|
|
17
|
+
}
|
|
18
|
+
interface TypeExtendsTypedNode<Type, Payload> extends Function {
|
|
19
|
+
new (id: string, payload: Payload, metadata: Metadata | undefined, typeName: string): Type;
|
|
20
|
+
}
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,89 @@
|
|
|
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 __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.TypedEdge = exports.TypedNode = void 0;
|
|
27
|
+
const common_1 = require("@nestjs/common");
|
|
28
|
+
const core_1 = require("./core");
|
|
29
|
+
// tslint:disable-next-line
|
|
30
|
+
const ms = __importStar(require("./ms"));
|
|
31
|
+
const logContext = 'core-typed';
|
|
32
|
+
class TypedNode extends core_1.Node {
|
|
33
|
+
constructor(id, payload, metadata, typeName) {
|
|
34
|
+
super(id, new core_1.Content(typeName, metadata, payload));
|
|
35
|
+
}
|
|
36
|
+
getNodes(type) {
|
|
37
|
+
return this.nodes
|
|
38
|
+
.filter(node => node.content.type === type.name)
|
|
39
|
+
.map(node => node);
|
|
40
|
+
}
|
|
41
|
+
addOrExtendTypedNode(type, name, extraPayload = {}, metadata) {
|
|
42
|
+
const node = this.ensureContainsNodeOfTypeAndName(type, name, extraPayload, metadata);
|
|
43
|
+
// TODO: does not work for methods inherited from TypedNode
|
|
44
|
+
Object.assign(node, new ms[type](node.id, node.content.payload, metadata));
|
|
45
|
+
return node;
|
|
46
|
+
}
|
|
47
|
+
addOrExtendNamedNode(type, name, extraPayload = {}, metadata) {
|
|
48
|
+
const existingNode = this.findTypedNodeWithName(type, name);
|
|
49
|
+
if (existingNode) {
|
|
50
|
+
if (extraPayload) {
|
|
51
|
+
Object.getOwnPropertyNames(extraPayload)
|
|
52
|
+
.forEach(payloadPropertyName => existingNode.content.payload[payloadPropertyName] = extraPayload[payloadPropertyName]);
|
|
53
|
+
}
|
|
54
|
+
return existingNode;
|
|
55
|
+
}
|
|
56
|
+
const node = new type(this.id + '__' + type.name + '_' + name, { name, ...extraPayload }, metadata,
|
|
57
|
+
// keep type name as last parameter because classes inheriting from TypedNode omit the type name
|
|
58
|
+
// in their own constructors.
|
|
59
|
+
type.name);
|
|
60
|
+
if (node.content.type !== type.name) {
|
|
61
|
+
common_1.Logger.error('created node of type ' + type.name + ' but type was not set in content.', undefined, logContext);
|
|
62
|
+
}
|
|
63
|
+
this.nodes.push(node);
|
|
64
|
+
return node;
|
|
65
|
+
}
|
|
66
|
+
findTypedNodeWithName(type, name) {
|
|
67
|
+
return this.findNodeOfTypeWithName(type.name, name);
|
|
68
|
+
}
|
|
69
|
+
getEdges(type) {
|
|
70
|
+
return this.edges
|
|
71
|
+
.filter(edge => { var _a; return ((_a = edge.content) === null || _a === void 0 ? void 0 : _a.type) === type.name; })
|
|
72
|
+
.map(edge => edge);
|
|
73
|
+
}
|
|
74
|
+
getPayload() {
|
|
75
|
+
return this.content.payload;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.TypedNode = TypedNode;
|
|
79
|
+
class TypedEdge extends core_1.Edge {
|
|
80
|
+
constructor(source, target, payload, metadata, typeName) {
|
|
81
|
+
super(source, target, new core_1.Content(typeName, metadata, payload));
|
|
82
|
+
}
|
|
83
|
+
getPayload() {
|
|
84
|
+
var _a;
|
|
85
|
+
return (_a = this.content) === null || _a === void 0 ? void 0 : _a.payload;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
exports.TypedEdge = TypedEdge;
|
|
89
|
+
//# sourceMappingURL=core-typed.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-typed.js","sourceRoot":"","sources":["../../../src/model/core-typed.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const ms_1 = require("./ms");
|
|
4
|
+
const core_typed_1 = require("./core-typed");
|
|
5
|
+
class TestNode extends core_typed_1.TypedNode {
|
|
6
|
+
constructor(id, payload, metadata) {
|
|
7
|
+
super(id, payload, metadata, TestNode.name);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
describe('core-typed', () => {
|
|
11
|
+
it('add named node only once and extend payload', () => {
|
|
12
|
+
const system = new ms_1.System('test');
|
|
13
|
+
const node = system.addOrExtendNamedNode(TestNode, 'name');
|
|
14
|
+
system.addOrExtendNamedNode(TestNode, 'name', { p1: '1' });
|
|
15
|
+
system.addOrExtendNamedNode(TestNode, 'name', { p2: '2' });
|
|
16
|
+
expect(system.nodes).toHaveLength(1);
|
|
17
|
+
expect(node.getPayload().name).toEqual('name');
|
|
18
|
+
expect(system.findTypedNodeWithName(TestNode, 'name')).toBeDefined();
|
|
19
|
+
expect(node.content.payload.p1).toEqual('1');
|
|
20
|
+
expect(node.content.payload.p2).toEqual('2');
|
|
21
|
+
});
|
|
22
|
+
it.skip('adds nodes with an object of the given type', () => {
|
|
23
|
+
const system = new ms_1.System('test');
|
|
24
|
+
const node = system.addOrExtendTypedNode(ms_1.MessageExchange.name, 'name', undefined);
|
|
25
|
+
expect(node.getName()).toEqual('name');
|
|
26
|
+
expect(node.getPayload().name).toEqual('name');
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=core-typed.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-typed.test.js","sourceRoot":"","sources":["../../../src/model/core-typed.test.ts"],"names":[],"mappings":";;AAAA,6BAA2D;AAC3D,6CAAwC;AAGxC,MAAM,QAAS,SAAQ,sBAAsB;IAC3C,YAAY,EAAU,EAAE,OAAoB,EAAE,QAAkB;QAC9D,KAAK,CAAC,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC7C,CAAC;CACF;AAED,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAE1B,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,IAAI,WAAM,CAAC,MAAM,CAAC,CAAA;QAEjC,MAAM,IAAI,GAAG,MAAM,CAAC,oBAAoB,CAAW,QAAQ,EAAE,MAAM,CAAC,CAAA;QACpE,MAAM,CAAC,oBAAoB,CAAW,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAA;QACpE,MAAM,CAAC,oBAAoB,CAAW,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAA;QAEpE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QACpC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;QAC9C,MAAM,CAAC,MAAM,CAAC,qBAAqB,CAAW,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;QAE9E,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAC5C,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;IAC9C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,IAAI,CAAC,6CAA6C,EAAE,GAAG,EAAE;QAC1D,MAAM,MAAM,GAAG,IAAI,WAAM,CAAC,MAAM,CAAC,CAAA;QAEjC,MAAM,IAAI,GAAG,MAAM,CAAC,oBAAoB,CAAC,oBAAe,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,CAAC,CAAA;QAEjF,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;QACtC,MAAM,CAAE,IAA+B,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;IAC5E,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|