specweave 0.18.1 → 0.20.1

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 (389) hide show
  1. package/CLAUDE.md +229 -1817
  2. package/README.md +68 -0
  3. package/bin/specweave.js +62 -6
  4. package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +1 -1
  5. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +3 -0
  6. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +1 -1
  7. package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts +21 -0
  8. package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts.map +1 -0
  9. package/dist/plugins/specweave/lib/hooks/update-ac-status.js +162 -0
  10. package/dist/plugins/specweave/lib/hooks/update-ac-status.js.map +1 -0
  11. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.d.ts.map +1 -1
  12. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js +65 -6
  13. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js.map +1 -1
  14. package/dist/plugins/specweave-github/lib/completion-calculator.d.ts +112 -0
  15. package/dist/plugins/specweave-github/lib/completion-calculator.d.ts.map +1 -0
  16. package/dist/plugins/specweave-github/lib/completion-calculator.js +301 -0
  17. package/dist/plugins/specweave-github/lib/completion-calculator.js.map +1 -0
  18. package/dist/plugins/specweave-github/lib/duplicate-detector.d.ts +3 -3
  19. package/dist/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  20. package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts +7 -0
  21. package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts.map +1 -1
  22. package/dist/plugins/specweave-github/lib/epic-content-builder.js +42 -0
  23. package/dist/plugins/specweave-github/lib/epic-content-builder.js.map +1 -1
  24. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +14 -0
  25. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +1 -1
  26. package/dist/plugins/specweave-github/lib/github-client-v2.js +51 -0
  27. package/dist/plugins/specweave-github/lib/github-client-v2.js.map +1 -1
  28. package/dist/plugins/specweave-github/lib/github-epic-sync.js +1 -1
  29. package/dist/plugins/specweave-github/lib/github-epic-sync.js.map +1 -1
  30. package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts +87 -0
  31. package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts.map +1 -0
  32. package/dist/plugins/specweave-github/lib/github-feature-sync.js +412 -0
  33. package/dist/plugins/specweave-github/lib/github-feature-sync.js.map +1 -0
  34. package/dist/plugins/specweave-github/lib/github-spec-content-sync.d.ts.map +1 -1
  35. package/dist/plugins/specweave-github/lib/github-spec-content-sync.js +64 -13
  36. package/dist/plugins/specweave-github/lib/github-spec-content-sync.js.map +1 -1
  37. package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts +78 -0
  38. package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts.map +1 -0
  39. package/dist/plugins/specweave-github/lib/progress-comment-builder.js +237 -0
  40. package/dist/plugins/specweave-github/lib/progress-comment-builder.js.map +1 -0
  41. package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts +97 -0
  42. package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts.map +1 -0
  43. package/dist/plugins/specweave-github/lib/user-story-content-builder.js +301 -0
  44. package/dist/plugins/specweave-github/lib/user-story-content-builder.js.map +1 -0
  45. package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts +83 -0
  46. package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts.map +1 -0
  47. package/dist/plugins/specweave-github/lib/user-story-issue-builder.js +386 -0
  48. package/dist/plugins/specweave-github/lib/user-story-issue-builder.js.map +1 -0
  49. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts +8 -6
  50. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts.map +1 -1
  51. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js +78 -117
  52. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js.map +1 -1
  53. package/dist/src/cli/commands/import-docs.js +4 -4
  54. package/dist/src/cli/commands/import-docs.js.map +1 -1
  55. package/dist/src/cli/commands/init-multiproject.d.ts.map +1 -1
  56. package/dist/src/cli/commands/init-multiproject.js +17 -18
  57. package/dist/src/cli/commands/init-multiproject.js.map +1 -1
  58. package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +1 -1
  59. package/dist/src/cli/commands/migrate-to-multiproject.js +8 -4
  60. package/dist/src/cli/commands/migrate-to-multiproject.js.map +1 -1
  61. package/dist/src/cli/commands/switch-project.d.ts.map +1 -1
  62. package/dist/src/cli/commands/switch-project.js +9 -26
  63. package/dist/src/cli/commands/switch-project.js.map +1 -1
  64. package/dist/src/cli/commands/sync-spec-content.js +3 -0
  65. package/dist/src/cli/commands/sync-spec-content.js.map +1 -1
  66. package/dist/src/core/deduplication/command-deduplicator.d.ts +166 -0
  67. package/dist/src/core/deduplication/command-deduplicator.d.ts.map +1 -0
  68. package/dist/src/core/deduplication/command-deduplicator.js +254 -0
  69. package/dist/src/core/deduplication/command-deduplicator.js.map +1 -0
  70. package/dist/src/core/increment/active-increment-manager.d.ts +42 -15
  71. package/dist/src/core/increment/active-increment-manager.d.ts.map +1 -1
  72. package/dist/src/core/increment/active-increment-manager.js +113 -46
  73. package/dist/src/core/increment/active-increment-manager.js.map +1 -1
  74. package/dist/src/core/increment/conflict-resolver.d.ts +40 -0
  75. package/dist/src/core/increment/conflict-resolver.d.ts.map +1 -0
  76. package/dist/src/core/increment/conflict-resolver.js +219 -0
  77. package/dist/src/core/increment/conflict-resolver.js.map +1 -0
  78. package/dist/src/core/increment/discipline-checker.d.ts.map +1 -1
  79. package/dist/src/core/increment/discipline-checker.js +7 -1
  80. package/dist/src/core/increment/discipline-checker.js.map +1 -1
  81. package/dist/src/core/increment/duplicate-detector.d.ts +52 -0
  82. package/dist/src/core/increment/duplicate-detector.d.ts.map +1 -0
  83. package/dist/src/core/increment/duplicate-detector.js +276 -0
  84. package/dist/src/core/increment/duplicate-detector.js.map +1 -0
  85. package/dist/src/core/increment/increment-archiver.d.ts +90 -0
  86. package/dist/src/core/increment/increment-archiver.d.ts.map +1 -0
  87. package/dist/src/core/increment/increment-archiver.js +368 -0
  88. package/dist/src/core/increment/increment-archiver.js.map +1 -0
  89. package/dist/src/core/increment/increment-reopener.d.ts +165 -0
  90. package/dist/src/core/increment/increment-reopener.d.ts.map +1 -0
  91. package/dist/src/core/increment/increment-reopener.js +390 -0
  92. package/dist/src/core/increment/increment-reopener.js.map +1 -0
  93. package/dist/src/core/increment/metadata-manager.d.ts +26 -1
  94. package/dist/src/core/increment/metadata-manager.d.ts.map +1 -1
  95. package/dist/src/core/increment/metadata-manager.js +143 -5
  96. package/dist/src/core/increment/metadata-manager.js.map +1 -1
  97. package/dist/src/core/increment/recent-work-scanner.d.ts +121 -0
  98. package/dist/src/core/increment/recent-work-scanner.d.ts.map +1 -0
  99. package/dist/src/core/increment/recent-work-scanner.js +303 -0
  100. package/dist/src/core/increment/recent-work-scanner.js.map +1 -0
  101. package/dist/src/core/increment/types.d.ts +1 -0
  102. package/dist/src/core/increment/types.d.ts.map +1 -1
  103. package/dist/src/core/increment-utils.d.ts +112 -0
  104. package/dist/src/core/increment-utils.d.ts.map +1 -0
  105. package/dist/src/core/increment-utils.js +210 -0
  106. package/dist/src/core/increment-utils.js.map +1 -0
  107. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts +65 -0
  108. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts.map +1 -0
  109. package/dist/src/core/living-docs/ac-project-specific-generator.js +175 -0
  110. package/dist/src/core/living-docs/ac-project-specific-generator.js.map +1 -0
  111. package/dist/src/core/living-docs/feature-archiver.d.ts +130 -0
  112. package/dist/src/core/living-docs/feature-archiver.d.ts.map +1 -0
  113. package/dist/src/core/living-docs/feature-archiver.js +549 -0
  114. package/dist/src/core/living-docs/feature-archiver.js.map +1 -0
  115. package/dist/src/core/living-docs/feature-id-manager.d.ts +81 -0
  116. package/dist/src/core/living-docs/feature-id-manager.d.ts.map +1 -0
  117. package/dist/src/core/living-docs/feature-id-manager.js +339 -0
  118. package/dist/src/core/living-docs/feature-id-manager.js.map +1 -0
  119. package/dist/src/core/living-docs/hierarchy-mapper.d.ts +144 -83
  120. package/dist/src/core/living-docs/hierarchy-mapper.d.ts.map +1 -1
  121. package/dist/src/core/living-docs/hierarchy-mapper.js +488 -270
  122. package/dist/src/core/living-docs/hierarchy-mapper.js.map +1 -1
  123. package/dist/src/core/living-docs/index.d.ts +6 -0
  124. package/dist/src/core/living-docs/index.d.ts.map +1 -1
  125. package/dist/src/core/living-docs/index.js +6 -0
  126. package/dist/src/core/living-docs/index.js.map +1 -1
  127. package/dist/src/core/living-docs/project-detector.d.ts +6 -0
  128. package/dist/src/core/living-docs/project-detector.d.ts.map +1 -1
  129. package/dist/src/core/living-docs/project-detector.js +35 -1
  130. package/dist/src/core/living-docs/project-detector.js.map +1 -1
  131. package/dist/src/core/living-docs/spec-distributor.d.ts +100 -26
  132. package/dist/src/core/living-docs/spec-distributor.d.ts.map +1 -1
  133. package/dist/src/core/living-docs/spec-distributor.js +1275 -258
  134. package/dist/src/core/living-docs/spec-distributor.js.map +1 -1
  135. package/dist/src/core/living-docs/task-project-specific-generator.d.ts +109 -0
  136. package/dist/src/core/living-docs/task-project-specific-generator.d.ts.map +1 -0
  137. package/dist/src/core/living-docs/task-project-specific-generator.js +221 -0
  138. package/dist/src/core/living-docs/task-project-specific-generator.js.map +1 -0
  139. package/dist/src/core/living-docs/types.d.ts +143 -0
  140. package/dist/src/core/living-docs/types.d.ts.map +1 -1
  141. package/dist/src/core/project-manager.d.ts +2 -17
  142. package/dist/src/core/project-manager.d.ts.map +1 -1
  143. package/dist/src/core/project-manager.js +68 -48
  144. package/dist/src/core/project-manager.js.map +1 -1
  145. package/dist/src/core/spec-content-sync.d.ts +1 -1
  146. package/dist/src/core/spec-content-sync.d.ts.map +1 -1
  147. package/dist/src/core/sync/enhanced-content-builder.d.ts.map +1 -1
  148. package/dist/src/core/sync/enhanced-content-builder.js +2 -1
  149. package/dist/src/core/sync/enhanced-content-builder.js.map +1 -1
  150. package/dist/src/core/sync/performance-optimizer.d.ts +153 -0
  151. package/dist/src/core/sync/performance-optimizer.d.ts.map +1 -0
  152. package/dist/src/core/sync/performance-optimizer.js +220 -0
  153. package/dist/src/core/sync/performance-optimizer.js.map +1 -0
  154. package/dist/src/core/sync/retry-handler.d.ts +98 -0
  155. package/dist/src/core/sync/retry-handler.d.ts.map +1 -0
  156. package/dist/src/core/sync/retry-handler.js +196 -0
  157. package/dist/src/core/sync/retry-handler.js.map +1 -0
  158. package/dist/src/core/types/config.d.ts +94 -0
  159. package/dist/src/core/types/config.d.ts.map +1 -1
  160. package/dist/src/core/types/config.js +16 -0
  161. package/dist/src/core/types/config.js.map +1 -1
  162. package/dist/src/core/types/increment-metadata.d.ts +6 -0
  163. package/dist/src/core/types/increment-metadata.d.ts.map +1 -1
  164. package/dist/src/core/types/increment-metadata.js +10 -1
  165. package/dist/src/core/types/increment-metadata.js.map +1 -1
  166. package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +1 -1
  167. package/dist/src/integrations/jira/jira-incremental-mapper.js +4 -8
  168. package/dist/src/integrations/jira/jira-incremental-mapper.js.map +1 -1
  169. package/dist/src/integrations/jira/jira-mapper.d.ts.map +1 -1
  170. package/dist/src/integrations/jira/jira-mapper.js +4 -8
  171. package/dist/src/integrations/jira/jira-mapper.js.map +1 -1
  172. package/package.json +1 -1
  173. package/plugins/specweave/COMMANDS.md +13 -4
  174. package/plugins/specweave/commands/specweave-abandon.md +22 -20
  175. package/plugins/specweave/commands/specweave-archive-features.md +121 -0
  176. package/plugins/specweave/commands/specweave-archive-increments.md +82 -0
  177. package/plugins/specweave/commands/specweave-archive.md +363 -0
  178. package/plugins/specweave/commands/specweave-backlog.md +211 -0
  179. package/plugins/specweave/commands/specweave-fix-duplicates.md +517 -0
  180. package/plugins/specweave/commands/specweave-increment.md +4 -3
  181. package/plugins/specweave/commands/specweave-progress.md +176 -27
  182. package/plugins/specweave/commands/specweave-reopen.md +391 -0
  183. package/plugins/specweave/commands/specweave-restore-feature.md +90 -0
  184. package/plugins/specweave/commands/specweave-restore.md +309 -0
  185. package/plugins/specweave/commands/specweave-resume.md +51 -23
  186. package/plugins/specweave/commands/specweave-status.md +41 -7
  187. package/plugins/specweave/commands/specweave-sync-specs.md +425 -0
  188. package/plugins/specweave/hooks/hooks.json +4 -0
  189. package/plugins/specweave/hooks/lib/sync-spec-content.sh +2 -2
  190. package/plugins/specweave/hooks/post-task-completion.sh +39 -0
  191. package/plugins/specweave/hooks/pre-command-deduplication.sh +83 -0
  192. package/plugins/specweave/hooks/user-prompt-submit.sh +1 -1
  193. package/plugins/specweave/lib/hooks/sync-living-docs.js +2 -0
  194. package/plugins/specweave/lib/hooks/sync-living-docs.ts +4 -0
  195. package/plugins/specweave/lib/hooks/update-ac-status.js +102 -0
  196. package/plugins/specweave/lib/hooks/update-ac-status.ts +192 -0
  197. package/plugins/specweave/skills/archive-increments/SKILL.md +198 -0
  198. package/plugins/specweave/skills/increment-planner/scripts/feature-utils.js +14 -0
  199. package/plugins/specweave/skills/smart-reopen-detector/SKILL.md +244 -0
  200. package/plugins/specweave-ado/lib/ado-spec-content-sync.js +49 -5
  201. package/plugins/specweave-ado/lib/ado-spec-content-sync.ts +72 -6
  202. package/plugins/specweave-confluent/.claude-plugin/plugin.json +23 -0
  203. package/plugins/specweave-confluent/README.md +375 -0
  204. package/plugins/specweave-confluent/agents/confluent-architect/AGENT.md +306 -0
  205. package/plugins/specweave-confluent/skills/confluent-kafka-connect/SKILL.md +453 -0
  206. package/plugins/specweave-confluent/skills/confluent-ksqldb/SKILL.md +470 -0
  207. package/plugins/specweave-confluent/skills/confluent-schema-registry/SKILL.md +316 -0
  208. package/plugins/specweave-github/agents/github-task-splitter/AGENT.md +2 -2
  209. package/plugins/specweave-github/agents/user-story-updater/AGENT.md +148 -0
  210. package/plugins/specweave-github/commands/specweave-github-cleanup-duplicates.md +1 -1
  211. package/plugins/specweave-github/commands/specweave-github-update-user-story.md +156 -0
  212. package/plugins/specweave-github/hooks/post-task-completion.sh +10 -9
  213. package/plugins/specweave-github/lib/completion-calculator.js +262 -0
  214. package/plugins/specweave-github/lib/completion-calculator.ts +434 -0
  215. package/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  216. package/plugins/specweave-github/lib/duplicate-detector.ts +4 -4
  217. package/plugins/specweave-github/lib/epic-content-builder.js +38 -0
  218. package/plugins/specweave-github/lib/epic-content-builder.ts +59 -0
  219. package/plugins/specweave-github/lib/github-client-v2.js +49 -0
  220. package/plugins/specweave-github/lib/github-client-v2.ts +59 -0
  221. package/plugins/specweave-github/lib/github-epic-sync.ts +1 -1
  222. package/plugins/specweave-github/lib/github-feature-sync.js +381 -0
  223. package/plugins/specweave-github/lib/github-feature-sync.ts +568 -0
  224. package/plugins/specweave-github/lib/github-spec-content-sync.js +40 -10
  225. package/plugins/specweave-github/lib/github-spec-content-sync.ts +82 -14
  226. package/plugins/specweave-github/lib/progress-comment-builder.js +229 -0
  227. package/plugins/specweave-github/lib/progress-comment-builder.ts +324 -0
  228. package/plugins/specweave-github/lib/user-story-content-builder.js +299 -0
  229. package/plugins/specweave-github/lib/user-story-content-builder.ts +413 -0
  230. package/plugins/specweave-github/lib/user-story-issue-builder.js +344 -0
  231. package/plugins/specweave-github/lib/user-story-issue-builder.ts +543 -0
  232. package/plugins/specweave-github/skills/github-issue-standard/SKILL.md +189 -0
  233. package/plugins/{specweave-ado/lib/enhanced-ado-sync.js → specweave-jira/lib/enhanced-jira-sync.js} +25 -61
  234. package/plugins/specweave-jira/lib/{enhanced-jira-sync.ts.disabled → enhanced-jira-sync.ts} +26 -52
  235. package/plugins/specweave-kafka/.claude-plugin/plugin.json +26 -0
  236. package/plugins/specweave-kafka/IMPLEMENTATION-COMPLETE.md +483 -0
  237. package/plugins/specweave-kafka/README.md +242 -0
  238. package/plugins/specweave-kafka/agents/kafka-architect/AGENT.md +235 -0
  239. package/plugins/specweave-kafka/agents/kafka-devops/AGENT.md +209 -0
  240. package/plugins/specweave-kafka/agents/kafka-observability/AGENT.md +266 -0
  241. package/plugins/specweave-kafka/commands/deploy.md +99 -0
  242. package/plugins/specweave-kafka/commands/dev-env.md +176 -0
  243. package/plugins/specweave-kafka/commands/mcp-configure.md +101 -0
  244. package/plugins/specweave-kafka/commands/monitor-setup.md +96 -0
  245. package/plugins/specweave-kafka/docker/kafka-local/docker-compose.yml +187 -0
  246. package/plugins/specweave-kafka/docker/redpanda/docker-compose.yml +199 -0
  247. package/plugins/specweave-kafka/docker/templates/consumer-nodejs.js +225 -0
  248. package/plugins/specweave-kafka/docker/templates/consumer-python.py +220 -0
  249. package/plugins/specweave-kafka/docker/templates/producer-nodejs.js +168 -0
  250. package/plugins/specweave-kafka/docker/templates/producer-python.py +167 -0
  251. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.js +438 -0
  252. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.ts +541 -0
  253. package/plugins/specweave-kafka/lib/adapters/platform-adapter.js +47 -0
  254. package/plugins/specweave-kafka/lib/adapters/platform-adapter.ts +343 -0
  255. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +258 -0
  256. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.ts +298 -0
  257. package/plugins/specweave-kafka/lib/cli/types.js +10 -0
  258. package/plugins/specweave-kafka/lib/cli/types.ts +92 -0
  259. package/plugins/specweave-kafka/lib/connectors/connector-catalog.js +305 -0
  260. package/plugins/specweave-kafka/lib/connectors/connector-catalog.ts +528 -0
  261. package/plugins/specweave-kafka/lib/documentation/diagram-generator.js +114 -0
  262. package/plugins/specweave-kafka/lib/documentation/diagram-generator.ts +195 -0
  263. package/plugins/specweave-kafka/lib/documentation/exporter.js +210 -0
  264. package/plugins/specweave-kafka/lib/documentation/exporter.ts +338 -0
  265. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.js +60 -0
  266. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.ts +130 -0
  267. package/plugins/specweave-kafka/lib/documentation/topology-generator.js +143 -0
  268. package/plugins/specweave-kafka/lib/documentation/topology-generator.ts +290 -0
  269. package/plugins/specweave-kafka/lib/mcp/detector.js +298 -0
  270. package/plugins/specweave-kafka/lib/mcp/detector.ts +352 -0
  271. package/plugins/specweave-kafka/lib/mcp/types.js +21 -0
  272. package/plugins/specweave-kafka/lib/mcp/types.ts +77 -0
  273. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.js +193 -0
  274. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.ts +362 -0
  275. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.js +188 -0
  276. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.ts +359 -0
  277. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.js +195 -0
  278. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.ts +380 -0
  279. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.js +209 -0
  280. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.ts +358 -0
  281. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.js +354 -0
  282. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.ts +563 -0
  283. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.js +259 -0
  284. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.ts +516 -0
  285. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.js +233 -0
  286. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.ts +423 -0
  287. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.js +266 -0
  288. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.ts +445 -0
  289. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.js +312 -0
  290. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.ts +561 -0
  291. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.js +289 -0
  292. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.ts +607 -0
  293. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.js +264 -0
  294. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.ts +498 -0
  295. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.js +263 -0
  296. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.ts +549 -0
  297. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.js +205 -0
  298. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.ts +399 -0
  299. package/plugins/specweave-kafka/lib/performance/performance-optimizer.js +249 -0
  300. package/plugins/specweave-kafka/lib/performance/performance-optimizer.ts +427 -0
  301. package/plugins/specweave-kafka/lib/security/kafka-security.js +252 -0
  302. package/plugins/specweave-kafka/lib/security/kafka-security.ts +494 -0
  303. package/plugins/specweave-kafka/lib/utils/capacity-planner.js +203 -0
  304. package/plugins/specweave-kafka/lib/utils/capacity-planner.ts +469 -0
  305. package/plugins/specweave-kafka/lib/utils/config-validator.js +419 -0
  306. package/plugins/specweave-kafka/lib/utils/config-validator.ts +564 -0
  307. package/plugins/specweave-kafka/lib/utils/partitioning.js +329 -0
  308. package/plugins/specweave-kafka/lib/utils/partitioning.ts +473 -0
  309. package/plugins/specweave-kafka/lib/utils/sizing.js +221 -0
  310. package/plugins/specweave-kafka/lib/utils/sizing.ts +374 -0
  311. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-broker-metrics.json +628 -0
  312. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-cluster-overview.json +564 -0
  313. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-consumer-lag.json +509 -0
  314. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-jvm-metrics.json +674 -0
  315. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-topic-metrics.json +578 -0
  316. package/plugins/specweave-kafka/monitoring/grafana/provisioning/dashboards/kafka.yml +17 -0
  317. package/plugins/specweave-kafka/monitoring/grafana/provisioning/datasources/prometheus.yml +17 -0
  318. package/plugins/specweave-kafka/monitoring/prometheus/kafka-alerts.yml +415 -0
  319. package/plugins/specweave-kafka/monitoring/prometheus/kafka-jmx-exporter.yml +256 -0
  320. package/plugins/specweave-kafka/package.json +41 -0
  321. package/plugins/specweave-kafka/skills/kafka-architecture/SKILL.md +647 -0
  322. package/plugins/specweave-kafka/skills/kafka-cli-tools/SKILL.md +433 -0
  323. package/plugins/specweave-kafka/skills/kafka-iac-deployment/SKILL.md +449 -0
  324. package/plugins/specweave-kafka/skills/kafka-kubernetes/SKILL.md +667 -0
  325. package/plugins/specweave-kafka/skills/kafka-mcp-integration/SKILL.md +273 -0
  326. package/plugins/specweave-kafka/skills/kafka-observability/SKILL.md +576 -0
  327. package/plugins/specweave-kafka/templates/config/broker-production.properties +254 -0
  328. package/plugins/specweave-kafka/templates/config/consumer-low-latency.properties +112 -0
  329. package/plugins/specweave-kafka/templates/config/producer-high-throughput.properties +120 -0
  330. package/plugins/specweave-kafka/templates/migration/mirrormaker2-config.properties +234 -0
  331. package/plugins/specweave-kafka/templates/monitoring/grafana/multi-cluster-dashboard.json +686 -0
  332. package/plugins/specweave-kafka/terraform/apache-kafka/main.tf +347 -0
  333. package/plugins/specweave-kafka/terraform/apache-kafka/outputs.tf +107 -0
  334. package/plugins/specweave-kafka/terraform/apache-kafka/templates/kafka-broker-init.sh.tpl +216 -0
  335. package/plugins/specweave-kafka/terraform/apache-kafka/variables.tf +156 -0
  336. package/plugins/specweave-kafka/terraform/aws-msk/main.tf +362 -0
  337. package/plugins/specweave-kafka/terraform/aws-msk/outputs.tf +93 -0
  338. package/plugins/specweave-kafka/terraform/aws-msk/templates/server.properties.tpl +32 -0
  339. package/plugins/specweave-kafka/terraform/aws-msk/variables.tf +235 -0
  340. package/plugins/specweave-kafka/terraform/azure-event-hubs/main.tf +281 -0
  341. package/plugins/specweave-kafka/terraform/azure-event-hubs/outputs.tf +118 -0
  342. package/plugins/specweave-kafka/terraform/azure-event-hubs/variables.tf +148 -0
  343. package/plugins/specweave-kafka/tsconfig.json +21 -0
  344. package/plugins/specweave-kafka-streams/.claude-plugin/plugin.json +23 -0
  345. package/plugins/specweave-kafka-streams/README.md +310 -0
  346. package/plugins/specweave-kafka-streams/skills/kafka-streams-topology/SKILL.md +539 -0
  347. package/plugins/specweave-n8n/.claude-plugin/plugin.json +22 -0
  348. package/plugins/specweave-n8n/README.md +354 -0
  349. package/plugins/specweave-n8n/skills/n8n-kafka-workflows/SKILL.md +504 -0
  350. package/plugins/specweave-release/commands/specweave-release-platform.md +1 -1
  351. package/plugins/specweave-release/hooks/post-task-completion.sh +2 -2
  352. package/src/templates/AGENTS.md.template +601 -7
  353. package/src/templates/CLAUDE.md.template +188 -88
  354. package/dist/locales/de/.gitkeep +0 -0
  355. package/dist/locales/de/cli.json +0 -108
  356. package/dist/locales/en/cli.json +0 -287
  357. package/dist/locales/en/errors.json +0 -7
  358. package/dist/locales/en/templates.json +0 -6
  359. package/dist/locales/es/.gitkeep +0 -0
  360. package/dist/locales/es/cli.json +0 -41
  361. package/dist/locales/fr/.gitkeep +0 -0
  362. package/dist/locales/fr/cli.json +0 -108
  363. package/dist/locales/ja/.gitkeep +0 -0
  364. package/dist/locales/ja/cli.json +0 -108
  365. package/dist/locales/ko/.gitkeep +0 -0
  366. package/dist/locales/ko/cli.json +0 -108
  367. package/dist/locales/pt/.gitkeep +0 -0
  368. package/dist/locales/pt/cli.json +0 -108
  369. package/dist/locales/ru/.gitkeep +0 -0
  370. package/dist/locales/ru/cli.json +0 -269
  371. package/dist/locales/zh/.gitkeep +0 -0
  372. package/dist/locales/zh/cli.json +0 -108
  373. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.d.ts +0 -25
  374. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.d.ts.map +0 -1
  375. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.js +0 -191
  376. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.js.map +0 -1
  377. package/dist/spec-parser.js +0 -629
  378. package/dist/src/core/sync/spec-content-sync.d.ts +0 -88
  379. package/dist/src/core/sync/spec-content-sync.d.ts.map +0 -1
  380. package/dist/src/core/sync/spec-content-sync.js +0 -5
  381. package/dist/src/core/sync/spec-content-sync.js.map +0 -1
  382. package/dist/tsconfig.tsbuildinfo +0 -1
  383. package/plugins/specweave-ado/commands/specweave-ado-sync-spec.md +0 -255
  384. package/plugins/specweave-github/commands/specweave-github-sync-epic.md +0 -248
  385. package/plugins/specweave-github/commands/specweave-github-sync-from.md +0 -147
  386. package/plugins/specweave-github/commands/specweave-github-sync-spec.md +0 -208
  387. package/plugins/specweave-github/commands/specweave-github-sync-tasks.md +0 -530
  388. package/plugins/specweave-jira/commands/specweave-jira-sync-epic.md +0 -267
  389. package/plugins/specweave-jira/commands/specweave-jira-sync-spec.md +0 -240
@@ -0,0 +1,352 @@
1
+ /**
2
+ * MCP Server Detector
3
+ *
4
+ * Auto-detects installed and running MCP servers for Kafka integration.
5
+ * Supports: kanapuli, tuannvm, Joel-hanson, Confluent
6
+ */
7
+
8
+ import { exec } from 'child_process';
9
+ import { promisify } from 'util';
10
+ import {
11
+ MCPServerType,
12
+ MCPServerInfo,
13
+ MCPDetectionResult,
14
+ MCPServerCapabilities,
15
+ AuthMethod
16
+ } from './types';
17
+
18
+ const execAsync = promisify(exec);
19
+
20
+ export class MCPServerDetector {
21
+ /**
22
+ * Detect all available MCP servers
23
+ */
24
+ async detectAll(): Promise<MCPDetectionResult> {
25
+ const servers: MCPServerInfo[] = [];
26
+
27
+ // Check each MCP server type
28
+ const checks = [
29
+ this.detectKanapuli(),
30
+ this.detectTuannvm(),
31
+ this.detectJoelHanson(),
32
+ this.detectConfluent()
33
+ ];
34
+
35
+ const results = await Promise.allSettled(checks);
36
+
37
+ results.forEach((result) => {
38
+ if (result.status === 'fulfilled' && result.value) {
39
+ servers.push(result.value);
40
+ }
41
+ });
42
+
43
+ // Rank servers (Confluent > tuannvm > kanapuli > Joel-hanson)
44
+ const recommended = this.rankServers(servers);
45
+
46
+ return {
47
+ servers,
48
+ recommended: recommended?.type || null,
49
+ rankingReason: this.getRankingReason(recommended, servers)
50
+ };
51
+ }
52
+
53
+ /**
54
+ * Detect kanapuli/mcp-kafka server
55
+ */
56
+ private async detectKanapuli(): Promise<MCPServerInfo | null> {
57
+ try {
58
+ // Check if npm package installed
59
+ const { stdout } = await execAsync('npm list -g mcp-kafka --json 2>/dev/null || echo "{}"');
60
+ const packageInfo = JSON.parse(stdout);
61
+
62
+ const installed = !!packageInfo.dependencies?.['mcp-kafka'];
63
+
64
+ if (!installed) {
65
+ return {
66
+ type: MCPServerType.KANAPULI,
67
+ version: 'unknown',
68
+ installed: false,
69
+ running: false,
70
+ capabilities: this.getKanapuliCapabilities()
71
+ };
72
+ }
73
+
74
+ // Check if running (look for process)
75
+ const running = await this.isProcessRunning('mcp-kafka');
76
+ const version = packageInfo.dependencies?.['mcp-kafka']?.version || 'unknown';
77
+
78
+ return {
79
+ type: MCPServerType.KANAPULI,
80
+ version,
81
+ installed: true,
82
+ running,
83
+ capabilities: this.getKanapuliCapabilities(),
84
+ connectionDetails: running ? {
85
+ host: 'localhost',
86
+ port: 3000, // Default MCP port
87
+ protocol: 'http',
88
+ healthEndpoint: '/health',
89
+ infoEndpoint: '/info'
90
+ } : undefined
91
+ };
92
+ } catch (error) {
93
+ return null;
94
+ }
95
+ }
96
+
97
+ /**
98
+ * Detect tuannvm/kafka-mcp-server (Go implementation)
99
+ */
100
+ private async detectTuannvm(): Promise<MCPServerInfo | null> {
101
+ try {
102
+ // Check if binary exists
103
+ const { stdout } = await execAsync('which kafka-mcp-server 2>/dev/null || echo ""');
104
+ const installed = !!stdout.trim();
105
+
106
+ if (!installed) {
107
+ return {
108
+ type: MCPServerType.TUANNVM,
109
+ version: 'unknown',
110
+ installed: false,
111
+ running: false,
112
+ capabilities: this.getTuannvmCapabilities()
113
+ };
114
+ }
115
+
116
+ // Check if running
117
+ const running = await this.isProcessRunning('kafka-mcp-server');
118
+
119
+ // Try to get version
120
+ let version = 'unknown';
121
+ try {
122
+ const { stdout: versionOut } = await execAsync('kafka-mcp-server --version 2>/dev/null');
123
+ version = versionOut.trim();
124
+ } catch {}
125
+
126
+ return {
127
+ type: MCPServerType.TUANNVM,
128
+ version,
129
+ installed: true,
130
+ running,
131
+ capabilities: this.getTuannvmCapabilities(),
132
+ connectionDetails: running ? {
133
+ host: 'localhost',
134
+ port: 8080, // Default port
135
+ protocol: 'http'
136
+ } : undefined
137
+ };
138
+ } catch (error) {
139
+ return null;
140
+ }
141
+ }
142
+
143
+ /**
144
+ * Detect Joel-hanson/kafka-mcp-server
145
+ */
146
+ private async detectJoelHanson(): Promise<MCPServerInfo | null> {
147
+ try {
148
+ // Check if Python package installed
149
+ const { stdout } = await execAsync('pip show kafka-mcp-server 2>/dev/null || echo ""');
150
+ const installed = stdout.includes('Name: kafka-mcp-server');
151
+
152
+ if (!installed) {
153
+ return {
154
+ type: MCPServerType.JOEL_HANSON,
155
+ version: 'unknown',
156
+ installed: false,
157
+ running: false,
158
+ capabilities: this.getJoelHansonCapabilities()
159
+ };
160
+ }
161
+
162
+ // Extract version
163
+ const versionMatch = stdout.match(/Version: ([\d.]+)/);
164
+ const version = versionMatch ? versionMatch[1] : 'unknown';
165
+
166
+ // Check if running
167
+ const running = await this.isProcessRunning('kafka-mcp-server');
168
+
169
+ return {
170
+ type: MCPServerType.JOEL_HANSON,
171
+ version,
172
+ installed: true,
173
+ running,
174
+ capabilities: this.getJoelHansonCapabilities(),
175
+ connectionDetails: running ? {
176
+ host: 'localhost',
177
+ port: 5000, // Default Python MCP port
178
+ protocol: 'http'
179
+ } : undefined
180
+ };
181
+ } catch (error) {
182
+ return null;
183
+ }
184
+ }
185
+
186
+ /**
187
+ * Detect Confluent official MCP server
188
+ */
189
+ private async detectConfluent(): Promise<MCPServerInfo | null> {
190
+ try {
191
+ // Confluent MCP is typically part of Confluent Cloud CLI
192
+ const { stdout } = await execAsync('confluent version 2>/dev/null || echo ""');
193
+ const installed = !!stdout.trim();
194
+
195
+ if (!installed) {
196
+ return {
197
+ type: MCPServerType.CONFLUENT,
198
+ version: 'unknown',
199
+ installed: false,
200
+ running: false,
201
+ capabilities: this.getConfluentCapabilities()
202
+ };
203
+ }
204
+
205
+ // Extract version
206
+ const versionMatch = stdout.match(/Version:\s+([\d.]+)/);
207
+ const version = versionMatch ? versionMatch[1] : 'unknown';
208
+
209
+ // Confluent MCP runs as part of CLI, check if CLI is authenticated
210
+ let running = false;
211
+ try {
212
+ const { stdout: authOut } = await execAsync('confluent auth current 2>/dev/null');
213
+ running = authOut.includes('Logged in as');
214
+ } catch {}
215
+
216
+ return {
217
+ type: MCPServerType.CONFLUENT,
218
+ version,
219
+ installed: true,
220
+ running,
221
+ capabilities: this.getConfluentCapabilities()
222
+ };
223
+ } catch (error) {
224
+ return null;
225
+ }
226
+ }
227
+
228
+ /**
229
+ * Check if process is running
230
+ */
231
+ private async isProcessRunning(processName: string): Promise<boolean> {
232
+ try {
233
+ const { stdout } = await execAsync(`ps aux | grep "${processName}" | grep -v grep || echo ""`);
234
+ return !!stdout.trim();
235
+ } catch {
236
+ return false;
237
+ }
238
+ }
239
+
240
+ /**
241
+ * Rank servers by priority (Confluent > tuannvm > kanapuli > Joel-hanson)
242
+ */
243
+ private rankServers(servers: MCPServerInfo[]): MCPServerInfo | null {
244
+ const ranking = [
245
+ MCPServerType.CONFLUENT,
246
+ MCPServerType.TUANNVM,
247
+ MCPServerType.KANAPULI,
248
+ MCPServerType.JOEL_HANSON
249
+ ];
250
+
251
+ // Find highest-ranked installed server
252
+ for (const type of ranking) {
253
+ const server = servers.find(s => s.type === type && s.installed);
254
+ if (server) return server;
255
+ }
256
+
257
+ return null;
258
+ }
259
+
260
+ /**
261
+ * Get ranking reason
262
+ */
263
+ private getRankingReason(recommended: MCPServerInfo | null, servers: MCPServerInfo[]): string {
264
+ if (!recommended) {
265
+ return 'No MCP servers installed';
266
+ }
267
+
268
+ const reasons: Record<MCPServerType, string> = {
269
+ [MCPServerType.CONFLUENT]: 'Confluent official MCP (best features: natural language, Flink SQL)',
270
+ [MCPServerType.TUANNVM]: 'Go implementation (advanced SASL: SCRAM-SHA-256/512)',
271
+ [MCPServerType.KANAPULI]: 'Node.js implementation (basic operations, SASL_PLAINTEXT)',
272
+ [MCPServerType.JOEL_HANSON]: 'Python implementation (Claude Desktop integration)'
273
+ };
274
+
275
+ return reasons[recommended.type];
276
+ }
277
+
278
+ /**
279
+ * Get capabilities for each MCP server type
280
+ */
281
+ private getKanapuliCapabilities(): MCPServerCapabilities {
282
+ return {
283
+ authentication: [AuthMethod.SASL_PLAINTEXT, AuthMethod.PLAINTEXT],
284
+ operations: ['produce', 'consume', 'list-topics', 'describe-topic', 'get-offsets'],
285
+ advancedFeatures: []
286
+ };
287
+ }
288
+
289
+ private getTuannvmCapabilities(): MCPServerCapabilities {
290
+ return {
291
+ authentication: [
292
+ AuthMethod.SASL_SCRAM_SHA_256,
293
+ AuthMethod.SASL_SCRAM_SHA_512,
294
+ AuthMethod.SASL_PLAINTEXT,
295
+ AuthMethod.SASL_SSL,
296
+ AuthMethod.PLAINTEXT
297
+ ],
298
+ operations: [
299
+ 'produce',
300
+ 'consume',
301
+ 'list-topics',
302
+ 'create-topic',
303
+ 'delete-topic',
304
+ 'describe-topic',
305
+ 'list-consumer-groups',
306
+ 'describe-consumer-group',
307
+ 'get-offsets',
308
+ 'reset-offsets'
309
+ ],
310
+ advancedFeatures: ['consumer-group-management', 'offset-management']
311
+ };
312
+ }
313
+
314
+ private getJoelHansonCapabilities(): MCPServerCapabilities {
315
+ return {
316
+ authentication: [AuthMethod.SASL_PLAINTEXT, AuthMethod.PLAINTEXT, AuthMethod.SSL],
317
+ operations: ['produce', 'consume', 'list-topics', 'describe-topic'],
318
+ advancedFeatures: ['claude-desktop-integration']
319
+ };
320
+ }
321
+
322
+ private getConfluentCapabilities(): MCPServerCapabilities {
323
+ return {
324
+ authentication: [
325
+ AuthMethod.OAUTH,
326
+ AuthMethod.SASL_SCRAM_SHA_256,
327
+ AuthMethod.SASL_SCRAM_SHA_512,
328
+ AuthMethod.SASL_SSL
329
+ ],
330
+ operations: [
331
+ 'produce',
332
+ 'consume',
333
+ 'list-topics',
334
+ 'create-topic',
335
+ 'delete-topic',
336
+ 'describe-topic',
337
+ 'list-consumer-groups',
338
+ 'describe-consumer-group',
339
+ 'schema-registry-operations',
340
+ 'ksqldb-query',
341
+ 'flink-sql-query'
342
+ ],
343
+ advancedFeatures: [
344
+ 'natural-language-interface',
345
+ 'schema-registry',
346
+ 'ksqldb',
347
+ 'flink-sql',
348
+ 'cloud-managed'
349
+ ]
350
+ };
351
+ }
352
+ }
@@ -0,0 +1,21 @@
1
+ var MCPServerType = /* @__PURE__ */ ((MCPServerType2) => {
2
+ MCPServerType2["KANAPULI"] = "kanapuli";
3
+ MCPServerType2["TUANNVM"] = "tuannvm";
4
+ MCPServerType2["JOEL_HANSON"] = "joel-hanson";
5
+ MCPServerType2["CONFLUENT"] = "confluent";
6
+ return MCPServerType2;
7
+ })(MCPServerType || {});
8
+ var AuthMethod = /* @__PURE__ */ ((AuthMethod2) => {
9
+ AuthMethod2["SASL_PLAINTEXT"] = "SASL_PLAINTEXT";
10
+ AuthMethod2["SASL_SCRAM_SHA_256"] = "SASL/SCRAM-SHA-256";
11
+ AuthMethod2["SASL_SCRAM_SHA_512"] = "SASL/SCRAM-SHA-512";
12
+ AuthMethod2["SASL_SSL"] = "SASL_SSL";
13
+ AuthMethod2["SSL"] = "SSL";
14
+ AuthMethod2["PLAINTEXT"] = "PLAINTEXT";
15
+ AuthMethod2["OAUTH"] = "OAUTH";
16
+ return AuthMethod2;
17
+ })(AuthMethod || {});
18
+ export {
19
+ AuthMethod,
20
+ MCPServerType
21
+ };
@@ -0,0 +1,77 @@
1
+ /**
2
+ * MCP Server Types and Interfaces
3
+ *
4
+ * Defines types for MCP server detection, configuration, and operations.
5
+ */
6
+
7
+ export enum MCPServerType {
8
+ KANAPULI = 'kanapuli',
9
+ TUANNVM = 'tuannvm',
10
+ JOEL_HANSON = 'joel-hanson',
11
+ CONFLUENT = 'confluent'
12
+ }
13
+
14
+ export interface MCPServerInfo {
15
+ type: MCPServerType;
16
+ version: string;
17
+ installed: boolean;
18
+ running: boolean;
19
+ capabilities: MCPServerCapabilities;
20
+ connectionDetails?: MCPConnectionDetails;
21
+ }
22
+
23
+ export interface MCPServerCapabilities {
24
+ authentication: AuthMethod[];
25
+ operations: string[];
26
+ advancedFeatures: string[];
27
+ }
28
+
29
+ export enum AuthMethod {
30
+ SASL_PLAINTEXT = 'SASL_PLAINTEXT',
31
+ SASL_SCRAM_SHA_256 = 'SASL/SCRAM-SHA-256',
32
+ SASL_SCRAM_SHA_512 = 'SASL/SCRAM-SHA-512',
33
+ SASL_SSL = 'SASL_SSL',
34
+ SSL = 'SSL',
35
+ PLAINTEXT = 'PLAINTEXT',
36
+ OAUTH = 'OAUTH'
37
+ }
38
+
39
+ export interface MCPConnectionDetails {
40
+ host: string;
41
+ port: number;
42
+ protocol: string;
43
+ healthEndpoint?: string;
44
+ infoEndpoint?: string;
45
+ }
46
+
47
+ export interface MCPServerConfig {
48
+ serverType: MCPServerType;
49
+ brokerUrls: string[];
50
+ authentication: {
51
+ mechanism: AuthMethod;
52
+ username?: string;
53
+ password?: string;
54
+ saslMechanism?: string;
55
+ sslCertPath?: string;
56
+ sslKeyPath?: string;
57
+ sslCaPath?: string;
58
+ };
59
+ options?: Record<string, any>;
60
+ }
61
+
62
+ export interface MCPDetectionResult {
63
+ servers: MCPServerInfo[];
64
+ recommended: MCPServerType | null;
65
+ rankingReason: string;
66
+ }
67
+
68
+ export interface MCPOperationResult {
69
+ success: boolean;
70
+ data?: any;
71
+ error?: string;
72
+ metadata?: {
73
+ serverType: MCPServerType;
74
+ operation: string;
75
+ duration: number;
76
+ };
77
+ }
@@ -0,0 +1,193 @@
1
+ import * as fs from "fs";
2
+ import * as path from "path";
3
+ class ClusterConfigManager {
4
+ constructor(configFilePath = path.join(process.cwd(), ".kafka-clusters.json")) {
5
+ this.configFilePath = configFilePath;
6
+ this.config = this.loadConfig();
7
+ }
8
+ /**
9
+ * Load configuration from file
10
+ */
11
+ loadConfig() {
12
+ if (fs.existsSync(this.configFilePath)) {
13
+ const data = fs.readFileSync(this.configFilePath, "utf-8");
14
+ return JSON.parse(data);
15
+ }
16
+ return {
17
+ activeClusterId: "dev",
18
+ clusters: [
19
+ {
20
+ id: "dev",
21
+ name: "Development",
22
+ environment: "dev",
23
+ bootstrapServers: ["localhost:9092"],
24
+ securityProtocol: "PLAINTEXT",
25
+ cloudProvider: "Self-Hosted"
26
+ }
27
+ ]
28
+ };
29
+ }
30
+ /**
31
+ * Save configuration to file
32
+ */
33
+ saveConfig() {
34
+ fs.writeFileSync(
35
+ this.configFilePath,
36
+ JSON.stringify(this.config, null, 2),
37
+ "utf-8"
38
+ );
39
+ }
40
+ /**
41
+ * Add cluster configuration
42
+ */
43
+ addCluster(cluster) {
44
+ if (this.config.clusters.some((c) => c.id === cluster.id)) {
45
+ throw new Error(`Cluster with ID "${cluster.id}" already exists`);
46
+ }
47
+ this.config.clusters.push(cluster);
48
+ this.saveConfig();
49
+ }
50
+ /**
51
+ * Update cluster configuration
52
+ */
53
+ updateCluster(clusterId, updates) {
54
+ const index = this.config.clusters.findIndex((c) => c.id === clusterId);
55
+ if (index === -1) {
56
+ throw new Error(`Cluster "${clusterId}" not found`);
57
+ }
58
+ this.config.clusters[index] = {
59
+ ...this.config.clusters[index],
60
+ ...updates,
61
+ id: clusterId
62
+ // Prevent ID change
63
+ };
64
+ this.saveConfig();
65
+ }
66
+ /**
67
+ * Remove cluster configuration
68
+ */
69
+ removeCluster(clusterId) {
70
+ if (clusterId === this.config.activeClusterId) {
71
+ throw new Error(`Cannot remove active cluster "${clusterId}". Switch to another cluster first.`);
72
+ }
73
+ const index = this.config.clusters.findIndex((c) => c.id === clusterId);
74
+ if (index === -1) {
75
+ throw new Error(`Cluster "${clusterId}" not found`);
76
+ }
77
+ this.config.clusters.splice(index, 1);
78
+ this.saveConfig();
79
+ }
80
+ /**
81
+ * Get cluster configuration
82
+ */
83
+ getCluster(clusterId) {
84
+ return this.config.clusters.find((c) => c.id === clusterId);
85
+ }
86
+ /**
87
+ * Get all clusters
88
+ */
89
+ getAllClusters() {
90
+ return [...this.config.clusters];
91
+ }
92
+ /**
93
+ * Get clusters by environment
94
+ */
95
+ getClustersByEnvironment(environment) {
96
+ return this.config.clusters.filter((c) => c.environment === environment);
97
+ }
98
+ /**
99
+ * Get active cluster ID
100
+ */
101
+ getActiveClusterId() {
102
+ return this.config.activeClusterId;
103
+ }
104
+ /**
105
+ * Get active cluster configuration
106
+ */
107
+ getActiveCluster() {
108
+ const cluster = this.getCluster(this.config.activeClusterId);
109
+ if (!cluster) {
110
+ throw new Error(`Active cluster "${this.config.activeClusterId}" not found`);
111
+ }
112
+ return cluster;
113
+ }
114
+ /**
115
+ * Set active cluster
116
+ */
117
+ setActiveCluster(clusterId) {
118
+ const cluster = this.getCluster(clusterId);
119
+ if (!cluster) {
120
+ throw new Error(`Cluster "${clusterId}" not found`);
121
+ }
122
+ this.config.activeClusterId = clusterId;
123
+ this.saveConfig();
124
+ }
125
+ /**
126
+ * Export configuration as JSON
127
+ */
128
+ exportConfig() {
129
+ return JSON.stringify(this.config, null, 2);
130
+ }
131
+ /**
132
+ * Import configuration from JSON
133
+ */
134
+ importConfig(jsonConfig) {
135
+ const imported = JSON.parse(jsonConfig);
136
+ if (!imported.activeClusterId || !Array.isArray(imported.clusters)) {
137
+ throw new Error("Invalid configuration format");
138
+ }
139
+ if (!imported.clusters.some((c) => c.id === imported.activeClusterId)) {
140
+ throw new Error(`Active cluster "${imported.activeClusterId}" not found in imported clusters`);
141
+ }
142
+ this.config = imported;
143
+ this.saveConfig();
144
+ }
145
+ /**
146
+ * Generate kafkajs client config for active cluster
147
+ */
148
+ getKafkaJSConfig() {
149
+ const cluster = this.getActiveCluster();
150
+ const config = {
151
+ clientId: `kafka-client-${cluster.id}`,
152
+ brokers: cluster.bootstrapServers
153
+ };
154
+ if (cluster.securityProtocol !== "PLAINTEXT") {
155
+ config.ssl = cluster.securityProtocol === "SSL" || cluster.securityProtocol === "SASL_SSL" ? {
156
+ rejectUnauthorized: true,
157
+ ...cluster.sslCaPath && { ca: [fs.readFileSync(cluster.sslCaPath)] },
158
+ ...cluster.sslCertPath && { cert: [fs.readFileSync(cluster.sslCertPath)] },
159
+ ...cluster.sslKeyPath && { key: [fs.readFileSync(cluster.sslKeyPath)] }
160
+ } : void 0;
161
+ if (cluster.securityProtocol.startsWith("SASL")) {
162
+ config.sasl = {
163
+ mechanism: cluster.saslMechanism || "PLAIN",
164
+ username: cluster.saslUsername || "",
165
+ password: cluster.saslPassword || ""
166
+ };
167
+ }
168
+ }
169
+ return config;
170
+ }
171
+ /**
172
+ * Validate cluster connectivity
173
+ */
174
+ async validateCluster(clusterId) {
175
+ const cluster = this.getCluster(clusterId);
176
+ if (!cluster) {
177
+ return { valid: false, error: `Cluster "${clusterId}" not found` };
178
+ }
179
+ try {
180
+ if (!cluster.bootstrapServers || cluster.bootstrapServers.length === 0) {
181
+ return { valid: false, error: "No bootstrap servers configured" };
182
+ }
183
+ return { valid: true };
184
+ } catch (error) {
185
+ return { valid: false, error: error.message };
186
+ }
187
+ }
188
+ }
189
+ var cluster_config_manager_default = ClusterConfigManager;
190
+ export {
191
+ ClusterConfigManager,
192
+ cluster_config_manager_default as default
193
+ };