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.
Files changed (234) hide show
  1. package/build/src/app/code-pattern/main.d.ts +1 -0
  2. package/build/src/app/code-pattern/main.js +14 -0
  3. package/build/src/app/code-pattern/main.js.map +1 -0
  4. package/build/src/app/default/main.d.ts +1 -0
  5. package/build/src/app/default/main.js +15 -0
  6. package/build/src/app/default/main.js.map +1 -0
  7. package/build/src/app/error.d.ts +3 -0
  8. package/build/src/app/error.js +10 -0
  9. package/build/src/app/error.js.map +1 -0
  10. package/build/src/config/Config.module.d.ts +4 -0
  11. package/build/src/config/Config.module.js +28 -0
  12. package/build/src/config/Config.module.js.map +1 -0
  13. package/build/src/config/Config.service.d.ts +19 -0
  14. package/build/src/config/Config.service.js +105 -0
  15. package/build/src/config/Config.service.js.map +1 -0
  16. package/build/src/config/Config.service.test.d.ts +1 -0
  17. package/build/src/config/Config.service.test.js +33 -0
  18. package/build/src/config/Config.service.test.js.map +1 -0
  19. package/build/src/deprecated-modules/CommonTransformers.module.d.ts +5 -0
  20. package/build/src/deprecated-modules/CommonTransformers.module.js +34 -0
  21. package/build/src/deprecated-modules/CommonTransformers.module.js.map +1 -0
  22. package/build/src/deprecated-modules/Msa.module.d.ts +13 -0
  23. package/build/src/deprecated-modules/Msa.module.js +63 -0
  24. package/build/src/deprecated-modules/Msa.module.js.map +1 -0
  25. package/build/src/deprecated-modules/SourceCodeAnalysis.module.d.ts +6 -0
  26. package/build/src/deprecated-modules/SourceCodeAnalysis.module.js +60 -0
  27. package/build/src/deprecated-modules/SourceCodeAnalysis.module.js.map +1 -0
  28. package/build/src/git/Git.module.d.ts +5 -0
  29. package/build/src/git/Git.module.js +28 -0
  30. package/build/src/git/Git.module.js.map +1 -0
  31. package/build/src/git/GitStorage.controller.d.ts +17 -0
  32. package/build/src/git/GitStorage.controller.js +88 -0
  33. package/build/src/git/GitStorage.controller.js.map +1 -0
  34. package/build/src/git/GitStorage.controller.test.d.ts +1 -0
  35. package/build/src/git/GitStorage.controller.test.js +30 -0
  36. package/build/src/git/GitStorage.controller.test.js.map +1 -0
  37. package/build/src/git/GitStorage.d.ts +23 -0
  38. package/build/src/git/GitStorage.js +153 -0
  39. package/build/src/git/GitStorage.js.map +1 -0
  40. package/build/src/git/GitStorage.service.d.ts +10 -0
  41. package/build/src/git/GitStorage.service.js +36 -0
  42. package/build/src/git/GitStorage.service.js.map +1 -0
  43. package/build/src/git/SourceLocationDecorator.d.ts +12 -0
  44. package/build/src/git/SourceLocationDecorator.js +46 -0
  45. package/build/src/git/SourceLocationDecorator.js.map +1 -0
  46. package/build/src/git/SourceLocationDecorator.test.d.ts +1 -0
  47. package/build/src/git/SourceLocationDecorator.test.js +35 -0
  48. package/build/src/git/SourceLocationDecorator.test.js.map +1 -0
  49. package/build/src/lib.d.ts +21 -0
  50. package/build/src/lib.js +57 -0
  51. package/build/src/lib.js.map +1 -0
  52. package/build/src/model/core-typed.d.ts +21 -0
  53. package/build/src/model/core-typed.js +89 -0
  54. package/build/src/model/core-typed.js.map +1 -0
  55. package/build/src/model/core-typed.test.d.ts +1 -0
  56. package/build/src/model/core-typed.test.js +29 -0
  57. package/build/src/model/core-typed.test.js.map +1 -0
  58. package/build/src/model/core.d.ts +33 -0
  59. package/build/src/model/core.js +117 -0
  60. package/build/src/model/core.js.map +1 -0
  61. package/build/src/model/ms.d.ts +58 -0
  62. package/build/src/model/ms.js +83 -0
  63. package/build/src/model/ms.js.map +1 -0
  64. package/build/src/model/transport.d.ts +17 -0
  65. package/build/src/model/transport.js +20 -0
  66. package/build/src/model/transport.js.map +1 -0
  67. package/build/src/model/v1-legacy/model.d.ts +53 -0
  68. package/build/src/model/v1-legacy/model.js +85 -0
  69. package/build/src/model/v1-legacy/model.js.map +1 -0
  70. package/build/src/model/v1-legacy/v1-adapter.d.ts +3 -0
  71. package/build/src/model/v1-legacy/v1-adapter.js +68 -0
  72. package/build/src/model/v1-legacy/v1-adapter.js.map +1 -0
  73. package/build/src/model/v1-legacy/v1-adapter.test.d.ts +1 -0
  74. package/build/src/model/v1-legacy/v1-adapter.test.js +66 -0
  75. package/build/src/model/v1-legacy/v1-adapter.test.js.map +1 -0
  76. package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.d.ts +12 -0
  77. package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.js +107 -0
  78. package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.js.map +1 -0
  79. package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.d.ts +1 -0
  80. package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.js +111 -0
  81. package/build/src/post-processors/MicroserviceWithOutgoingExchangeMerger.test.js.map +1 -0
  82. package/build/src/post-processors/PostProcessors.module.d.ts +6 -0
  83. package/build/src/post-processors/PostProcessors.module.js +37 -0
  84. package/build/src/post-processors/PostProcessors.module.js.map +1 -0
  85. package/build/src/post-processors/PostProcessors.module.test.d.ts +1 -0
  86. package/build/src/post-processors/PostProcessors.module.test.js +23 -0
  87. package/build/src/post-processors/PostProcessors.module.test.js.map +1 -0
  88. package/build/src/post-processors/StaticNodeFilter.d.ts +9 -0
  89. package/build/src/post-processors/StaticNodeFilter.js +91 -0
  90. package/build/src/post-processors/StaticNodeFilter.js.map +1 -0
  91. package/build/src/post-processors/StaticNodeFilter.test.d.ts +1 -0
  92. package/build/src/post-processors/StaticNodeFilter.test.js +36 -0
  93. package/build/src/post-processors/StaticNodeFilter.test.js.map +1 -0
  94. package/build/src/post-processors/SubSystemFromPayloadTransformer.d.ts +13 -0
  95. package/build/src/post-processors/SubSystemFromPayloadTransformer.js +103 -0
  96. package/build/src/post-processors/SubSystemFromPayloadTransformer.js.map +1 -0
  97. package/build/src/post-processors/SubSystemFromPayloadTransformer.test.d.ts +1 -0
  98. package/build/src/post-processors/SubSystemFromPayloadTransformer.test.js +56 -0
  99. package/build/src/post-processors/SubSystemFromPayloadTransformer.test.js.map +1 -0
  100. package/build/src/system-assemblers/controllers/ISystemAssembler.d.ts +5 -0
  101. package/build/src/system-assemblers/controllers/ISystemAssembler.js +3 -0
  102. package/build/src/system-assemblers/controllers/ISystemAssembler.js.map +1 -0
  103. package/build/src/system-assemblers/controllers/SystemAssembler.controller.d.ts +19 -0
  104. package/build/src/system-assemblers/controllers/SystemAssembler.controller.js +95 -0
  105. package/build/src/system-assemblers/controllers/SystemAssembler.controller.js.map +1 -0
  106. package/build/src/system-assemblers/controllers/SystemAssembler.controller.test.d.ts +1 -0
  107. package/build/src/system-assemblers/controllers/SystemAssembler.controller.test.js +54 -0
  108. package/build/src/system-assemblers/controllers/SystemAssembler.controller.test.js.map +1 -0
  109. package/build/src/system-assemblers/controllers/SystemAssembler.module.d.ts +6 -0
  110. package/build/src/system-assemblers/controllers/SystemAssembler.module.js +28 -0
  111. package/build/src/system-assemblers/controllers/SystemAssembler.module.js.map +1 -0
  112. package/build/src/system-assemblers/controllers/SystemAssembler.service.d.ts +6 -0
  113. package/build/src/system-assemblers/controllers/SystemAssembler.service.js +24 -0
  114. package/build/src/system-assemblers/controllers/SystemAssembler.service.js.map +1 -0
  115. package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.d.ts +4 -0
  116. package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.js +46 -0
  117. package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.module.js.map +1 -0
  118. package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.d.ts +16 -0
  119. package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.js +53 -0
  120. package/build/src/system-assemblers/kubernetes-rabbitmq/KubernetesRabbitMqAssembler.service.js.map +1 -0
  121. package/build/src/system-element-extractors/env-variables/EnvVariables.module.d.ts +4 -0
  122. package/build/src/system-element-extractors/env-variables/EnvVariables.module.js +25 -0
  123. package/build/src/system-element-extractors/env-variables/EnvVariables.module.js.map +1 -0
  124. package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.d.ts +13 -0
  125. package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.js +64 -0
  126. package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.js.map +1 -0
  127. package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.d.ts +1 -0
  128. package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.js +56 -0
  129. package/build/src/system-element-extractors/env-variables/ExchangesFromEnvPayloadCreator.test.js.map +1 -0
  130. package/build/src/system-element-extractors/experimental/code-pattern/CodePattern.module.d.ts +4 -0
  131. package/build/src/system-element-extractors/experimental/code-pattern/CodePattern.module.js +26 -0
  132. package/build/src/system-element-extractors/experimental/code-pattern/CodePattern.module.js.map +1 -0
  133. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.controller.d.ts +8 -0
  134. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.controller.js +54 -0
  135. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.controller.js.map +1 -0
  136. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.d.ts +10 -0
  137. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.js +345 -0
  138. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.js.map +1 -0
  139. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.multiFile.test.d.ts +1 -0
  140. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.multiFile.test.js +130 -0
  141. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.multiFile.test.js.map +1 -0
  142. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.service.d.ts +16 -0
  143. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.service.js +47 -0
  144. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.service.js.map +1 -0
  145. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.singleFile.test.d.ts +1 -0
  146. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.singleFile.test.js +177 -0
  147. package/build/src/system-element-extractors/experimental/code-pattern/PatternAnalyzer.singleFile.test.js.map +1 -0
  148. package/build/src/system-element-extractors/experimental/code-pattern/behavior-model.d.ts +1 -0
  149. package/build/src/system-element-extractors/experimental/code-pattern/behavior-model.js +3 -0
  150. package/build/src/system-element-extractors/experimental/code-pattern/behavior-model.js.map +1 -0
  151. package/build/src/system-element-extractors/experimental/code-pattern/model.d.ts +116 -0
  152. package/build/src/system-element-extractors/experimental/code-pattern/model.js +23 -0
  153. package/build/src/system-element-extractors/experimental/code-pattern/model.js.map +1 -0
  154. package/build/src/system-element-extractors/experimental/code-pattern/prototyping/pattern-dsl.d.ts +8 -0
  155. package/build/src/system-element-extractors/experimental/code-pattern/prototyping/pattern-dsl.js +26 -0
  156. package/build/src/system-element-extractors/experimental/code-pattern/prototyping/pattern-dsl.js.map +1 -0
  157. package/build/src/system-element-extractors/experimental/code-pattern/prototyping/regexp-test.d.ts +0 -0
  158. package/build/src/system-element-extractors/experimental/code-pattern/prototyping/regexp-test.js +18 -0
  159. package/build/src/system-element-extractors/experimental/code-pattern/prototyping/regexp-test.js.map +1 -0
  160. package/build/src/system-element-extractors/java/Java.module.d.ts +4 -0
  161. package/build/src/system-element-extractors/java/Java.module.js +26 -0
  162. package/build/src/system-element-extractors/java/Java.module.js.map +1 -0
  163. package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.d.ts +35 -0
  164. package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.js +155 -0
  165. package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.js.map +1 -0
  166. package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.test.d.ts +1 -0
  167. package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.test.js +85 -0
  168. package/build/src/system-element-extractors/java/JavaAnnotationAnalyzer.test.js.map +1 -0
  169. package/build/src/system-element-extractors/kubernetes/Kubernetes.module.d.ts +7 -0
  170. package/build/src/system-element-extractors/kubernetes/Kubernetes.module.js +43 -0
  171. package/build/src/system-element-extractors/kubernetes/Kubernetes.module.js.map +1 -0
  172. package/build/src/system-element-extractors/kubernetes/api/api.service.d.ts +9 -0
  173. package/build/src/system-element-extractors/kubernetes/api/api.service.js +78 -0
  174. package/build/src/system-element-extractors/kubernetes/api/api.service.js.map +1 -0
  175. package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.d.ts +10 -0
  176. package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.js +80 -0
  177. package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.js.map +1 -0
  178. package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.test.d.ts +1 -0
  179. package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.test.js +32 -0
  180. package/build/src/system-element-extractors/kubernetes/transformer/EnvDefinitionFromPodDecorator.test.js.map +1 -0
  181. package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.d.ts +12 -0
  182. package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.js +82 -0
  183. package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.js.map +1 -0
  184. package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.test.d.ts +1 -0
  185. package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.test.js +30 -0
  186. package/build/src/system-element-extractors/kubernetes/transformer/LabelsFromDeploymentDecorator.test.js.map +1 -0
  187. package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.d.ts +12 -0
  188. package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.js +67 -0
  189. package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.js.map +1 -0
  190. package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.test.d.ts +1 -0
  191. package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.test.js +38 -0
  192. package/build/src/system-element-extractors/kubernetes/transformer/MicroservicesFromKubernetesCreator.test.js.map +1 -0
  193. package/build/src/system-element-extractors/kubernetes/transformer/testdata/api/deployments.json +256 -0
  194. package/build/src/system-element-extractors/kubernetes/transformer/testdata/api/pods.json +101 -0
  195. package/build/src/system-element-extractors/kubernetes/transformer/testdata/api/services.json +75 -0
  196. package/build/src/system-element-extractors/rabbitmq/RabbitMq.module.d.ts +6 -0
  197. package/build/src/system-element-extractors/rabbitmq/RabbitMq.module.js +38 -0
  198. package/build/src/system-element-extractors/rabbitmq/RabbitMq.module.js.map +1 -0
  199. package/build/src/system-element-extractors/rabbitmq/api/api.service.d.ts +11 -0
  200. package/build/src/system-element-extractors/rabbitmq/api/api.service.js +63 -0
  201. package/build/src/system-element-extractors/rabbitmq/api/api.service.js.map +1 -0
  202. package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.d.ts +9 -0
  203. package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.js +117 -0
  204. package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.js.map +1 -0
  205. package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.test.d.ts +1 -0
  206. package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.test.js +43 -0
  207. package/build/src/system-element-extractors/rabbitmq/transformer/OutgoingExchangesFromSourceCreator.test.js.map +1 -0
  208. package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.d.ts +14 -0
  209. package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.js +117 -0
  210. package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.js.map +1 -0
  211. package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.test.d.ts +1 -0
  212. package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.test.js +121 -0
  213. package/build/src/system-element-extractors/rabbitmq/transformer/RabbitMqBindingsFromApiAnalyzer.test.js.map +1 -0
  214. package/build/src/system-element-extractors/rabbitmq/transformer/testdata/api/bindings.json +20 -0
  215. package/build/src/system-element-extractors/rabbitmq/transformer/testdata/api/queues.json +5 -0
  216. package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.d.ts +15 -0
  217. package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.js +131 -0
  218. package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.js.map +1 -0
  219. package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.test.d.ts +1 -0
  220. package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.test.js +54 -0
  221. package/build/src/system-element-extractors/spring-boot/FeignClientAnnotationAnalyzer.test.js.map +1 -0
  222. package/build/src/system-element-extractors/spring-boot/SpringBoot.module.d.ts +4 -0
  223. package/build/src/system-element-extractors/spring-boot/SpringBoot.module.js +25 -0
  224. package/build/src/system-element-extractors/spring-boot/SpringBoot.module.js.map +1 -0
  225. package/build/src/test/expect-extensions.d.ts +7 -0
  226. package/build/src/test/expect-extensions.js +20 -0
  227. package/build/src/test/expect-extensions.js.map +1 -0
  228. package/build/src/test/verifiers.d.ts +4 -0
  229. package/build/src/test/verifiers.js +19 -0
  230. package/build/src/test/verifiers.js.map +1 -0
  231. package/build/src/utils/files/analysis.d.ts +30 -0
  232. package/build/src/utils/files/analysis.js +109 -0
  233. package/build/src/utils/files/analysis.js.map +1 -0
  234. 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":"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"}
@@ -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';
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAAuC;AAEvC,iCAAsD;AAEtD,2BAA2B;AAC3B,yCAA0B;AAE1B,MAAM,UAAU,GAAG,YAAY,CAAA;AAE/B,MAAa,SAAmB,SAAQ,WAAI;IAE1C,YAAY,EAAU,EAAE,OAAgB,EAAE,QAA8B,EAAE,QAAgB;QACxF,KAAK,CAAC,EAAE,EAAE,IAAI,cAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAA;IACrD,CAAC;IAEM,QAAQ,CAAwB,IAAoB;QACzD,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;aAC/C,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAgB,CAAC,CAAA;IAClC,CAAC;IAEM,oBAAoB,CACzB,IAAY,EAAE,IAAY,EAAE,eAAoB,EAAE,EAAE,QAAmB;QAEvE,MAAM,IAAI,GAAG,IAAI,CAAC,+BAA+B,CAAC,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAA;QAErF,2DAA2D;QAC3D,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAA;QAE1E,OAAO,IAAI,CAAA;IACb,CAAC;IAEM,oBAAoB,CACzB,IAA6C,EAAE,IAAY,EAAE,eAAoB,EAAE,EAAE,QAAmB;QAExG,MAAM,YAAY,GAAG,IAAI,CAAC,qBAAqB,CAAW,IAAI,EAAE,IAAI,CAAC,CAAA;QACrE,IAAI,YAAY,EAAE;YAChB,IAAI,YAAY,EAAE;gBAChB,MAAM,CAAC,mBAAmB,CAAC,YAAY,CAAC;qBACrC,OAAO,CAAC,mBAAmB,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,mBAAmB,CAAC,GAAG,YAAY,CAAC,mBAAmB,CAAC,CAAC,CAAA;aACzH;YACD,OAAO,YAAY,CAAA;SACpB;QAED,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,YAAY,EAAE,EAAE,QAAQ;QAChG,gGAAgG;QAChG,6BAA6B;QAC7B,IAAI,CAAC,IAAI,CAAC,CAAA;QACZ,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE;YACnC,eAAM,CAAC,KAAK,CAAC,uBAAuB,GAAG,IAAI,CAAC,IAAI,GAAG,mCAAmC,EAAE,SAAS,EAAE,UAAU,CAAC,CAAA;SAC/G;QACD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACrB,OAAO,IAAI,CAAA;IACb,CAAC;IAEM,qBAAqB,CAC1B,IAAoB,EAAE,IAAY;QAClC,OAAO,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAa,CAAA;IACjE,CAAC;IAEM,QAAQ,CAAwB,IAAoB;QACzD,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,IAAI,CAAC,EAAE,WAAC,OAAA,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,IAAI,MAAK,IAAI,CAAC,IAAI,CAAA,EAAA,CAAC;aAChD,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAgB,CAAC,CAAA;IAClC,CAAC;IAEM,UAAU;QACf,OAAO,IAAI,CAAC,OAAO,CAAC,OAAkB,CAAA;IACxC,CAAC;CACF;AA5DD,8BA4DC;AAED,MAAa,SAAmB,SAAQ,WAAI;IAE1C,YAAY,MAAY,EAAE,MAAY,EAAE,OAAgB,EAAE,QAA8B,EAAE,QAAgB;QACxG,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,cAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAA;IACjE,CAAC;IAEM,UAAU;;QACf,OAAO,MAAA,IAAI,CAAC,OAAO,0CAAE,OAAkB,CAAA;IACzC,CAAC;CACF;AATD,8BASC"}
@@ -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"}