specweave 0.18.1 → 0.20.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (389) hide show
  1. package/CLAUDE.md +229 -1817
  2. package/README.md +68 -0
  3. package/bin/specweave.js +62 -6
  4. package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +1 -1
  5. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +3 -0
  6. package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +1 -1
  7. package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts +21 -0
  8. package/dist/plugins/specweave/lib/hooks/update-ac-status.d.ts.map +1 -0
  9. package/dist/plugins/specweave/lib/hooks/update-ac-status.js +162 -0
  10. package/dist/plugins/specweave/lib/hooks/update-ac-status.js.map +1 -0
  11. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.d.ts.map +1 -1
  12. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js +65 -6
  13. package/dist/plugins/specweave-ado/lib/ado-spec-content-sync.js.map +1 -1
  14. package/dist/plugins/specweave-github/lib/completion-calculator.d.ts +112 -0
  15. package/dist/plugins/specweave-github/lib/completion-calculator.d.ts.map +1 -0
  16. package/dist/plugins/specweave-github/lib/completion-calculator.js +301 -0
  17. package/dist/plugins/specweave-github/lib/completion-calculator.js.map +1 -0
  18. package/dist/plugins/specweave-github/lib/duplicate-detector.d.ts +3 -3
  19. package/dist/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  20. package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts +7 -0
  21. package/dist/plugins/specweave-github/lib/epic-content-builder.d.ts.map +1 -1
  22. package/dist/plugins/specweave-github/lib/epic-content-builder.js +42 -0
  23. package/dist/plugins/specweave-github/lib/epic-content-builder.js.map +1 -1
  24. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +14 -0
  25. package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +1 -1
  26. package/dist/plugins/specweave-github/lib/github-client-v2.js +51 -0
  27. package/dist/plugins/specweave-github/lib/github-client-v2.js.map +1 -1
  28. package/dist/plugins/specweave-github/lib/github-epic-sync.js +1 -1
  29. package/dist/plugins/specweave-github/lib/github-epic-sync.js.map +1 -1
  30. package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts +87 -0
  31. package/dist/plugins/specweave-github/lib/github-feature-sync.d.ts.map +1 -0
  32. package/dist/plugins/specweave-github/lib/github-feature-sync.js +412 -0
  33. package/dist/plugins/specweave-github/lib/github-feature-sync.js.map +1 -0
  34. package/dist/plugins/specweave-github/lib/github-spec-content-sync.d.ts.map +1 -1
  35. package/dist/plugins/specweave-github/lib/github-spec-content-sync.js +64 -13
  36. package/dist/plugins/specweave-github/lib/github-spec-content-sync.js.map +1 -1
  37. package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts +78 -0
  38. package/dist/plugins/specweave-github/lib/progress-comment-builder.d.ts.map +1 -0
  39. package/dist/plugins/specweave-github/lib/progress-comment-builder.js +237 -0
  40. package/dist/plugins/specweave-github/lib/progress-comment-builder.js.map +1 -0
  41. package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts +97 -0
  42. package/dist/plugins/specweave-github/lib/user-story-content-builder.d.ts.map +1 -0
  43. package/dist/plugins/specweave-github/lib/user-story-content-builder.js +301 -0
  44. package/dist/plugins/specweave-github/lib/user-story-content-builder.js.map +1 -0
  45. package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts +83 -0
  46. package/dist/plugins/specweave-github/lib/user-story-issue-builder.d.ts.map +1 -0
  47. package/dist/plugins/specweave-github/lib/user-story-issue-builder.js +386 -0
  48. package/dist/plugins/specweave-github/lib/user-story-issue-builder.js.map +1 -0
  49. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts +8 -6
  50. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.d.ts.map +1 -1
  51. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js +78 -117
  52. package/dist/plugins/specweave-jira/lib/enhanced-jira-sync.js.map +1 -1
  53. package/dist/src/cli/commands/import-docs.js +4 -4
  54. package/dist/src/cli/commands/import-docs.js.map +1 -1
  55. package/dist/src/cli/commands/init-multiproject.d.ts.map +1 -1
  56. package/dist/src/cli/commands/init-multiproject.js +17 -18
  57. package/dist/src/cli/commands/init-multiproject.js.map +1 -1
  58. package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +1 -1
  59. package/dist/src/cli/commands/migrate-to-multiproject.js +8 -4
  60. package/dist/src/cli/commands/migrate-to-multiproject.js.map +1 -1
  61. package/dist/src/cli/commands/switch-project.d.ts.map +1 -1
  62. package/dist/src/cli/commands/switch-project.js +9 -26
  63. package/dist/src/cli/commands/switch-project.js.map +1 -1
  64. package/dist/src/cli/commands/sync-spec-content.js +3 -0
  65. package/dist/src/cli/commands/sync-spec-content.js.map +1 -1
  66. package/dist/src/core/deduplication/command-deduplicator.d.ts +166 -0
  67. package/dist/src/core/deduplication/command-deduplicator.d.ts.map +1 -0
  68. package/dist/src/core/deduplication/command-deduplicator.js +254 -0
  69. package/dist/src/core/deduplication/command-deduplicator.js.map +1 -0
  70. package/dist/src/core/increment/active-increment-manager.d.ts +42 -15
  71. package/dist/src/core/increment/active-increment-manager.d.ts.map +1 -1
  72. package/dist/src/core/increment/active-increment-manager.js +113 -46
  73. package/dist/src/core/increment/active-increment-manager.js.map +1 -1
  74. package/dist/src/core/increment/conflict-resolver.d.ts +40 -0
  75. package/dist/src/core/increment/conflict-resolver.d.ts.map +1 -0
  76. package/dist/src/core/increment/conflict-resolver.js +219 -0
  77. package/dist/src/core/increment/conflict-resolver.js.map +1 -0
  78. package/dist/src/core/increment/discipline-checker.d.ts.map +1 -1
  79. package/dist/src/core/increment/discipline-checker.js +7 -1
  80. package/dist/src/core/increment/discipline-checker.js.map +1 -1
  81. package/dist/src/core/increment/duplicate-detector.d.ts +52 -0
  82. package/dist/src/core/increment/duplicate-detector.d.ts.map +1 -0
  83. package/dist/src/core/increment/duplicate-detector.js +276 -0
  84. package/dist/src/core/increment/duplicate-detector.js.map +1 -0
  85. package/dist/src/core/increment/increment-archiver.d.ts +90 -0
  86. package/dist/src/core/increment/increment-archiver.d.ts.map +1 -0
  87. package/dist/src/core/increment/increment-archiver.js +368 -0
  88. package/dist/src/core/increment/increment-archiver.js.map +1 -0
  89. package/dist/src/core/increment/increment-reopener.d.ts +165 -0
  90. package/dist/src/core/increment/increment-reopener.d.ts.map +1 -0
  91. package/dist/src/core/increment/increment-reopener.js +390 -0
  92. package/dist/src/core/increment/increment-reopener.js.map +1 -0
  93. package/dist/src/core/increment/metadata-manager.d.ts +26 -1
  94. package/dist/src/core/increment/metadata-manager.d.ts.map +1 -1
  95. package/dist/src/core/increment/metadata-manager.js +143 -5
  96. package/dist/src/core/increment/metadata-manager.js.map +1 -1
  97. package/dist/src/core/increment/recent-work-scanner.d.ts +121 -0
  98. package/dist/src/core/increment/recent-work-scanner.d.ts.map +1 -0
  99. package/dist/src/core/increment/recent-work-scanner.js +303 -0
  100. package/dist/src/core/increment/recent-work-scanner.js.map +1 -0
  101. package/dist/src/core/increment/types.d.ts +1 -0
  102. package/dist/src/core/increment/types.d.ts.map +1 -1
  103. package/dist/src/core/increment-utils.d.ts +112 -0
  104. package/dist/src/core/increment-utils.d.ts.map +1 -0
  105. package/dist/src/core/increment-utils.js +210 -0
  106. package/dist/src/core/increment-utils.js.map +1 -0
  107. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts +65 -0
  108. package/dist/src/core/living-docs/ac-project-specific-generator.d.ts.map +1 -0
  109. package/dist/src/core/living-docs/ac-project-specific-generator.js +175 -0
  110. package/dist/src/core/living-docs/ac-project-specific-generator.js.map +1 -0
  111. package/dist/src/core/living-docs/feature-archiver.d.ts +130 -0
  112. package/dist/src/core/living-docs/feature-archiver.d.ts.map +1 -0
  113. package/dist/src/core/living-docs/feature-archiver.js +549 -0
  114. package/dist/src/core/living-docs/feature-archiver.js.map +1 -0
  115. package/dist/src/core/living-docs/feature-id-manager.d.ts +81 -0
  116. package/dist/src/core/living-docs/feature-id-manager.d.ts.map +1 -0
  117. package/dist/src/core/living-docs/feature-id-manager.js +339 -0
  118. package/dist/src/core/living-docs/feature-id-manager.js.map +1 -0
  119. package/dist/src/core/living-docs/hierarchy-mapper.d.ts +144 -83
  120. package/dist/src/core/living-docs/hierarchy-mapper.d.ts.map +1 -1
  121. package/dist/src/core/living-docs/hierarchy-mapper.js +488 -270
  122. package/dist/src/core/living-docs/hierarchy-mapper.js.map +1 -1
  123. package/dist/src/core/living-docs/index.d.ts +6 -0
  124. package/dist/src/core/living-docs/index.d.ts.map +1 -1
  125. package/dist/src/core/living-docs/index.js +6 -0
  126. package/dist/src/core/living-docs/index.js.map +1 -1
  127. package/dist/src/core/living-docs/project-detector.d.ts +6 -0
  128. package/dist/src/core/living-docs/project-detector.d.ts.map +1 -1
  129. package/dist/src/core/living-docs/project-detector.js +35 -1
  130. package/dist/src/core/living-docs/project-detector.js.map +1 -1
  131. package/dist/src/core/living-docs/spec-distributor.d.ts +100 -26
  132. package/dist/src/core/living-docs/spec-distributor.d.ts.map +1 -1
  133. package/dist/src/core/living-docs/spec-distributor.js +1275 -258
  134. package/dist/src/core/living-docs/spec-distributor.js.map +1 -1
  135. package/dist/src/core/living-docs/task-project-specific-generator.d.ts +109 -0
  136. package/dist/src/core/living-docs/task-project-specific-generator.d.ts.map +1 -0
  137. package/dist/src/core/living-docs/task-project-specific-generator.js +221 -0
  138. package/dist/src/core/living-docs/task-project-specific-generator.js.map +1 -0
  139. package/dist/src/core/living-docs/types.d.ts +143 -0
  140. package/dist/src/core/living-docs/types.d.ts.map +1 -1
  141. package/dist/src/core/project-manager.d.ts +2 -17
  142. package/dist/src/core/project-manager.d.ts.map +1 -1
  143. package/dist/src/core/project-manager.js +68 -48
  144. package/dist/src/core/project-manager.js.map +1 -1
  145. package/dist/src/core/spec-content-sync.d.ts +1 -1
  146. package/dist/src/core/spec-content-sync.d.ts.map +1 -1
  147. package/dist/src/core/sync/enhanced-content-builder.d.ts.map +1 -1
  148. package/dist/src/core/sync/enhanced-content-builder.js +2 -1
  149. package/dist/src/core/sync/enhanced-content-builder.js.map +1 -1
  150. package/dist/src/core/sync/performance-optimizer.d.ts +153 -0
  151. package/dist/src/core/sync/performance-optimizer.d.ts.map +1 -0
  152. package/dist/src/core/sync/performance-optimizer.js +220 -0
  153. package/dist/src/core/sync/performance-optimizer.js.map +1 -0
  154. package/dist/src/core/sync/retry-handler.d.ts +98 -0
  155. package/dist/src/core/sync/retry-handler.d.ts.map +1 -0
  156. package/dist/src/core/sync/retry-handler.js +196 -0
  157. package/dist/src/core/sync/retry-handler.js.map +1 -0
  158. package/dist/src/core/types/config.d.ts +94 -0
  159. package/dist/src/core/types/config.d.ts.map +1 -1
  160. package/dist/src/core/types/config.js +16 -0
  161. package/dist/src/core/types/config.js.map +1 -1
  162. package/dist/src/core/types/increment-metadata.d.ts +6 -0
  163. package/dist/src/core/types/increment-metadata.d.ts.map +1 -1
  164. package/dist/src/core/types/increment-metadata.js +10 -1
  165. package/dist/src/core/types/increment-metadata.js.map +1 -1
  166. package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +1 -1
  167. package/dist/src/integrations/jira/jira-incremental-mapper.js +4 -8
  168. package/dist/src/integrations/jira/jira-incremental-mapper.js.map +1 -1
  169. package/dist/src/integrations/jira/jira-mapper.d.ts.map +1 -1
  170. package/dist/src/integrations/jira/jira-mapper.js +4 -8
  171. package/dist/src/integrations/jira/jira-mapper.js.map +1 -1
  172. package/package.json +1 -1
  173. package/plugins/specweave/COMMANDS.md +13 -4
  174. package/plugins/specweave/commands/specweave-abandon.md +22 -20
  175. package/plugins/specweave/commands/specweave-archive-features.md +121 -0
  176. package/plugins/specweave/commands/specweave-archive-increments.md +82 -0
  177. package/plugins/specweave/commands/specweave-archive.md +363 -0
  178. package/plugins/specweave/commands/specweave-backlog.md +211 -0
  179. package/plugins/specweave/commands/specweave-fix-duplicates.md +517 -0
  180. package/plugins/specweave/commands/specweave-increment.md +4 -3
  181. package/plugins/specweave/commands/specweave-progress.md +176 -27
  182. package/plugins/specweave/commands/specweave-reopen.md +391 -0
  183. package/plugins/specweave/commands/specweave-restore-feature.md +90 -0
  184. package/plugins/specweave/commands/specweave-restore.md +309 -0
  185. package/plugins/specweave/commands/specweave-resume.md +51 -23
  186. package/plugins/specweave/commands/specweave-status.md +41 -7
  187. package/plugins/specweave/commands/specweave-sync-specs.md +425 -0
  188. package/plugins/specweave/hooks/hooks.json +4 -0
  189. package/plugins/specweave/hooks/lib/sync-spec-content.sh +2 -2
  190. package/plugins/specweave/hooks/post-task-completion.sh +39 -0
  191. package/plugins/specweave/hooks/pre-command-deduplication.sh +83 -0
  192. package/plugins/specweave/hooks/user-prompt-submit.sh +1 -1
  193. package/plugins/specweave/lib/hooks/sync-living-docs.js +2 -0
  194. package/plugins/specweave/lib/hooks/sync-living-docs.ts +4 -0
  195. package/plugins/specweave/lib/hooks/update-ac-status.js +102 -0
  196. package/plugins/specweave/lib/hooks/update-ac-status.ts +192 -0
  197. package/plugins/specweave/skills/archive-increments/SKILL.md +198 -0
  198. package/plugins/specweave/skills/increment-planner/scripts/feature-utils.js +14 -0
  199. package/plugins/specweave/skills/smart-reopen-detector/SKILL.md +244 -0
  200. package/plugins/specweave-ado/lib/ado-spec-content-sync.js +49 -5
  201. package/plugins/specweave-ado/lib/ado-spec-content-sync.ts +72 -6
  202. package/plugins/specweave-confluent/.claude-plugin/plugin.json +23 -0
  203. package/plugins/specweave-confluent/README.md +375 -0
  204. package/plugins/specweave-confluent/agents/confluent-architect/AGENT.md +306 -0
  205. package/plugins/specweave-confluent/skills/confluent-kafka-connect/SKILL.md +453 -0
  206. package/plugins/specweave-confluent/skills/confluent-ksqldb/SKILL.md +470 -0
  207. package/plugins/specweave-confluent/skills/confluent-schema-registry/SKILL.md +316 -0
  208. package/plugins/specweave-github/agents/github-task-splitter/AGENT.md +2 -2
  209. package/plugins/specweave-github/agents/user-story-updater/AGENT.md +148 -0
  210. package/plugins/specweave-github/commands/specweave-github-cleanup-duplicates.md +1 -1
  211. package/plugins/specweave-github/commands/specweave-github-update-user-story.md +156 -0
  212. package/plugins/specweave-github/hooks/post-task-completion.sh +10 -9
  213. package/plugins/specweave-github/lib/completion-calculator.js +262 -0
  214. package/plugins/specweave-github/lib/completion-calculator.ts +434 -0
  215. package/plugins/specweave-github/lib/duplicate-detector.js +3 -3
  216. package/plugins/specweave-github/lib/duplicate-detector.ts +4 -4
  217. package/plugins/specweave-github/lib/epic-content-builder.js +38 -0
  218. package/plugins/specweave-github/lib/epic-content-builder.ts +59 -0
  219. package/plugins/specweave-github/lib/github-client-v2.js +49 -0
  220. package/plugins/specweave-github/lib/github-client-v2.ts +59 -0
  221. package/plugins/specweave-github/lib/github-epic-sync.ts +1 -1
  222. package/plugins/specweave-github/lib/github-feature-sync.js +381 -0
  223. package/plugins/specweave-github/lib/github-feature-sync.ts +568 -0
  224. package/plugins/specweave-github/lib/github-spec-content-sync.js +40 -10
  225. package/plugins/specweave-github/lib/github-spec-content-sync.ts +82 -14
  226. package/plugins/specweave-github/lib/progress-comment-builder.js +229 -0
  227. package/plugins/specweave-github/lib/progress-comment-builder.ts +324 -0
  228. package/plugins/specweave-github/lib/user-story-content-builder.js +299 -0
  229. package/plugins/specweave-github/lib/user-story-content-builder.ts +413 -0
  230. package/plugins/specweave-github/lib/user-story-issue-builder.js +344 -0
  231. package/plugins/specweave-github/lib/user-story-issue-builder.ts +543 -0
  232. package/plugins/specweave-github/skills/github-issue-standard/SKILL.md +189 -0
  233. package/plugins/{specweave-ado/lib/enhanced-ado-sync.js → specweave-jira/lib/enhanced-jira-sync.js} +25 -61
  234. package/plugins/specweave-jira/lib/{enhanced-jira-sync.ts.disabled → enhanced-jira-sync.ts} +26 -52
  235. package/plugins/specweave-kafka/.claude-plugin/plugin.json +26 -0
  236. package/plugins/specweave-kafka/IMPLEMENTATION-COMPLETE.md +483 -0
  237. package/plugins/specweave-kafka/README.md +242 -0
  238. package/plugins/specweave-kafka/agents/kafka-architect/AGENT.md +235 -0
  239. package/plugins/specweave-kafka/agents/kafka-devops/AGENT.md +209 -0
  240. package/plugins/specweave-kafka/agents/kafka-observability/AGENT.md +266 -0
  241. package/plugins/specweave-kafka/commands/deploy.md +99 -0
  242. package/plugins/specweave-kafka/commands/dev-env.md +176 -0
  243. package/plugins/specweave-kafka/commands/mcp-configure.md +101 -0
  244. package/plugins/specweave-kafka/commands/monitor-setup.md +96 -0
  245. package/plugins/specweave-kafka/docker/kafka-local/docker-compose.yml +187 -0
  246. package/plugins/specweave-kafka/docker/redpanda/docker-compose.yml +199 -0
  247. package/plugins/specweave-kafka/docker/templates/consumer-nodejs.js +225 -0
  248. package/plugins/specweave-kafka/docker/templates/consumer-python.py +220 -0
  249. package/plugins/specweave-kafka/docker/templates/producer-nodejs.js +168 -0
  250. package/plugins/specweave-kafka/docker/templates/producer-python.py +167 -0
  251. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.js +438 -0
  252. package/plugins/specweave-kafka/lib/adapters/apache-kafka-adapter.ts +541 -0
  253. package/plugins/specweave-kafka/lib/adapters/platform-adapter.js +47 -0
  254. package/plugins/specweave-kafka/lib/adapters/platform-adapter.ts +343 -0
  255. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.js +258 -0
  256. package/plugins/specweave-kafka/lib/cli/kcat-wrapper.ts +298 -0
  257. package/plugins/specweave-kafka/lib/cli/types.js +10 -0
  258. package/plugins/specweave-kafka/lib/cli/types.ts +92 -0
  259. package/plugins/specweave-kafka/lib/connectors/connector-catalog.js +305 -0
  260. package/plugins/specweave-kafka/lib/connectors/connector-catalog.ts +528 -0
  261. package/plugins/specweave-kafka/lib/documentation/diagram-generator.js +114 -0
  262. package/plugins/specweave-kafka/lib/documentation/diagram-generator.ts +195 -0
  263. package/plugins/specweave-kafka/lib/documentation/exporter.js +210 -0
  264. package/plugins/specweave-kafka/lib/documentation/exporter.ts +338 -0
  265. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.js +60 -0
  266. package/plugins/specweave-kafka/lib/documentation/schema-catalog-generator.ts +130 -0
  267. package/plugins/specweave-kafka/lib/documentation/topology-generator.js +143 -0
  268. package/plugins/specweave-kafka/lib/documentation/topology-generator.ts +290 -0
  269. package/plugins/specweave-kafka/lib/mcp/detector.js +298 -0
  270. package/plugins/specweave-kafka/lib/mcp/detector.ts +352 -0
  271. package/plugins/specweave-kafka/lib/mcp/types.js +21 -0
  272. package/plugins/specweave-kafka/lib/mcp/types.ts +77 -0
  273. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.js +193 -0
  274. package/plugins/specweave-kafka/lib/multi-cluster/cluster-config-manager.ts +362 -0
  275. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.js +188 -0
  276. package/plugins/specweave-kafka/lib/multi-cluster/cluster-switcher.ts +359 -0
  277. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.js +195 -0
  278. package/plugins/specweave-kafka/lib/multi-cluster/health-aggregator.ts +380 -0
  279. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.js +209 -0
  280. package/plugins/specweave-kafka/lib/observability/opentelemetry-kafka.ts +358 -0
  281. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.js +354 -0
  282. package/plugins/specweave-kafka/lib/patterns/advanced-ksqldb-patterns.ts +563 -0
  283. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.js +259 -0
  284. package/plugins/specweave-kafka/lib/patterns/circuit-breaker-resilience.ts +516 -0
  285. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.js +233 -0
  286. package/plugins/specweave-kafka/lib/patterns/dead-letter-queue.ts +423 -0
  287. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.js +266 -0
  288. package/plugins/specweave-kafka/lib/patterns/exactly-once-semantics.ts +445 -0
  289. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.js +312 -0
  290. package/plugins/specweave-kafka/lib/patterns/flink-kafka-integration.ts +561 -0
  291. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.js +289 -0
  292. package/plugins/specweave-kafka/lib/patterns/multi-dc-replication.ts +607 -0
  293. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.js +264 -0
  294. package/plugins/specweave-kafka/lib/patterns/rate-limiting-backpressure.ts +498 -0
  295. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.js +263 -0
  296. package/plugins/specweave-kafka/lib/patterns/stream-processing-optimization.ts +549 -0
  297. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.js +205 -0
  298. package/plugins/specweave-kafka/lib/patterns/tiered-storage-compaction.ts +399 -0
  299. package/plugins/specweave-kafka/lib/performance/performance-optimizer.js +249 -0
  300. package/plugins/specweave-kafka/lib/performance/performance-optimizer.ts +427 -0
  301. package/plugins/specweave-kafka/lib/security/kafka-security.js +252 -0
  302. package/plugins/specweave-kafka/lib/security/kafka-security.ts +494 -0
  303. package/plugins/specweave-kafka/lib/utils/capacity-planner.js +203 -0
  304. package/plugins/specweave-kafka/lib/utils/capacity-planner.ts +469 -0
  305. package/plugins/specweave-kafka/lib/utils/config-validator.js +419 -0
  306. package/plugins/specweave-kafka/lib/utils/config-validator.ts +564 -0
  307. package/plugins/specweave-kafka/lib/utils/partitioning.js +329 -0
  308. package/plugins/specweave-kafka/lib/utils/partitioning.ts +473 -0
  309. package/plugins/specweave-kafka/lib/utils/sizing.js +221 -0
  310. package/plugins/specweave-kafka/lib/utils/sizing.ts +374 -0
  311. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-broker-metrics.json +628 -0
  312. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-cluster-overview.json +564 -0
  313. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-consumer-lag.json +509 -0
  314. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-jvm-metrics.json +674 -0
  315. package/plugins/specweave-kafka/monitoring/grafana/dashboards/kafka-topic-metrics.json +578 -0
  316. package/plugins/specweave-kafka/monitoring/grafana/provisioning/dashboards/kafka.yml +17 -0
  317. package/plugins/specweave-kafka/monitoring/grafana/provisioning/datasources/prometheus.yml +17 -0
  318. package/plugins/specweave-kafka/monitoring/prometheus/kafka-alerts.yml +415 -0
  319. package/plugins/specweave-kafka/monitoring/prometheus/kafka-jmx-exporter.yml +256 -0
  320. package/plugins/specweave-kafka/package.json +41 -0
  321. package/plugins/specweave-kafka/skills/kafka-architecture/SKILL.md +647 -0
  322. package/plugins/specweave-kafka/skills/kafka-cli-tools/SKILL.md +433 -0
  323. package/plugins/specweave-kafka/skills/kafka-iac-deployment/SKILL.md +449 -0
  324. package/plugins/specweave-kafka/skills/kafka-kubernetes/SKILL.md +667 -0
  325. package/plugins/specweave-kafka/skills/kafka-mcp-integration/SKILL.md +273 -0
  326. package/plugins/specweave-kafka/skills/kafka-observability/SKILL.md +576 -0
  327. package/plugins/specweave-kafka/templates/config/broker-production.properties +254 -0
  328. package/plugins/specweave-kafka/templates/config/consumer-low-latency.properties +112 -0
  329. package/plugins/specweave-kafka/templates/config/producer-high-throughput.properties +120 -0
  330. package/plugins/specweave-kafka/templates/migration/mirrormaker2-config.properties +234 -0
  331. package/plugins/specweave-kafka/templates/monitoring/grafana/multi-cluster-dashboard.json +686 -0
  332. package/plugins/specweave-kafka/terraform/apache-kafka/main.tf +347 -0
  333. package/plugins/specweave-kafka/terraform/apache-kafka/outputs.tf +107 -0
  334. package/plugins/specweave-kafka/terraform/apache-kafka/templates/kafka-broker-init.sh.tpl +216 -0
  335. package/plugins/specweave-kafka/terraform/apache-kafka/variables.tf +156 -0
  336. package/plugins/specweave-kafka/terraform/aws-msk/main.tf +362 -0
  337. package/plugins/specweave-kafka/terraform/aws-msk/outputs.tf +93 -0
  338. package/plugins/specweave-kafka/terraform/aws-msk/templates/server.properties.tpl +32 -0
  339. package/plugins/specweave-kafka/terraform/aws-msk/variables.tf +235 -0
  340. package/plugins/specweave-kafka/terraform/azure-event-hubs/main.tf +281 -0
  341. package/plugins/specweave-kafka/terraform/azure-event-hubs/outputs.tf +118 -0
  342. package/plugins/specweave-kafka/terraform/azure-event-hubs/variables.tf +148 -0
  343. package/plugins/specweave-kafka/tsconfig.json +21 -0
  344. package/plugins/specweave-kafka-streams/.claude-plugin/plugin.json +23 -0
  345. package/plugins/specweave-kafka-streams/README.md +310 -0
  346. package/plugins/specweave-kafka-streams/skills/kafka-streams-topology/SKILL.md +539 -0
  347. package/plugins/specweave-n8n/.claude-plugin/plugin.json +22 -0
  348. package/plugins/specweave-n8n/README.md +354 -0
  349. package/plugins/specweave-n8n/skills/n8n-kafka-workflows/SKILL.md +504 -0
  350. package/plugins/specweave-release/commands/specweave-release-platform.md +1 -1
  351. package/plugins/specweave-release/hooks/post-task-completion.sh +2 -2
  352. package/src/templates/AGENTS.md.template +601 -7
  353. package/src/templates/CLAUDE.md.template +188 -88
  354. package/dist/locales/de/.gitkeep +0 -0
  355. package/dist/locales/de/cli.json +0 -108
  356. package/dist/locales/en/cli.json +0 -287
  357. package/dist/locales/en/errors.json +0 -7
  358. package/dist/locales/en/templates.json +0 -6
  359. package/dist/locales/es/.gitkeep +0 -0
  360. package/dist/locales/es/cli.json +0 -41
  361. package/dist/locales/fr/.gitkeep +0 -0
  362. package/dist/locales/fr/cli.json +0 -108
  363. package/dist/locales/ja/.gitkeep +0 -0
  364. package/dist/locales/ja/cli.json +0 -108
  365. package/dist/locales/ko/.gitkeep +0 -0
  366. package/dist/locales/ko/cli.json +0 -108
  367. package/dist/locales/pt/.gitkeep +0 -0
  368. package/dist/locales/pt/cli.json +0 -108
  369. package/dist/locales/ru/.gitkeep +0 -0
  370. package/dist/locales/ru/cli.json +0 -269
  371. package/dist/locales/zh/.gitkeep +0 -0
  372. package/dist/locales/zh/cli.json +0 -108
  373. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.d.ts +0 -25
  374. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.d.ts.map +0 -1
  375. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.js +0 -191
  376. package/dist/plugins/specweave-ado/lib/enhanced-ado-sync.js.map +0 -1
  377. package/dist/spec-parser.js +0 -629
  378. package/dist/src/core/sync/spec-content-sync.d.ts +0 -88
  379. package/dist/src/core/sync/spec-content-sync.d.ts.map +0 -1
  380. package/dist/src/core/sync/spec-content-sync.js +0 -5
  381. package/dist/src/core/sync/spec-content-sync.js.map +0 -1
  382. package/dist/tsconfig.tsbuildinfo +0 -1
  383. package/plugins/specweave-ado/commands/specweave-ado-sync-spec.md +0 -255
  384. package/plugins/specweave-github/commands/specweave-github-sync-epic.md +0 -248
  385. package/plugins/specweave-github/commands/specweave-github-sync-from.md +0 -147
  386. package/plugins/specweave-github/commands/specweave-github-sync-spec.md +0 -208
  387. package/plugins/specweave-github/commands/specweave-github-sync-tasks.md +0 -530
  388. package/plugins/specweave-jira/commands/specweave-jira-sync-epic.md +0 -267
  389. package/plugins/specweave-jira/commands/specweave-jira-sync-spec.md +0 -240
@@ -0,0 +1,494 @@
1
+ /**
2
+ * Kafka Security Patterns
3
+ *
4
+ * TLS/SSL encryption, SASL authentication, and ACL management
5
+ *
6
+ * @module kafka-security
7
+ */
8
+
9
+ import { Kafka, SASLOptions, ConnectionOptions } from 'kafkajs';
10
+ import * as fs from 'fs';
11
+ import * as path from 'path';
12
+
13
+ /**
14
+ * TLS/SSL Configuration
15
+ */
16
+ export interface TLSConfig {
17
+ /** Enable TLS */
18
+ enabled: boolean;
19
+ /** CA certificate (PEM format) */
20
+ ca?: string | Buffer;
21
+ /** Client certificate (PEM format) */
22
+ cert?: string | Buffer;
23
+ /** Client private key (PEM format) */
24
+ key?: string | Buffer;
25
+ /** Reject unauthorized certificates (default: true) */
26
+ rejectUnauthorized?: boolean;
27
+ /** Server name for SNI */
28
+ servername?: string;
29
+ }
30
+
31
+ /**
32
+ * SASL Authentication Configuration
33
+ */
34
+ export interface SASLConfig {
35
+ /** SASL mechanism */
36
+ mechanism: 'plain' | 'scram-sha-256' | 'scram-sha-512' | 'aws' | 'oauthbearer';
37
+ /** Username */
38
+ username?: string;
39
+ /** Password */
40
+ password?: string;
41
+ /** AWS specific configuration */
42
+ aws?: {
43
+ accessKeyId: string;
44
+ secretAccessKey: string;
45
+ region: string;
46
+ };
47
+ /** OAuth specific configuration */
48
+ oauthBearer?: {
49
+ oauthBearerProvider: () => Promise<{ value: string }>;
50
+ };
51
+ }
52
+
53
+ /**
54
+ * ACL (Access Control List) Configuration
55
+ */
56
+ export interface ACLConfig {
57
+ /** Principal (user) */
58
+ principal: string;
59
+ /** Resource type */
60
+ resourceType: 'TOPIC' | 'GROUP' | 'CLUSTER' | 'TRANSACTIONAL_ID';
61
+ /** Resource name (or '*' for all) */
62
+ resourceName: string;
63
+ /** Resource pattern type */
64
+ patternType: 'LITERAL' | 'PREFIXED';
65
+ /** Operation */
66
+ operation: 'READ' | 'WRITE' | 'CREATE' | 'DELETE' | 'ALTER' | 'DESCRIBE' | 'CLUSTER_ACTION' | 'DESCRIBE_CONFIGS' | 'ALTER_CONFIGS' | 'IDEMPOTENT_WRITE' | 'ALL';
67
+ /** Permission type */
68
+ permissionType: 'ALLOW' | 'DENY';
69
+ /** Host (or '*' for all) */
70
+ host: string;
71
+ }
72
+
73
+ /**
74
+ * Kafka Security Manager
75
+ */
76
+ export class KafkaSecurityManager {
77
+ /**
78
+ * Create TLS configuration from files
79
+ */
80
+ static createTLSConfigFromFiles(options: {
81
+ caPath?: string;
82
+ certPath?: string;
83
+ keyPath?: string;
84
+ rejectUnauthorized?: boolean;
85
+ servername?: string;
86
+ }): TLSConfig {
87
+ const config: TLSConfig = {
88
+ enabled: true,
89
+ rejectUnauthorized: options.rejectUnauthorized !== false,
90
+ servername: options.servername,
91
+ };
92
+
93
+ if (options.caPath) {
94
+ config.ca = fs.readFileSync(path.resolve(options.caPath));
95
+ }
96
+
97
+ if (options.certPath) {
98
+ config.cert = fs.readFileSync(path.resolve(options.certPath));
99
+ }
100
+
101
+ if (options.keyPath) {
102
+ config.key = fs.readFileSync(path.resolve(options.keyPath));
103
+ }
104
+
105
+ return config;
106
+ }
107
+
108
+ /**
109
+ * Create SASL/PLAIN configuration
110
+ */
111
+ static createSASLPlainConfig(username: string, password: string): SASLConfig {
112
+ return {
113
+ mechanism: 'plain',
114
+ username,
115
+ password,
116
+ };
117
+ }
118
+
119
+ /**
120
+ * Create SASL/SCRAM-SHA-256 configuration
121
+ */
122
+ static createSASLScramSHA256Config(username: string, password: string): SASLConfig {
123
+ return {
124
+ mechanism: 'scram-sha-256',
125
+ username,
126
+ password,
127
+ };
128
+ }
129
+
130
+ /**
131
+ * Create SASL/SCRAM-SHA-512 configuration
132
+ */
133
+ static createSASLScramSHA512Config(username: string, password: string): SASLConfig {
134
+ return {
135
+ mechanism: 'scram-sha-512',
136
+ username,
137
+ password,
138
+ };
139
+ }
140
+
141
+ /**
142
+ * Create AWS IAM authentication configuration
143
+ */
144
+ static createSASLAWSConfig(
145
+ accessKeyId: string,
146
+ secretAccessKey: string,
147
+ region: string
148
+ ): SASLConfig {
149
+ return {
150
+ mechanism: 'aws',
151
+ aws: {
152
+ accessKeyId,
153
+ secretAccessKey,
154
+ region,
155
+ },
156
+ };
157
+ }
158
+
159
+ /**
160
+ * Create OAuth Bearer configuration
161
+ */
162
+ static createSASLOAuthBearerConfig(
163
+ tokenProvider: () => Promise<{ value: string }>
164
+ ): SASLConfig {
165
+ return {
166
+ mechanism: 'oauthbearer',
167
+ oauthBearer: {
168
+ oauthBearerProvider: tokenProvider,
169
+ },
170
+ };
171
+ }
172
+
173
+ /**
174
+ * Create Kafka client with security configuration
175
+ */
176
+ static createSecureKafkaClient(options: {
177
+ brokers: string[];
178
+ clientId: string;
179
+ tls?: TLSConfig;
180
+ sasl?: SASLConfig;
181
+ }): Kafka {
182
+ const connectionOptions: ConnectionOptions = {};
183
+
184
+ // TLS Configuration
185
+ if (options.tls?.enabled) {
186
+ connectionOptions.ssl = {
187
+ rejectUnauthorized: options.tls.rejectUnauthorized !== false,
188
+ ca: options.tls.ca ? [options.tls.ca] : undefined,
189
+ cert: options.tls.cert,
190
+ key: options.tls.key,
191
+ servername: options.tls.servername,
192
+ };
193
+ }
194
+
195
+ // SASL Configuration
196
+ if (options.sasl) {
197
+ let saslOptions: SASLOptions;
198
+
199
+ switch (options.sasl.mechanism) {
200
+ case 'plain':
201
+ saslOptions = {
202
+ mechanism: 'plain',
203
+ username: options.sasl.username!,
204
+ password: options.sasl.password!,
205
+ };
206
+ break;
207
+
208
+ case 'scram-sha-256':
209
+ saslOptions = {
210
+ mechanism: 'scram-sha-256',
211
+ username: options.sasl.username!,
212
+ password: options.sasl.password!,
213
+ };
214
+ break;
215
+
216
+ case 'scram-sha-512':
217
+ saslOptions = {
218
+ mechanism: 'scram-sha-512',
219
+ username: options.sasl.username!,
220
+ password: options.sasl.password!,
221
+ };
222
+ break;
223
+
224
+ case 'aws':
225
+ // @ts-ignore - AWS IAM auth typing
226
+ saslOptions = {
227
+ mechanism: 'aws',
228
+ authorizationIdentity: options.sasl.aws!.accessKeyId,
229
+ accessKeyId: options.sasl.aws!.accessKeyId,
230
+ secretAccessKey: options.sasl.aws!.secretAccessKey,
231
+ };
232
+ break;
233
+
234
+ case 'oauthbearer':
235
+ // @ts-ignore - OAuth bearer typing
236
+ saslOptions = {
237
+ mechanism: 'oauthbearer',
238
+ oauthBearerProvider: options.sasl.oauthBearer!.oauthBearerProvider,
239
+ };
240
+ break;
241
+
242
+ default:
243
+ throw new Error(`Unsupported SASL mechanism: ${options.sasl.mechanism}`);
244
+ }
245
+
246
+ connectionOptions.sasl = saslOptions;
247
+ }
248
+
249
+ return new Kafka({
250
+ clientId: options.clientId,
251
+ brokers: options.brokers,
252
+ ...connectionOptions,
253
+ });
254
+ }
255
+ }
256
+
257
+ /**
258
+ * ACL Manager (Kafka Admin CLI wrapper)
259
+ *
260
+ * Note: Requires kafka-acls.sh CLI tool and admin permissions
261
+ */
262
+ export class KafkaACLManager {
263
+ private kafkaHome: string;
264
+
265
+ constructor(kafkaHome: string = process.env.KAFKA_HOME || '/opt/kafka') {
266
+ this.kafkaHome = kafkaHome;
267
+ }
268
+
269
+ /**
270
+ * Create ACL
271
+ */
272
+ async createACL(options: {
273
+ bootstrapServer: string;
274
+ acl: ACLConfig;
275
+ commandConfig?: string;
276
+ }): Promise<void> {
277
+ const args = [
278
+ '--bootstrap-server',
279
+ options.bootstrapServer,
280
+ '--add',
281
+ '--allow-principal',
282
+ options.acl.principal,
283
+ '--operation',
284
+ options.acl.operation,
285
+ ];
286
+
287
+ // Resource type
288
+ if (options.acl.resourceType === 'TOPIC') {
289
+ args.push('--topic', options.acl.resourceName);
290
+ } else if (options.acl.resourceType === 'GROUP') {
291
+ args.push('--group', options.acl.resourceName);
292
+ } else if (options.acl.resourceType === 'CLUSTER') {
293
+ args.push('--cluster');
294
+ } else if (options.acl.resourceType === 'TRANSACTIONAL_ID') {
295
+ args.push('--transactional-id', options.acl.resourceName);
296
+ }
297
+
298
+ // Pattern type
299
+ if (options.acl.patternType === 'PREFIXED') {
300
+ args.push('--resource-pattern-type', 'PREFIXED');
301
+ }
302
+
303
+ // Host
304
+ if (options.acl.host !== '*') {
305
+ args.push('--allow-host', options.acl.host);
306
+ }
307
+
308
+ // Command config (for TLS/SASL)
309
+ if (options.commandConfig) {
310
+ args.push('--command-config', options.commandConfig);
311
+ }
312
+
313
+ await this.runKafkaACLCommand(args);
314
+ }
315
+
316
+ /**
317
+ * List ACLs
318
+ */
319
+ async listACLs(options: {
320
+ bootstrapServer: string;
321
+ resourceType?: ACLConfig['resourceType'];
322
+ resourceName?: string;
323
+ principal?: string;
324
+ commandConfig?: string;
325
+ }): Promise<string> {
326
+ const args = [
327
+ '--bootstrap-server',
328
+ options.bootstrapServer,
329
+ '--list',
330
+ ];
331
+
332
+ if (options.resourceType) {
333
+ if (options.resourceType === 'TOPIC') {
334
+ args.push('--topic', options.resourceName || '*');
335
+ } else if (options.resourceType === 'GROUP') {
336
+ args.push('--group', options.resourceName || '*');
337
+ } else if (options.resourceType === 'CLUSTER') {
338
+ args.push('--cluster');
339
+ }
340
+ }
341
+
342
+ if (options.principal) {
343
+ args.push('--principal', options.principal);
344
+ }
345
+
346
+ if (options.commandConfig) {
347
+ args.push('--command-config', options.commandConfig);
348
+ }
349
+
350
+ return this.runKafkaACLCommand(args);
351
+ }
352
+
353
+ /**
354
+ * Delete ACL
355
+ */
356
+ async deleteACL(options: {
357
+ bootstrapServer: string;
358
+ acl: Partial<ACLConfig>;
359
+ commandConfig?: string;
360
+ }): Promise<void> {
361
+ const args = [
362
+ '--bootstrap-server',
363
+ options.bootstrapServer,
364
+ '--remove',
365
+ ];
366
+
367
+ if (options.acl.principal) {
368
+ args.push('--allow-principal', options.acl.principal);
369
+ }
370
+
371
+ if (options.acl.resourceType === 'TOPIC' && options.acl.resourceName) {
372
+ args.push('--topic', options.acl.resourceName);
373
+ }
374
+
375
+ if (options.acl.operation) {
376
+ args.push('--operation', options.acl.operation);
377
+ }
378
+
379
+ if (options.commandConfig) {
380
+ args.push('--command-config', options.commandConfig);
381
+ }
382
+
383
+ await this.runKafkaACLCommand(args);
384
+ }
385
+
386
+ /**
387
+ * Run kafka-acls.sh command
388
+ */
389
+ private async runKafkaACLCommand(args: string[]): Promise<string> {
390
+ const { exec } = require('child_process');
391
+ const { promisify } = require('util');
392
+ const execAsync = promisify(exec);
393
+
394
+ const command = `${this.kafkaHome}/bin/kafka-acls.sh ${args.join(' ')}`;
395
+ const { stdout, stderr } = await execAsync(command);
396
+
397
+ if (stderr) {
398
+ console.error('ACL command stderr:', stderr);
399
+ }
400
+
401
+ return stdout;
402
+ }
403
+ }
404
+
405
+ /**
406
+ * Example Usage: TLS + SASL/SCRAM-SHA-512
407
+ *
408
+ * ```typescript
409
+ * const tls = KafkaSecurityManager.createTLSConfigFromFiles({
410
+ * caPath: './ca-cert.pem',
411
+ * certPath: './client-cert.pem',
412
+ * keyPath: './client-key.pem',
413
+ * });
414
+ *
415
+ * const sasl = KafkaSecurityManager.createSASLScramSHA512Config(
416
+ * 'kafka-user',
417
+ * 'secure-password'
418
+ * );
419
+ *
420
+ * const kafka = KafkaSecurityManager.createSecureKafkaClient({
421
+ * brokers: ['broker1:9093', 'broker2:9093'],
422
+ * clientId: 'secure-client',
423
+ * tls,
424
+ * sasl,
425
+ * });
426
+ * ```
427
+ */
428
+
429
+ /**
430
+ * Example Usage: AWS MSK IAM Authentication
431
+ *
432
+ * ```typescript
433
+ * const sasl = KafkaSecurityManager.createSASLAWSConfig(
434
+ * process.env.AWS_ACCESS_KEY_ID!,
435
+ * process.env.AWS_SECRET_ACCESS_KEY!,
436
+ * 'us-east-1'
437
+ * );
438
+ *
439
+ * const kafka = KafkaSecurityManager.createSecureKafkaClient({
440
+ * brokers: ['b-1.msk-cluster.amazonaws.com:9098'],
441
+ * clientId: 'msk-client',
442
+ * tls: { enabled: true },
443
+ * sasl,
444
+ * });
445
+ * ```
446
+ */
447
+
448
+ /**
449
+ * Example Usage: ACL Management
450
+ *
451
+ * ```typescript
452
+ * const aclManager = new KafkaACLManager('/opt/kafka');
453
+ *
454
+ * // Grant read access to topic
455
+ * await aclManager.createACL({
456
+ * bootstrapServer: 'localhost:9092',
457
+ * acl: {
458
+ * principal: 'User:alice',
459
+ * resourceType: 'TOPIC',
460
+ * resourceName: 'orders',
461
+ * patternType: 'LITERAL',
462
+ * operation: 'READ',
463
+ * permissionType: 'ALLOW',
464
+ * host: '*',
465
+ * },
466
+ * });
467
+ *
468
+ * // Grant write access with prefix matching
469
+ * await aclManager.createACL({
470
+ * bootstrapServer: 'localhost:9092',
471
+ * acl: {
472
+ * principal: 'User:bob',
473
+ * resourceType: 'TOPIC',
474
+ * resourceName: 'analytics-',
475
+ * patternType: 'PREFIXED',
476
+ * operation: 'WRITE',
477
+ * permissionType: 'ALLOW',
478
+ * host: '*',
479
+ * },
480
+ * });
481
+ *
482
+ * // List ACLs
483
+ * const acls = await aclManager.listACLs({
484
+ * bootstrapServer: 'localhost:9092',
485
+ * resourceType: 'TOPIC',
486
+ * });
487
+ * console.log(acls);
488
+ * ```
489
+ */
490
+
491
+ export default {
492
+ KafkaSecurityManager,
493
+ KafkaACLManager,
494
+ };
@@ -0,0 +1,203 @@
1
+ class KafkaCapacityPlanner {
2
+ constructor(constraints = {}) {
3
+ this.constraints = {
4
+ maxPartitionsPerBroker: constraints.maxPartitionsPerBroker || 4e3,
5
+ maxDiskUtilization: constraints.maxDiskUtilization || 70,
6
+ networkBandwidthMBps: constraints.networkBandwidthMBps || 125,
7
+ // 1Gbps
8
+ cpuCoresPerBroker: constraints.cpuCoresPerBroker || 8,
9
+ ramPerBrokerGB: constraints.ramPerBrokerGB || 32
10
+ };
11
+ }
12
+ /**
13
+ * Calculate optimal cluster sizing
14
+ */
15
+ calculateClusterSize(throughput, storage, topicCount = 1) {
16
+ const partitioning = this.calculatePartitionCount(throughput);
17
+ const storageCalc = this.calculateStorageRequirements(
18
+ throughput,
19
+ storage,
20
+ partitioning.partitionCount
21
+ );
22
+ const brokerCountOptions = {
23
+ throughput: this.calculateBrokersForThroughput(throughput),
24
+ storage: this.calculateBrokersForStorage(storageCalc.totalStorageGB),
25
+ partitions: this.calculateBrokersForPartitions(partitioning.partitionCount),
26
+ network: this.calculateBrokersForNetwork(throughput)
27
+ };
28
+ const brokerCount = Math.max(
29
+ brokerCountOptions.throughput,
30
+ brokerCountOptions.storage,
31
+ brokerCountOptions.partitions,
32
+ brokerCountOptions.network,
33
+ 3
34
+ // Minimum for production (quorum)
35
+ );
36
+ const utilization = this.calculateUtilization(
37
+ brokerCount,
38
+ partitioning.partitionCount,
39
+ throughput,
40
+ storageCalc.totalStorageGB
41
+ );
42
+ const warnings = [];
43
+ if (utilization.cpu > 80) {
44
+ warnings.push(`High CPU utilization (${utilization.cpu.toFixed(1)}%) - consider more brokers`);
45
+ }
46
+ if (utilization.disk > this.constraints.maxDiskUtilization) {
47
+ warnings.push(`Disk utilization (${utilization.disk.toFixed(1)}%) exceeds ${this.constraints.maxDiskUtilization}% threshold`);
48
+ }
49
+ if (utilization.network > 70) {
50
+ warnings.push(`Network utilization (${utilization.network.toFixed(1)}%) is high - risk of bottleneck`);
51
+ }
52
+ if (utilization.partitions > 80) {
53
+ warnings.push(`Partition count (${partitioning.partitionCount}) is ${utilization.partitions.toFixed(1)}% of broker capacity`);
54
+ }
55
+ if (brokerCount < 3) {
56
+ warnings.push("Less than 3 brokers - not suitable for production (no fault tolerance)");
57
+ }
58
+ if (partitioning.partitionCount < brokerCount) {
59
+ warnings.push(`Partition count (${partitioning.partitionCount}) < broker count (${brokerCount}) - underutilized`);
60
+ }
61
+ return {
62
+ brokerCount,
63
+ partitionCount: partitioning.partitionCount,
64
+ storagePerBrokerGB: storageCalc.totalStorageGB / brokerCount,
65
+ totalStorageGB: storageCalc.totalStorageGB,
66
+ throughputHeadroom: this.calculateThroughputHeadroom(brokerCount, throughput),
67
+ utilization,
68
+ warnings
69
+ };
70
+ }
71
+ /**
72
+ * Calculate optimal partition count
73
+ */
74
+ calculatePartitionCount(throughput) {
75
+ const reasoning = [];
76
+ const maxThroughputPerPartition = 50;
77
+ const partitionsForProducerThroughput = Math.ceil(
78
+ throughput.producerThroughputMBps / maxThroughputPerPartition
79
+ );
80
+ reasoning.push(
81
+ `Producer throughput: ${throughput.producerThroughputMBps} MB/s \xF7 ${maxThroughputPerPartition} MB/s/partition = ${partitionsForProducerThroughput} partitions`
82
+ );
83
+ const partitionsForConsumerThroughput = Math.ceil(
84
+ throughput.consumerThroughputMBps / maxThroughputPerPartition
85
+ );
86
+ reasoning.push(
87
+ `Consumer throughput: ${throughput.consumerThroughputMBps} MB/s \xF7 ${maxThroughputPerPartition} MB/s/partition = ${partitionsForConsumerThroughput} partitions`
88
+ );
89
+ const targetPartitionSizeGB = 10;
90
+ const minPartitions = Math.max(
91
+ partitionsForProducerThroughput,
92
+ partitionsForConsumerThroughput,
93
+ 1
94
+ // At least 1 partition
95
+ );
96
+ const partitionCount = this.nextPowerOfTwo(minPartitions);
97
+ reasoning.push(`Rounded to power of 2: ${partitionCount} partitions (for even distribution)`);
98
+ return {
99
+ partitionCount,
100
+ maxThroughputPerPartition,
101
+ consumerParallelism: partitionCount,
102
+ partitionSizeGB: targetPartitionSizeGB,
103
+ reasoning
104
+ };
105
+ }
106
+ /**
107
+ * Calculate storage requirements
108
+ */
109
+ calculateStorageRequirements(throughput, storage, partitionCount) {
110
+ const compressionRatio = storage.compressionRatio || 0.3;
111
+ const growthBuffer = storage.growthBuffer || 1.5;
112
+ const dataRateMBps = throughput.producerThroughputMBps;
113
+ const dataRateGBperHour = dataRateMBps * 3.6;
114
+ const rawStorageGB = dataRateGBperHour * storage.retentionHours;
115
+ const compressedStorageGB = rawStorageGB * compressionRatio;
116
+ const replicatedStorageGB = compressedStorageGB * storage.replicationFactor;
117
+ const totalStorageGB = replicatedStorageGB * growthBuffer;
118
+ const storagePerPartitionGB = totalStorageGB / partitionCount;
119
+ return {
120
+ totalStorageGB,
121
+ storagePerPartitionGB,
122
+ rawStorageGB,
123
+ compressedStorageGB
124
+ };
125
+ }
126
+ /**
127
+ * Calculate brokers needed for throughput
128
+ */
129
+ calculateBrokersForThroughput(throughput) {
130
+ const maxBrokerThroughputMBps = 100;
131
+ const totalThroughput = throughput.producerThroughputMBps + throughput.consumerThroughputMBps;
132
+ return Math.ceil(totalThroughput / maxBrokerThroughputMBps);
133
+ }
134
+ /**
135
+ * Calculate brokers needed for storage
136
+ */
137
+ calculateBrokersForStorage(totalStorageGB) {
138
+ const usableStoragePerBrokerGB = 2e3;
139
+ const maxUtilization = this.constraints.maxDiskUtilization / 100;
140
+ const effectiveStoragePerBroker = usableStoragePerBrokerGB * maxUtilization;
141
+ return Math.ceil(totalStorageGB / effectiveStoragePerBroker);
142
+ }
143
+ /**
144
+ * Calculate brokers needed for partition count
145
+ */
146
+ calculateBrokersForPartitions(partitionCount) {
147
+ return Math.ceil(partitionCount / this.constraints.maxPartitionsPerBroker);
148
+ }
149
+ /**
150
+ * Calculate brokers needed for network bandwidth
151
+ */
152
+ calculateBrokersForNetwork(throughput) {
153
+ const totalNetworkMBps = throughput.producerThroughputMBps + throughput.consumerThroughputMBps;
154
+ const maxNetworkUtilization = 0.7;
155
+ const effectiveBandwidth = this.constraints.networkBandwidthMBps * maxNetworkUtilization;
156
+ return Math.ceil(totalNetworkMBps / effectiveBandwidth);
157
+ }
158
+ /**
159
+ * Calculate resource utilization
160
+ */
161
+ calculateUtilization(brokerCount, partitionCount, throughput, totalStorageGB) {
162
+ const totalThroughput = throughput.producerThroughputMBps + throughput.consumerThroughputMBps;
163
+ const cpuPerBroker = totalThroughput / brokerCount / 10 * 5;
164
+ const cpu = Math.min(cpuPerBroker, 100);
165
+ const memoryPerBroker = (2 + partitionCount / brokerCount * 1e-3) / this.constraints.ramPerBrokerGB * 100;
166
+ const memory = Math.min(memoryPerBroker, 100);
167
+ const storagePerBroker = totalStorageGB / brokerCount;
168
+ const disk = storagePerBroker / 2e3 * 100;
169
+ const networkPerBroker = totalThroughput / brokerCount;
170
+ const network = networkPerBroker / this.constraints.networkBandwidthMBps * 100;
171
+ const partitionsPerBroker = partitionCount / brokerCount;
172
+ const partitions = partitionsPerBroker / this.constraints.maxPartitionsPerBroker * 100;
173
+ return {
174
+ cpu: Math.round(cpu * 10) / 10,
175
+ memory: Math.round(memory * 10) / 10,
176
+ disk: Math.round(disk * 10) / 10,
177
+ network: Math.round(network * 10) / 10,
178
+ partitions: Math.round(partitions * 10) / 10
179
+ };
180
+ }
181
+ /**
182
+ * Calculate throughput headroom
183
+ */
184
+ calculateThroughputHeadroom(brokerCount, throughput) {
185
+ const maxClusterThroughput = brokerCount * 100;
186
+ const actualThroughput = throughput.producerThroughputMBps + throughput.consumerThroughputMBps;
187
+ return Math.round((maxClusterThroughput - actualThroughput) / maxClusterThroughput * 100);
188
+ }
189
+ /**
190
+ * Round up to next power of 2
191
+ */
192
+ nextPowerOfTwo(n) {
193
+ if (n <= 1) return 1;
194
+ return Math.pow(2, Math.ceil(Math.log2(n)));
195
+ }
196
+ }
197
+ var capacity_planner_default = {
198
+ KafkaCapacityPlanner
199
+ };
200
+ export {
201
+ KafkaCapacityPlanner,
202
+ capacity_planner_default as default
203
+ };