specweave 0.18.1 → 0.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (384) 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/plugins/specweave-kafka/lib/cli/kcat-wrapper.d.ts +57 -0
  54. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.d.ts.map +1 -0
  55. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +248 -0
  56. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.js.map +1 -0
  57. package/dist/plugins/specweave-kafka/lib/cli/types.d.ts +82 -0
  58. package/dist/plugins/specweave-kafka/lib/cli/types.d.ts.map +1 -0
  59. package/dist/plugins/specweave-kafka/lib/cli/types.js +13 -0
  60. package/dist/plugins/specweave-kafka/lib/cli/types.js.map +1 -0
  61. package/dist/plugins/specweave-kafka/lib/mcp/detector.d.ts +49 -0
  62. package/dist/plugins/specweave-kafka/lib/mcp/detector.d.ts.map +1 -0
  63. package/dist/plugins/specweave-kafka/lib/mcp/detector.js +316 -0
  64. package/dist/plugins/specweave-kafka/lib/mcp/detector.js.map +1 -0
  65. package/dist/plugins/specweave-kafka/lib/mcp/types.d.ts +70 -0
  66. package/dist/plugins/specweave-kafka/lib/mcp/types.d.ts.map +1 -0
  67. package/dist/plugins/specweave-kafka/lib/mcp/types.js +23 -0
  68. package/dist/plugins/specweave-kafka/lib/mcp/types.js.map +1 -0
  69. package/dist/plugins/specweave-kafka/lib/utils/partitioning.d.ts +85 -0
  70. package/dist/plugins/specweave-kafka/lib/utils/partitioning.d.ts.map +1 -0
  71. package/dist/plugins/specweave-kafka/lib/utils/partitioning.js +281 -0
  72. package/dist/plugins/specweave-kafka/lib/utils/partitioning.js.map +1 -0
  73. package/dist/plugins/specweave-kafka/lib/utils/sizing.d.ts +75 -0
  74. package/dist/plugins/specweave-kafka/lib/utils/sizing.d.ts.map +1 -0
  75. package/dist/plugins/specweave-kafka/lib/utils/sizing.js +238 -0
  76. package/dist/plugins/specweave-kafka/lib/utils/sizing.js.map +1 -0
  77. package/dist/src/cli/commands/import-docs.js +4 -4
  78. package/dist/src/cli/commands/import-docs.js.map +1 -1
  79. package/dist/src/cli/commands/init-multiproject.d.ts.map +1 -1
  80. package/dist/src/cli/commands/init-multiproject.js +17 -18
  81. package/dist/src/cli/commands/init-multiproject.js.map +1 -1
  82. package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +1 -1
  83. package/dist/src/cli/commands/migrate-to-multiproject.js +8 -4
  84. package/dist/src/cli/commands/migrate-to-multiproject.js.map +1 -1
  85. package/dist/src/cli/commands/switch-project.d.ts.map +1 -1
  86. package/dist/src/cli/commands/switch-project.js +9 -26
  87. package/dist/src/cli/commands/switch-project.js.map +1 -1
  88. package/dist/src/cli/commands/sync-spec-content.js +3 -0
  89. package/dist/src/cli/commands/sync-spec-content.js.map +1 -1
  90. package/dist/src/core/deduplication/command-deduplicator.d.ts +166 -0
  91. package/dist/src/core/deduplication/command-deduplicator.d.ts.map +1 -0
  92. package/dist/src/core/deduplication/command-deduplicator.js +254 -0
  93. package/dist/src/core/deduplication/command-deduplicator.js.map +1 -0
  94. package/dist/src/core/increment/active-increment-manager.d.ts +42 -15
  95. package/dist/src/core/increment/active-increment-manager.d.ts.map +1 -1
  96. package/dist/src/core/increment/active-increment-manager.js +113 -46
  97. package/dist/src/core/increment/active-increment-manager.js.map +1 -1
  98. package/dist/src/core/increment/conflict-resolver.d.ts +40 -0
  99. package/dist/src/core/increment/conflict-resolver.d.ts.map +1 -0
  100. package/dist/src/core/increment/conflict-resolver.js +219 -0
  101. package/dist/src/core/increment/conflict-resolver.js.map +1 -0
  102. package/dist/src/core/increment/discipline-checker.d.ts.map +1 -1
  103. package/dist/src/core/increment/discipline-checker.js +7 -1
  104. package/dist/src/core/increment/discipline-checker.js.map +1 -1
  105. package/dist/src/core/increment/duplicate-detector.d.ts +52 -0
  106. package/dist/src/core/increment/duplicate-detector.d.ts.map +1 -0
  107. package/dist/src/core/increment/duplicate-detector.js +276 -0
  108. package/dist/src/core/increment/duplicate-detector.js.map +1 -0
  109. package/dist/src/core/increment/increment-archiver.d.ts +90 -0
  110. package/dist/src/core/increment/increment-archiver.d.ts.map +1 -0
  111. package/dist/src/core/increment/increment-archiver.js +368 -0
  112. package/dist/src/core/increment/increment-archiver.js.map +1 -0
  113. package/dist/src/core/increment/increment-reopener.d.ts +165 -0
  114. package/dist/src/core/increment/increment-reopener.d.ts.map +1 -0
  115. package/dist/src/core/increment/increment-reopener.js +390 -0
  116. package/dist/src/core/increment/increment-reopener.js.map +1 -0
  117. package/dist/src/core/increment/metadata-manager.d.ts +26 -1
  118. package/dist/src/core/increment/metadata-manager.d.ts.map +1 -1
  119. package/dist/src/core/increment/metadata-manager.js +143 -5
  120. package/dist/src/core/increment/metadata-manager.js.map +1 -1
  121. package/dist/src/core/increment/recent-work-scanner.d.ts +121 -0
  122. package/dist/src/core/increment/recent-work-scanner.d.ts.map +1 -0
  123. package/dist/src/core/increment/recent-work-scanner.js +303 -0
  124. package/dist/src/core/increment/recent-work-scanner.js.map +1 -0
  125. package/dist/src/core/increment/types.d.ts +1 -0
  126. package/dist/src/core/increment/types.d.ts.map +1 -1
  127. package/dist/src/core/increment-utils.d.ts +112 -0
  128. package/dist/src/core/increment-utils.d.ts.map +1 -0
  129. package/dist/src/core/increment-utils.js +210 -0
  130. package/dist/src/core/increment-utils.js.map +1 -0
  131. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts +65 -0
  132. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts.map +1 -0
  133. package/dist/src/core/living-docs/ac-project-specific-generator.js +175 -0
  134. package/dist/src/core/living-docs/ac-project-specific-generator.js.map +1 -0
  135. package/dist/src/core/living-docs/feature-archiver.d.ts +130 -0
  136. package/dist/src/core/living-docs/feature-archiver.d.ts.map +1 -0
  137. package/dist/src/core/living-docs/feature-archiver.js +549 -0
  138. package/dist/src/core/living-docs/feature-archiver.js.map +1 -0
  139. package/dist/src/core/living-docs/feature-id-manager.d.ts +81 -0
  140. package/dist/src/core/living-docs/feature-id-manager.d.ts.map +1 -0
  141. package/dist/src/core/living-docs/feature-id-manager.js +339 -0
  142. package/dist/src/core/living-docs/feature-id-manager.js.map +1 -0
  143. package/dist/src/core/living-docs/hierarchy-mapper.d.ts +144 -83
  144. package/dist/src/core/living-docs/hierarchy-mapper.d.ts.map +1 -1
  145. package/dist/src/core/living-docs/hierarchy-mapper.js +488 -270
  146. package/dist/src/core/living-docs/hierarchy-mapper.js.map +1 -1
  147. package/dist/src/core/living-docs/index.d.ts +6 -0
  148. package/dist/src/core/living-docs/index.d.ts.map +1 -1
  149. package/dist/src/core/living-docs/index.js +6 -0
  150. package/dist/src/core/living-docs/index.js.map +1 -1
  151. package/dist/src/core/living-docs/project-detector.d.ts +6 -0
  152. package/dist/src/core/living-docs/project-detector.d.ts.map +1 -1
  153. package/dist/src/core/living-docs/project-detector.js +35 -1
  154. package/dist/src/core/living-docs/project-detector.js.map +1 -1
  155. package/dist/src/core/living-docs/spec-distributor.d.ts +100 -26
  156. package/dist/src/core/living-docs/spec-distributor.d.ts.map +1 -1
  157. package/dist/src/core/living-docs/spec-distributor.js +1275 -258
  158. package/dist/src/core/living-docs/spec-distributor.js.map +1 -1
  159. package/dist/src/core/living-docs/task-project-specific-generator.d.ts +109 -0
  160. package/dist/src/core/living-docs/task-project-specific-generator.d.ts.map +1 -0
  161. package/dist/src/core/living-docs/task-project-specific-generator.js +221 -0
  162. package/dist/src/core/living-docs/task-project-specific-generator.js.map +1 -0
  163. package/dist/src/core/living-docs/types.d.ts +143 -0
  164. package/dist/src/core/living-docs/types.d.ts.map +1 -1
  165. package/dist/src/core/project-manager.d.ts +2 -17
  166. package/dist/src/core/project-manager.d.ts.map +1 -1
  167. package/dist/src/core/project-manager.js +68 -48
  168. package/dist/src/core/project-manager.js.map +1 -1
  169. package/dist/src/core/spec-content-sync.d.ts +1 -1
  170. package/dist/src/core/spec-content-sync.d.ts.map +1 -1
  171. package/dist/src/core/sync/enhanced-content-builder.d.ts.map +1 -1
  172. package/dist/src/core/sync/enhanced-content-builder.js +2 -1
  173. package/dist/src/core/sync/enhanced-content-builder.js.map +1 -1
  174. package/dist/src/core/sync/performance-optimizer.d.ts +153 -0
  175. package/dist/src/core/sync/performance-optimizer.d.ts.map +1 -0
  176. package/dist/src/core/sync/performance-optimizer.js +220 -0
  177. package/dist/src/core/sync/performance-optimizer.js.map +1 -0
  178. package/dist/src/core/sync/retry-handler.d.ts +98 -0
  179. package/dist/src/core/sync/retry-handler.d.ts.map +1 -0
  180. package/dist/src/core/sync/retry-handler.js +196 -0
  181. package/dist/src/core/sync/retry-handler.js.map +1 -0
  182. package/dist/src/core/types/config.d.ts +94 -0
  183. package/dist/src/core/types/config.d.ts.map +1 -1
  184. package/dist/src/core/types/config.js +16 -0
  185. package/dist/src/core/types/config.js.map +1 -1
  186. package/dist/src/core/types/increment-metadata.d.ts +6 -0
  187. package/dist/src/core/types/increment-metadata.d.ts.map +1 -1
  188. package/dist/src/core/types/increment-metadata.js +10 -1
  189. package/dist/src/core/types/increment-metadata.js.map +1 -1
  190. package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +1 -1
  191. package/dist/src/integrations/jira/jira-incremental-mapper.js +4 -8
  192. package/dist/src/integrations/jira/jira-incremental-mapper.js.map +1 -1
  193. package/dist/src/integrations/jira/jira-mapper.d.ts.map +1 -1
  194. package/dist/src/integrations/jira/jira-mapper.js +4 -8
  195. package/dist/src/integrations/jira/jira-mapper.js.map +1 -1
  196. package/package.json +1 -1
  197. package/plugins/specweave/COMMANDS.md +13 -4
  198. package/plugins/specweave/commands/specweave-abandon.md +22 -20
  199. package/plugins/specweave/commands/specweave-archive-features.md +121 -0
  200. package/plugins/specweave/commands/specweave-archive-increments.md +82 -0
  201. package/plugins/specweave/commands/specweave-archive.md +363 -0
  202. package/plugins/specweave/commands/specweave-backlog.md +211 -0
  203. package/plugins/specweave/commands/specweave-fix-duplicates.md +517 -0
  204. package/plugins/specweave/commands/specweave-increment.md +4 -3
  205. package/plugins/specweave/commands/specweave-progress.md +176 -27
  206. package/plugins/specweave/commands/specweave-reopen.md +391 -0
  207. package/plugins/specweave/commands/specweave-restore-feature.md +90 -0
  208. package/plugins/specweave/commands/specweave-restore.md +309 -0
  209. package/plugins/specweave/commands/specweave-resume.md +51 -23
  210. package/plugins/specweave/commands/specweave-status.md +41 -7
  211. package/plugins/specweave/commands/specweave-sync-specs.md +425 -0
  212. package/plugins/specweave/hooks/hooks.json +4 -0
  213. package/plugins/specweave/hooks/lib/sync-spec-content.sh +2 -2
  214. package/plugins/specweave/hooks/post-task-completion.sh +39 -0
  215. package/plugins/specweave/hooks/pre-command-deduplication.sh +83 -0
  216. package/plugins/specweave/hooks/user-prompt-submit.sh +1 -1
  217. package/plugins/specweave/lib/hooks/sync-living-docs.js +2 -0
  218. package/plugins/specweave/lib/hooks/sync-living-docs.ts +4 -0
  219. package/plugins/specweave/lib/hooks/update-ac-status.js +102 -0
  220. package/plugins/specweave/lib/hooks/update-ac-status.ts +192 -0
  221. package/plugins/specweave/skills/archive-increments/SKILL.md +198 -0
  222. package/plugins/specweave/skills/increment-planner/scripts/feature-utils.js +14 -0
  223. package/plugins/specweave/skills/smart-reopen-detector/SKILL.md +244 -0
  224. package/plugins/specweave-ado/lib/ado-spec-content-sync.js +49 -5
  225. package/plugins/specweave-ado/lib/ado-spec-content-sync.ts +72 -6
  226. package/plugins/specweave-confluent/.claude-plugin/plugin.json +23 -0
  227. package/plugins/specweave-confluent/README.md +375 -0
  228. package/plugins/specweave-confluent/agents/confluent-architect/AGENT.md +306 -0
  229. package/plugins/specweave-confluent/skills/confluent-kafka-connect/SKILL.md +453 -0
  230. package/plugins/specweave-confluent/skills/confluent-ksqldb/SKILL.md +470 -0
  231. package/plugins/specweave-confluent/skills/confluent-schema-registry/SKILL.md +316 -0
  232. package/plugins/specweave-github/agents/github-task-splitter/AGENT.md +2 -2
  233. package/plugins/specweave-github/agents/user-story-updater/AGENT.md +148 -0
  234. package/plugins/specweave-github/commands/specweave-github-cleanup-duplicates.md +1 -1
  235. package/plugins/specweave-github/commands/specweave-github-update-user-story.md +156 -0
  236. package/plugins/specweave-github/hooks/post-task-completion.sh +10 -9
  237. package/plugins/specweave-github/lib/completion-calculator.js +262 -0
  238. package/plugins/specweave-github/lib/completion-calculator.ts +434 -0
  239. package/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  240. package/plugins/specweave-github/lib/duplicate-detector.ts +4 -4
  241. package/plugins/specweave-github/lib/epic-content-builder.js +38 -0
  242. package/plugins/specweave-github/lib/epic-content-builder.ts +59 -0
  243. package/plugins/specweave-github/lib/github-client-v2.js +49 -0
  244. package/plugins/specweave-github/lib/github-client-v2.ts +59 -0
  245. package/plugins/specweave-github/lib/github-epic-sync.ts +1 -1
  246. package/plugins/specweave-github/lib/github-feature-sync.js +381 -0
  247. package/plugins/specweave-github/lib/github-feature-sync.ts +568 -0
  248. package/plugins/specweave-github/lib/github-spec-content-sync.js +40 -10
  249. package/plugins/specweave-github/lib/github-spec-content-sync.ts +82 -14
  250. package/plugins/specweave-github/lib/progress-comment-builder.js +229 -0
  251. package/plugins/specweave-github/lib/progress-comment-builder.ts +324 -0
  252. package/plugins/specweave-github/lib/user-story-content-builder.js +299 -0
  253. package/plugins/specweave-github/lib/user-story-content-builder.ts +413 -0
  254. package/plugins/specweave-github/lib/user-story-issue-builder.js +344 -0
  255. package/plugins/specweave-github/lib/user-story-issue-builder.ts +543 -0
  256. package/plugins/specweave-github/skills/github-issue-standard/SKILL.md +189 -0
  257. package/plugins/specweave-jira/lib/enhanced-jira-sync.js +134 -0
  258. package/plugins/specweave-jira/lib/{enhanced-jira-sync.ts.disabled → enhanced-jira-sync.ts} +26 -52
  259. package/plugins/specweave-kafka/.claude-plugin/plugin.json +26 -0
  260. package/plugins/specweave-kafka/IMPLEMENTATION-COMPLETE.md +483 -0
  261. package/plugins/specweave-kafka/README.md +242 -0
  262. package/plugins/specweave-kafka/agents/kafka-architect/AGENT.md +235 -0
  263. package/plugins/specweave-kafka/agents/kafka-devops/AGENT.md +209 -0
  264. package/plugins/specweave-kafka/agents/kafka-observability/AGENT.md +266 -0
  265. package/plugins/specweave-kafka/commands/deploy.md +99 -0
  266. package/plugins/specweave-kafka/commands/dev-env.md +176 -0
  267. package/plugins/specweave-kafka/commands/mcp-configure.md +101 -0
  268. package/plugins/specweave-kafka/commands/monitor-setup.md +96 -0
  269. package/plugins/specweave-kafka/docker/kafka-local/docker-compose.yml +187 -0
  270. package/plugins/specweave-kafka/docker/redpanda/docker-compose.yml +199 -0
  271. package/plugins/specweave-kafka/docker/templates/consumer-nodejs.js +225 -0
  272. package/plugins/specweave-kafka/docker/templates/consumer-python.py +220 -0
  273. package/plugins/specweave-kafka/docker/templates/producer-nodejs.js +168 -0
  274. package/plugins/specweave-kafka/docker/templates/producer-python.py +167 -0
  275. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.js +438 -0
  276. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.ts +541 -0
  277. package/plugins/specweave-kafka/lib/adapters/platform-adapter.js +47 -0
  278. package/plugins/specweave-kafka/lib/adapters/platform-adapter.ts +343 -0
  279. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +258 -0
  280. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.ts +298 -0
  281. package/plugins/specweave-kafka/lib/cli/types.js +10 -0
  282. package/plugins/specweave-kafka/lib/cli/types.ts +92 -0
  283. package/plugins/specweave-kafka/lib/connectors/connector-catalog.js +305 -0
  284. package/plugins/specweave-kafka/lib/connectors/connector-catalog.ts +528 -0
  285. package/plugins/specweave-kafka/lib/documentation/diagram-generator.js +114 -0
  286. package/plugins/specweave-kafka/lib/documentation/diagram-generator.ts +195 -0
  287. package/plugins/specweave-kafka/lib/documentation/exporter.js +210 -0
  288. package/plugins/specweave-kafka/lib/documentation/exporter.ts +338 -0
  289. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.js +60 -0
  290. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.ts +130 -0
  291. package/plugins/specweave-kafka/lib/documentation/topology-generator.js +143 -0
  292. package/plugins/specweave-kafka/lib/documentation/topology-generator.ts +290 -0
  293. package/plugins/specweave-kafka/lib/mcp/detector.js +298 -0
  294. package/plugins/specweave-kafka/lib/mcp/detector.ts +352 -0
  295. package/plugins/specweave-kafka/lib/mcp/types.js +21 -0
  296. package/plugins/specweave-kafka/lib/mcp/types.ts +77 -0
  297. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.js +193 -0
  298. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.ts +362 -0
  299. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.js +188 -0
  300. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.ts +359 -0
  301. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.js +195 -0
  302. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.ts +380 -0
  303. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.js +209 -0
  304. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.ts +358 -0
  305. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.js +354 -0
  306. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.ts +563 -0
  307. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.js +259 -0
  308. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.ts +516 -0
  309. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.js +233 -0
  310. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.ts +423 -0
  311. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.js +266 -0
  312. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.ts +445 -0
  313. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.js +312 -0
  314. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.ts +561 -0
  315. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.js +289 -0
  316. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.ts +607 -0
  317. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.js +264 -0
  318. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.ts +498 -0
  319. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.js +263 -0
  320. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.ts +549 -0
  321. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.js +205 -0
  322. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.ts +399 -0
  323. package/plugins/specweave-kafka/lib/performance/performance-optimizer.js +249 -0
  324. package/plugins/specweave-kafka/lib/performance/performance-optimizer.ts +427 -0
  325. package/plugins/specweave-kafka/lib/security/kafka-security.js +252 -0
  326. package/plugins/specweave-kafka/lib/security/kafka-security.ts +494 -0
  327. package/plugins/specweave-kafka/lib/utils/capacity-planner.js +203 -0
  328. package/plugins/specweave-kafka/lib/utils/capacity-planner.ts +469 -0
  329. package/plugins/specweave-kafka/lib/utils/config-validator.js +419 -0
  330. package/plugins/specweave-kafka/lib/utils/config-validator.ts +564 -0
  331. package/plugins/specweave-kafka/lib/utils/partitioning.js +329 -0
  332. package/plugins/specweave-kafka/lib/utils/partitioning.ts +473 -0
  333. package/plugins/specweave-kafka/lib/utils/sizing.js +221 -0
  334. package/plugins/specweave-kafka/lib/utils/sizing.ts +374 -0
  335. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-broker-metrics.json +628 -0
  336. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-cluster-overview.json +564 -0
  337. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-consumer-lag.json +509 -0
  338. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-jvm-metrics.json +674 -0
  339. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-topic-metrics.json +578 -0
  340. package/plugins/specweave-kafka/monitoring/grafana/provisioning/dashboards/kafka.yml +17 -0
  341. package/plugins/specweave-kafka/monitoring/grafana/provisioning/datasources/prometheus.yml +17 -0
  342. package/plugins/specweave-kafka/monitoring/prometheus/kafka-alerts.yml +415 -0
  343. package/plugins/specweave-kafka/monitoring/prometheus/kafka-jmx-exporter.yml +256 -0
  344. package/plugins/specweave-kafka/package.json +41 -0
  345. package/plugins/specweave-kafka/skills/kafka-architecture/SKILL.md +647 -0
  346. package/plugins/specweave-kafka/skills/kafka-cli-tools/SKILL.md +433 -0
  347. package/plugins/specweave-kafka/skills/kafka-iac-deployment/SKILL.md +449 -0
  348. package/plugins/specweave-kafka/skills/kafka-kubernetes/SKILL.md +667 -0
  349. package/plugins/specweave-kafka/skills/kafka-mcp-integration/SKILL.md +273 -0
  350. package/plugins/specweave-kafka/skills/kafka-observability/SKILL.md +576 -0
  351. package/plugins/specweave-kafka/templates/config/broker-production.properties +254 -0
  352. package/plugins/specweave-kafka/templates/config/consumer-low-latency.properties +112 -0
  353. package/plugins/specweave-kafka/templates/config/producer-high-throughput.properties +120 -0
  354. package/plugins/specweave-kafka/templates/migration/mirrormaker2-config.properties +234 -0
  355. package/plugins/specweave-kafka/templates/monitoring/grafana/multi-cluster-dashboard.json +686 -0
  356. package/plugins/specweave-kafka/terraform/apache-kafka/main.tf +347 -0
  357. package/plugins/specweave-kafka/terraform/apache-kafka/outputs.tf +107 -0
  358. package/plugins/specweave-kafka/terraform/apache-kafka/templates/kafka-broker-init.sh.tpl +216 -0
  359. package/plugins/specweave-kafka/terraform/apache-kafka/variables.tf +156 -0
  360. package/plugins/specweave-kafka/terraform/aws-msk/main.tf +362 -0
  361. package/plugins/specweave-kafka/terraform/aws-msk/outputs.tf +93 -0
  362. package/plugins/specweave-kafka/terraform/aws-msk/templates/server.properties.tpl +32 -0
  363. package/plugins/specweave-kafka/terraform/aws-msk/variables.tf +235 -0
  364. package/plugins/specweave-kafka/terraform/azure-event-hubs/main.tf +281 -0
  365. package/plugins/specweave-kafka/terraform/azure-event-hubs/outputs.tf +118 -0
  366. package/plugins/specweave-kafka/terraform/azure-event-hubs/variables.tf +148 -0
  367. package/plugins/specweave-kafka/tsconfig.json +21 -0
  368. package/plugins/specweave-kafka-streams/.claude-plugin/plugin.json +23 -0
  369. package/plugins/specweave-kafka-streams/README.md +310 -0
  370. package/plugins/specweave-kafka-streams/skills/kafka-streams-topology/SKILL.md +539 -0
  371. package/plugins/specweave-n8n/.claude-plugin/plugin.json +22 -0
  372. package/plugins/specweave-n8n/README.md +354 -0
  373. package/plugins/specweave-n8n/skills/n8n-kafka-workflows/SKILL.md +504 -0
  374. package/plugins/specweave-release/commands/specweave-release-platform.md +1 -1
  375. package/plugins/specweave-release/hooks/post-task-completion.sh +2 -2
  376. package/src/templates/AGENTS.md.template +601 -7
  377. package/src/templates/CLAUDE.md.template +188 -88
  378. package/plugins/specweave-ado/commands/specweave-ado-sync-spec.md +0 -255
  379. package/plugins/specweave-github/commands/specweave-github-sync-epic.md +0 -248
  380. package/plugins/specweave-github/commands/specweave-github-sync-from.md +0 -147
  381. package/plugins/specweave-github/commands/specweave-github-sync-spec.md +0 -208
  382. package/plugins/specweave-github/commands/specweave-github-sync-tasks.md +0 -530
  383. package/plugins/specweave-jira/commands/specweave-jira-sync-epic.md +0 -267
  384. package/plugins/specweave-jira/commands/specweave-jira-sync-spec.md +0 -240
@@ -0,0 +1,438 @@
1
+ import { Kafka, ResourceTypes, AclResourceTypes, AclOperationTypes, AclPermissionTypes } from "kafkajs";
2
+ import {
3
+ KafkaPlatform
4
+ } from "./platform-adapter";
5
+ class ApacheKafkaAdapter {
6
+ constructor() {
7
+ this.platform = KafkaPlatform.APACHE_KAFKA;
8
+ this.kafka = null;
9
+ this.admin = null;
10
+ this.connected = false;
11
+ this.config = null;
12
+ }
13
+ // ==================================================
14
+ // Connection Management
15
+ // ==================================================
16
+ async connect(config) {
17
+ if (this.connected) {
18
+ throw new Error("Already connected. Call disconnect() first.");
19
+ }
20
+ this.config = config;
21
+ const kafkaConfig = {
22
+ clientId: config.clientId || "specweave-kafka-adapter",
23
+ brokers: config.brokers,
24
+ connectionTimeout: config.connectionTimeout || 3e4,
25
+ requestTimeout: config.requestTimeout || 3e4
26
+ };
27
+ if (config.ssl?.enabled) {
28
+ kafkaConfig.ssl = {
29
+ rejectUnauthorized: true,
30
+ ca: config.ssl.truststore ? [config.ssl.truststore] : void 0,
31
+ key: config.ssl.keystore,
32
+ cert: config.ssl.keystore
33
+ };
34
+ }
35
+ if (config.sasl) {
36
+ kafkaConfig.sasl = {
37
+ mechanism: config.sasl.mechanism.toLowerCase().replace("_", "-"),
38
+ username: config.sasl.username,
39
+ password: config.sasl.password
40
+ };
41
+ if (config.sasl.mechanism === "OAUTHBEARER" && config.sasl.oauthConfig) {
42
+ kafkaConfig.sasl.oauthBearer = async () => {
43
+ const response = await fetch(config.sasl.oauthConfig.tokenUrl, {
44
+ method: "POST",
45
+ headers: { "Content-Type": "application/x-www-form-urlencoded" },
46
+ body: new URLSearchParams({
47
+ grant_type: "client_credentials",
48
+ client_id: config.sasl.oauthConfig.clientId,
49
+ client_secret: config.sasl.oauthConfig.clientSecret
50
+ })
51
+ });
52
+ const data = await response.json();
53
+ return { value: data.access_token };
54
+ };
55
+ }
56
+ }
57
+ try {
58
+ this.kafka = new Kafka(kafkaConfig);
59
+ this.admin = this.kafka.admin();
60
+ await this.admin.connect();
61
+ this.connected = true;
62
+ } catch (error) {
63
+ throw new Error(`Failed to connect to Kafka: ${error.message}`);
64
+ }
65
+ }
66
+ async disconnect() {
67
+ if (!this.connected || !this.admin) {
68
+ return;
69
+ }
70
+ try {
71
+ await this.admin.disconnect();
72
+ this.connected = false;
73
+ this.admin = null;
74
+ this.kafka = null;
75
+ this.config = null;
76
+ } catch (error) {
77
+ throw new Error(`Failed to disconnect from Kafka: ${error.message}`);
78
+ }
79
+ }
80
+ ensureConnected() {
81
+ if (!this.connected || !this.admin) {
82
+ throw new Error("Not connected to Kafka. Call connect() first.");
83
+ }
84
+ return this.admin;
85
+ }
86
+ // ==================================================
87
+ // Cluster Information
88
+ // ==================================================
89
+ async getClusterInfo() {
90
+ const admin = this.ensureConnected();
91
+ try {
92
+ const cluster = await admin.describeCluster();
93
+ return {
94
+ clusterId: cluster.clusterId || "unknown",
95
+ clusterName: "apache-kafka",
96
+ // Self-hosted Kafka doesn't have cluster names
97
+ platform: this.platform,
98
+ version: "unknown",
99
+ // kafkajs doesn't expose broker version directly
100
+ brokerCount: cluster.brokers.length,
101
+ bootstrapServers: this.config.brokers,
102
+ endpoints: {
103
+ bootstrap: this.config.brokers.join(",")
104
+ }
105
+ };
106
+ } catch (error) {
107
+ throw new Error(`Failed to get cluster info: ${error.message}`);
108
+ }
109
+ }
110
+ async getClusterMetrics() {
111
+ const admin = this.ensureConnected();
112
+ try {
113
+ const topics = await admin.listTopics();
114
+ const cluster = await admin.describeCluster();
115
+ let partitionCount = 0;
116
+ let underReplicatedPartitions = 0;
117
+ let offlinePartitions = 0;
118
+ for (const topic of topics) {
119
+ const metadata = await admin.fetchTopicMetadata({ topics: [topic] });
120
+ const topicMetadata = metadata.topics[0];
121
+ partitionCount += topicMetadata.partitions.length;
122
+ for (const partition of topicMetadata.partitions) {
123
+ if (partition.isr.length < partition.replicas.length) {
124
+ underReplicatedPartitions++;
125
+ }
126
+ if (partition.isr.length === 0) {
127
+ offlinePartitions++;
128
+ }
129
+ }
130
+ }
131
+ return {
132
+ brokerCount: cluster.brokers.length,
133
+ topicCount: topics.length,
134
+ partitionCount,
135
+ underReplicatedPartitions,
136
+ offlinePartitions,
137
+ activeController: cluster.controller ? 1 : 0,
138
+ messagesInPerSec: 0,
139
+ // Requires JMX metrics (not available via Admin API)
140
+ bytesInPerSec: 0,
141
+ // Requires JMX metrics
142
+ bytesOutPerSec: 0
143
+ // Requires JMX metrics
144
+ };
145
+ } catch (error) {
146
+ throw new Error(`Failed to get cluster metrics: ${error.message}`);
147
+ }
148
+ }
149
+ // ==================================================
150
+ // Topic Operations
151
+ // ==================================================
152
+ async listTopics() {
153
+ const admin = this.ensureConnected();
154
+ try {
155
+ const topics = await admin.listTopics();
156
+ return topics;
157
+ } catch (error) {
158
+ throw new Error(`Failed to list topics: ${error.message}`);
159
+ }
160
+ }
161
+ async getTopicMetadata(topic) {
162
+ const admin = this.ensureConnected();
163
+ try {
164
+ const metadata = await admin.fetchTopicMetadata({ topics: [topic] });
165
+ const topicMetadata = metadata.topics[0];
166
+ if (!topicMetadata) {
167
+ throw new Error(`Topic '${topic}' not found`);
168
+ }
169
+ const partitions = topicMetadata.partitions.map((p) => ({
170
+ partition: p.partitionId,
171
+ leader: p.leader,
172
+ replicas: p.replicas,
173
+ isr: p.isr,
174
+ offlineReplicas: p.offlineReplicas || []
175
+ }));
176
+ return {
177
+ name: topic,
178
+ partitions
179
+ };
180
+ } catch (error) {
181
+ throw new Error(`Failed to get topic metadata for '${topic}': ${error.message}`);
182
+ }
183
+ }
184
+ async createTopic(config) {
185
+ const admin = this.ensureConnected();
186
+ try {
187
+ const topicConfig = {
188
+ topic: config.name,
189
+ numPartitions: config.partitions,
190
+ replicationFactor: config.replicationFactor,
191
+ configEntries: config.config ? Object.entries(config.config).map(([name, value]) => ({ name, value: String(value) })) : []
192
+ };
193
+ await admin.createTopics({
194
+ topics: [topicConfig],
195
+ waitForLeaders: true
196
+ });
197
+ return {
198
+ success: true,
199
+ message: `Topic '${config.name}' created successfully`,
200
+ details: { partitions: config.partitions, replicationFactor: config.replicationFactor }
201
+ };
202
+ } catch (error) {
203
+ return {
204
+ success: false,
205
+ message: `Failed to create topic '${config.name}': ${error.message}`
206
+ };
207
+ }
208
+ }
209
+ async deleteTopic(topic) {
210
+ const admin = this.ensureConnected();
211
+ try {
212
+ await admin.deleteTopics({ topics: [topic] });
213
+ return {
214
+ success: true,
215
+ message: `Topic '${topic}' deleted successfully`
216
+ };
217
+ } catch (error) {
218
+ return {
219
+ success: false,
220
+ message: `Failed to delete topic '${topic}': ${error.message}`
221
+ };
222
+ }
223
+ }
224
+ async updateTopicConfig(topic, config) {
225
+ const admin = this.ensureConnected();
226
+ try {
227
+ await admin.alterConfigs({
228
+ resources: [
229
+ {
230
+ type: ResourceTypes.TOPIC,
231
+ name: topic,
232
+ configEntries: Object.entries(config).map(([name, value]) => ({ name, value }))
233
+ }
234
+ ]
235
+ });
236
+ return {
237
+ success: true,
238
+ message: `Topic '${topic}' configuration updated`,
239
+ details: config
240
+ };
241
+ } catch (error) {
242
+ return {
243
+ success: false,
244
+ message: `Failed to update topic '${topic}' config: ${error.message}`
245
+ };
246
+ }
247
+ }
248
+ async getTopicConfig(topic) {
249
+ const admin = this.ensureConnected();
250
+ try {
251
+ const result = await admin.describeConfigs({
252
+ resources: [{ type: ResourceTypes.TOPIC, name: topic }]
253
+ });
254
+ const configs = {};
255
+ for (const entry of result.resources[0].configEntries) {
256
+ configs[entry.configName] = entry.configValue;
257
+ }
258
+ return configs;
259
+ } catch (error) {
260
+ throw new Error(`Failed to get topic config for '${topic}': ${error.message}`);
261
+ }
262
+ }
263
+ // ==================================================
264
+ // Consumer Group Operations
265
+ // ==================================================
266
+ async listConsumerGroups() {
267
+ const admin = this.ensureConnected();
268
+ try {
269
+ const groups = await admin.listGroups();
270
+ return groups.groups.map((g) => g.groupId);
271
+ } catch (error) {
272
+ throw new Error(`Failed to list consumer groups: ${error.message}`);
273
+ }
274
+ }
275
+ async describeConsumerGroup(groupId) {
276
+ const admin = this.ensureConnected();
277
+ try {
278
+ const result = await admin.describeGroups([groupId]);
279
+ const group = result.groups[0];
280
+ if (!group) {
281
+ throw new Error(`Consumer group '${groupId}' not found`);
282
+ }
283
+ return {
284
+ groupId: group.groupId,
285
+ state: group.state,
286
+ protocolType: group.protocolType,
287
+ protocol: group.protocol,
288
+ members: group.members.map((m) => ({
289
+ memberId: m.memberId,
290
+ clientId: m.clientId,
291
+ clientHost: m.clientHost,
292
+ memberMetadata: m.memberMetadata,
293
+ memberAssignment: m.memberAssignment
294
+ })),
295
+ coordinator: {
296
+ id: group.coordinator.nodeId,
297
+ host: group.coordinator.host,
298
+ port: group.coordinator.port
299
+ }
300
+ };
301
+ } catch (error) {
302
+ throw new Error(`Failed to describe consumer group '${groupId}': ${error.message}`);
303
+ }
304
+ }
305
+ async getConsumerGroupOffsets(groupId) {
306
+ const admin = this.ensureConnected();
307
+ try {
308
+ const offsets = await admin.fetchOffsets({ groupId });
309
+ const result = [];
310
+ for (const topic of offsets) {
311
+ for (const partition of topic.partitions) {
312
+ result.push({
313
+ topic: topic.topic,
314
+ partition: partition.partition,
315
+ currentOffset: Number(partition.offset),
316
+ logEndOffset: 0,
317
+ // Need to fetch from topic metadata
318
+ lag: 0,
319
+ // Calculate after fetching logEndOffset
320
+ metadata: partition.metadata || ""
321
+ });
322
+ }
323
+ }
324
+ for (const offset of result) {
325
+ const metadata = await admin.fetchTopicOffsets(offset.topic);
326
+ const partitionMetadata = metadata.find((p) => p.partition === offset.partition);
327
+ if (partitionMetadata) {
328
+ offset.logEndOffset = Number(partitionMetadata.high);
329
+ offset.lag = offset.logEndOffset - offset.currentOffset;
330
+ }
331
+ }
332
+ return result;
333
+ } catch (error) {
334
+ throw new Error(`Failed to get consumer group offsets for '${groupId}': ${error.message}`);
335
+ }
336
+ }
337
+ async deleteConsumerGroup(groupId) {
338
+ const admin = this.ensureConnected();
339
+ try {
340
+ await admin.deleteGroups([groupId]);
341
+ return {
342
+ success: true,
343
+ message: `Consumer group '${groupId}' deleted successfully`
344
+ };
345
+ } catch (error) {
346
+ return {
347
+ success: false,
348
+ message: `Failed to delete consumer group '${groupId}': ${error.message}`
349
+ };
350
+ }
351
+ }
352
+ async resetConsumerGroupOffsets(groupId, topic, options) {
353
+ const admin = this.ensureConnected();
354
+ try {
355
+ const topicPartitions = await admin.fetchTopicOffsets(topic);
356
+ const resetOffsets = [];
357
+ for (const partition of topicPartitions) {
358
+ let offset;
359
+ if (options.toEarliest) {
360
+ offset = partition.low;
361
+ } else if (options.toLatest) {
362
+ offset = partition.high;
363
+ } else if (options.toOffset !== void 0) {
364
+ offset = String(options.toOffset);
365
+ } else if (options.toDateTime) {
366
+ throw new Error("toDateTime not implemented yet");
367
+ } else {
368
+ throw new Error("Must specify one of: toEarliest, toLatest, toOffset, toDateTime");
369
+ }
370
+ resetOffsets.push({ partition: partition.partition, offset });
371
+ }
372
+ await admin.setOffsets({
373
+ groupId,
374
+ topic,
375
+ partitions: resetOffsets
376
+ });
377
+ return {
378
+ success: true,
379
+ message: `Consumer group '${groupId}' offsets reset for topic '${topic}'`,
380
+ details: { resetOffsets }
381
+ };
382
+ } catch (error) {
383
+ return {
384
+ success: false,
385
+ message: `Failed to reset consumer group offsets: ${error.message}`
386
+ };
387
+ }
388
+ }
389
+ // ==================================================
390
+ // ACL Operations
391
+ // ==================================================
392
+ async createAcl(acl) {
393
+ const admin = this.ensureConnected();
394
+ try {
395
+ await admin.createAcls({
396
+ acl: [
397
+ {
398
+ resourceType: AclResourceTypes[acl.resourceType.toUpperCase()],
399
+ resourceName: acl.resourceName,
400
+ principal: acl.principal,
401
+ operation: AclOperationTypes[acl.operation.toUpperCase()],
402
+ permissionType: AclPermissionTypes[acl.permissionType.toUpperCase()],
403
+ resourcePatternType: 2,
404
+ // LITERAL
405
+ host: "*"
406
+ }
407
+ ]
408
+ });
409
+ return {
410
+ success: true,
411
+ message: `ACL created for '${acl.principal}' on ${acl.resourceType} '${acl.resourceName}'`
412
+ };
413
+ } catch (error) {
414
+ return {
415
+ success: false,
416
+ message: `Failed to create ACL: ${error.message}`
417
+ };
418
+ }
419
+ }
420
+ async listAcls() {
421
+ const admin = this.ensureConnected();
422
+ try {
423
+ const result = await admin.describeAcls({
424
+ resourceType: AclResourceTypes.ANY,
425
+ resourceName: null,
426
+ principal: null,
427
+ operation: AclOperationTypes.ANY,
428
+ permissionType: AclPermissionTypes.ANY
429
+ });
430
+ return result.resources;
431
+ } catch (error) {
432
+ throw new Error(`Failed to list ACLs: ${error.message}`);
433
+ }
434
+ }
435
+ }
436
+ export {
437
+ ApacheKafkaAdapter
438
+ };