@erode-app/core 0.6.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (326) hide show
  1. package/dist/adapters/adapter-factory.d.ts +3 -0
  2. package/dist/adapters/adapter-factory.d.ts.map +1 -0
  3. package/dist/adapters/adapter-factory.js +19 -0
  4. package/dist/adapters/adapter-factory.js.map +1 -0
  5. package/dist/adapters/adapter-metadata.d.ts +12 -0
  6. package/dist/adapters/adapter-metadata.d.ts.map +1 -0
  7. package/dist/adapters/adapter-metadata.js +2 -0
  8. package/dist/adapters/adapter-metadata.js.map +1 -0
  9. package/dist/adapters/architecture-adapter.d.ts +42 -0
  10. package/dist/adapters/architecture-adapter.d.ts.map +1 -0
  11. package/dist/adapters/architecture-adapter.js +2 -0
  12. package/dist/adapters/architecture-adapter.js.map +1 -0
  13. package/dist/adapters/architecture-types.d.ts +32 -0
  14. package/dist/adapters/architecture-types.d.ts.map +1 -0
  15. package/dist/adapters/architecture-types.js +2 -0
  16. package/dist/adapters/architecture-types.js.map +1 -0
  17. package/dist/adapters/base-patcher.d.ts +38 -0
  18. package/dist/adapters/base-patcher.d.ts.map +1 -0
  19. package/dist/adapters/base-patcher.js +266 -0
  20. package/dist/adapters/base-patcher.js.map +1 -0
  21. package/dist/adapters/dsl-validation.d.ts +2 -0
  22. package/dist/adapters/dsl-validation.d.ts.map +1 -0
  23. package/dist/adapters/dsl-validation.js +24 -0
  24. package/dist/adapters/dsl-validation.js.map +1 -0
  25. package/dist/adapters/likec4/adapter.d.ts +37 -0
  26. package/dist/adapters/likec4/adapter.d.ts.map +1 -0
  27. package/dist/adapters/likec4/adapter.js +302 -0
  28. package/dist/adapters/likec4/adapter.js.map +1 -0
  29. package/dist/adapters/likec4/dsl-validator.d.ts +3 -0
  30. package/dist/adapters/likec4/dsl-validator.d.ts.map +1 -0
  31. package/dist/adapters/likec4/dsl-validator.js +22 -0
  32. package/dist/adapters/likec4/dsl-validator.js.map +1 -0
  33. package/dist/adapters/likec4/index.d.ts +2 -0
  34. package/dist/adapters/likec4/index.d.ts.map +1 -0
  35. package/dist/adapters/likec4/index.js +2 -0
  36. package/dist/adapters/likec4/index.js.map +1 -0
  37. package/dist/adapters/likec4/likec4-types.d.ts +7 -0
  38. package/dist/adapters/likec4/likec4-types.d.ts.map +1 -0
  39. package/dist/adapters/likec4/likec4-types.js +2 -0
  40. package/dist/adapters/likec4/likec4-types.js.map +1 -0
  41. package/dist/adapters/likec4/metadata.d.ts +3 -0
  42. package/dist/adapters/likec4/metadata.d.ts.map +1 -0
  43. package/dist/adapters/likec4/metadata.js +30 -0
  44. package/dist/adapters/likec4/metadata.js.map +1 -0
  45. package/dist/adapters/likec4/patcher.d.ts +15 -0
  46. package/dist/adapters/likec4/patcher.d.ts.map +1 -0
  47. package/dist/adapters/likec4/patcher.js +69 -0
  48. package/dist/adapters/likec4/patcher.js.map +1 -0
  49. package/dist/adapters/likec4/version-check.d.ts +11 -0
  50. package/dist/adapters/likec4/version-check.d.ts.map +1 -0
  51. package/dist/adapters/likec4/version-check.js +75 -0
  52. package/dist/adapters/likec4/version-check.js.map +1 -0
  53. package/dist/adapters/model-patcher.d.ts +49 -0
  54. package/dist/adapters/model-patcher.d.ts.map +1 -0
  55. package/dist/adapters/model-patcher.js +15 -0
  56. package/dist/adapters/model-patcher.js.map +1 -0
  57. package/dist/adapters/structurizr/adapter.d.ts +39 -0
  58. package/dist/adapters/structurizr/adapter.d.ts.map +1 -0
  59. package/dist/adapters/structurizr/adapter.js +372 -0
  60. package/dist/adapters/structurizr/adapter.js.map +1 -0
  61. package/dist/adapters/structurizr/dsl-validator.d.ts +3 -0
  62. package/dist/adapters/structurizr/dsl-validator.d.ts.map +1 -0
  63. package/dist/adapters/structurizr/dsl-validator.js +26 -0
  64. package/dist/adapters/structurizr/dsl-validator.js.map +1 -0
  65. package/dist/adapters/structurizr/index.d.ts +2 -0
  66. package/dist/adapters/structurizr/index.d.ts.map +1 -0
  67. package/dist/adapters/structurizr/index.js +2 -0
  68. package/dist/adapters/structurizr/index.js.map +1 -0
  69. package/dist/adapters/structurizr/metadata.d.ts +3 -0
  70. package/dist/adapters/structurizr/metadata.d.ts.map +1 -0
  71. package/dist/adapters/structurizr/metadata.js +35 -0
  72. package/dist/adapters/structurizr/metadata.js.map +1 -0
  73. package/dist/adapters/structurizr/patcher.d.ts +15 -0
  74. package/dist/adapters/structurizr/patcher.d.ts.map +1 -0
  75. package/dist/adapters/structurizr/patcher.js +53 -0
  76. package/dist/adapters/structurizr/patcher.js.map +1 -0
  77. package/dist/adapters/structurizr/structurizr-cli.d.ts +2 -0
  78. package/dist/adapters/structurizr/structurizr-cli.d.ts.map +1 -0
  79. package/dist/adapters/structurizr/structurizr-cli.js +91 -0
  80. package/dist/adapters/structurizr/structurizr-cli.js.map +1 -0
  81. package/dist/adapters/structurizr/structurizr-types.d.ts +3 -0
  82. package/dist/adapters/structurizr/structurizr-types.d.ts.map +1 -0
  83. package/dist/adapters/structurizr/structurizr-types.js +2 -0
  84. package/dist/adapters/structurizr/structurizr-types.js.map +1 -0
  85. package/dist/adapters/url-utils.d.ts +3 -0
  86. package/dist/adapters/url-utils.d.ts.map +1 -0
  87. package/dist/adapters/url-utils.js +53 -0
  88. package/dist/adapters/url-utils.js.map +1 -0
  89. package/dist/analysis/analysis-types.d.ts +152 -0
  90. package/dist/analysis/analysis-types.d.ts.map +1 -0
  91. package/dist/analysis/analysis-types.js +2 -0
  92. package/dist/analysis/analysis-types.js.map +1 -0
  93. package/dist/analysis/prompt-builder.d.ts +27 -0
  94. package/dist/analysis/prompt-builder.d.ts.map +1 -0
  95. package/dist/analysis/prompt-builder.js +159 -0
  96. package/dist/analysis/prompt-builder.js.map +1 -0
  97. package/dist/analysis/prompt-variables.d.ts +72 -0
  98. package/dist/analysis/prompt-variables.d.ts.map +1 -0
  99. package/dist/analysis/prompt-variables.js +2 -0
  100. package/dist/analysis/prompt-variables.js.map +1 -0
  101. package/dist/analysis/prompts/component-selection.md +50 -0
  102. package/dist/analysis/prompts/dependency-extraction.md +219 -0
  103. package/dist/analysis/prompts/drift-analysis.md +154 -0
  104. package/dist/analysis/prompts/model-patch.md +29 -0
  105. package/dist/analysis/section-formatters.d.ts +54 -0
  106. package/dist/analysis/section-formatters.d.ts.map +1 -0
  107. package/dist/analysis/section-formatters.js +95 -0
  108. package/dist/analysis/section-formatters.js.map +1 -0
  109. package/dist/analysis/template-engine.d.ts +11 -0
  110. package/dist/analysis/template-engine.d.ts.map +1 -0
  111. package/dist/analysis/template-engine.js +64 -0
  112. package/dist/analysis/template-engine.js.map +1 -0
  113. package/dist/ci-entry.d.ts +3 -0
  114. package/dist/ci-entry.d.ts.map +1 -0
  115. package/dist/ci-entry.js +67 -0
  116. package/dist/ci-entry.js.map +1 -0
  117. package/dist/errors.d.ts +60 -0
  118. package/dist/errors.d.ts.map +1 -0
  119. package/dist/errors.js +134 -0
  120. package/dist/errors.js.map +1 -0
  121. package/dist/index.d.ts +45 -0
  122. package/dist/index.d.ts.map +1 -0
  123. package/dist/index.js +38 -0
  124. package/dist/index.js.map +1 -0
  125. package/dist/output/ci-output.d.ts +13 -0
  126. package/dist/output/ci-output.d.ts.map +1 -0
  127. package/dist/output/ci-output.js +106 -0
  128. package/dist/output/ci-output.js.map +1 -0
  129. package/dist/output/structured-output.d.ts +89 -0
  130. package/dist/output/structured-output.d.ts.map +1 -0
  131. package/dist/output/structured-output.js +2 -0
  132. package/dist/output/structured-output.js.map +1 -0
  133. package/dist/output.d.ts +73 -0
  134. package/dist/output.d.ts.map +1 -0
  135. package/dist/output.js +304 -0
  136. package/dist/output.js.map +1 -0
  137. package/dist/pipelines/analyze.d.ts +35 -0
  138. package/dist/pipelines/analyze.d.ts.map +1 -0
  139. package/dist/pipelines/analyze.js +316 -0
  140. package/dist/pipelines/analyze.js.map +1 -0
  141. package/dist/pipelines/check.d.ts +48 -0
  142. package/dist/pipelines/check.d.ts.map +1 -0
  143. package/dist/pipelines/check.js +218 -0
  144. package/dist/pipelines/check.js.map +1 -0
  145. package/dist/pipelines/components.d.ts +8 -0
  146. package/dist/pipelines/components.d.ts.map +1 -0
  147. package/dist/pipelines/components.js +14 -0
  148. package/dist/pipelines/components.js.map +1 -0
  149. package/dist/pipelines/connections.d.ts +34 -0
  150. package/dist/pipelines/connections.d.ts.map +1 -0
  151. package/dist/pipelines/connections.js +53 -0
  152. package/dist/pipelines/connections.js.map +1 -0
  153. package/dist/pipelines/pr-creation.d.ts +30 -0
  154. package/dist/pipelines/pr-creation.d.ts.map +1 -0
  155. package/dist/pipelines/pr-creation.js +26 -0
  156. package/dist/pipelines/pr-creation.js.map +1 -0
  157. package/dist/pipelines/progress.d.ts +23 -0
  158. package/dist/pipelines/progress.d.ts.map +1 -0
  159. package/dist/pipelines/progress.js +22 -0
  160. package/dist/pipelines/progress.js.map +1 -0
  161. package/dist/pipelines/publish.d.ts +39 -0
  162. package/dist/pipelines/publish.d.ts.map +1 -0
  163. package/dist/pipelines/publish.js +125 -0
  164. package/dist/pipelines/publish.js.map +1 -0
  165. package/dist/pipelines/validate.d.ts +24 -0
  166. package/dist/pipelines/validate.d.ts.map +1 -0
  167. package/dist/pipelines/validate.js +79 -0
  168. package/dist/pipelines/validate.js.map +1 -0
  169. package/dist/platforms/bitbucket/api-client.d.ts +21 -0
  170. package/dist/platforms/bitbucket/api-client.d.ts.map +1 -0
  171. package/dist/platforms/bitbucket/api-client.js +98 -0
  172. package/dist/platforms/bitbucket/api-client.js.map +1 -0
  173. package/dist/platforms/bitbucket/index.d.ts +3 -0
  174. package/dist/platforms/bitbucket/index.d.ts.map +1 -0
  175. package/dist/platforms/bitbucket/index.js +3 -0
  176. package/dist/platforms/bitbucket/index.js.map +1 -0
  177. package/dist/platforms/bitbucket/reader.d.ts +9 -0
  178. package/dist/platforms/bitbucket/reader.d.ts.map +1 -0
  179. package/dist/platforms/bitbucket/reader.js +119 -0
  180. package/dist/platforms/bitbucket/reader.js.map +1 -0
  181. package/dist/platforms/bitbucket/writer.d.ts +15 -0
  182. package/dist/platforms/bitbucket/writer.d.ts.map +1 -0
  183. package/dist/platforms/bitbucket/writer.js +172 -0
  184. package/dist/platforms/bitbucket/writer.js.map +1 -0
  185. package/dist/platforms/github/index.d.ts +3 -0
  186. package/dist/platforms/github/index.d.ts.map +1 -0
  187. package/dist/platforms/github/index.js +3 -0
  188. package/dist/platforms/github/index.js.map +1 -0
  189. package/dist/platforms/github/reader.d.ts +9 -0
  190. package/dist/platforms/github/reader.d.ts.map +1 -0
  191. package/dist/platforms/github/reader.js +141 -0
  192. package/dist/platforms/github/reader.js.map +1 -0
  193. package/dist/platforms/github/writer.d.ts +15 -0
  194. package/dist/platforms/github/writer.d.ts.map +1 -0
  195. package/dist/platforms/github/writer.js +225 -0
  196. package/dist/platforms/github/writer.js.map +1 -0
  197. package/dist/platforms/gitlab/index.d.ts +3 -0
  198. package/dist/platforms/gitlab/index.d.ts.map +1 -0
  199. package/dist/platforms/gitlab/index.js +3 -0
  200. package/dist/platforms/gitlab/index.js.map +1 -0
  201. package/dist/platforms/gitlab/reader.d.ts +9 -0
  202. package/dist/platforms/gitlab/reader.d.ts.map +1 -0
  203. package/dist/platforms/gitlab/reader.js +136 -0
  204. package/dist/platforms/gitlab/reader.js.map +1 -0
  205. package/dist/platforms/gitlab/writer.d.ts +14 -0
  206. package/dist/platforms/gitlab/writer.d.ts.map +1 -0
  207. package/dist/platforms/gitlab/writer.js +130 -0
  208. package/dist/platforms/gitlab/writer.js.map +1 -0
  209. package/dist/platforms/platform-factory.d.ts +7 -0
  210. package/dist/platforms/platform-factory.d.ts.map +1 -0
  211. package/dist/platforms/platform-factory.js +53 -0
  212. package/dist/platforms/platform-factory.js.map +1 -0
  213. package/dist/platforms/platform-utils.d.ts +12 -0
  214. package/dist/platforms/platform-utils.d.ts.map +1 -0
  215. package/dist/platforms/platform-utils.js +48 -0
  216. package/dist/platforms/platform-utils.js.map +1 -0
  217. package/dist/platforms/source-platform.d.ts +117 -0
  218. package/dist/platforms/source-platform.d.ts.map +1 -0
  219. package/dist/platforms/source-platform.js +2 -0
  220. package/dist/platforms/source-platform.js.map +1 -0
  221. package/dist/providers/ai-provider.d.ts +23 -0
  222. package/dist/providers/ai-provider.d.ts.map +1 -0
  223. package/dist/providers/ai-provider.js +2 -0
  224. package/dist/providers/ai-provider.js.map +1 -0
  225. package/dist/providers/analysis-phase.d.ts +13 -0
  226. package/dist/providers/analysis-phase.d.ts.map +1 -0
  227. package/dist/providers/analysis-phase.js +14 -0
  228. package/dist/providers/analysis-phase.js.map +1 -0
  229. package/dist/providers/anthropic/models.d.ts +5 -0
  230. package/dist/providers/anthropic/models.d.ts.map +1 -0
  231. package/dist/providers/anthropic/models.js +5 -0
  232. package/dist/providers/anthropic/models.js.map +1 -0
  233. package/dist/providers/anthropic/provider.d.ts +12 -0
  234. package/dist/providers/anthropic/provider.d.ts.map +1 -0
  235. package/dist/providers/anthropic/provider.js +47 -0
  236. package/dist/providers/anthropic/provider.js.map +1 -0
  237. package/dist/providers/base-provider.d.ts +34 -0
  238. package/dist/providers/base-provider.d.ts.map +1 -0
  239. package/dist/providers/base-provider.js +100 -0
  240. package/dist/providers/base-provider.js.map +1 -0
  241. package/dist/providers/gemini/models.d.ts +5 -0
  242. package/dist/providers/gemini/models.d.ts.map +1 -0
  243. package/dist/providers/gemini/models.js +5 -0
  244. package/dist/providers/gemini/models.js.map +1 -0
  245. package/dist/providers/gemini/provider.d.ts +12 -0
  246. package/dist/providers/gemini/provider.d.ts.map +1 -0
  247. package/dist/providers/gemini/provider.js +42 -0
  248. package/dist/providers/gemini/provider.js.map +1 -0
  249. package/dist/providers/openai/models.d.ts +5 -0
  250. package/dist/providers/openai/models.d.ts.map +1 -0
  251. package/dist/providers/openai/models.js +5 -0
  252. package/dist/providers/openai/models.js.map +1 -0
  253. package/dist/providers/openai/provider.d.ts +12 -0
  254. package/dist/providers/openai/provider.d.ts.map +1 -0
  255. package/dist/providers/openai/provider.js +49 -0
  256. package/dist/providers/openai/provider.js.map +1 -0
  257. package/dist/providers/provider-factory.d.ts +3 -0
  258. package/dist/providers/provider-factory.d.ts.map +1 -0
  259. package/dist/providers/provider-factory.js +45 -0
  260. package/dist/providers/provider-factory.js.map +1 -0
  261. package/dist/schemas/bitbucket-api.schema.d.ts +52 -0
  262. package/dist/schemas/bitbucket-api.schema.d.ts.map +1 -0
  263. package/dist/schemas/bitbucket-api.schema.js +50 -0
  264. package/dist/schemas/bitbucket-api.schema.js.map +1 -0
  265. package/dist/schemas/common.schema.d.ts +46 -0
  266. package/dist/schemas/common.schema.d.ts.map +1 -0
  267. package/dist/schemas/common.schema.js +67 -0
  268. package/dist/schemas/common.schema.js.map +1 -0
  269. package/dist/schemas/dependency-extraction.schema.d.ts +17 -0
  270. package/dist/schemas/dependency-extraction.schema.d.ts.map +1 -0
  271. package/dist/schemas/dependency-extraction.schema.js +13 -0
  272. package/dist/schemas/dependency-extraction.schema.js.map +1 -0
  273. package/dist/schemas/drift-analysis.schema.d.ts +40 -0
  274. package/dist/schemas/drift-analysis.schema.d.ts.map +1 -0
  275. package/dist/schemas/drift-analysis.schema.js +15 -0
  276. package/dist/schemas/drift-analysis.schema.js.map +1 -0
  277. package/dist/schemas/gitlab-api.schema.d.ts +33 -0
  278. package/dist/schemas/gitlab-api.schema.d.ts.map +1 -0
  279. package/dist/schemas/gitlab-api.schema.js +33 -0
  280. package/dist/schemas/gitlab-api.schema.js.map +1 -0
  281. package/dist/schemas/likec4.schema.d.ts +26 -0
  282. package/dist/schemas/likec4.schema.d.ts.map +1 -0
  283. package/dist/schemas/likec4.schema.js +23 -0
  284. package/dist/schemas/likec4.schema.js.map +1 -0
  285. package/dist/schemas/package.schema.d.ts +5 -0
  286. package/dist/schemas/package.schema.d.ts.map +1 -0
  287. package/dist/schemas/package.schema.js +5 -0
  288. package/dist/schemas/package.schema.js.map +1 -0
  289. package/dist/schemas/source-platform.schema.d.ts +56 -0
  290. package/dist/schemas/source-platform.schema.d.ts.map +1 -0
  291. package/dist/schemas/source-platform.schema.js +49 -0
  292. package/dist/schemas/source-platform.schema.js.map +1 -0
  293. package/dist/schemas/structurizr.schema.d.ts +234 -0
  294. package/dist/schemas/structurizr.schema.d.ts.map +1 -0
  295. package/dist/schemas/structurizr.schema.js +54 -0
  296. package/dist/schemas/structurizr.schema.js.map +1 -0
  297. package/dist/skip-patterns +62 -0
  298. package/dist/utils/config.d.ts +156 -0
  299. package/dist/utils/config.d.ts.map +1 -0
  300. package/dist/utils/config.js +267 -0
  301. package/dist/utils/config.js.map +1 -0
  302. package/dist/utils/error-utils.d.ts +2 -0
  303. package/dist/utils/error-utils.d.ts.map +1 -0
  304. package/dist/utils/error-utils.js +6 -0
  305. package/dist/utils/error-utils.js.map +1 -0
  306. package/dist/utils/git-diff.d.ts +35 -0
  307. package/dist/utils/git-diff.d.ts.map +1 -0
  308. package/dist/utils/git-diff.js +114 -0
  309. package/dist/utils/git-diff.js.map +1 -0
  310. package/dist/utils/model-source.d.ts +30 -0
  311. package/dist/utils/model-source.d.ts.map +1 -0
  312. package/dist/utils/model-source.js +167 -0
  313. package/dist/utils/model-source.js.map +1 -0
  314. package/dist/utils/retry.d.ts +9 -0
  315. package/dist/utils/retry.d.ts.map +1 -0
  316. package/dist/utils/retry.js +51 -0
  317. package/dist/utils/retry.js.map +1 -0
  318. package/dist/utils/skip-patterns.d.ts +7 -0
  319. package/dist/utils/skip-patterns.d.ts.map +1 -0
  320. package/dist/utils/skip-patterns.js +35 -0
  321. package/dist/utils/skip-patterns.js.map +1 -0
  322. package/dist/utils/validation.d.ts +4 -0
  323. package/dist/utils/validation.d.ts.map +1 -0
  324. package/dist/utils/validation.js +37 -0
  325. package/dist/utils/validation.js.map +1 -0
  326. package/package.json +78 -0
@@ -0,0 +1,14 @@
1
+ import { SilentProgress } from './progress.js';
2
+ import { createAdapter } from '../adapters/adapter-factory.js';
3
+ import { validatePath } from '../utils/validation.js';
4
+ export async function runComponents(options, progress) {
5
+ const p = progress ?? new SilentProgress();
6
+ const adapter = createAdapter(options.modelFormat);
7
+ p.section(`Loading ${adapter.metadata.displayName} Architecture Model`);
8
+ validatePath(options.modelPath, 'directory');
9
+ p.start('Loading architecture model');
10
+ const components = await adapter.loadAndListComponents(options.modelPath);
11
+ p.succeed(`Loaded ${String(components.length)} components`);
12
+ return components;
13
+ }
14
+ //# sourceMappingURL=components.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"components.js","sourceRoot":"","sources":["../../src/pipelines/components.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAQtD,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,OAA0B,EAC1B,QAA2B;IAE3B,MAAM,CAAC,GAAG,QAAQ,IAAI,IAAI,cAAc,EAAE,CAAC;IAC3C,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAEnD,CAAC,CAAC,OAAO,CAAC,WAAW,OAAO,CAAC,QAAQ,CAAC,WAAW,qBAAqB,CAAC,CAAC;IACxE,YAAY,CAAC,OAAO,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IAC7C,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;IAEtC,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,qBAAqB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC1E,CAAC,CAAC,OAAO,CAAC,UAAU,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAE5D,OAAO,UAAU,CAAC;AACpB,CAAC"}
@@ -0,0 +1,34 @@
1
+ import type { ProgressReporter } from './progress.js';
2
+ export interface ConnectionsOptions {
3
+ modelPath: string;
4
+ modelFormat?: string;
5
+ repo: string;
6
+ }
7
+ export interface ComponentConnections {
8
+ component: {
9
+ id: string;
10
+ name: string;
11
+ type: string;
12
+ repository?: string;
13
+ };
14
+ dependencies: {
15
+ id: string;
16
+ name: string;
17
+ type: string;
18
+ repository?: string;
19
+ }[];
20
+ dependents: {
21
+ id: string;
22
+ name: string;
23
+ type: string;
24
+ repository?: string;
25
+ }[];
26
+ relationships: {
27
+ targetId: string;
28
+ targetName: string;
29
+ kind?: string;
30
+ title?: string;
31
+ }[];
32
+ }
33
+ export declare function runConnections(options: ConnectionsOptions, progress?: ProgressReporter): Promise<ComponentConnections[]>;
34
+ //# sourceMappingURL=connections.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connections.d.ts","sourceRoot":"","sources":["../../src/pipelines/connections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKtD,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE;QACT,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;IACF,YAAY,EAAE;QACZ,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,EAAE,CAAC;IACJ,UAAU,EAAE;QACV,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,EAAE,CAAC;IACJ,aAAa,EAAE;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,EAAE,CAAC;CACL;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,CAAC,EAAE,gBAAgB,GAC1B,OAAO,CAAC,oBAAoB,EAAE,CAAC,CAqDjC"}
@@ -0,0 +1,53 @@
1
+ import { SilentProgress } from './progress.js';
2
+ import { createAdapter } from '../adapters/adapter-factory.js';
3
+ import { validatePath } from '../utils/validation.js';
4
+ export async function runConnections(options, progress) {
5
+ const p = progress ?? new SilentProgress();
6
+ const adapter = createAdapter(options.modelFormat);
7
+ p.section(`Loading ${adapter.metadata.displayName} Architecture Model`);
8
+ validatePath(options.modelPath, 'directory');
9
+ p.start('Loading architecture model');
10
+ await adapter.loadFromPath(options.modelPath);
11
+ p.succeed('Architecture model loaded');
12
+ p.start(`Finding components for ${options.repo}`);
13
+ const components = adapter.findAllComponentsByRepository(options.repo);
14
+ if (components.length === 0) {
15
+ p.warn(`No components found for repository: ${options.repo}`);
16
+ p.info('Run "erode validate [model-path]" to check which components have repository links.');
17
+ return [];
18
+ }
19
+ p.succeed(`Found ${String(components.length)} component(s)`);
20
+ const results = components.map((component) => {
21
+ const dependencies = adapter.getComponentDependencies(component.id);
22
+ const dependents = adapter.getComponentDependents(component.id);
23
+ const relationships = adapter.getComponentRelationships(component.id);
24
+ return {
25
+ component: {
26
+ id: component.id,
27
+ name: component.name,
28
+ type: component.type,
29
+ repository: component.repository,
30
+ },
31
+ dependencies: dependencies.map((d) => ({
32
+ id: d.id,
33
+ name: d.name,
34
+ type: d.type,
35
+ repository: d.repository,
36
+ })),
37
+ dependents: dependents.map((d) => ({
38
+ id: d.id,
39
+ name: d.name,
40
+ type: d.type,
41
+ repository: d.repository,
42
+ })),
43
+ relationships: relationships.map((r) => ({
44
+ targetId: r.target.id,
45
+ targetName: r.target.name,
46
+ kind: r.kind,
47
+ title: r.title,
48
+ })),
49
+ };
50
+ });
51
+ return results;
52
+ }
53
+ //# sourceMappingURL=connections.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connections.js","sourceRoot":"","sources":["../../src/pipelines/connections.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAmCtD,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,OAA2B,EAC3B,QAA2B;IAE3B,MAAM,CAAC,GAAG,QAAQ,IAAI,IAAI,cAAc,EAAE,CAAC;IAC3C,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAEnD,CAAC,CAAC,OAAO,CAAC,WAAW,OAAO,CAAC,QAAQ,CAAC,WAAW,qBAAqB,CAAC,CAAC;IACxE,YAAY,CAAC,OAAO,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IAC7C,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;IACtC,MAAM,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC;IAEvC,CAAC,CAAC,KAAK,CAAC,0BAA0B,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IAClD,MAAM,UAAU,GAAG,OAAO,CAAC,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvE,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,CAAC,CAAC,IAAI,CAAC,uCAAuC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QAC9D,CAAC,CAAC,IAAI,CAAC,oFAAoF,CAAC,CAAC;QAC7F,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,CAAC,CAAC,OAAO,CAAC,SAAS,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;IAE7D,MAAM,OAAO,GAA2B,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;QACnE,MAAM,YAAY,GAAG,OAAO,CAAC,wBAAwB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QACpE,MAAM,UAAU,GAAG,OAAO,CAAC,sBAAsB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QAChE,MAAM,aAAa,GAAG,OAAO,CAAC,yBAAyB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QACtE,OAAO;YACL,SAAS,EAAE;gBACT,EAAE,EAAE,SAAS,CAAC,EAAE;gBAChB,IAAI,EAAE,SAAS,CAAC,IAAI;gBACpB,IAAI,EAAE,SAAS,CAAC,IAAI;gBACpB,UAAU,EAAE,SAAS,CAAC,UAAU;aACjC;YACD,YAAY,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACrC,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,UAAU,EAAE,CAAC,CAAC,UAAU;aACzB,CAAC,CAAC;YACH,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACjC,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,UAAU,EAAE,CAAC,CAAC,UAAU;aACzB,CAAC,CAAC;YACH,aAAa,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACvC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE;gBACrB,UAAU,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI;gBACzB,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,KAAK,EAAE,CAAC,CAAC,KAAK;aACf,CAAC,CAAC;SACJ,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,30 @@
1
+ import type { ChangeRequestFileWrite } from '../platforms/source-platform.js';
2
+ import type { AdapterMetadata } from '../adapters/adapter-metadata.js';
3
+ export declare function modelPrBranchName(sourceRepo: string, prNumber: number): string;
4
+ export interface CreateModelPrOptions {
5
+ repositoryUrl: string;
6
+ owner: string;
7
+ repo: string;
8
+ prNumber: number;
9
+ prTitle: string;
10
+ sourceRepo: string;
11
+ adapterMetadata: AdapterMetadata;
12
+ fileChanges: ChangeRequestFileWrite[];
13
+ body: string;
14
+ draft?: boolean;
15
+ }
16
+ export interface CreateModelPrResult {
17
+ url: string;
18
+ number: number;
19
+ action: 'created' | 'updated';
20
+ branch: string;
21
+ }
22
+ export declare function createModelPr(options: CreateModelPrOptions): Promise<CreateModelPrResult>;
23
+ export declare function closeModelPr(options: {
24
+ repositoryUrl: string;
25
+ owner: string;
26
+ repo: string;
27
+ sourceRepo: string;
28
+ prNumber: number;
29
+ }): Promise<void>;
30
+ //# sourceMappingURL=pr-creation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pr-creation.d.ts","sourceRoot":"","sources":["../../src/pipelines/pr-creation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAEvE,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAG9E;AAED,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,eAAe,CAAC;IACjC,WAAW,EAAE,sBAAsB,EAAE,CAAC;IACtC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,mBAAmB;IAClC,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,wBAAsB,aAAa,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAe/F;AAED,wBAAsB,YAAY,CAAC,OAAO,EAAE;IAC1C,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;CAClB,GAAG,OAAO,CAAC,IAAI,CAAC,CAGhB"}
@@ -0,0 +1,26 @@
1
+ import { createPlatformWriter } from '../platforms/platform-factory.js';
2
+ export function modelPrBranchName(sourceRepo, prNumber) {
3
+ const slug = sourceRepo.replace(/\//g, '-').replace(/[^a-zA-Z0-9._-]/g, '');
4
+ return `erode/${slug}/pr-${String(prNumber)}`;
5
+ }
6
+ export async function createModelPr(options) {
7
+ const writer = createPlatformWriter(options.repositoryUrl, options.owner, options.repo);
8
+ const branchName = modelPrBranchName(options.sourceRepo, options.prNumber);
9
+ const prTitle = options.adapterMetadata.prTitleTemplate
10
+ .replace('{{prNumber}}', String(options.prNumber))
11
+ .replace('{{prTitle}}', options.prTitle)
12
+ .replace('{{sourceRepo}}', options.sourceRepo);
13
+ const prResult = await writer.createOrUpdateChangeRequest({
14
+ branchName,
15
+ title: prTitle,
16
+ body: options.body,
17
+ fileChanges: options.fileChanges,
18
+ draft: options.draft,
19
+ });
20
+ return { ...prResult, branch: branchName };
21
+ }
22
+ export async function closeModelPr(options) {
23
+ const writer = createPlatformWriter(options.repositoryUrl, options.owner, options.repo);
24
+ await writer.closeChangeRequest(modelPrBranchName(options.sourceRepo, options.prNumber));
25
+ }
26
+ //# sourceMappingURL=pr-creation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pr-creation.js","sourceRoot":"","sources":["../../src/pipelines/pr-creation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAIxE,MAAM,UAAU,iBAAiB,CAAC,UAAkB,EAAE,QAAgB;IACpE,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;IAC5E,OAAO,SAAS,IAAI,OAAO,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;AAChD,CAAC;AAsBD,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAA6B;IAC/D,MAAM,MAAM,GAAG,oBAAoB,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IACxF,MAAM,UAAU,GAAG,iBAAiB,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC3E,MAAM,OAAO,GAAG,OAAO,CAAC,eAAe,CAAC,eAAe;SACpD,OAAO,CAAC,cAAc,EAAE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;SACjD,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,OAAO,CAAC;SACvC,OAAO,CAAC,gBAAgB,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;IACjD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,2BAA2B,CAAC;QACxD,UAAU;QACV,KAAK,EAAE,OAAO;QACd,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,KAAK,EAAE,OAAO,CAAC,KAAK;KACrB,CAAC,CAAC;IACH,OAAO,EAAE,GAAG,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;AAC7C,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAMlC;IACC,MAAM,MAAM,GAAG,oBAAoB,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IACxF,MAAM,MAAM,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;AAC3F,CAAC"}
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Progress reporting abstraction for pipeline functions.
3
+ *
4
+ * CI callers pass SilentProgress; CLI callers pass a ConsoleProgress reporter.
5
+ */
6
+ export interface ProgressReporter {
7
+ section(title: string): void;
8
+ start(message: string): void;
9
+ succeed(message: string): void;
10
+ fail(message: string): void;
11
+ warn(message: string): void;
12
+ info(message: string): void;
13
+ }
14
+ /** No-op progress reporter — swallows every call silently. */
15
+ export declare class SilentProgress implements ProgressReporter {
16
+ section(_title: string): void;
17
+ start(_message: string): void;
18
+ succeed(_message: string): void;
19
+ fail(_message: string): void;
20
+ warn(_message: string): void;
21
+ info(_message: string): void;
22
+ }
23
+ //# sourceMappingURL=progress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress.d.ts","sourceRoot":"","sources":["../../src/pipelines/progress.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,WAAW,gBAAgB;IAC/B,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,8DAA8D;AAC9D,qBAAa,cAAe,YAAW,gBAAgB;IACrD,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAG7B,KAAK,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG7B,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG/B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;CAG7B"}
@@ -0,0 +1,22 @@
1
+ /** No-op progress reporter — swallows every call silently. */
2
+ export class SilentProgress {
3
+ section(_title) {
4
+ /* noop */
5
+ }
6
+ start(_message) {
7
+ /* noop */
8
+ }
9
+ succeed(_message) {
10
+ /* noop */
11
+ }
12
+ fail(_message) {
13
+ /* noop */
14
+ }
15
+ warn(_message) {
16
+ /* noop */
17
+ }
18
+ info(_message) {
19
+ /* noop */
20
+ }
21
+ }
22
+ //# sourceMappingURL=progress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress.js","sourceRoot":"","sources":["../../src/pipelines/progress.ts"],"names":[],"mappings":"AAcA,8DAA8D;AAC9D,MAAM,OAAO,cAAc;IACzB,OAAO,CAAC,MAAc;QACpB,UAAU;IACZ,CAAC;IACD,KAAK,CAAC,QAAgB;QACpB,UAAU;IACZ,CAAC;IACD,OAAO,CAAC,QAAgB;QACtB,UAAU;IACZ,CAAC;IACD,IAAI,CAAC,QAAgB;QACnB,UAAU;IACZ,CAAC;IACD,IAAI,CAAC,QAAgB;QACnB,UAAU;IACZ,CAAC;IACD,IAAI,CAAC,QAAgB;QACnB,UAAU;IACZ,CAAC;CACF"}
@@ -0,0 +1,39 @@
1
+ import type { ProgressReporter } from './progress.js';
2
+ import type { ChangeRequestRef } from '../platforms/source-platform.js';
3
+ import type { AdapterMetadata } from '../adapters/adapter-metadata.js';
4
+ import type { DriftAnalysisResult } from '../analysis/analysis-types.js';
5
+ import type { PatchResult } from '../adapters/model-patcher.js';
6
+ import type { StructuredAnalysisOutput } from '../output/structured-output.js';
7
+ export interface PublishOptions {
8
+ ref: ChangeRequestRef;
9
+ analysisResult: DriftAnalysisResult;
10
+ patchResult: PatchResult | null;
11
+ structured: StructuredAnalysisOutput | undefined;
12
+ adapterMetadata: AdapterMetadata;
13
+ options: {
14
+ openPr?: boolean;
15
+ dryRun?: boolean;
16
+ draft?: boolean;
17
+ modelRepo?: string;
18
+ comment?: boolean;
19
+ githubActions?: boolean;
20
+ };
21
+ context: {
22
+ selectedComponentId?: string;
23
+ candidateComponents?: {
24
+ id: string;
25
+ name: string;
26
+ type: string;
27
+ }[];
28
+ };
29
+ }
30
+ export interface PublishResult {
31
+ generatedChangeRequest?: {
32
+ url: string;
33
+ number: number;
34
+ action: 'created' | 'updated';
35
+ branch: string;
36
+ };
37
+ }
38
+ export declare function publishResults(publish: PublishOptions, p: ProgressReporter): Promise<PublishResult>;
39
+ //# sourceMappingURL=publish.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"publish.d.ts","sourceRoot":"","sources":["../../src/pipelines/publish.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAoB/E,MAAM,WAAW,cAAc;IAC7B,GAAG,EAAE,gBAAgB,CAAC;IACtB,cAAc,EAAE,mBAAmB,CAAC;IACpC,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAChC,UAAU,EAAE,wBAAwB,GAAG,SAAS,CAAC;IACjD,eAAe,EAAE,eAAe,CAAC;IACjC,OAAO,EAAE;QACP,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,aAAa,CAAC,EAAE,OAAO,CAAC;KACzB,CAAC;IACF,OAAO,EAAE;QACP,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,mBAAmB,CAAC,EAAE;YAAE,EAAE,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,EAAE,CAAC;KACpE,CAAC;CACH;AAED,MAAM,WAAW,aAAa;IAC5B,sBAAsB,CAAC,EAAE;QACvB,GAAG,EAAE,MAAM,CAAC;QACZ,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC;QAC9B,MAAM,EAAE,MAAM,CAAC;KAChB,CAAC;CACH;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,cAAc,EACvB,CAAC,EAAE,gBAAgB,GAClB,OAAO,CAAC,aAAa,CAAC,CA0HxB"}
@@ -0,0 +1,125 @@
1
+ import { createModelPr, closeModelPr } from './pr-creation.js';
2
+ import { createPlatformWriter } from '../platforms/platform-factory.js';
3
+ import { formatAnalysisAsComment, formatPatchPrBody, analysisHasFindings, COMMENT_MARKER, } from '../output.js';
4
+ import { writeGitHubActionsOutputs, writeGitHubStepSummary } from '../output/ci-output.js';
5
+ import { CONFIG } from '../utils/config.js';
6
+ function parseOwnerRepo(modelRepo) {
7
+ const i = modelRepo.lastIndexOf('/');
8
+ return {
9
+ owner: modelRepo.substring(0, i),
10
+ repo: modelRepo.substring(i + 1),
11
+ };
12
+ }
13
+ export async function publishResults(publish, p) {
14
+ const { ref, analysisResult, patchResult, structured, adapterMetadata, options, context } = publish;
15
+ // ── Resolve model repo target ────────────────────────────────────────
16
+ const modelTarget = options.modelRepo ? parseOwnerRepo(options.modelRepo) : ref.platformId;
17
+ // ── PR creation ──────────────────────────────────────────────────────
18
+ let generatedChangeRequest;
19
+ if (options.openPr && !options.dryRun) {
20
+ if (patchResult) {
21
+ p.start('Opening PR with patched model');
22
+ const prNumber = analysisResult.metadata.number;
23
+ const prTitle = analysisResult.metadata.title;
24
+ const body = formatPatchPrBody({
25
+ prNumber,
26
+ prTitle,
27
+ prUrl: ref.url,
28
+ summary: analysisResult.summary,
29
+ insertedLines: patchResult.insertedLines,
30
+ relationshipLines: patchResult.relationshipLines,
31
+ skipped: patchResult.skipped,
32
+ removals: analysisResult.modelUpdates?.remove,
33
+ newComponents: patchResult.newComponents,
34
+ });
35
+ const result = await createModelPr({
36
+ repositoryUrl: ref.repositoryUrl,
37
+ owner: modelTarget.owner,
38
+ repo: modelTarget.repo,
39
+ prNumber,
40
+ prTitle,
41
+ sourceRepo: `${ref.platformId.owner}/${ref.platformId.repo}`,
42
+ adapterMetadata,
43
+ fileChanges: [{ path: patchResult.filePath, content: patchResult.content }],
44
+ body,
45
+ draft: options.draft,
46
+ });
47
+ generatedChangeRequest = result;
48
+ if (structured)
49
+ structured.generatedChangeRequest = generatedChangeRequest;
50
+ p.succeed(`PR ${result.action} successfully: ${result.url}`);
51
+ }
52
+ else {
53
+ p.warn('--open-pr requires structured relationships from analysis. Skipping PR creation.');
54
+ }
55
+ // Auto-close stale model PR when re-analysis finds no violations
56
+ if (!analysisResult.hasViolations && !generatedChangeRequest) {
57
+ try {
58
+ await closeModelPr({
59
+ repositoryUrl: ref.repositoryUrl,
60
+ owner: modelTarget.owner,
61
+ repo: modelTarget.repo,
62
+ sourceRepo: `${ref.platformId.owner}/${ref.platformId.repo}`,
63
+ prNumber: analysisResult.metadata.number,
64
+ });
65
+ }
66
+ catch (error) {
67
+ p.warn(`Could not close stale model PR: ${error instanceof Error ? error.message : String(error)}`);
68
+ }
69
+ }
70
+ }
71
+ else if (options.openPr && options.dryRun) {
72
+ p.info('Dry run: skipped PR creation');
73
+ }
74
+ // ── PR commenting ────────────────────────────────────────────────────
75
+ if (options.comment) {
76
+ try {
77
+ p.section('Publishing PR Comment');
78
+ const commentWriter = createPlatformWriter(ref.repositoryUrl, ref.platformId.owner, ref.platformId.repo);
79
+ if (analysisHasFindings(analysisResult)) {
80
+ p.start('Publishing analysis comment on PR');
81
+ const providerName = CONFIG.ai.provider;
82
+ const providerConfig = CONFIG[providerName];
83
+ const commentBody = formatAnalysisAsComment(analysisResult, {
84
+ selectedComponentId: context.selectedComponentId,
85
+ candidateComponents: context.candidateComponents,
86
+ generatedChangeRequest,
87
+ githubActions: options.githubActions,
88
+ modelInfo: {
89
+ provider: providerName,
90
+ fastModel: providerConfig.fastModel,
91
+ advancedModel: providerConfig.advancedModel,
92
+ },
93
+ });
94
+ await commentWriter.commentOnChangeRequest(ref, commentBody, {
95
+ upsertMarker: COMMENT_MARKER,
96
+ });
97
+ p.succeed('Analysis comment published on PR');
98
+ }
99
+ else {
100
+ p.start('Removing stale comment (no findings)');
101
+ await commentWriter.deleteComment(ref, COMMENT_MARKER);
102
+ p.succeed('No findings — old comment cleared (if any)');
103
+ }
104
+ }
105
+ catch (error) {
106
+ const message = error instanceof Error ? error.message : String(error);
107
+ p.warn(`Could not publish PR comment: ${message}`);
108
+ if (options.githubActions) {
109
+ console.warn(`::warning::Could not publish PR comment: ${message}`);
110
+ }
111
+ }
112
+ }
113
+ // ── GitHub Actions outputs ───────────────────────────────────────────
114
+ if (options.githubActions && structured) {
115
+ try {
116
+ writeGitHubActionsOutputs(structured);
117
+ writeGitHubStepSummary(structured);
118
+ }
119
+ catch (error) {
120
+ p.warn(`Could not write GitHub Actions outputs: ${error instanceof Error ? error.message : String(error)}`);
121
+ }
122
+ }
123
+ return { generatedChangeRequest };
124
+ }
125
+ //# sourceMappingURL=publish.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"publish.js","sourceRoot":"","sources":["../../src/pipelines/publish.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { ProgressReporter } from './progress.js';
2
+ export interface ValidateOptions {
3
+ modelPath: string;
4
+ modelFormat?: string;
5
+ }
6
+ export interface ValidateResult {
7
+ components: {
8
+ id: string;
9
+ title: string;
10
+ kind: string;
11
+ repository: string;
12
+ }[];
13
+ total: number;
14
+ linked: number;
15
+ unlinked: number;
16
+ versionCheck: {
17
+ detected: string | null;
18
+ minimum: string;
19
+ compatible: boolean | null;
20
+ } | null;
21
+ hasIssues: boolean;
22
+ }
23
+ export declare function runValidate(options: ValidateOptions, progress?: ProgressReporter): Promise<ValidateResult>;
24
+ //# sourceMappingURL=validate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../src/pipelines/validate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKtD,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE;QACV,EAAE,EAAE,MAAM,CAAC;QACX,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CAAC;IACJ,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE;QACZ,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,OAAO,GAAG,IAAI,CAAC;KAC5B,GAAG,IAAI,CAAC;IACT,SAAS,EAAE,OAAO,CAAC;CACpB;AAuBD,wBAAsB,WAAW,CAC/B,OAAO,EAAE,eAAe,EACxB,QAAQ,CAAC,EAAE,gBAAgB,GAC1B,OAAO,CAAC,cAAc,CAAC,CAmEzB"}
@@ -0,0 +1,79 @@
1
+ import { SilentProgress } from './progress.js';
2
+ import { createAdapter } from '../adapters/adapter-factory.js';
3
+ import { validatePath } from '../utils/validation.js';
4
+ function isRepositoryUrl(url) {
5
+ try {
6
+ const parsed = new URL(url);
7
+ if (parsed.protocol !== 'https:' && parsed.protocol !== 'http:')
8
+ return false;
9
+ return [
10
+ 'github.com',
11
+ 'www.github.com',
12
+ 'gitlab.com',
13
+ 'www.gitlab.com',
14
+ 'bitbucket.org',
15
+ 'www.bitbucket.org',
16
+ ].includes(parsed.hostname);
17
+ }
18
+ catch {
19
+ return false;
20
+ }
21
+ }
22
+ function findRepositoryLink(links) {
23
+ return links.find(isRepositoryUrl);
24
+ }
25
+ export async function runValidate(options, progress) {
26
+ const p = progress ?? new SilentProgress();
27
+ const adapter = createAdapter(options.modelFormat);
28
+ // Version check
29
+ let versionCheck = null;
30
+ if (adapter.checkVersion) {
31
+ p.start(`Checking ${adapter.metadata.displayName} version compatibility`);
32
+ const versionResult = adapter.checkVersion(options.modelPath);
33
+ if (versionResult.found && versionResult.compatible) {
34
+ p.succeed(`${adapter.metadata.displayName} version ${versionResult.version ?? 'unknown'} is compatible (minimum: ${versionResult.minimum})`);
35
+ }
36
+ else if (versionResult.found && !versionResult.compatible) {
37
+ p.warn(`${adapter.metadata.displayName} version ${versionResult.version ?? 'unknown'} is below minimum ${versionResult.minimum}. Update the ${adapter.metadata.id} dependency in the source repo.`);
38
+ }
39
+ else {
40
+ p.warn(`Could not detect ${adapter.metadata.displayName} version — skipping compatibility check`);
41
+ }
42
+ versionCheck = {
43
+ detected: versionResult.version ?? null,
44
+ minimum: versionResult.minimum,
45
+ compatible: versionResult.compatible ?? null,
46
+ };
47
+ }
48
+ validatePath(options.modelPath, 'directory');
49
+ p.start('Loading architecture model');
50
+ const components = await adapter.loadAndListComponents(options.modelPath);
51
+ p.succeed(`Loaded ${String(components.length)} components`);
52
+ const mapped = components.map((c) => ({
53
+ id: c.id,
54
+ title: c.title ?? c.id,
55
+ kind: c.kind,
56
+ repository: findRepositoryLink(c.links) ?? 'MISSING',
57
+ }));
58
+ const linked = mapped.filter((c) => c.repository !== 'MISSING');
59
+ const unlinked = mapped.filter((c) => c.repository === 'MISSING');
60
+ if (unlinked.length > 0) {
61
+ p.warn(`${String(unlinked.length)} of ${String(mapped.length)} component(s) are missing repository links`);
62
+ for (const line of adapter.metadata.missingLinksHelpLines) {
63
+ p.info(line);
64
+ }
65
+ }
66
+ else if (mapped.length > 0) {
67
+ p.succeed('All components have repository links');
68
+ }
69
+ const hasIssues = unlinked.length > 0 || (versionCheck !== null && versionCheck.compatible === false);
70
+ return {
71
+ components: mapped,
72
+ total: mapped.length,
73
+ linked: linked.length,
74
+ unlinked: unlinked.length,
75
+ versionCheck,
76
+ hasIssues,
77
+ };
78
+ }
79
+ //# sourceMappingURL=validate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate.js","sourceRoot":"","sources":["../../src/pipelines/validate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import { z } from 'zod';
2
+ interface BitbucketRequestOptions {
3
+ method?: string;
4
+ headers?: Record<string, string>;
5
+ body?: RequestInit['body'];
6
+ }
7
+ export declare class BitbucketApiClient {
8
+ private readonly baseUrl;
9
+ private readonly token;
10
+ constructor(token?: string);
11
+ private buildHeaders;
12
+ /** App passwords use Basic auth (username:password), OAuth/PATs use Bearer. */
13
+ private buildAuthHeader;
14
+ request<T>(path: string, schema: z.ZodType<T>, options?: BitbucketRequestOptions): Promise<T>;
15
+ requestText(path: string, options?: BitbucketRequestOptions): Promise<string>;
16
+ requestVoid(path: string, options?: BitbucketRequestOptions): Promise<void>;
17
+ /** Fetch all pages of a paginated Bitbucket API response. */
18
+ paginate<T>(path: string, itemSchema: z.ZodType<T>): Promise<T[]>;
19
+ }
20
+ export {};
21
+ //# sourceMappingURL=api-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-client.d.ts","sourceRoot":"","sources":["../../../src/platforms/bitbucket/api-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAKxB,UAAU,uBAAuB;IAC/B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;CAC5B;AAED,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAqB;gBAE/B,KAAK,CAAC,EAAE,MAAM;IAK1B,OAAO,CAAC,YAAY;IAQpB,+EAA+E;IAC/E,OAAO,CAAC,eAAe;IAOjB,OAAO,CAAC,CAAC,EACb,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EACpB,OAAO,GAAE,uBAA4B,GACpC,OAAO,CAAC,CAAC,CAAC;IAmBP,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,uBAA4B,GAAG,OAAO,CAAC,MAAM,CAAC;IAkBjF,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,uBAA4B,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBrF,6DAA6D;IACvD,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;CA0CxE"}