specweave 0.18.0 → 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 (428) hide show
  1. package/CLAUDE.md +229 -1817
  2. package/README.md +68 -0
  3. package/bin/specweave.js +62 -6
  4. package/dist/locales/de/.gitkeep +0 -0
  5. package/dist/locales/de/cli.json +108 -0
  6. package/dist/locales/en/cli.json +287 -0
  7. package/dist/locales/en/errors.json +7 -0
  8. package/dist/locales/en/templates.json +6 -0
  9. package/dist/locales/es/.gitkeep +0 -0
  10. package/dist/locales/es/cli.json +41 -0
  11. package/dist/locales/fr/.gitkeep +0 -0
  12. package/dist/locales/fr/cli.json +108 -0
  13. package/dist/locales/ja/.gitkeep +0 -0
  14. package/dist/locales/ja/cli.json +108 -0
  15. package/dist/locales/ko/.gitkeep +0 -0
  16. package/dist/locales/ko/cli.json +108 -0
  17. package/dist/locales/pt/.gitkeep +0 -0
  18. package/dist/locales/pt/cli.json +108 -0
  19. package/dist/locales/ru/.gitkeep +0 -0
  20. package/dist/locales/ru/cli.json +269 -0
  21. package/dist/locales/zh/.gitkeep +0 -0
  22. package/dist/locales/zh/cli.json +108 -0
  23. package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +1 -1
  24. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +3 -0
  25. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +1 -1
  26. package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts +21 -0
  27. package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts.map +1 -0
  28. package/dist/plugins/specweave/lib/hooks/update-ac-status.js +162 -0
  29. package/dist/plugins/specweave/lib/hooks/update-ac-status.js.map +1 -0
  30. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.d.ts.map +1 -1
  31. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js +65 -6
  32. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js.map +1 -1
  33. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.d.ts +25 -0
  34. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.d.ts.map +1 -0
  35. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.js +191 -0
  36. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.js.map +1 -0
  37. package/dist/plugins/specweave-github/lib/completion-calculator.d.ts +112 -0
  38. package/dist/plugins/specweave-github/lib/completion-calculator.d.ts.map +1 -0
  39. package/dist/plugins/specweave-github/lib/completion-calculator.js +301 -0
  40. package/dist/plugins/specweave-github/lib/completion-calculator.js.map +1 -0
  41. package/dist/plugins/specweave-github/lib/duplicate-detector.d.ts +3 -3
  42. package/dist/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  43. package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts +70 -0
  44. package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts.map +1 -0
  45. package/dist/plugins/specweave-github/lib/epic-content-builder.js +258 -0
  46. package/dist/plugins/specweave-github/lib/epic-content-builder.js.map +1 -0
  47. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +14 -0
  48. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +1 -1
  49. package/dist/plugins/specweave-github/lib/github-client-v2.js +51 -0
  50. package/dist/plugins/specweave-github/lib/github-client-v2.js.map +1 -1
  51. package/dist/plugins/specweave-github/lib/github-epic-sync.d.ts +2 -2
  52. package/dist/plugins/specweave-github/lib/github-epic-sync.d.ts.map +1 -1
  53. package/dist/plugins/specweave-github/lib/github-epic-sync.js +20 -5
  54. package/dist/plugins/specweave-github/lib/github-epic-sync.js.map +1 -1
  55. package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts +87 -0
  56. package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts.map +1 -0
  57. package/dist/plugins/specweave-github/lib/github-feature-sync.js +412 -0
  58. package/dist/plugins/specweave-github/lib/github-feature-sync.js.map +1 -0
  59. package/dist/plugins/specweave-github/lib/github-spec-content-sync.d.ts.map +1 -1
  60. package/dist/plugins/specweave-github/lib/github-spec-content-sync.js +64 -13
  61. package/dist/plugins/specweave-github/lib/github-spec-content-sync.js.map +1 -1
  62. package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts +78 -0
  63. package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts.map +1 -0
  64. package/dist/plugins/specweave-github/lib/progress-comment-builder.js +237 -0
  65. package/dist/plugins/specweave-github/lib/progress-comment-builder.js.map +1 -0
  66. package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts +97 -0
  67. package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts.map +1 -0
  68. package/dist/plugins/specweave-github/lib/user-story-content-builder.js +301 -0
  69. package/dist/plugins/specweave-github/lib/user-story-content-builder.js.map +1 -0
  70. package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts +83 -0
  71. package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts.map +1 -0
  72. package/dist/plugins/specweave-github/lib/user-story-issue-builder.js +386 -0
  73. package/dist/plugins/specweave-github/lib/user-story-issue-builder.js.map +1 -0
  74. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts +28 -0
  75. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts.map +1 -0
  76. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js +156 -0
  77. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js.map +1 -0
  78. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.d.ts +57 -0
  79. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.d.ts.map +1 -0
  80. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +248 -0
  81. package/dist/plugins/specweave-kafka/lib/cli/kcat-wrapper.js.map +1 -0
  82. package/dist/plugins/specweave-kafka/lib/cli/types.d.ts +82 -0
  83. package/dist/plugins/specweave-kafka/lib/cli/types.d.ts.map +1 -0
  84. package/dist/plugins/specweave-kafka/lib/cli/types.js +13 -0
  85. package/dist/plugins/specweave-kafka/lib/cli/types.js.map +1 -0
  86. package/dist/plugins/specweave-kafka/lib/mcp/detector.d.ts +49 -0
  87. package/dist/plugins/specweave-kafka/lib/mcp/detector.d.ts.map +1 -0
  88. package/dist/plugins/specweave-kafka/lib/mcp/detector.js +316 -0
  89. package/dist/plugins/specweave-kafka/lib/mcp/detector.js.map +1 -0
  90. package/dist/plugins/specweave-kafka/lib/mcp/types.d.ts +70 -0
  91. package/dist/plugins/specweave-kafka/lib/mcp/types.d.ts.map +1 -0
  92. package/dist/plugins/specweave-kafka/lib/mcp/types.js +23 -0
  93. package/dist/plugins/specweave-kafka/lib/mcp/types.js.map +1 -0
  94. package/dist/plugins/specweave-kafka/lib/utils/partitioning.d.ts +85 -0
  95. package/dist/plugins/specweave-kafka/lib/utils/partitioning.d.ts.map +1 -0
  96. package/dist/plugins/specweave-kafka/lib/utils/partitioning.js +281 -0
  97. package/dist/plugins/specweave-kafka/lib/utils/partitioning.js.map +1 -0
  98. package/dist/plugins/specweave-kafka/lib/utils/sizing.d.ts +75 -0
  99. package/dist/plugins/specweave-kafka/lib/utils/sizing.d.ts.map +1 -0
  100. package/dist/plugins/specweave-kafka/lib/utils/sizing.js +238 -0
  101. package/dist/plugins/specweave-kafka/lib/utils/sizing.js.map +1 -0
  102. package/dist/spec-parser.js +629 -0
  103. package/dist/src/cli/commands/import-docs.js +4 -4
  104. package/dist/src/cli/commands/import-docs.js.map +1 -1
  105. package/dist/src/cli/commands/init-multiproject.d.ts.map +1 -1
  106. package/dist/src/cli/commands/init-multiproject.js +17 -18
  107. package/dist/src/cli/commands/init-multiproject.js.map +1 -1
  108. package/dist/src/cli/commands/init.d.ts.map +1 -1
  109. package/dist/src/cli/commands/init.js +107 -3
  110. package/dist/src/cli/commands/init.js.map +1 -1
  111. package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +1 -1
  112. package/dist/src/cli/commands/migrate-to-multiproject.js +8 -4
  113. package/dist/src/cli/commands/migrate-to-multiproject.js.map +1 -1
  114. package/dist/src/cli/commands/switch-project.d.ts.map +1 -1
  115. package/dist/src/cli/commands/switch-project.js +9 -26
  116. package/dist/src/cli/commands/switch-project.js.map +1 -1
  117. package/dist/src/cli/commands/sync-spec-content.js +3 -0
  118. package/dist/src/cli/commands/sync-spec-content.js.map +1 -1
  119. package/dist/src/core/deduplication/command-deduplicator.d.ts +166 -0
  120. package/dist/src/core/deduplication/command-deduplicator.d.ts.map +1 -0
  121. package/dist/src/core/deduplication/command-deduplicator.js +254 -0
  122. package/dist/src/core/deduplication/command-deduplicator.js.map +1 -0
  123. package/dist/src/core/increment/active-increment-manager.d.ts +42 -15
  124. package/dist/src/core/increment/active-increment-manager.d.ts.map +1 -1
  125. package/dist/src/core/increment/active-increment-manager.js +113 -46
  126. package/dist/src/core/increment/active-increment-manager.js.map +1 -1
  127. package/dist/src/core/increment/conflict-resolver.d.ts +40 -0
  128. package/dist/src/core/increment/conflict-resolver.d.ts.map +1 -0
  129. package/dist/src/core/increment/conflict-resolver.js +219 -0
  130. package/dist/src/core/increment/conflict-resolver.js.map +1 -0
  131. package/dist/src/core/increment/discipline-checker.d.ts.map +1 -1
  132. package/dist/src/core/increment/discipline-checker.js +7 -1
  133. package/dist/src/core/increment/discipline-checker.js.map +1 -1
  134. package/dist/src/core/increment/duplicate-detector.d.ts +52 -0
  135. package/dist/src/core/increment/duplicate-detector.d.ts.map +1 -0
  136. package/dist/src/core/increment/duplicate-detector.js +276 -0
  137. package/dist/src/core/increment/duplicate-detector.js.map +1 -0
  138. package/dist/src/core/increment/increment-archiver.d.ts +90 -0
  139. package/dist/src/core/increment/increment-archiver.d.ts.map +1 -0
  140. package/dist/src/core/increment/increment-archiver.js +368 -0
  141. package/dist/src/core/increment/increment-archiver.js.map +1 -0
  142. package/dist/src/core/increment/increment-reopener.d.ts +165 -0
  143. package/dist/src/core/increment/increment-reopener.d.ts.map +1 -0
  144. package/dist/src/core/increment/increment-reopener.js +390 -0
  145. package/dist/src/core/increment/increment-reopener.js.map +1 -0
  146. package/dist/src/core/increment/metadata-manager.d.ts +26 -1
  147. package/dist/src/core/increment/metadata-manager.d.ts.map +1 -1
  148. package/dist/src/core/increment/metadata-manager.js +143 -5
  149. package/dist/src/core/increment/metadata-manager.js.map +1 -1
  150. package/dist/src/core/increment/recent-work-scanner.d.ts +121 -0
  151. package/dist/src/core/increment/recent-work-scanner.d.ts.map +1 -0
  152. package/dist/src/core/increment/recent-work-scanner.js +303 -0
  153. package/dist/src/core/increment/recent-work-scanner.js.map +1 -0
  154. package/dist/src/core/increment/types.d.ts +1 -0
  155. package/dist/src/core/increment/types.d.ts.map +1 -1
  156. package/dist/src/core/increment-utils.d.ts +112 -0
  157. package/dist/src/core/increment-utils.d.ts.map +1 -0
  158. package/dist/src/core/increment-utils.js +210 -0
  159. package/dist/src/core/increment-utils.js.map +1 -0
  160. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts +65 -0
  161. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts.map +1 -0
  162. package/dist/src/core/living-docs/ac-project-specific-generator.js +175 -0
  163. package/dist/src/core/living-docs/ac-project-specific-generator.js.map +1 -0
  164. package/dist/src/core/living-docs/feature-archiver.d.ts +130 -0
  165. package/dist/src/core/living-docs/feature-archiver.d.ts.map +1 -0
  166. package/dist/src/core/living-docs/feature-archiver.js +549 -0
  167. package/dist/src/core/living-docs/feature-archiver.js.map +1 -0
  168. package/dist/src/core/living-docs/feature-id-manager.d.ts +81 -0
  169. package/dist/src/core/living-docs/feature-id-manager.d.ts.map +1 -0
  170. package/dist/src/core/living-docs/feature-id-manager.js +339 -0
  171. package/dist/src/core/living-docs/feature-id-manager.js.map +1 -0
  172. package/dist/src/core/living-docs/hierarchy-mapper.d.ts +144 -83
  173. package/dist/src/core/living-docs/hierarchy-mapper.d.ts.map +1 -1
  174. package/dist/src/core/living-docs/hierarchy-mapper.js +488 -270
  175. package/dist/src/core/living-docs/hierarchy-mapper.js.map +1 -1
  176. package/dist/src/core/living-docs/index.d.ts +6 -0
  177. package/dist/src/core/living-docs/index.d.ts.map +1 -1
  178. package/dist/src/core/living-docs/index.js +6 -0
  179. package/dist/src/core/living-docs/index.js.map +1 -1
  180. package/dist/src/core/living-docs/project-detector.d.ts +6 -0
  181. package/dist/src/core/living-docs/project-detector.d.ts.map +1 -1
  182. package/dist/src/core/living-docs/project-detector.js +35 -1
  183. package/dist/src/core/living-docs/project-detector.js.map +1 -1
  184. package/dist/src/core/living-docs/spec-distributor.d.ts +100 -26
  185. package/dist/src/core/living-docs/spec-distributor.d.ts.map +1 -1
  186. package/dist/src/core/living-docs/spec-distributor.js +1275 -258
  187. package/dist/src/core/living-docs/spec-distributor.js.map +1 -1
  188. package/dist/src/core/living-docs/task-project-specific-generator.d.ts +109 -0
  189. package/dist/src/core/living-docs/task-project-specific-generator.d.ts.map +1 -0
  190. package/dist/src/core/living-docs/task-project-specific-generator.js +221 -0
  191. package/dist/src/core/living-docs/task-project-specific-generator.js.map +1 -0
  192. package/dist/src/core/living-docs/types.d.ts +143 -0
  193. package/dist/src/core/living-docs/types.d.ts.map +1 -1
  194. package/dist/src/core/project-manager.d.ts +2 -17
  195. package/dist/src/core/project-manager.d.ts.map +1 -1
  196. package/dist/src/core/project-manager.js +68 -48
  197. package/dist/src/core/project-manager.js.map +1 -1
  198. package/dist/src/core/spec-content-sync.d.ts +1 -1
  199. package/dist/src/core/spec-content-sync.d.ts.map +1 -1
  200. package/dist/src/core/sync/enhanced-content-builder.d.ts +32 -54
  201. package/dist/src/core/sync/enhanced-content-builder.d.ts.map +1 -1
  202. package/dist/src/core/sync/enhanced-content-builder.js +142 -138
  203. package/dist/src/core/sync/enhanced-content-builder.js.map +1 -1
  204. package/dist/src/core/sync/performance-optimizer.d.ts +153 -0
  205. package/dist/src/core/sync/performance-optimizer.d.ts.map +1 -0
  206. package/dist/src/core/sync/performance-optimizer.js +220 -0
  207. package/dist/src/core/sync/performance-optimizer.js.map +1 -0
  208. package/dist/src/core/sync/retry-handler.d.ts +98 -0
  209. package/dist/src/core/sync/retry-handler.d.ts.map +1 -0
  210. package/dist/src/core/sync/retry-handler.js +196 -0
  211. package/dist/src/core/sync/retry-handler.js.map +1 -0
  212. package/dist/src/core/sync/spec-content-sync.d.ts +88 -0
  213. package/dist/src/core/sync/spec-content-sync.d.ts.map +1 -0
  214. package/dist/src/core/sync/spec-content-sync.js +5 -0
  215. package/dist/src/core/sync/spec-content-sync.js.map +1 -0
  216. package/dist/src/core/sync/types.d.ts +52 -0
  217. package/dist/src/core/sync/types.d.ts.map +1 -0
  218. package/dist/src/core/sync/types.js +5 -0
  219. package/dist/src/core/sync/types.js.map +1 -0
  220. package/dist/src/core/types/config.d.ts +125 -0
  221. package/dist/src/core/types/config.d.ts.map +1 -1
  222. package/dist/src/core/types/config.js +25 -0
  223. package/dist/src/core/types/config.js.map +1 -1
  224. package/dist/src/core/types/increment-metadata.d.ts +10 -0
  225. package/dist/src/core/types/increment-metadata.d.ts.map +1 -1
  226. package/dist/src/core/types/increment-metadata.js +10 -1
  227. package/dist/src/core/types/increment-metadata.js.map +1 -1
  228. package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +1 -1
  229. package/dist/src/integrations/jira/jira-incremental-mapper.js +4 -8
  230. package/dist/src/integrations/jira/jira-incremental-mapper.js.map +1 -1
  231. package/dist/src/integrations/jira/jira-mapper.d.ts.map +1 -1
  232. package/dist/src/integrations/jira/jira-mapper.js +4 -8
  233. package/dist/src/integrations/jira/jira-mapper.js.map +1 -1
  234. package/dist/tsconfig.tsbuildinfo +1 -0
  235. package/package.json +1 -1
  236. package/plugins/specweave/COMMANDS.md +13 -4
  237. package/plugins/specweave/agents/pm/AGENT.md +159 -12
  238. package/plugins/specweave/commands/specweave-abandon.md +22 -20
  239. package/plugins/specweave/commands/specweave-archive-features.md +121 -0
  240. package/plugins/specweave/commands/specweave-archive-increments.md +82 -0
  241. package/plugins/specweave/commands/specweave-archive.md +363 -0
  242. package/plugins/specweave/commands/specweave-backlog.md +211 -0
  243. package/plugins/specweave/commands/specweave-fix-duplicates.md +517 -0
  244. package/plugins/specweave/commands/specweave-increment.md +4 -3
  245. package/plugins/specweave/commands/specweave-progress.md +176 -27
  246. package/plugins/specweave/commands/specweave-reopen.md +391 -0
  247. package/plugins/specweave/commands/specweave-restore-feature.md +90 -0
  248. package/plugins/specweave/commands/specweave-restore.md +309 -0
  249. package/plugins/specweave/commands/specweave-resume.md +51 -23
  250. package/plugins/specweave/commands/specweave-status.md +41 -7
  251. package/plugins/specweave/commands/specweave-sync-specs.md +425 -0
  252. package/plugins/specweave/commands/specweave.md +70 -405
  253. package/plugins/specweave/hooks/hooks.json +4 -0
  254. package/plugins/specweave/hooks/lib/sync-spec-content.sh +2 -2
  255. package/plugins/specweave/hooks/post-increment-planning.sh +26 -2
  256. package/plugins/specweave/hooks/post-task-completion.sh +39 -0
  257. package/plugins/specweave/hooks/pre-command-deduplication.sh +83 -0
  258. package/plugins/specweave/hooks/user-prompt-submit.sh +1 -1
  259. package/plugins/specweave/lib/hooks/sync-living-docs.js +2 -0
  260. package/plugins/specweave/lib/hooks/sync-living-docs.ts +4 -0
  261. package/plugins/specweave/lib/hooks/update-ac-status.js +102 -0
  262. package/plugins/specweave/lib/hooks/update-ac-status.ts +192 -0
  263. package/plugins/specweave/skills/archive-increments/SKILL.md +198 -0
  264. package/plugins/specweave/skills/increment-planner/scripts/feature-utils.js +14 -0
  265. package/plugins/specweave/skills/smart-reopen-detector/SKILL.md +244 -0
  266. package/plugins/specweave-ado/lib/ado-spec-content-sync.js +49 -5
  267. package/plugins/specweave-ado/lib/ado-spec-content-sync.ts +72 -6
  268. package/plugins/specweave-ado/lib/enhanced-ado-sync.js +170 -0
  269. package/plugins/specweave-confluent/.claude-plugin/plugin.json +23 -0
  270. package/plugins/specweave-confluent/README.md +375 -0
  271. package/plugins/specweave-confluent/agents/confluent-architect/AGENT.md +306 -0
  272. package/plugins/specweave-confluent/skills/confluent-kafka-connect/SKILL.md +453 -0
  273. package/plugins/specweave-confluent/skills/confluent-ksqldb/SKILL.md +470 -0
  274. package/plugins/specweave-confluent/skills/confluent-schema-registry/SKILL.md +316 -0
  275. package/plugins/specweave-github/agents/github-task-splitter/AGENT.md +2 -2
  276. package/plugins/specweave-github/agents/user-story-updater/AGENT.md +148 -0
  277. package/plugins/specweave-github/commands/specweave-github-cleanup-duplicates.md +1 -1
  278. package/plugins/specweave-github/commands/specweave-github-update-user-story.md +156 -0
  279. package/plugins/specweave-github/hooks/post-task-completion.sh +42 -9
  280. package/plugins/specweave-github/lib/completion-calculator.js +262 -0
  281. package/plugins/specweave-github/lib/completion-calculator.ts +434 -0
  282. package/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  283. package/plugins/specweave-github/lib/duplicate-detector.ts +4 -4
  284. package/plugins/specweave-github/lib/epic-content-builder.js +265 -0
  285. package/plugins/specweave-github/lib/epic-content-builder.ts +376 -0
  286. package/plugins/specweave-github/lib/github-client-v2.js +49 -0
  287. package/plugins/specweave-github/lib/github-client-v2.ts +59 -0
  288. package/plugins/specweave-github/lib/github-epic-sync.js +23 -24
  289. package/plugins/specweave-github/lib/github-epic-sync.ts +30 -5
  290. package/plugins/specweave-github/lib/github-feature-sync.js +381 -0
  291. package/plugins/specweave-github/lib/github-feature-sync.ts +568 -0
  292. package/plugins/specweave-github/lib/github-spec-content-sync.js +40 -10
  293. package/plugins/specweave-github/lib/github-spec-content-sync.ts +82 -14
  294. package/plugins/specweave-github/lib/progress-comment-builder.js +229 -0
  295. package/plugins/specweave-github/lib/progress-comment-builder.ts +324 -0
  296. package/plugins/specweave-github/lib/user-story-content-builder.js +299 -0
  297. package/plugins/specweave-github/lib/user-story-content-builder.ts +413 -0
  298. package/plugins/specweave-github/lib/user-story-issue-builder.js +344 -0
  299. package/plugins/specweave-github/lib/user-story-issue-builder.ts +543 -0
  300. package/plugins/specweave-github/skills/github-issue-standard/SKILL.md +189 -0
  301. package/plugins/specweave-jira/lib/enhanced-jira-sync.js +134 -0
  302. package/plugins/specweave-jira/lib/{enhanced-jira-sync.ts.disabled → enhanced-jira-sync.ts} +26 -52
  303. package/plugins/specweave-kafka/.claude-plugin/plugin.json +26 -0
  304. package/plugins/specweave-kafka/IMPLEMENTATION-COMPLETE.md +483 -0
  305. package/plugins/specweave-kafka/README.md +242 -0
  306. package/plugins/specweave-kafka/agents/kafka-architect/AGENT.md +235 -0
  307. package/plugins/specweave-kafka/agents/kafka-devops/AGENT.md +209 -0
  308. package/plugins/specweave-kafka/agents/kafka-observability/AGENT.md +266 -0
  309. package/plugins/specweave-kafka/commands/deploy.md +99 -0
  310. package/plugins/specweave-kafka/commands/dev-env.md +176 -0
  311. package/plugins/specweave-kafka/commands/mcp-configure.md +101 -0
  312. package/plugins/specweave-kafka/commands/monitor-setup.md +96 -0
  313. package/plugins/specweave-kafka/docker/kafka-local/docker-compose.yml +187 -0
  314. package/plugins/specweave-kafka/docker/redpanda/docker-compose.yml +199 -0
  315. package/plugins/specweave-kafka/docker/templates/consumer-nodejs.js +225 -0
  316. package/plugins/specweave-kafka/docker/templates/consumer-python.py +220 -0
  317. package/plugins/specweave-kafka/docker/templates/producer-nodejs.js +168 -0
  318. package/plugins/specweave-kafka/docker/templates/producer-python.py +167 -0
  319. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.js +438 -0
  320. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.ts +541 -0
  321. package/plugins/specweave-kafka/lib/adapters/platform-adapter.js +47 -0
  322. package/plugins/specweave-kafka/lib/adapters/platform-adapter.ts +343 -0
  323. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +258 -0
  324. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.ts +298 -0
  325. package/plugins/specweave-kafka/lib/cli/types.js +10 -0
  326. package/plugins/specweave-kafka/lib/cli/types.ts +92 -0
  327. package/plugins/specweave-kafka/lib/connectors/connector-catalog.js +305 -0
  328. package/plugins/specweave-kafka/lib/connectors/connector-catalog.ts +528 -0
  329. package/plugins/specweave-kafka/lib/documentation/diagram-generator.js +114 -0
  330. package/plugins/specweave-kafka/lib/documentation/diagram-generator.ts +195 -0
  331. package/plugins/specweave-kafka/lib/documentation/exporter.js +210 -0
  332. package/plugins/specweave-kafka/lib/documentation/exporter.ts +338 -0
  333. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.js +60 -0
  334. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.ts +130 -0
  335. package/plugins/specweave-kafka/lib/documentation/topology-generator.js +143 -0
  336. package/plugins/specweave-kafka/lib/documentation/topology-generator.ts +290 -0
  337. package/plugins/specweave-kafka/lib/mcp/detector.js +298 -0
  338. package/plugins/specweave-kafka/lib/mcp/detector.ts +352 -0
  339. package/plugins/specweave-kafka/lib/mcp/types.js +21 -0
  340. package/plugins/specweave-kafka/lib/mcp/types.ts +77 -0
  341. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.js +193 -0
  342. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.ts +362 -0
  343. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.js +188 -0
  344. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.ts +359 -0
  345. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.js +195 -0
  346. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.ts +380 -0
  347. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.js +209 -0
  348. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.ts +358 -0
  349. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.js +354 -0
  350. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.ts +563 -0
  351. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.js +259 -0
  352. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.ts +516 -0
  353. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.js +233 -0
  354. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.ts +423 -0
  355. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.js +266 -0
  356. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.ts +445 -0
  357. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.js +312 -0
  358. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.ts +561 -0
  359. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.js +289 -0
  360. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.ts +607 -0
  361. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.js +264 -0
  362. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.ts +498 -0
  363. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.js +263 -0
  364. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.ts +549 -0
  365. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.js +205 -0
  366. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.ts +399 -0
  367. package/plugins/specweave-kafka/lib/performance/performance-optimizer.js +249 -0
  368. package/plugins/specweave-kafka/lib/performance/performance-optimizer.ts +427 -0
  369. package/plugins/specweave-kafka/lib/security/kafka-security.js +252 -0
  370. package/plugins/specweave-kafka/lib/security/kafka-security.ts +494 -0
  371. package/plugins/specweave-kafka/lib/utils/capacity-planner.js +203 -0
  372. package/plugins/specweave-kafka/lib/utils/capacity-planner.ts +469 -0
  373. package/plugins/specweave-kafka/lib/utils/config-validator.js +419 -0
  374. package/plugins/specweave-kafka/lib/utils/config-validator.ts +564 -0
  375. package/plugins/specweave-kafka/lib/utils/partitioning.js +329 -0
  376. package/plugins/specweave-kafka/lib/utils/partitioning.ts +473 -0
  377. package/plugins/specweave-kafka/lib/utils/sizing.js +221 -0
  378. package/plugins/specweave-kafka/lib/utils/sizing.ts +374 -0
  379. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-broker-metrics.json +628 -0
  380. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-cluster-overview.json +564 -0
  381. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-consumer-lag.json +509 -0
  382. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-jvm-metrics.json +674 -0
  383. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-topic-metrics.json +578 -0
  384. package/plugins/specweave-kafka/monitoring/grafana/provisioning/dashboards/kafka.yml +17 -0
  385. package/plugins/specweave-kafka/monitoring/grafana/provisioning/datasources/prometheus.yml +17 -0
  386. package/plugins/specweave-kafka/monitoring/prometheus/kafka-alerts.yml +415 -0
  387. package/plugins/specweave-kafka/monitoring/prometheus/kafka-jmx-exporter.yml +256 -0
  388. package/plugins/specweave-kafka/package.json +41 -0
  389. package/plugins/specweave-kafka/skills/kafka-architecture/SKILL.md +647 -0
  390. package/plugins/specweave-kafka/skills/kafka-cli-tools/SKILL.md +433 -0
  391. package/plugins/specweave-kafka/skills/kafka-iac-deployment/SKILL.md +449 -0
  392. package/plugins/specweave-kafka/skills/kafka-kubernetes/SKILL.md +667 -0
  393. package/plugins/specweave-kafka/skills/kafka-mcp-integration/SKILL.md +273 -0
  394. package/plugins/specweave-kafka/skills/kafka-observability/SKILL.md +576 -0
  395. package/plugins/specweave-kafka/templates/config/broker-production.properties +254 -0
  396. package/plugins/specweave-kafka/templates/config/consumer-low-latency.properties +112 -0
  397. package/plugins/specweave-kafka/templates/config/producer-high-throughput.properties +120 -0
  398. package/plugins/specweave-kafka/templates/migration/mirrormaker2-config.properties +234 -0
  399. package/plugins/specweave-kafka/templates/monitoring/grafana/multi-cluster-dashboard.json +686 -0
  400. package/plugins/specweave-kafka/terraform/apache-kafka/main.tf +347 -0
  401. package/plugins/specweave-kafka/terraform/apache-kafka/outputs.tf +107 -0
  402. package/plugins/specweave-kafka/terraform/apache-kafka/templates/kafka-broker-init.sh.tpl +216 -0
  403. package/plugins/specweave-kafka/terraform/apache-kafka/variables.tf +156 -0
  404. package/plugins/specweave-kafka/terraform/aws-msk/main.tf +362 -0
  405. package/plugins/specweave-kafka/terraform/aws-msk/outputs.tf +93 -0
  406. package/plugins/specweave-kafka/terraform/aws-msk/templates/server.properties.tpl +32 -0
  407. package/plugins/specweave-kafka/terraform/aws-msk/variables.tf +235 -0
  408. package/plugins/specweave-kafka/terraform/azure-event-hubs/main.tf +281 -0
  409. package/plugins/specweave-kafka/terraform/azure-event-hubs/outputs.tf +118 -0
  410. package/plugins/specweave-kafka/terraform/azure-event-hubs/variables.tf +148 -0
  411. package/plugins/specweave-kafka/tsconfig.json +21 -0
  412. package/plugins/specweave-kafka-streams/.claude-plugin/plugin.json +23 -0
  413. package/plugins/specweave-kafka-streams/README.md +310 -0
  414. package/plugins/specweave-kafka-streams/skills/kafka-streams-topology/SKILL.md +539 -0
  415. package/plugins/specweave-n8n/.claude-plugin/plugin.json +22 -0
  416. package/plugins/specweave-n8n/README.md +354 -0
  417. package/plugins/specweave-n8n/skills/n8n-kafka-workflows/SKILL.md +504 -0
  418. package/plugins/specweave-release/commands/specweave-release-platform.md +1 -1
  419. package/plugins/specweave-release/hooks/post-task-completion.sh +2 -2
  420. package/src/templates/AGENTS.md.template +601 -7
  421. package/src/templates/CLAUDE.md.template +188 -88
  422. package/plugins/specweave-ado/commands/specweave-ado-sync-spec.md +0 -255
  423. package/plugins/specweave-github/commands/specweave-github-sync-epic.md +0 -248
  424. package/plugins/specweave-github/commands/specweave-github-sync-from.md +0 -147
  425. package/plugins/specweave-github/commands/specweave-github-sync-spec.md +0 -208
  426. package/plugins/specweave-github/commands/specweave-github-sync-tasks.md +0 -530
  427. package/plugins/specweave-jira/commands/specweave-jira-sync-epic.md +0 -267
  428. package/plugins/specweave-jira/commands/specweave-jira-sync-spec.md +0 -240
@@ -0,0 +1,564 @@
1
+ /**
2
+ * Kafka Configuration Validator
3
+ *
4
+ * Validates Kafka broker and client configurations against best practices.
5
+ * Detects common misconfigurations and provides recommendations.
6
+ */
7
+
8
+ export interface KafkaConfig {
9
+ // Broker configuration
10
+ broker?: {
11
+ 'log.dirs'?: string;
12
+ 'num.network.threads'?: number;
13
+ 'num.io.threads'?: number;
14
+ 'socket.send.buffer.bytes'?: number;
15
+ 'socket.receive.buffer.bytes'?: number;
16
+ 'socket.request.max.bytes'?: number;
17
+ 'log.retention.hours'?: number;
18
+ 'log.retention.bytes'?: number;
19
+ 'log.segment.bytes'?: number;
20
+ 'num.partitions'?: number;
21
+ 'num.replica.fetchers'?: number;
22
+ 'replica.lag.time.max.ms'?: number;
23
+ 'replica.socket.timeout.ms'?: number;
24
+ 'replica.fetch.max.bytes'?: number;
25
+ 'default.replication.factor'?: number;
26
+ 'min.insync.replicas'?: number;
27
+ 'unclean.leader.election.enable'?: boolean;
28
+ 'auto.create.topics.enable'?: boolean;
29
+ 'delete.topic.enable'?: boolean;
30
+ 'compression.type'?: string;
31
+ 'message.max.bytes'?: number;
32
+ [key: string]: any;
33
+ };
34
+
35
+ // Producer configuration
36
+ producer?: {
37
+ 'bootstrap.servers'?: string;
38
+ 'acks'?: string | number;
39
+ 'retries'?: number;
40
+ 'batch.size'?: number;
41
+ 'linger.ms'?: number;
42
+ 'buffer.memory'?: number;
43
+ 'compression.type'?: string;
44
+ 'max.in.flight.requests.per.connection'?: number;
45
+ 'enable.idempotence'?: boolean;
46
+ 'transactional.id'?: string;
47
+ [key: string]: any;
48
+ };
49
+
50
+ // Consumer configuration
51
+ consumer?: {
52
+ 'bootstrap.servers'?: string;
53
+ 'group.id'?: string;
54
+ 'auto.offset.reset'?: string;
55
+ 'enable.auto.commit'?: boolean;
56
+ 'auto.commit.interval.ms'?: number;
57
+ 'session.timeout.ms'?: number;
58
+ 'heartbeat.interval.ms'?: number;
59
+ 'max.poll.records'?: number;
60
+ 'max.poll.interval.ms'?: number;
61
+ 'fetch.min.bytes'?: number;
62
+ 'fetch.max.wait.ms'?: number;
63
+ [key: string]: any;
64
+ };
65
+ }
66
+
67
+ export interface ValidationIssue {
68
+ severity: 'error' | 'warning' | 'info';
69
+ category: 'broker' | 'producer' | 'consumer' | 'general';
70
+ property: string;
71
+ currentValue: any;
72
+ recommendedValue?: any;
73
+ message: string;
74
+ impact: string;
75
+ fix?: string;
76
+ }
77
+
78
+ export interface ValidationResult {
79
+ valid: boolean;
80
+ issues: ValidationIssue[];
81
+ score: number; // 0-100
82
+ summary: {
83
+ errors: number;
84
+ warnings: number;
85
+ infos: number;
86
+ };
87
+ }
88
+
89
+ export class ConfigValidator {
90
+ private issues: ValidationIssue[] = [];
91
+
92
+ /**
93
+ * Validate complete Kafka configuration
94
+ */
95
+ validate(config: KafkaConfig): ValidationResult {
96
+ this.issues = [];
97
+
98
+ // Validate broker config
99
+ if (config.broker) {
100
+ this.validateBroker(config.broker);
101
+ }
102
+
103
+ // Validate producer config
104
+ if (config.producer) {
105
+ this.validateProducer(config.producer);
106
+ }
107
+
108
+ // Validate consumer config
109
+ if (config.consumer) {
110
+ this.validateConsumer(config.consumer);
111
+ }
112
+
113
+ // Calculate score
114
+ const score = this.calculateScore();
115
+
116
+ // Summary
117
+ const summary = {
118
+ errors: this.issues.filter(i => i.severity === 'error').length,
119
+ warnings: this.issues.filter(i => i.severity === 'warning').length,
120
+ infos: this.issues.filter(i => i.severity === 'info').length
121
+ };
122
+
123
+ return {
124
+ valid: summary.errors === 0,
125
+ issues: this.issues,
126
+ score,
127
+ summary
128
+ };
129
+ }
130
+
131
+ /**
132
+ * Validate broker configuration
133
+ */
134
+ private validateBroker(broker: any): void {
135
+ // Replication settings
136
+ const rf = broker['default.replication.factor'];
137
+ const minISR = broker['min.insync.replicas'];
138
+
139
+ if (rf && minISR) {
140
+ if (minISR >= rf) {
141
+ this.addIssue({
142
+ severity: 'error',
143
+ category: 'broker',
144
+ property: 'min.insync.replicas',
145
+ currentValue: minISR,
146
+ recommendedValue: rf - 1,
147
+ message: 'min.insync.replicas >= replication.factor will cause write failures',
148
+ impact: 'CRITICAL: All writes will fail!',
149
+ fix: `Set min.insync.replicas to ${rf - 1} (replication.factor - 1)`
150
+ });
151
+ }
152
+
153
+ if (minISR === 1 && rf > 1) {
154
+ this.addIssue({
155
+ severity: 'warning',
156
+ category: 'broker',
157
+ property: 'min.insync.replicas',
158
+ currentValue: 1,
159
+ recommendedValue: 2,
160
+ message: 'min.insync.replicas=1 provides no durability guarantees',
161
+ impact: 'Data loss possible if leader fails before replication',
162
+ fix: 'Set min.insync.replicas to 2 for production'
163
+ });
164
+ }
165
+ }
166
+
167
+ // Unclean leader election
168
+ if (broker['unclean.leader.election.enable'] === true) {
169
+ this.addIssue({
170
+ severity: 'warning',
171
+ category: 'broker',
172
+ property: 'unclean.leader.election.enable',
173
+ currentValue: true,
174
+ recommendedValue: false,
175
+ message: 'Unclean leader election enabled (data loss risk)',
176
+ impact: 'Potential data loss if out-of-sync replica becomes leader',
177
+ fix: 'Set unclean.leader.election.enable=false for production'
178
+ });
179
+ }
180
+
181
+ // Thread configuration
182
+ const networkThreads = broker['num.network.threads'];
183
+ if (networkThreads && networkThreads < 3) {
184
+ this.addIssue({
185
+ severity: 'info',
186
+ category: 'broker',
187
+ property: 'num.network.threads',
188
+ currentValue: networkThreads,
189
+ recommendedValue: 8,
190
+ message: 'Low network thread count may limit throughput',
191
+ impact: 'Reduced connection handling capacity',
192
+ fix: 'Increase num.network.threads to 8 for high-traffic brokers'
193
+ });
194
+ }
195
+
196
+ const ioThreads = broker['num.io.threads'];
197
+ if (ioThreads && ioThreads < 8) {
198
+ this.addIssue({
199
+ severity: 'info',
200
+ category: 'broker',
201
+ property: 'num.io.threads',
202
+ currentValue: ioThreads,
203
+ recommendedValue: 16,
204
+ message: 'Low I/O thread count may bottleneck disk operations',
205
+ impact: 'Reduced disk throughput',
206
+ fix: 'Set num.io.threads to 16 (or 2x number of disks)'
207
+ });
208
+ }
209
+
210
+ // Message size limits
211
+ const maxMessageBytes = broker['message.max.bytes'];
212
+ if (maxMessageBytes && maxMessageBytes > 10485760) { // 10 MB
213
+ this.addIssue({
214
+ severity: 'warning',
215
+ category: 'broker',
216
+ property: 'message.max.bytes',
217
+ currentValue: maxMessageBytes,
218
+ recommendedValue: 1048576,
219
+ message: 'Very large max message size',
220
+ impact: 'High memory usage, potential OOM, slow replication',
221
+ fix: 'Consider chunking large messages or using object storage'
222
+ });
223
+ }
224
+
225
+ // Compression
226
+ const compression = broker['compression.type'];
227
+ if (!compression || compression === 'none') {
228
+ this.addIssue({
229
+ severity: 'info',
230
+ category: 'broker',
231
+ property: 'compression.type',
232
+ currentValue: compression || 'none',
233
+ recommendedValue: 'lz4',
234
+ message: 'No compression configured',
235
+ impact: 'Higher network and disk usage',
236
+ fix: 'Enable lz4 compression for balanced CPU/storage tradeoff'
237
+ });
238
+ }
239
+
240
+ // Auto topic creation
241
+ if (broker['auto.create.topics.enable'] === true) {
242
+ this.addIssue({
243
+ severity: 'warning',
244
+ category: 'broker',
245
+ property: 'auto.create.topics.enable',
246
+ currentValue: true,
247
+ recommendedValue: false,
248
+ message: 'Auto topic creation enabled',
249
+ impact: 'Typos in topic names create unwanted topics',
250
+ fix: 'Disable auto.create.topics.enable and use explicit topic creation'
251
+ });
252
+ }
253
+ }
254
+
255
+ /**
256
+ * Validate producer configuration
257
+ */
258
+ private validateProducer(producer: any): void {
259
+ const acks = producer['acks'];
260
+ const idempotence = producer['enable.idempotence'];
261
+
262
+ // Acks configuration
263
+ if (acks === 0) {
264
+ this.addIssue({
265
+ severity: 'warning',
266
+ category: 'producer',
267
+ property: 'acks',
268
+ currentValue: 0,
269
+ recommendedValue: 1,
270
+ message: 'acks=0 provides no delivery guarantees',
271
+ impact: 'Messages may be lost without notification',
272
+ fix: 'Use acks=1 (leader) or acks=all (all replicas) for durability'
273
+ });
274
+ }
275
+
276
+ if (acks === 1 && !idempotence) {
277
+ this.addIssue({
278
+ severity: 'info',
279
+ category: 'producer',
280
+ property: 'acks',
281
+ currentValue: 1,
282
+ recommendedValue: 'all',
283
+ message: 'acks=1 may cause duplicates on retry',
284
+ impact: 'Potential duplicate messages on network failures',
285
+ fix: 'Use acks=all with enable.idempotence=true for exactly-once'
286
+ });
287
+ }
288
+
289
+ // Idempotence
290
+ if (idempotence === true) {
291
+ const maxInFlight = producer['max.in.flight.requests.per.connection'];
292
+ if (maxInFlight && maxInFlight > 5) {
293
+ this.addIssue({
294
+ severity: 'error',
295
+ category: 'producer',
296
+ property: 'max.in.flight.requests.per.connection',
297
+ currentValue: maxInFlight,
298
+ recommendedValue: 5,
299
+ message: 'Idempotent producer requires max.in.flight ≤ 5',
300
+ impact: 'Producer will fail to start',
301
+ fix: 'Set max.in.flight.requests.per.connection to 5 or less'
302
+ });
303
+ }
304
+
305
+ if (acks !== 'all' && acks !== -1) {
306
+ this.addIssue({
307
+ severity: 'error',
308
+ category: 'producer',
309
+ property: 'acks',
310
+ currentValue: acks,
311
+ recommendedValue: 'all',
312
+ message: 'Idempotent producer requires acks=all',
313
+ impact: 'Producer will fail to start',
314
+ fix: 'Set acks=all when enable.idempotence=true'
315
+ });
316
+ }
317
+ }
318
+
319
+ // Batch size
320
+ const batchSize = producer['batch.size'];
321
+ if (batchSize && batchSize < 4096) {
322
+ this.addIssue({
323
+ severity: 'warning',
324
+ category: 'producer',
325
+ property: 'batch.size',
326
+ currentValue: batchSize,
327
+ recommendedValue: 16384,
328
+ message: 'Very small batch size reduces throughput',
329
+ impact: 'More network requests, lower throughput',
330
+ fix: 'Increase batch.size to 16384 bytes (16 KB) for better batching'
331
+ });
332
+ }
333
+
334
+ // Linger
335
+ const lingerMs = producer['linger.ms'];
336
+ if (batchSize && batchSize > 16384 && (!lingerMs || lingerMs === 0)) {
337
+ this.addIssue({
338
+ severity: 'info',
339
+ category: 'producer',
340
+ property: 'linger.ms',
341
+ currentValue: lingerMs || 0,
342
+ recommendedValue: 10,
343
+ message: 'Large batch size without linger may not fill batches',
344
+ impact: 'Batches sent before filling, wasting batch potential',
345
+ fix: 'Set linger.ms=10 to allow time for batches to fill'
346
+ });
347
+ }
348
+
349
+ // Compression
350
+ const compression = producer['compression.type'];
351
+ if (!compression || compression === 'none') {
352
+ this.addIssue({
353
+ severity: 'info',
354
+ category: 'producer',
355
+ property: 'compression.type',
356
+ currentValue: compression || 'none',
357
+ recommendedValue: 'lz4',
358
+ message: 'No producer compression',
359
+ impact: 'Higher network and storage usage',
360
+ fix: 'Enable lz4 compression (fast, good ratio)'
361
+ });
362
+ }
363
+ }
364
+
365
+ /**
366
+ * Validate consumer configuration
367
+ */
368
+ private validateConsumer(consumer: any): void {
369
+ const sessionTimeout = consumer['session.timeout.ms'];
370
+ const heartbeatInterval = consumer['heartbeat.interval.ms'];
371
+ const maxPollInterval = consumer['max.poll.interval.ms'];
372
+ const maxPollRecords = consumer['max.poll.records'];
373
+
374
+ // Session timeout vs heartbeat
375
+ if (sessionTimeout && heartbeatInterval) {
376
+ if (heartbeatInterval >= sessionTimeout / 3) {
377
+ this.addIssue({
378
+ severity: 'warning',
379
+ category: 'consumer',
380
+ property: 'heartbeat.interval.ms',
381
+ currentValue: heartbeatInterval,
382
+ recommendedValue: Math.floor(sessionTimeout / 3),
383
+ message: 'heartbeat.interval should be < session.timeout / 3',
384
+ impact: 'Consumer may be marked dead during normal operation',
385
+ fix: `Set heartbeat.interval.ms to ${Math.floor(sessionTimeout / 3)} or less`
386
+ });
387
+ }
388
+ }
389
+
390
+ // Max poll interval vs session timeout
391
+ if (maxPollInterval && sessionTimeout) {
392
+ if (maxPollInterval < sessionTimeout) {
393
+ this.addIssue({
394
+ severity: 'warning',
395
+ category: 'consumer',
396
+ property: 'max.poll.interval.ms',
397
+ currentValue: maxPollInterval,
398
+ recommendedValue: sessionTimeout * 2,
399
+ message: 'max.poll.interval < session.timeout is risky',
400
+ impact: 'Slow processing may trigger unnecessary rebalances',
401
+ fix: `Increase max.poll.interval.ms to at least ${sessionTimeout * 2}`
402
+ });
403
+ }
404
+ }
405
+
406
+ // Max poll records
407
+ if (maxPollRecords && maxPollRecords > 1000) {
408
+ this.addIssue({
409
+ severity: 'info',
410
+ category: 'consumer',
411
+ property: 'max.poll.records',
412
+ currentValue: maxPollRecords,
413
+ recommendedValue: 500,
414
+ message: 'Very high max.poll.records',
415
+ impact: 'Long processing time may exceed max.poll.interval',
416
+ fix: 'Reduce max.poll.records if processing is slow (< 1ms per message)'
417
+ });
418
+ }
419
+
420
+ // Auto offset reset
421
+ const autoOffsetReset = consumer['auto.offset.reset'];
422
+ if (!autoOffsetReset || autoOffsetReset === 'latest') {
423
+ this.addIssue({
424
+ severity: 'info',
425
+ category: 'consumer',
426
+ property: 'auto.offset.reset',
427
+ currentValue: autoOffsetReset || 'latest',
428
+ recommendedValue: 'earliest',
429
+ message: 'auto.offset.reset=latest may skip messages',
430
+ impact: 'New consumers miss messages produced before startup',
431
+ fix: 'Consider auto.offset.reset=earliest to process all messages'
432
+ });
433
+ }
434
+
435
+ // Auto commit
436
+ const autoCommit = consumer['enable.auto.commit'];
437
+ if (autoCommit === true) {
438
+ this.addIssue({
439
+ severity: 'info',
440
+ category: 'consumer',
441
+ property: 'enable.auto.commit',
442
+ currentValue: true,
443
+ recommendedValue: false,
444
+ message: 'Auto-commit enabled',
445
+ impact: 'Potential message loss or duplicates on consumer failure',
446
+ fix: 'Consider manual offset management for exactly-once processing'
447
+ });
448
+ }
449
+
450
+ // Group ID
451
+ if (!consumer['group.id']) {
452
+ this.addIssue({
453
+ severity: 'error',
454
+ category: 'consumer',
455
+ property: 'group.id',
456
+ currentValue: undefined,
457
+ recommendedValue: 'my-consumer-group',
458
+ message: 'Missing group.id',
459
+ impact: 'Consumer will fail to start',
460
+ fix: 'Set group.id to a unique consumer group name'
461
+ });
462
+ }
463
+ }
464
+
465
+ /**
466
+ * Add validation issue
467
+ */
468
+ private addIssue(issue: ValidationIssue): void {
469
+ this.issues.push(issue);
470
+ }
471
+
472
+ /**
473
+ * Calculate configuration score (0-100)
474
+ */
475
+ private calculateScore(): number {
476
+ const weights = {
477
+ error: 30,
478
+ warning: 10,
479
+ info: 2
480
+ };
481
+
482
+ const penalties = this.issues.reduce((total, issue) => {
483
+ return total + weights[issue.severity];
484
+ }, 0);
485
+
486
+ const score = Math.max(0, 100 - penalties);
487
+ return Math.round(score);
488
+ }
489
+
490
+ /**
491
+ * Generate configuration report
492
+ */
493
+ static generateReport(result: ValidationResult): string {
494
+ const lines: string[] = [];
495
+
496
+ lines.push('# Kafka Configuration Validation Report\n');
497
+ lines.push(`**Score**: ${result.score}/100`);
498
+ lines.push(`**Status**: ${result.valid ? '✅ VALID' : '❌ INVALID'}\n`);
499
+
500
+ lines.push(`## Summary`);
501
+ lines.push(`- Errors: ${result.summary.errors}`);
502
+ lines.push(`- Warnings: ${result.summary.warnings}`);
503
+ lines.push(`- Info: ${result.summary.infos}\n`);
504
+
505
+ if (result.issues.length === 0) {
506
+ lines.push('✅ No issues found!\n');
507
+ return lines.join('\n');
508
+ }
509
+
510
+ // Group by severity
511
+ const errors = result.issues.filter(i => i.severity === 'error');
512
+ const warnings = result.issues.filter(i => i.severity === 'warning');
513
+ const infos = result.issues.filter(i => i.severity === 'info');
514
+
515
+ if (errors.length > 0) {
516
+ lines.push(`## 🚨 Errors (${errors.length})\n`);
517
+ errors.forEach((issue, idx) => {
518
+ lines.push(`### ${idx + 1}. ${issue.property}`);
519
+ lines.push(`- **Message**: ${issue.message}`);
520
+ lines.push(`- **Current**: \`${issue.currentValue}\``);
521
+ if (issue.recommendedValue !== undefined) {
522
+ lines.push(`- **Recommended**: \`${issue.recommendedValue}\``);
523
+ }
524
+ lines.push(`- **Impact**: ${issue.impact}`);
525
+ if (issue.fix) {
526
+ lines.push(`- **Fix**: ${issue.fix}`);
527
+ }
528
+ lines.push('');
529
+ });
530
+ }
531
+
532
+ if (warnings.length > 0) {
533
+ lines.push(`## ⚠️ Warnings (${warnings.length})\n`);
534
+ warnings.forEach((issue, idx) => {
535
+ lines.push(`### ${idx + 1}. ${issue.property}`);
536
+ lines.push(`- **Message**: ${issue.message}`);
537
+ lines.push(`- **Current**: \`${issue.currentValue}\``);
538
+ if (issue.recommendedValue !== undefined) {
539
+ lines.push(`- **Recommended**: \`${issue.recommendedValue}\``);
540
+ }
541
+ lines.push(`- **Impact**: ${issue.impact}`);
542
+ if (issue.fix) {
543
+ lines.push(`- **Fix**: ${issue.fix}`);
544
+ }
545
+ lines.push('');
546
+ });
547
+ }
548
+
549
+ if (infos.length > 0) {
550
+ lines.push(`## 💡 Recommendations (${infos.length})\n`);
551
+ infos.forEach((issue, idx) => {
552
+ lines.push(`### ${idx + 1}. ${issue.property}`);
553
+ lines.push(`- **Message**: ${issue.message}`);
554
+ lines.push(`- **Impact**: ${issue.impact}`);
555
+ if (issue.fix) {
556
+ lines.push(`- **Fix**: ${issue.fix}`);
557
+ }
558
+ lines.push('');
559
+ });
560
+ }
561
+
562
+ return lines.join('\n');
563
+ }
564
+ }