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,343 @@
1
+ // ==================================================
2
+ // Platform Adapter Interface
3
+ // ==================================================
4
+ // Provides unified API for Kafka operations across different platforms:
5
+ // - Apache Kafka (self-hosted)
6
+ // - AWS MSK (Managed Streaming for Kafka)
7
+ // - Azure Event Hubs (Kafka API)
8
+ // - Confluent Cloud
9
+
10
+ export enum KafkaPlatform {
11
+ APACHE_KAFKA = 'apache-kafka',
12
+ AWS_MSK = 'aws-msk',
13
+ AZURE_EVENT_HUBS = 'azure-event-hubs',
14
+ CONFLUENT_CLOUD = 'confluent-cloud',
15
+ }
16
+
17
+ export interface ClusterInfo {
18
+ clusterId: string;
19
+ clusterName: string;
20
+ platform: KafkaPlatform;
21
+ version: string;
22
+ brokerCount: number;
23
+ bootstrapServers: string[];
24
+ endpoints: {
25
+ bootstrap: string;
26
+ metrics?: string;
27
+ admin?: string;
28
+ };
29
+ }
30
+
31
+ export interface TopicConfig {
32
+ name: string;
33
+ partitions: number;
34
+ replicationFactor: number;
35
+ config?: {
36
+ 'retention.ms'?: number;
37
+ 'retention.bytes'?: number;
38
+ 'segment.bytes'?: number;
39
+ 'compression.type'?: 'none' | 'gzip' | 'snappy' | 'lz4' | 'zstd';
40
+ 'cleanup.policy'?: 'delete' | 'compact' | 'delete,compact';
41
+ 'min.insync.replicas'?: number;
42
+ 'max.message.bytes'?: number;
43
+ [key: string]: any;
44
+ };
45
+ }
46
+
47
+ export interface Topic {
48
+ name: string;
49
+ partitions: number;
50
+ replicationFactor: number;
51
+ isInternal: boolean;
52
+ config: Record<string, string>;
53
+ }
54
+
55
+ export interface Partition {
56
+ partition: number;
57
+ leader: number;
58
+ replicas: number[];
59
+ isr: number[]; // In-Sync Replicas
60
+ offlineReplicas: number[];
61
+ }
62
+
63
+ export interface TopicMetadata {
64
+ name: string;
65
+ partitions: Partition[];
66
+ }
67
+
68
+ export interface ConsumerGroupDescription {
69
+ groupId: string;
70
+ state: 'Stable' | 'Empty' | 'PreparingRebalance' | 'CompletingRebalance' | 'Dead';
71
+ protocolType: string;
72
+ protocol: string;
73
+ members: ConsumerGroupMember[];
74
+ coordinator: {
75
+ id: number;
76
+ host: string;
77
+ port: number;
78
+ };
79
+ }
80
+
81
+ export interface ConsumerGroupMember {
82
+ memberId: string;
83
+ clientId: string;
84
+ clientHost: string;
85
+ memberMetadata: any;
86
+ memberAssignment: {
87
+ topic: string;
88
+ partitions: number[];
89
+ }[];
90
+ }
91
+
92
+ export interface ConsumerGroupOffset {
93
+ topic: string;
94
+ partition: number;
95
+ currentOffset: number;
96
+ logEndOffset: number;
97
+ lag: number;
98
+ metadata: string;
99
+ }
100
+
101
+ export interface ClusterMetrics {
102
+ brokerCount: number;
103
+ topicCount: number;
104
+ partitionCount: number;
105
+ underReplicatedPartitions: number;
106
+ offlinePartitions: number;
107
+ activeController: number;
108
+ messagesInPerSec: number;
109
+ bytesInPerSec: number;
110
+ bytesOutPerSec: number;
111
+ }
112
+
113
+ export interface ConnectionConfig {
114
+ platform: KafkaPlatform;
115
+ brokers: string[];
116
+ ssl?: {
117
+ enabled: boolean;
118
+ truststore?: string;
119
+ keystore?: string;
120
+ password?: string;
121
+ };
122
+ sasl?: {
123
+ mechanism: 'PLAIN' | 'SCRAM-SHA-256' | 'SCRAM-SHA-512' | 'AWS_MSK_IAM' | 'OAUTHBEARER';
124
+ username?: string;
125
+ password?: string;
126
+ awsRegion?: string; // For AWS MSK IAM
127
+ oauthConfig?: { // For Confluent Cloud / OAUTHBEARER
128
+ tokenUrl: string;
129
+ clientId: string;
130
+ clientSecret: string;
131
+ };
132
+ };
133
+ clientId?: string;
134
+ connectionTimeout?: number;
135
+ requestTimeout?: number;
136
+ }
137
+
138
+ export interface AdminOperationResult {
139
+ success: boolean;
140
+ message: string;
141
+ details?: any;
142
+ }
143
+
144
+ /**
145
+ * Platform Adapter Interface
146
+ *
147
+ * Unified API for Kafka operations across different platforms.
148
+ * Implementations:
149
+ * - ApacheKafkaAdapter (self-hosted Kafka)
150
+ * - AwsMskAdapter (AWS MSK)
151
+ * - AzureEventHubsAdapter (Azure Event Hubs with Kafka API)
152
+ * - ConfluentCloudAdapter (Confluent Cloud)
153
+ */
154
+ export interface PlatformAdapter {
155
+ readonly platform: KafkaPlatform;
156
+
157
+ /**
158
+ * Connect to Kafka cluster
159
+ */
160
+ connect(config: ConnectionConfig): Promise<void>;
161
+
162
+ /**
163
+ * Disconnect from Kafka cluster
164
+ */
165
+ disconnect(): Promise<void>;
166
+
167
+ /**
168
+ * Get cluster information
169
+ */
170
+ getClusterInfo(): Promise<ClusterInfo>;
171
+
172
+ /**
173
+ * Get cluster metrics (for monitoring)
174
+ */
175
+ getClusterMetrics(): Promise<ClusterMetrics>;
176
+
177
+ // ==================================================
178
+ // Topic Operations
179
+ // ==================================================
180
+
181
+ /**
182
+ * List all topics
183
+ */
184
+ listTopics(): Promise<string[]>;
185
+
186
+ /**
187
+ * Get topic metadata
188
+ */
189
+ getTopicMetadata(topic: string): Promise<TopicMetadata>;
190
+
191
+ /**
192
+ * Create topic
193
+ */
194
+ createTopic(config: TopicConfig): Promise<AdminOperationResult>;
195
+
196
+ /**
197
+ * Delete topic
198
+ */
199
+ deleteTopic(topic: string): Promise<AdminOperationResult>;
200
+
201
+ /**
202
+ * Update topic configuration
203
+ */
204
+ updateTopicConfig(topic: string, config: Record<string, string>): Promise<AdminOperationResult>;
205
+
206
+ /**
207
+ * Get topic configuration
208
+ */
209
+ getTopicConfig(topic: string): Promise<Record<string, string>>;
210
+
211
+ // ==================================================
212
+ // Consumer Group Operations
213
+ // ==================================================
214
+
215
+ /**
216
+ * List all consumer groups
217
+ */
218
+ listConsumerGroups(): Promise<string[]>;
219
+
220
+ /**
221
+ * Get consumer group description
222
+ */
223
+ describeConsumerGroup(groupId: string): Promise<ConsumerGroupDescription>;
224
+
225
+ /**
226
+ * Get consumer group offsets
227
+ */
228
+ getConsumerGroupOffsets(groupId: string): Promise<ConsumerGroupOffset[]>;
229
+
230
+ /**
231
+ * Delete consumer group
232
+ */
233
+ deleteConsumerGroup(groupId: string): Promise<AdminOperationResult>;
234
+
235
+ /**
236
+ * Reset consumer group offsets
237
+ */
238
+ resetConsumerGroupOffsets(
239
+ groupId: string,
240
+ topic: string,
241
+ options: {
242
+ toEarliest?: boolean;
243
+ toLatest?: boolean;
244
+ toDateTime?: Date;
245
+ toOffset?: number;
246
+ }
247
+ ): Promise<AdminOperationResult>;
248
+
249
+ // ==================================================
250
+ // ACL Operations (Security)
251
+ // ==================================================
252
+
253
+ /**
254
+ * Create ACL (Access Control List)
255
+ *
256
+ * Not supported on all platforms:
257
+ * - Apache Kafka: ✅ Supported
258
+ * - AWS MSK: ⚠️ Use IAM policies instead
259
+ * - Azure Event Hubs: ⚠️ Use Azure RBAC instead
260
+ * - Confluent Cloud: ✅ Supported
261
+ */
262
+ createAcl?(acl: {
263
+ resourceType: 'Topic' | 'Group' | 'Cluster';
264
+ resourceName: string;
265
+ principal: string;
266
+ operation: 'Read' | 'Write' | 'Create' | 'Delete' | 'Alter' | 'Describe' | 'All';
267
+ permissionType: 'Allow' | 'Deny';
268
+ }): Promise<AdminOperationResult>;
269
+
270
+ /**
271
+ * List ACLs
272
+ */
273
+ listAcls?(): Promise<any[]>;
274
+
275
+ // ==================================================
276
+ // Platform-Specific Operations
277
+ // ==================================================
278
+
279
+ /**
280
+ * Platform-specific operation (optional)
281
+ * Examples:
282
+ * - AWS MSK: Get IAM policy for topic access
283
+ * - Azure Event Hubs: Get Event Hub connection string
284
+ * - Confluent Cloud: Get Schema Registry URL
285
+ */
286
+ platformSpecific?(operation: string, params?: any): Promise<any>;
287
+ }
288
+
289
+ /**
290
+ * Platform Adapter Factory
291
+ *
292
+ * Creates appropriate adapter based on platform type
293
+ */
294
+ export class PlatformAdapterFactory {
295
+ static create(platform: KafkaPlatform): PlatformAdapter {
296
+ switch (platform) {
297
+ case KafkaPlatform.APACHE_KAFKA:
298
+ // Lazy load to avoid circular dependencies
299
+ const { ApacheKafkaAdapter } = require('./apache-kafka-adapter');
300
+ return new ApacheKafkaAdapter();
301
+
302
+ case KafkaPlatform.AWS_MSK:
303
+ const { AwsMskAdapter } = require('./aws-msk-adapter');
304
+ return new AwsMskAdapter();
305
+
306
+ case KafkaPlatform.AZURE_EVENT_HUBS:
307
+ const { AzureEventHubsAdapter } = require('./azure-event-hubs-adapter');
308
+ return new AzureEventHubsAdapter();
309
+
310
+ case KafkaPlatform.CONFLUENT_CLOUD:
311
+ const { ConfluentCloudAdapter } = require('./confluent-cloud-adapter');
312
+ return new ConfluentCloudAdapter();
313
+
314
+ default:
315
+ throw new Error(`Unsupported platform: ${platform}`);
316
+ }
317
+ }
318
+
319
+ /**
320
+ * Auto-detect platform based on connection config
321
+ */
322
+ static detectPlatform(config: ConnectionConfig): KafkaPlatform {
323
+ const broker = config.brokers[0].toLowerCase();
324
+
325
+ // AWS MSK detection
326
+ if (broker.includes('.kafka.') && broker.includes('.amazonaws.com')) {
327
+ return KafkaPlatform.AWS_MSK;
328
+ }
329
+
330
+ // Azure Event Hubs detection
331
+ if (broker.includes('.servicebus.windows.net')) {
332
+ return KafkaPlatform.AZURE_EVENT_HUBS;
333
+ }
334
+
335
+ // Confluent Cloud detection
336
+ if (broker.includes('.confluent.cloud') || broker.includes('.gcp.confluent.cloud')) {
337
+ return KafkaPlatform.CONFLUENT_CLOUD;
338
+ }
339
+
340
+ // Default to Apache Kafka
341
+ return KafkaPlatform.APACHE_KAFKA;
342
+ }
343
+ }
@@ -0,0 +1,258 @@
1
+ import { exec } from "child_process";
2
+ import { promisify } from "util";
3
+ const execAsync = promisify(exec);
4
+ class KcatWrapper {
5
+ /**
6
+ * Produce a message to Kafka topic
7
+ */
8
+ async produce(message, options) {
9
+ const args = [
10
+ "kcat",
11
+ "-P",
12
+ // Producer mode
13
+ "-b",
14
+ options.brokers,
15
+ "-t",
16
+ options.topic
17
+ ];
18
+ if (options.key) {
19
+ args.push("-K", ":");
20
+ }
21
+ if (options.partition !== void 0) {
22
+ args.push("-p", options.partition.toString());
23
+ }
24
+ if (options.compression) {
25
+ args.push("-z", options.compression);
26
+ }
27
+ if (options.acks !== void 0) {
28
+ const acksValue = options.acks === "all" ? "-1" : options.acks.toString();
29
+ args.push("-X", `acks=${acksValue}`);
30
+ }
31
+ const command = args.join(" ");
32
+ const input = options.key ? `${options.key}:${message}` : message;
33
+ return this.execute(command, input);
34
+ }
35
+ /**
36
+ * Consume messages from Kafka topic
37
+ */
38
+ async consume(options) {
39
+ const args = [
40
+ "kcat",
41
+ "-C",
42
+ // Consumer mode
43
+ "-b",
44
+ options.brokers,
45
+ "-t",
46
+ options.topic,
47
+ "-f",
48
+ "%t:%p:%o:%k:%s\\n"
49
+ // Format: topic:partition:offset:key:value
50
+ ];
51
+ if (options.offset) {
52
+ args.push("-o", options.offset.toString());
53
+ }
54
+ if (options.partition !== void 0) {
55
+ args.push("-p", options.partition.toString());
56
+ }
57
+ if (options.count) {
58
+ args.push("-c", options.count.toString());
59
+ }
60
+ if (options.groupId) {
61
+ args.push("-G", options.groupId);
62
+ }
63
+ const command = args.join(" ");
64
+ const result = await this.execute(command);
65
+ if (!result.success) {
66
+ throw new Error(`kcat consume failed: ${result.error}`);
67
+ }
68
+ return this.parseConsumeOutput(result.output);
69
+ }
70
+ /**
71
+ * Get cluster metadata
72
+ */
73
+ async getMetadata(options) {
74
+ const args = [
75
+ "kcat",
76
+ "-L",
77
+ // Metadata mode
78
+ "-b",
79
+ options.brokers,
80
+ "-J"
81
+ // JSON output
82
+ ];
83
+ if (options.topic) {
84
+ args.push("-t", options.topic);
85
+ }
86
+ const command = args.join(" ");
87
+ const result = await this.execute(command);
88
+ if (!result.success) {
89
+ throw new Error(`kcat metadata failed: ${result.error}`);
90
+ }
91
+ return this.parseMetadataOutput(result.output);
92
+ }
93
+ /**
94
+ * Query topic offsets
95
+ */
96
+ async queryOffsets(options) {
97
+ const args = [
98
+ "kcat",
99
+ "-Q",
100
+ // Query mode
101
+ "-b",
102
+ options.brokers,
103
+ "-t",
104
+ options.topic
105
+ ];
106
+ if (options.partition !== void 0) {
107
+ args.push("-p", options.partition.toString());
108
+ }
109
+ const command = args.join(" ");
110
+ const result = await this.execute(command);
111
+ if (!result.success) {
112
+ throw new Error(`kcat query failed: ${result.error}`);
113
+ }
114
+ return this.parseQueryOutput(result.output);
115
+ }
116
+ /**
117
+ * Execute kcat command
118
+ */
119
+ async execute(command, input) {
120
+ const startTime = Date.now();
121
+ try {
122
+ const execOptions = {
123
+ maxBuffer: 10 * 1024 * 1024,
124
+ // 10MB buffer
125
+ timeout: 3e4
126
+ // 30 second timeout
127
+ };
128
+ if (input) {
129
+ execOptions.input = input;
130
+ }
131
+ const { stdout, stderr } = await execAsync(command, execOptions);
132
+ const duration = Date.now() - startTime;
133
+ return {
134
+ success: true,
135
+ output: stdout,
136
+ error: stderr || void 0,
137
+ exitCode: 0,
138
+ command,
139
+ duration
140
+ };
141
+ } catch (error) {
142
+ const duration = Date.now() - startTime;
143
+ return {
144
+ success: false,
145
+ output: error.stdout || "",
146
+ error: error.stderr || error.message,
147
+ exitCode: error.code || 1,
148
+ command,
149
+ duration
150
+ };
151
+ }
152
+ }
153
+ /**
154
+ * Parse consume output into messages
155
+ */
156
+ parseConsumeOutput(output) {
157
+ const lines = output.trim().split("\n").filter((line) => line.length > 0);
158
+ const messages = [];
159
+ for (const line of lines) {
160
+ const parts = line.split(":");
161
+ if (parts.length >= 5) {
162
+ messages.push({
163
+ topic: parts[0],
164
+ partition: parseInt(parts[1]),
165
+ offset: parseInt(parts[2]),
166
+ key: parts[3] || void 0,
167
+ value: parts.slice(4).join(":"),
168
+ // Rejoin in case value contains ':'
169
+ timestamp: Date.now()
170
+ // kcat doesn't provide timestamp in this format
171
+ });
172
+ }
173
+ }
174
+ return messages;
175
+ }
176
+ /**
177
+ * Parse metadata JSON output
178
+ */
179
+ parseMetadataOutput(output) {
180
+ const metadata = JSON.parse(output);
181
+ return {
182
+ clusterId: metadata.originatingBroker?.cluster || "unknown",
183
+ controllerId: metadata.controllerId || -1,
184
+ brokers: (metadata.brokers || []).map((b) => ({
185
+ id: b.id,
186
+ host: b.host,
187
+ port: b.port,
188
+ rack: b.rack
189
+ })),
190
+ topics: (metadata.topics || []).map((t) => ({
191
+ name: t.topic,
192
+ replicationFactor: this.calculateReplicationFactor(t.partitions),
193
+ configs: {},
194
+ partitions: (t.partitions || []).map((p) => ({
195
+ id: p.partition,
196
+ leader: p.leader,
197
+ replicas: p.replicas || [],
198
+ isr: p.isrs || [],
199
+ earliestOffset: 0,
200
+ // Not provided in metadata
201
+ latestOffset: 0
202
+ // Not provided in metadata
203
+ }))
204
+ }))
205
+ };
206
+ }
207
+ /**
208
+ * Calculate replication factor from partitions
209
+ */
210
+ calculateReplicationFactor(partitions) {
211
+ if (!partitions || partitions.length === 0) return 0;
212
+ return partitions[0].replicas?.length || 0;
213
+ }
214
+ /**
215
+ * Parse query offset output
216
+ */
217
+ parseQueryOutput(output) {
218
+ const lines = output.trim().split("\n");
219
+ const offsets = {};
220
+ for (const line of lines) {
221
+ const match = line.match(/(\d+)\s+\[(\d+)\]\s+\[(\d+)\]/);
222
+ if (match) {
223
+ const partition = parseInt(match[1]);
224
+ offsets[partition] = {
225
+ earliest: parseInt(match[2]),
226
+ latest: parseInt(match[3])
227
+ };
228
+ }
229
+ }
230
+ return offsets;
231
+ }
232
+ /**
233
+ * Check if kcat is installed
234
+ */
235
+ static async isInstalled() {
236
+ try {
237
+ const { stdout } = await execAsync("which kcat 2>/dev/null || which kafkacat 2>/dev/null");
238
+ return !!stdout.trim();
239
+ } catch {
240
+ return false;
241
+ }
242
+ }
243
+ /**
244
+ * Get kcat version
245
+ */
246
+ static async getVersion() {
247
+ try {
248
+ const { stdout } = await execAsync("kcat -V 2>&1 || kafkacat -V 2>&1");
249
+ const match = stdout.match(/kafkacat - Apache Kafka producer and consumer tool\s+(\S+)/);
250
+ return match ? match[1] : "unknown";
251
+ } catch {
252
+ return "unknown";
253
+ }
254
+ }
255
+ }
256
+ export {
257
+ KcatWrapper
258
+ };