specweave 0.4.0 → 0.6.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 (411) hide show
  1. package/.claude-plugin/README.md +325 -0
  2. package/.claude-plugin/marketplace.json +210 -0
  3. package/CLAUDE.md +1000 -252
  4. package/README.md +273 -180
  5. package/bin/install-agents.sh +1 -1
  6. package/bin/install-commands.sh +66 -14
  7. package/bin/install-hooks.sh +1 -1
  8. package/bin/install-skills.sh +1 -1
  9. package/bin/specweave.js +18 -0
  10. package/dist/adapters/adapter-base.d.ts +21 -0
  11. package/dist/adapters/adapter-base.d.ts.map +1 -1
  12. package/dist/adapters/adapter-base.js +28 -0
  13. package/dist/adapters/adapter-base.js.map +1 -1
  14. package/dist/adapters/adapter-interface.d.ts +41 -0
  15. package/dist/adapters/adapter-interface.d.ts.map +1 -1
  16. package/dist/adapters/claude/adapter.d.ts +85 -11
  17. package/dist/adapters/claude/adapter.d.ts.map +1 -1
  18. package/dist/adapters/claude/adapter.js +305 -37
  19. package/dist/adapters/claude/adapter.js.map +1 -1
  20. package/dist/adapters/copilot/adapter.d.ts +45 -2
  21. package/dist/adapters/copilot/adapter.d.ts.map +1 -1
  22. package/dist/adapters/copilot/adapter.js +226 -4
  23. package/dist/adapters/copilot/adapter.js.map +1 -1
  24. package/dist/adapters/cursor/adapter.d.ts +54 -0
  25. package/dist/adapters/cursor/adapter.d.ts.map +1 -1
  26. package/dist/adapters/cursor/adapter.js +192 -0
  27. package/dist/adapters/cursor/adapter.js.map +1 -1
  28. package/dist/adapters/generic/adapter.d.ts +43 -0
  29. package/dist/adapters/generic/adapter.d.ts.map +1 -1
  30. package/dist/adapters/generic/adapter.js +163 -0
  31. package/dist/adapters/generic/adapter.js.map +1 -1
  32. package/dist/cli/commands/init.d.ts +1 -0
  33. package/dist/cli/commands/init.d.ts.map +1 -1
  34. package/dist/cli/commands/init.js +392 -123
  35. package/dist/cli/commands/init.js.map +1 -1
  36. package/dist/cli/commands/install.d.ts +2 -0
  37. package/dist/cli/commands/install.d.ts.map +1 -1
  38. package/dist/cli/commands/install.js +28 -25
  39. package/dist/cli/commands/install.js.map +1 -1
  40. package/dist/cli/commands/list.d.ts +2 -0
  41. package/dist/cli/commands/list.d.ts.map +1 -1
  42. package/dist/cli/commands/list.js +26 -24
  43. package/dist/cli/commands/list.js.map +1 -1
  44. package/dist/cli/commands/plugin.d.ts +43 -0
  45. package/dist/cli/commands/plugin.d.ts.map +1 -0
  46. package/dist/cli/commands/plugin.js +307 -0
  47. package/dist/cli/commands/plugin.js.map +1 -0
  48. package/dist/core/i18n/language-detector.d.ts +29 -0
  49. package/dist/core/i18n/language-detector.d.ts.map +1 -0
  50. package/dist/core/i18n/language-detector.js +143 -0
  51. package/dist/core/i18n/language-detector.js.map +1 -0
  52. package/dist/core/i18n/language-manager.d.ts +101 -0
  53. package/dist/core/i18n/language-manager.d.ts.map +1 -0
  54. package/dist/core/i18n/language-manager.js +232 -0
  55. package/dist/core/i18n/language-manager.js.map +1 -0
  56. package/dist/core/i18n/language-registry.d.ts +44 -0
  57. package/dist/core/i18n/language-registry.d.ts.map +1 -0
  58. package/dist/core/i18n/language-registry.js +234 -0
  59. package/dist/core/i18n/language-registry.js.map +1 -0
  60. package/dist/core/i18n/locale-manager.d.ts +62 -0
  61. package/dist/core/i18n/locale-manager.d.ts.map +1 -0
  62. package/dist/core/i18n/locale-manager.js +137 -0
  63. package/dist/core/i18n/locale-manager.js.map +1 -0
  64. package/dist/core/i18n/system-prompt-injector.d.ts +33 -0
  65. package/dist/core/i18n/system-prompt-injector.d.ts.map +1 -0
  66. package/dist/core/i18n/system-prompt-injector.js +131 -0
  67. package/dist/core/i18n/system-prompt-injector.js.map +1 -0
  68. package/dist/core/i18n/types.d.ts +151 -0
  69. package/dist/core/i18n/types.d.ts.map +1 -0
  70. package/dist/core/i18n/types.js +11 -0
  71. package/dist/core/i18n/types.js.map +1 -0
  72. package/dist/core/increment-status.d.ts +72 -0
  73. package/dist/core/increment-status.d.ts.map +1 -0
  74. package/dist/core/increment-status.js +227 -0
  75. package/dist/core/increment-status.js.map +1 -0
  76. package/dist/core/plugin-detector.d.ts +96 -0
  77. package/dist/core/plugin-detector.d.ts.map +1 -0
  78. package/dist/core/plugin-detector.js +349 -0
  79. package/dist/core/plugin-detector.js.map +1 -0
  80. package/dist/core/plugin-loader.d.ts +131 -0
  81. package/dist/core/plugin-loader.d.ts.map +1 -0
  82. package/dist/core/plugin-loader.js +421 -0
  83. package/dist/core/plugin-loader.js.map +1 -0
  84. package/dist/core/plugin-manager.d.ts +144 -0
  85. package/dist/core/plugin-manager.d.ts.map +1 -0
  86. package/dist/core/plugin-manager.js +393 -0
  87. package/dist/core/plugin-manager.js.map +1 -0
  88. package/dist/core/schemas/plugin-manifest.schema.json +253 -0
  89. package/dist/core/types/config.d.ts +51 -0
  90. package/dist/core/types/config.d.ts.map +1 -0
  91. package/dist/core/types/config.js +21 -0
  92. package/dist/core/types/config.js.map +1 -0
  93. package/dist/core/types/plugin.d.ts +283 -0
  94. package/dist/core/types/plugin.d.ts.map +1 -0
  95. package/dist/core/types/plugin.js +49 -0
  96. package/dist/core/types/plugin.js.map +1 -0
  97. package/dist/hooks/lib/sync-living-docs.d.ts +27 -0
  98. package/dist/hooks/lib/sync-living-docs.d.ts.map +1 -0
  99. package/dist/hooks/lib/sync-living-docs.js +116 -0
  100. package/dist/hooks/lib/sync-living-docs.js.map +1 -0
  101. package/dist/hooks/lib/translate-living-docs.d.ts +13 -0
  102. package/dist/hooks/lib/translate-living-docs.d.ts.map +1 -0
  103. package/dist/hooks/lib/translate-living-docs.js +166 -0
  104. package/dist/hooks/lib/translate-living-docs.js.map +1 -0
  105. package/dist/hooks/lib/update-tasks-md.d.ts +29 -0
  106. package/dist/hooks/lib/update-tasks-md.d.ts.map +1 -0
  107. package/dist/hooks/lib/update-tasks-md.js +203 -0
  108. package/dist/hooks/lib/update-tasks-md.js.map +1 -0
  109. package/dist/integrations/jira/jira-incremental-mapper.js.map +1 -1
  110. package/dist/integrations/jira/jira-mapper.d.ts +2 -2
  111. package/dist/integrations/jira/jira-mapper.js +2 -2
  112. package/dist/integrations/jira/jira-mapper.js.map +1 -1
  113. package/dist/locales/de/.gitkeep +0 -0
  114. package/dist/locales/de/cli.json +108 -0
  115. package/dist/locales/en/cli.json +269 -0
  116. package/dist/locales/en/errors.json +7 -0
  117. package/dist/locales/en/templates.json +6 -0
  118. package/dist/locales/es/.gitkeep +0 -0
  119. package/dist/locales/es/cli.json +41 -0
  120. package/dist/locales/fr/.gitkeep +0 -0
  121. package/dist/locales/fr/cli.json +108 -0
  122. package/dist/locales/ja/.gitkeep +0 -0
  123. package/dist/locales/ja/cli.json +108 -0
  124. package/dist/locales/ko/.gitkeep +0 -0
  125. package/dist/locales/ko/cli.json +108 -0
  126. package/dist/locales/pt/.gitkeep +0 -0
  127. package/dist/locales/pt/cli.json +108 -0
  128. package/dist/locales/ru/.gitkeep +0 -0
  129. package/dist/locales/ru/cli.json +269 -0
  130. package/dist/locales/zh/.gitkeep +0 -0
  131. package/dist/locales/zh/cli.json +108 -0
  132. package/dist/plugins/specweave-github/lib/github-client.d.ts +86 -0
  133. package/dist/plugins/specweave-github/lib/github-client.d.ts.map +1 -0
  134. package/dist/plugins/specweave-github/lib/github-client.js +275 -0
  135. package/dist/plugins/specweave-github/lib/github-client.js.map +1 -0
  136. package/dist/plugins/specweave-github/lib/index.d.ts +10 -0
  137. package/dist/plugins/specweave-github/lib/index.d.ts.map +1 -0
  138. package/dist/plugins/specweave-github/lib/index.js +10 -0
  139. package/dist/plugins/specweave-github/lib/index.js.map +1 -0
  140. package/dist/plugins/specweave-github/lib/subtask-sync.d.ts +51 -0
  141. package/dist/plugins/specweave-github/lib/subtask-sync.d.ts.map +1 -0
  142. package/dist/plugins/specweave-github/lib/subtask-sync.js +147 -0
  143. package/dist/plugins/specweave-github/lib/subtask-sync.js.map +1 -0
  144. package/dist/plugins/specweave-github/lib/task-parser.d.ts +37 -0
  145. package/dist/plugins/specweave-github/lib/task-parser.d.ts.map +1 -0
  146. package/dist/plugins/specweave-github/lib/task-parser.js +211 -0
  147. package/dist/plugins/specweave-github/lib/task-parser.js.map +1 -0
  148. package/dist/plugins/specweave-github/lib/task-sync.d.ts +51 -0
  149. package/dist/plugins/specweave-github/lib/task-sync.d.ts.map +1 -0
  150. package/dist/plugins/specweave-github/lib/task-sync.js +332 -0
  151. package/dist/plugins/specweave-github/lib/task-sync.js.map +1 -0
  152. package/dist/plugins/specweave-github/lib/types.d.ts +80 -0
  153. package/dist/plugins/specweave-github/lib/types.d.ts.map +1 -0
  154. package/dist/plugins/specweave-github/lib/types.js +5 -0
  155. package/dist/plugins/specweave-github/lib/types.js.map +1 -0
  156. package/dist/utils/agents-md-compiler.d.ts +68 -0
  157. package/dist/utils/agents-md-compiler.d.ts.map +1 -0
  158. package/dist/utils/agents-md-compiler.js +420 -0
  159. package/dist/utils/agents-md-compiler.js.map +1 -0
  160. package/dist/utils/generate-skills-index.js +4 -4
  161. package/dist/utils/generate-skills-index.js.map +1 -1
  162. package/package.json +24 -21
  163. package/plugins/specweave-ado/.claude-plugin/plugin.json +8 -0
  164. package/plugins/specweave-alternatives/.claude-plugin/plugin.json +8 -0
  165. package/plugins/specweave-alternatives/skills/bmad-method-expert/SKILL.md +626 -0
  166. package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/analyze-project.js +318 -0
  167. package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/check-setup.js +208 -0
  168. package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/generate-template.js +1149 -0
  169. package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/validate-documents.js +340 -0
  170. package/plugins/specweave-alternatives/skills/spec-kit-expert/SKILL.md +1010 -0
  171. package/plugins/specweave-backend/.claude-plugin/plugin.json +8 -0
  172. package/plugins/specweave-core/.claude-plugin/plugin.json +25 -0
  173. package/{src → plugins/specweave-core}/agents/pm/AGENT.md +80 -0
  174. package/plugins/specweave-core/agents/translator/AGENT.md +282 -0
  175. package/{src → plugins/specweave-core}/commands/README.md +11 -11
  176. package/{src → plugins/specweave-core}/commands/specweave.costs.md +7 -7
  177. package/{src → plugins/specweave-core}/commands/specweave.do.md +34 -7
  178. package/{src → plugins/specweave-core}/commands/specweave.increment.md +131 -22
  179. package/{src → plugins/specweave-core}/commands/specweave.md +49 -17
  180. package/{src → plugins/specweave-core}/commands/specweave.sync-docs.md +5 -5
  181. package/plugins/specweave-core/commands/specweave.translate.md +425 -0
  182. package/{src → plugins/specweave-core}/commands/specweave.validate.md +1 -1
  183. package/plugins/specweave-core/hooks/hooks.json +13 -0
  184. package/plugins/specweave-core/hooks/post-increment-plugin-detect.sh +142 -0
  185. package/plugins/specweave-core/hooks/post-task-completion.sh +265 -0
  186. package/plugins/specweave-core/hooks/pre-task-plugin-detect.sh +96 -0
  187. package/plugins/specweave-core/skills/SKILLS-INDEX.md +229 -0
  188. package/{src → plugins/specweave-core}/skills/brownfield-analyzer/SKILL.md +66 -24
  189. package/{src → plugins/specweave-core}/skills/context-loader/SKILL.md +1 -1
  190. package/plugins/specweave-core/skills/context-optimizer/SKILL.md +588 -0
  191. package/plugins/specweave-core/skills/docs-updater/SKILL.md +0 -0
  192. package/{src → plugins/specweave-core}/skills/increment-planner/SKILL.md +81 -4
  193. package/plugins/specweave-core/skills/plugin-detector/SKILL.md +211 -0
  194. package/{src → plugins/specweave-core}/skills/project-kickstarter/SKILL.md +7 -7
  195. package/plugins/specweave-core/skills/rfc-generator/SKILL.md +369 -0
  196. package/{src → plugins/specweave-core}/skills/specweave-detector/SKILL.md +2 -2
  197. package/plugins/specweave-core/skills/specweave-framework/SKILL.md +498 -0
  198. package/plugins/specweave-core/skills/specweave-framework/test-cases/test-1-increment-naming.yaml +11 -0
  199. package/plugins/specweave-core/skills/specweave-framework/test-cases/test-2-source-of-truth.yaml +11 -0
  200. package/plugins/specweave-core/skills/specweave-framework/test-cases/test-3-increment-discipline.yaml +12 -0
  201. package/plugins/specweave-core/skills/specweave-framework/test-cases/test-4-file-placement.yaml +11 -0
  202. package/{src → plugins/specweave-core}/skills/tdd-workflow/SKILL.md +20 -20
  203. package/plugins/specweave-core/skills/translator/SKILL.md +172 -0
  204. package/plugins/specweave-cost-optimizer/.claude-plugin/plugin.json +8 -0
  205. package/plugins/specweave-diagrams/.claude-plugin/plugin.json +8 -0
  206. package/plugins/specweave-docs/.claude-plugin/plugin.json +8 -0
  207. package/plugins/specweave-docs/skills/docusaurus/SKILL.md +526 -0
  208. package/plugins/specweave-figma/.claude-plugin/.mcp.json +12 -0
  209. package/plugins/specweave-figma/.claude-plugin/plugin.json +8 -0
  210. package/plugins/specweave-figma/ARCHITECTURE.md +453 -0
  211. package/plugins/specweave-figma/README.md +728 -0
  212. package/plugins/specweave-figma/skills/figma-to-code/SKILL.md +632 -0
  213. package/plugins/specweave-figma/skills/figma-to-code/test-1-token-generation.yaml +29 -0
  214. package/plugins/specweave-figma/skills/figma-to-code/test-2-component-generation.yaml +27 -0
  215. package/plugins/specweave-figma/skills/figma-to-code/test-3-typescript-generation.yaml +28 -0
  216. package/plugins/specweave-frontend/.claude-plugin/plugin.json +8 -0
  217. package/plugins/specweave-github/.claude-plugin/plugin.json +8 -0
  218. package/plugins/specweave-github/agents/github-manager/AGENT.md +651 -0
  219. package/plugins/specweave-github/commands/github-close-issue.md +418 -0
  220. package/plugins/specweave-github/commands/github-create-issue.md +307 -0
  221. package/plugins/specweave-github/commands/github-status.md +533 -0
  222. package/plugins/specweave-github/commands/github-sync-tasks.md +530 -0
  223. package/plugins/specweave-github/commands/github-sync.md +443 -0
  224. package/plugins/specweave-github/lib/github-client.ts +330 -0
  225. package/plugins/specweave-github/lib/index.ts +10 -0
  226. package/plugins/specweave-github/lib/subtask-sync.ts +225 -0
  227. package/plugins/specweave-github/lib/task-parser.ts +246 -0
  228. package/plugins/specweave-github/lib/task-sync.ts +402 -0
  229. package/plugins/specweave-github/lib/types.ts +86 -0
  230. package/plugins/specweave-github/skills/github-issue-tracker/SKILL.md +497 -0
  231. package/plugins/specweave-github/skills/github-sync/SKILL.md +461 -0
  232. package/plugins/specweave-infrastructure/.claude-plugin/plugin.json +8 -0
  233. package/plugins/specweave-jira/.claude-plugin/plugin.json +8 -0
  234. package/{src → plugins/specweave-jira}/commands/specweave.sync-jira.md +18 -18
  235. package/plugins/specweave-kubernetes/.claude-plugin/plugin.json +8 -0
  236. package/plugins/specweave-ml/.claude-plugin/plugin.json +39 -0
  237. package/plugins/specweave-ml/README.md +885 -0
  238. package/plugins/specweave-ml/agents/ml-engineer/AGENT.md +402 -0
  239. package/plugins/specweave-ml/commands/ml-deploy.md +116 -0
  240. package/plugins/specweave-ml/commands/ml-evaluate.md +87 -0
  241. package/plugins/specweave-ml/commands/ml-explain.md +83 -0
  242. package/plugins/specweave-ml/skills/anomaly-detector/SKILL.md +559 -0
  243. package/plugins/specweave-ml/skills/automl-optimizer/SKILL.md +485 -0
  244. package/plugins/specweave-ml/skills/cv-pipeline-builder/SKILL.md +157 -0
  245. package/plugins/specweave-ml/skills/data-visualizer/SKILL.md +521 -0
  246. package/plugins/specweave-ml/skills/experiment-tracker/SKILL.md +535 -0
  247. package/plugins/specweave-ml/skills/feature-engineer/SKILL.md +566 -0
  248. package/plugins/specweave-ml/skills/ml-deployment-helper/SKILL.md +345 -0
  249. package/plugins/specweave-ml/skills/ml-pipeline-orchestrator/SKILL.md +518 -0
  250. package/plugins/specweave-ml/skills/model-evaluator/SKILL.md +155 -0
  251. package/plugins/specweave-ml/skills/model-explainer/SKILL.md +227 -0
  252. package/plugins/specweave-ml/skills/model-registry/SKILL.md +541 -0
  253. package/plugins/specweave-ml/skills/nlp-pipeline-builder/SKILL.md +180 -0
  254. package/plugins/specweave-ml/skills/time-series-forecaster/SKILL.md +569 -0
  255. package/plugins/specweave-payments/.claude-plugin/plugin.json +8 -0
  256. package/plugins/specweave-testing/.claude-plugin/plugin.json +8 -0
  257. package/plugins/specweave-tooling/.claude-plugin/plugin.json +8 -0
  258. package/plugins/specweave-ui/.claude-plugin/plugin.json +106 -0
  259. package/plugins/specweave-ui/.mcp.json +14 -0
  260. package/plugins/specweave-ui/README.md +386 -0
  261. package/src/adapters/adapter-base.ts +33 -0
  262. package/src/adapters/adapter-interface.ts +46 -0
  263. package/src/adapters/claude/adapter.ts +350 -39
  264. package/src/adapters/copilot/adapter.ts +267 -4
  265. package/src/adapters/cursor/adapter.ts +229 -0
  266. package/src/adapters/generic/adapter.ts +196 -0
  267. package/src/templates/AGENTS.md.template +170 -1
  268. package/src/templates/CLAUDE.md.template +122 -24
  269. package/src/templates/tasks.md.template +261 -0
  270. package/src/agents/ml-engineer/AGENT.md +0 -150
  271. package/src/commands/specweave.sync-github.md +0 -269
  272. package/src/hooks/post-task-completion.sh +0 -79
  273. package/src/skills/SKILLS-INDEX.md +0 -444
  274. package/src/skills/github-sync/SKILL.md +0 -234
  275. /package/{src → plugins/specweave-ado}/skills/ado-sync/README.md +0 -0
  276. /package/{src → plugins/specweave-ado}/skills/ado-sync/SKILL.md +0 -0
  277. /package/{src → plugins/specweave-ado}/skills/specweave-ado-mapper/SKILL.md +0 -0
  278. /package/{src → plugins/specweave-backend}/agents/database-optimizer/AGENT.md +0 -0
  279. /package/{src → plugins/specweave-backend}/skills/dotnet-backend/SKILL.md +0 -0
  280. /package/{src → plugins/specweave-backend}/skills/nodejs-backend/SKILL.md +0 -0
  281. /package/{src → plugins/specweave-backend}/skills/python-backend/SKILL.md +0 -0
  282. /package/{src → plugins/specweave-core}/agents/architect/AGENT.md +0 -0
  283. /package/{src → plugins/specweave-core}/agents/code-reviewer.md +0 -0
  284. /package/{src → plugins/specweave-core}/agents/docs-writer/AGENT.md +0 -0
  285. /package/{src → plugins/specweave-core}/agents/performance/AGENT.md +0 -0
  286. /package/{src → plugins/specweave-core}/agents/qa-lead/AGENT.md +0 -0
  287. /package/{src → plugins/specweave-core}/agents/security/AGENT.md +0 -0
  288. /package/{src → plugins/specweave-core}/agents/tdd-orchestrator/AGENT.md +0 -0
  289. /package/{src → plugins/specweave-core}/agents/tech-lead/AGENT.md +0 -0
  290. /package/{src → plugins/specweave-core}/commands/specweave.done.md +0 -0
  291. /package/{src → plugins/specweave-core}/commands/specweave.inc.md +0 -0
  292. /package/{src → plugins/specweave-core}/commands/specweave.list-increments.md +0 -0
  293. /package/{src → plugins/specweave-core}/commands/specweave.next.md +0 -0
  294. /package/{src → plugins/specweave-core}/commands/specweave.progress.md +0 -0
  295. /package/{src → plugins/specweave-core}/commands/specweave.tdd-cycle.md +0 -0
  296. /package/{src → plugins/specweave-core}/commands/specweave.tdd-green.md +0 -0
  297. /package/{src → plugins/specweave-core}/commands/specweave.tdd-red.md +0 -0
  298. /package/{src → plugins/specweave-core}/commands/specweave.tdd-refactor.md +0 -0
  299. /package/{src → plugins/specweave-core}/hooks/README.md +0 -0
  300. /package/{src → plugins/specweave-core}/hooks/docs-changed.sh +0 -0
  301. /package/{src → plugins/specweave-core}/hooks/human-input-required.sh +0 -0
  302. /package/{src → plugins/specweave-core}/hooks/pre-implementation.sh +0 -0
  303. /package/{src → plugins/specweave-core}/skills/brownfield-onboarder/SKILL.md +0 -0
  304. /package/{src → plugins/specweave-core}/skills/docs-updater/README.md +0 -0
  305. /package/{src → plugins/specweave-core}/skills/increment-planner/scripts/feature-utils.js +0 -0
  306. /package/{src → plugins/specweave-core}/skills/increment-quality-judge/SKILL.md +0 -0
  307. /package/{src → plugins/specweave-core}/skills/project-kickstarter/test-cases/test-1-high-confidence-full-product.yaml +0 -0
  308. /package/{src → plugins/specweave-core}/skills/project-kickstarter/test-cases/test-2-medium-confidence-partial.yaml +0 -0
  309. /package/{src → plugins/specweave-core}/skills/project-kickstarter/test-cases/test-3-low-confidence-technical-question.yaml +0 -0
  310. /package/{src → plugins/specweave-core}/skills/project-kickstarter/test-cases/test-4-opt-out-explicit.yaml +0 -0
  311. /package/{src → plugins/specweave-core}/skills/role-orchestrator/README.md +0 -0
  312. /package/{src → plugins/specweave-core}/skills/role-orchestrator/SKILL.md +0 -0
  313. /package/{src → plugins/specweave-core}/skills/task-builder/README.md +0 -0
  314. /package/{src → plugins/specweave-cost-optimizer}/skills/cost-optimizer/SKILL.md +0 -0
  315. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/AGENT.md +0 -0
  316. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/templates/c4-component-template.mmd +0 -0
  317. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/templates/c4-container-template.mmd +0 -0
  318. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/templates/c4-context-template.mmd +0 -0
  319. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/templates/deployment-template.mmd +0 -0
  320. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/templates/er-diagram-template.mmd +0 -0
  321. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/templates/sequence-template.mmd +0 -0
  322. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/test-cases/test-1-c4-context.yaml +0 -0
  323. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/test-cases/test-2-sequence.yaml +0 -0
  324. /package/{src → plugins/specweave-diagrams}/agents/diagrams-architect/test-cases/test-3-er-diagram.yaml +0 -0
  325. /package/{src → plugins/specweave-diagrams}/skills/diagrams-architect/SKILL.md +0 -0
  326. /package/{src → plugins/specweave-diagrams}/skills/diagrams-generator/SKILL.md +0 -0
  327. /package/{src → plugins/specweave-docs}/skills/spec-driven-brainstorming/README.md +0 -0
  328. /package/{src → plugins/specweave-docs}/skills/spec-driven-brainstorming/SKILL.md +0 -0
  329. /package/{src → plugins/specweave-docs}/skills/spec-driven-debugging/README.md +0 -0
  330. /package/{src → plugins/specweave-docs}/skills/spec-driven-debugging/SKILL.md +0 -0
  331. /package/{src → plugins/specweave-frontend}/skills/design-system-architect/SKILL.md +0 -0
  332. /package/{src → plugins/specweave-frontend}/skills/frontend/SKILL.md +0 -0
  333. /package/{src → plugins/specweave-frontend}/skills/nextjs/SKILL.md +0 -0
  334. /package/{src → plugins/specweave-infrastructure}/agents/devops/AGENT.md +0 -0
  335. /package/{src → plugins/specweave-infrastructure}/agents/network-engineer/AGENT.md +0 -0
  336. /package/{src → plugins/specweave-infrastructure}/agents/observability-engineer/AGENT.md +0 -0
  337. /package/{src → plugins/specweave-infrastructure}/agents/performance-engineer/AGENT.md +0 -0
  338. /package/{src → plugins/specweave-infrastructure}/agents/sre/AGENT.md +0 -0
  339. /package/{src → plugins/specweave-infrastructure}/agents/sre/modules/backend-diagnostics.md +0 -0
  340. /package/{src → plugins/specweave-infrastructure}/agents/sre/modules/database-diagnostics.md +0 -0
  341. /package/{src → plugins/specweave-infrastructure}/agents/sre/modules/infrastructure.md +0 -0
  342. /package/{src → plugins/specweave-infrastructure}/agents/sre/modules/monitoring.md +0 -0
  343. /package/{src → plugins/specweave-infrastructure}/agents/sre/modules/security-incidents.md +0 -0
  344. /package/{src → plugins/specweave-infrastructure}/agents/sre/modules/ui-diagnostics.md +0 -0
  345. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/01-high-cpu-usage.md +0 -0
  346. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/02-database-deadlock.md +0 -0
  347. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/03-memory-leak.md +0 -0
  348. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/04-slow-api-response.md +0 -0
  349. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/05-ddos-attack.md +0 -0
  350. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/06-disk-full.md +0 -0
  351. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/07-service-down.md +0 -0
  352. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/08-data-corruption.md +0 -0
  353. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/09-cascade-failure.md +0 -0
  354. /package/{src → plugins/specweave-infrastructure}/agents/sre/playbooks/10-rate-limit-exceeded.md +0 -0
  355. /package/{src → plugins/specweave-infrastructure}/agents/sre/scripts/health-check.sh +0 -0
  356. /package/{src → plugins/specweave-infrastructure}/agents/sre/scripts/log-analyzer.py +0 -0
  357. /package/{src → plugins/specweave-infrastructure}/agents/sre/scripts/metrics-collector.sh +0 -0
  358. /package/{src → plugins/specweave-infrastructure}/agents/sre/scripts/trace-analyzer.js +0 -0
  359. /package/{src → plugins/specweave-infrastructure}/agents/sre/templates/incident-report.md +0 -0
  360. /package/{src → plugins/specweave-infrastructure}/agents/sre/templates/mitigation-plan.md +0 -0
  361. /package/{src → plugins/specweave-infrastructure}/agents/sre/templates/post-mortem.md +0 -0
  362. /package/{src → plugins/specweave-infrastructure}/agents/sre/templates/runbook-template.md +0 -0
  363. /package/{src → plugins/specweave-infrastructure}/commands/specweave.monitor-setup.md +0 -0
  364. /package/{src → plugins/specweave-infrastructure}/commands/specweave.slo-implement.md +0 -0
  365. /package/{src → plugins/specweave-infrastructure}/skills/distributed-tracing/SKILL.md +0 -0
  366. /package/{src → plugins/specweave-infrastructure}/skills/grafana-dashboards/SKILL.md +0 -0
  367. /package/{src → plugins/specweave-infrastructure}/skills/hetzner-provisioner/README.md +0 -0
  368. /package/{src → plugins/specweave-infrastructure}/skills/hetzner-provisioner/SKILL.md +0 -0
  369. /package/{src → plugins/specweave-infrastructure}/skills/prometheus-configuration/SKILL.md +0 -0
  370. /package/{src → plugins/specweave-infrastructure}/skills/slo-implementation/SKILL.md +0 -0
  371. /package/{src → plugins/specweave-jira}/skills/jira-sync/README.md +0 -0
  372. /package/{src → plugins/specweave-jira}/skills/jira-sync/SKILL.md +0 -0
  373. /package/{src → plugins/specweave-jira}/skills/specweave-jira-mapper/SKILL.md +0 -0
  374. /package/{src → plugins/specweave-kubernetes}/agents/kubernetes-architect/AGENT.md +0 -0
  375. /package/{src → plugins/specweave-kubernetes}/skills/gitops-workflow/SKILL.md +0 -0
  376. /package/{src → plugins/specweave-kubernetes}/skills/gitops-workflow/references/argocd-setup.md +0 -0
  377. /package/{src → plugins/specweave-kubernetes}/skills/gitops-workflow/references/sync-policies.md +0 -0
  378. /package/{src → plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/SKILL.md +0 -0
  379. /package/{src → plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/assets/Chart.yaml.template +0 -0
  380. /package/{src → plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/assets/values.yaml.template +0 -0
  381. /package/{src → plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/references/chart-structure.md +0 -0
  382. /package/{src → plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/scripts/validate-chart.sh +0 -0
  383. /package/{src → plugins/specweave-kubernetes}/skills/k8s-manifest-generator/SKILL.md +0 -0
  384. /package/{src → plugins/specweave-kubernetes}/skills/k8s-manifest-generator/assets/configmap-template.yaml +0 -0
  385. /package/{src → plugins/specweave-kubernetes}/skills/k8s-manifest-generator/assets/deployment-template.yaml +0 -0
  386. /package/{src → plugins/specweave-kubernetes}/skills/k8s-manifest-generator/assets/service-template.yaml +0 -0
  387. /package/{src → plugins/specweave-kubernetes}/skills/k8s-manifest-generator/references/deployment-spec.md +0 -0
  388. /package/{src → plugins/specweave-kubernetes}/skills/k8s-manifest-generator/references/service-spec.md +0 -0
  389. /package/{src → plugins/specweave-kubernetes}/skills/k8s-security-policies/SKILL.md +0 -0
  390. /package/{src → plugins/specweave-kubernetes}/skills/k8s-security-policies/assets/network-policy-template.yaml +0 -0
  391. /package/{src → plugins/specweave-kubernetes}/skills/k8s-security-policies/references/rbac-patterns.md +0 -0
  392. /package/{src → plugins/specweave-ml}/agents/data-scientist/AGENT.md +0 -0
  393. /package/{src → plugins/specweave-ml}/agents/mlops-engineer/AGENT.md +0 -0
  394. /package/{src → plugins/specweave-ml}/commands/specweave.ml-pipeline.md +0 -0
  395. /package/{src → plugins/specweave-ml}/skills/ml-pipeline-workflow/SKILL.md +0 -0
  396. /package/{src → plugins/specweave-payments}/agents/payment-integration/AGENT.md +0 -0
  397. /package/{src → plugins/specweave-payments}/skills/billing-automation/SKILL.md +0 -0
  398. /package/{src → plugins/specweave-payments}/skills/paypal-integration/SKILL.md +0 -0
  399. /package/{src → plugins/specweave-payments}/skills/pci-compliance/SKILL.md +0 -0
  400. /package/{src → plugins/specweave-payments}/skills/stripe-integration/SKILL.md +0 -0
  401. /package/{src → plugins/specweave-testing}/skills/e2e-playwright/README.md +0 -0
  402. /package/{src → plugins/specweave-testing}/skills/e2e-playwright/SKILL.md +0 -0
  403. /package/{src → plugins/specweave-testing}/skills/e2e-playwright/execute.js +0 -0
  404. /package/{src → plugins/specweave-testing}/skills/e2e-playwright/lib/utils.js +0 -0
  405. /package/{src → plugins/specweave-testing}/skills/e2e-playwright/package.json +0 -0
  406. /package/{src → plugins/specweave-tooling}/skills/skill-creator/LICENSE.txt +0 -0
  407. /package/{src → plugins/specweave-tooling}/skills/skill-creator/SKILL.md +0 -0
  408. /package/{src → plugins/specweave-tooling}/skills/skill-creator/scripts/init_skill.py +0 -0
  409. /package/{src → plugins/specweave-tooling}/skills/skill-creator/scripts/package_skill.py +0 -0
  410. /package/{src → plugins/specweave-tooling}/skills/skill-creator/scripts/quick_validate.py +0 -0
  411. /package/{src → plugins/specweave-tooling}/skills/skill-router/SKILL.md +0 -0
@@ -0,0 +1,330 @@
1
+ /**
2
+ * GitHub CLI wrapper for SpecWeave
3
+ * Uses `gh` command for GitHub API operations
4
+ */
5
+
6
+ import { execSync } from 'child_process';
7
+ import { GitHubIssue, GitHubMilestone } from './types';
8
+
9
+ export class GitHubClient {
10
+ private repo: string;
11
+
12
+ constructor(repo?: string) {
13
+ // Auto-detect repo from git remote if not provided
14
+ this.repo = repo || this.detectRepo();
15
+ }
16
+
17
+ /**
18
+ * Auto-detect GitHub repository from git remote
19
+ */
20
+ private detectRepo(): string {
21
+ try {
22
+ const remote = execSync('git remote get-url origin', { encoding: 'utf-8' }).trim();
23
+ const match = remote.match(/github\.com[:/](.+\/.+?)(?:\.git)?$/);
24
+ if (!match) {
25
+ throw new Error('Could not detect GitHub repository from git remote');
26
+ }
27
+ return match[1];
28
+ } catch (error) {
29
+ throw new Error('Not a git repository or no GitHub remote configured');
30
+ }
31
+ }
32
+
33
+ /**
34
+ * Check if GitHub CLI is installed and authenticated
35
+ */
36
+ static checkGitHubCLI(): { installed: boolean; authenticated: boolean; error?: string } {
37
+ try {
38
+ execSync('gh --version', { encoding: 'utf-8', stdio: 'pipe' });
39
+ } catch {
40
+ return { installed: false, authenticated: false, error: 'GitHub CLI (gh) not installed' };
41
+ }
42
+
43
+ try {
44
+ execSync('gh auth status', { encoding: 'utf-8', stdio: 'pipe' });
45
+ return { installed: true, authenticated: true };
46
+ } catch {
47
+ return { installed: true, authenticated: false, error: 'GitHub CLI not authenticated. Run: gh auth login' };
48
+ }
49
+ }
50
+
51
+ /**
52
+ * Create or get existing milestone
53
+ *
54
+ * @param title Milestone title
55
+ * @param description Milestone description
56
+ * @param daysFromNow Days until milestone due (default: 2 days - SpecWeave AI velocity)
57
+ */
58
+ async createOrGetMilestone(
59
+ title: string,
60
+ description?: string,
61
+ daysFromNow: number = 2
62
+ ): Promise<GitHubMilestone> {
63
+ // Check if milestone already exists
64
+ const existing = await this.getMilestoneByTitle(title);
65
+ if (existing) {
66
+ return existing;
67
+ }
68
+
69
+ // Calculate due date (SpecWeave default: 1-2 days with AI assistance)
70
+ const dueDate = new Date();
71
+ dueDate.setDate(dueDate.getDate() + daysFromNow);
72
+ const dueDateISO = dueDate.toISOString();
73
+
74
+ // Create new milestone with due date
75
+ const cmd = `gh api repos/${this.repo}/milestones -f title="${title}" ${description ? `-f description="${description}"` : ''} -f due_on="${dueDateISO}" --jq '{number: .number, title: .title, description: .description, state: .state, due_on: .due_on}'`;
76
+
77
+ try {
78
+ const output = execSync(cmd, { encoding: 'utf-8' });
79
+ return JSON.parse(output);
80
+ } catch (error: any) {
81
+ throw new Error(`Failed to create milestone: ${error.message}`);
82
+ }
83
+ }
84
+
85
+ /**
86
+ * Get milestone by title
87
+ */
88
+ private async getMilestoneByTitle(title: string): Promise<GitHubMilestone | null> {
89
+ try {
90
+ const cmd = `gh api repos/${this.repo}/milestones --jq '.[] | select(.title=="${title}") | {number: .number, title: .title, description: .description, state: .state}'`;
91
+ const output = execSync(cmd, { encoding: 'utf-8' }).trim();
92
+ return output ? JSON.parse(output) : null;
93
+ } catch {
94
+ return null;
95
+ }
96
+ }
97
+
98
+ /**
99
+ * Create epic issue (increment-level)
100
+ */
101
+ async createEpicIssue(
102
+ title: string,
103
+ body: string,
104
+ milestone?: number | string,
105
+ labels: string[] = []
106
+ ): Promise<GitHubIssue> {
107
+ const labelArgs = labels.map(l => `-l "${l}"`).join(' ');
108
+ const milestoneArg = milestone ? `-m "${milestone}"` : '';
109
+
110
+ // Create issue (returns URL)
111
+ const createCmd = `gh issue create --repo ${this.repo} --title "${this.escapeQuotes(title)}" --body "${this.escapeQuotes(body)}" ${labelArgs} ${milestoneArg}`;
112
+
113
+ try {
114
+ const issueUrl = execSync(createCmd, { encoding: 'utf-8' }).trim();
115
+
116
+ // Extract issue number from URL (e.g., https://github.com/owner/repo/issues/123)
117
+ const issueNumber = parseInt(issueUrl.split('/').pop() || '0', 10);
118
+
119
+ if (!issueNumber) {
120
+ throw new Error('Failed to extract issue number from URL: ' + issueUrl);
121
+ }
122
+
123
+ // Fetch issue details
124
+ const viewCmd = `gh issue view ${issueNumber} --repo ${this.repo} --json number,title,body,state,url,labels,milestone`;
125
+ const output = execSync(viewCmd, { encoding: 'utf-8' });
126
+ const issue = JSON.parse(output);
127
+
128
+ return {
129
+ ...issue,
130
+ html_url: issue.url,
131
+ labels: issue.labels?.map((l: any) => l.name) || []
132
+ };
133
+ } catch (error: any) {
134
+ throw new Error(`Failed to create epic issue: ${error.message}`);
135
+ }
136
+ }
137
+
138
+ /**
139
+ * Create task issue (linked to epic)
140
+ */
141
+ async createTaskIssue(
142
+ title: string,
143
+ body: string,
144
+ epicNumber: number,
145
+ milestone?: number | string,
146
+ labels: string[] = []
147
+ ): Promise<GitHubIssue> {
148
+ // Add epic reference to body
149
+ const enhancedBody = `**Part of**: #${epicNumber}\n\n${body}`;
150
+
151
+ const labelArgs = labels.map(l => `-l "${l}"`).join(' ');
152
+ const milestoneArg = milestone ? `-m "${milestone}"` : '';
153
+
154
+ // Create issue (returns URL)
155
+ const createCmd = `gh issue create --repo ${this.repo} --title "${this.escapeQuotes(title)}" --body "${this.escapeQuotes(enhancedBody)}" ${labelArgs} ${milestoneArg}`;
156
+
157
+ try {
158
+ const issueUrl = execSync(createCmd, { encoding: 'utf-8' }).trim();
159
+
160
+ // Extract issue number from URL
161
+ const issueNumber = parseInt(issueUrl.split('/').pop() || '0', 10);
162
+
163
+ if (!issueNumber) {
164
+ throw new Error('Failed to extract issue number from URL: ' + issueUrl);
165
+ }
166
+
167
+ // Fetch issue details
168
+ const viewCmd = `gh issue view ${issueNumber} --repo ${this.repo} --json number,title,body,state,url,labels,milestone`;
169
+ const output = execSync(viewCmd, { encoding: 'utf-8' });
170
+ const issue = JSON.parse(output);
171
+
172
+ return {
173
+ ...issue,
174
+ html_url: issue.url,
175
+ labels: issue.labels?.map((l: any) => l.name) || []
176
+ };
177
+ } catch (error: any) {
178
+ throw new Error(`Failed to create task issue: ${error.message}`);
179
+ }
180
+ }
181
+
182
+ /**
183
+ * Update issue body
184
+ */
185
+ async updateIssueBody(issueNumber: number, newBody: string): Promise<void> {
186
+ const cmd = `gh issue edit ${issueNumber} --repo ${this.repo} --body "${this.escapeQuotes(newBody)}"`;
187
+
188
+ try {
189
+ execSync(cmd, { encoding: 'utf-8', stdio: 'pipe' });
190
+ } catch (error: any) {
191
+ throw new Error(`Failed to update issue #${issueNumber}: ${error.message}`);
192
+ }
193
+ }
194
+
195
+ /**
196
+ * Get issue details
197
+ */
198
+ async getIssue(issueNumber: number): Promise<GitHubIssue> {
199
+ const cmd = `gh issue view ${issueNumber} --repo ${this.repo} --json number,title,body,state,html_url,labels,milestone`;
200
+
201
+ try {
202
+ const output = execSync(cmd, { encoding: 'utf-8' });
203
+ const issue = JSON.parse(output);
204
+ return {
205
+ ...issue,
206
+ labels: issue.labels?.map((l: any) => l.name) || []
207
+ };
208
+ } catch (error: any) {
209
+ throw new Error(`Failed to get issue #${issueNumber}: ${error.message}`);
210
+ }
211
+ }
212
+
213
+ /**
214
+ * Close issue
215
+ */
216
+ async closeIssue(issueNumber: number, comment?: string): Promise<void> {
217
+ if (comment) {
218
+ await this.addComment(issueNumber, comment);
219
+ }
220
+
221
+ const cmd = `gh issue close ${issueNumber} --repo ${this.repo}`;
222
+
223
+ try {
224
+ execSync(cmd, { encoding: 'utf-8', stdio: 'pipe' });
225
+ } catch (error: any) {
226
+ throw new Error(`Failed to close issue #${issueNumber}: ${error.message}`);
227
+ }
228
+ }
229
+
230
+ /**
231
+ * Add comment to issue
232
+ */
233
+ async addComment(issueNumber: number, comment: string): Promise<void> {
234
+ const cmd = `gh issue comment ${issueNumber} --repo ${this.repo} --body "${this.escapeQuotes(comment)}"`;
235
+
236
+ try {
237
+ execSync(cmd, { encoding: 'utf-8', stdio: 'pipe' });
238
+ } catch (error: any) {
239
+ throw new Error(`Failed to add comment to issue #${issueNumber}: ${error.message}`);
240
+ }
241
+ }
242
+
243
+ /**
244
+ * Add labels to issue
245
+ */
246
+ async addLabels(issueNumber: number, labels: string[]): Promise<void> {
247
+ if (labels.length === 0) return;
248
+
249
+ const labelArgs = labels.map(l => `"${l}"`).join(',');
250
+ const cmd = `gh issue edit ${issueNumber} --repo ${this.repo} --add-label ${labelArgs}`;
251
+
252
+ try {
253
+ execSync(cmd, { encoding: 'utf-8', stdio: 'pipe' });
254
+ } catch (error: any) {
255
+ throw new Error(`Failed to add labels to issue #${issueNumber}: ${error.message}`);
256
+ }
257
+ }
258
+
259
+ /**
260
+ * Check rate limit status
261
+ */
262
+ async checkRateLimit(): Promise<{ remaining: number; limit: number; reset: Date }> {
263
+ const cmd = `gh api rate_limit --jq '.rate | {remaining: .remaining, limit: .limit, reset: .reset}'`;
264
+
265
+ try {
266
+ const output = execSync(cmd, { encoding: 'utf-8' });
267
+ const data = JSON.parse(output);
268
+ return {
269
+ ...data,
270
+ reset: new Date(data.reset * 1000)
271
+ };
272
+ } catch (error: any) {
273
+ throw new Error(`Failed to check rate limit: ${error.message}`);
274
+ }
275
+ }
276
+
277
+ /**
278
+ * Escape quotes in strings for shell commands
279
+ */
280
+ private escapeQuotes(str: string): string {
281
+ return str
282
+ .replace(/\\/g, '\\\\') // Escape backslashes first
283
+ .replace(/"/g, '\\"') // Escape double quotes
284
+ .replace(/`/g, '\\`') // Escape backticks
285
+ .replace(/\$/g, '\\$'); // Escape dollar signs
286
+ }
287
+
288
+ /**
289
+ * Batch create issues with rate limit handling
290
+ */
291
+ async batchCreateIssues(
292
+ issues: Array<{ title: string; body: string; labels?: string[] }>,
293
+ milestone?: number | string,
294
+ epicNumber?: number,
295
+ options: { batchSize?: number; delayMs?: number } = {}
296
+ ): Promise<GitHubIssue[]> {
297
+ const { batchSize = 10, delayMs = 6000 } = options; // 10 issues per minute by default
298
+ const createdIssues: GitHubIssue[] = [];
299
+
300
+ for (let i = 0; i < issues.length; i += batchSize) {
301
+ const batch = issues.slice(i, i + batchSize);
302
+
303
+ console.log(`Creating issues ${i + 1}-${Math.min(i + batchSize, issues.length)} of ${issues.length}...`);
304
+
305
+ for (const issue of batch) {
306
+ try {
307
+ const created = epicNumber
308
+ ? await this.createTaskIssue(issue.title, issue.body, epicNumber, milestone, issue.labels)
309
+ : await this.createEpicIssue(issue.title, issue.body, milestone, issue.labels);
310
+
311
+ createdIssues.push(created);
312
+ } catch (error: any) {
313
+ console.error(`Failed to create issue "${issue.title}":`, error.message);
314
+ }
315
+ }
316
+
317
+ // Delay between batches (except after last batch)
318
+ if (i + batchSize < issues.length) {
319
+ console.log(`Waiting ${delayMs / 1000}s to avoid rate limits...`);
320
+ await this.sleep(delayMs);
321
+ }
322
+ }
323
+
324
+ return createdIssues;
325
+ }
326
+
327
+ private sleep(ms: number): Promise<void> {
328
+ return new Promise(resolve => setTimeout(resolve, ms));
329
+ }
330
+ }
@@ -0,0 +1,10 @@
1
+ /**
2
+ * SpecWeave GitHub Plugin - Library Entry Point
3
+ * Task-level GitHub synchronization
4
+ */
5
+
6
+ export { GitHubClient } from './github-client';
7
+ export { TaskParser } from './task-parser';
8
+ export { TaskSync } from './task-sync';
9
+ export { SubtaskSync } from './subtask-sync';
10
+ export * from './types';
@@ -0,0 +1,225 @@
1
+ /**
2
+ * Subtask synchronization with GitHub issue checkboxes
3
+ * Updates GitHub issue body when subtasks complete
4
+ */
5
+
6
+ import { GitHubClient } from './github-client';
7
+ import { TaskParser } from './task-parser';
8
+ import { Task, Subtask } from './types';
9
+ import * as path from 'path';
10
+
11
+ export class SubtaskSync {
12
+ private client: GitHubClient;
13
+ private incrementPath: string;
14
+
15
+ constructor(incrementPath: string, repo?: string) {
16
+ this.incrementPath = incrementPath;
17
+ this.client = new GitHubClient(repo);
18
+ }
19
+
20
+ /**
21
+ * Update subtask status in GitHub issue
22
+ */
23
+ async updateSubtaskStatus(
24
+ taskId: string,
25
+ subtaskId: string,
26
+ completed: boolean
27
+ ): Promise<void> {
28
+ // 1. Parse tasks to get task info
29
+ const tasks = TaskParser.parseTasksFile(this.incrementPath);
30
+ const task = tasks.find(t => t.id === taskId);
31
+
32
+ if (!task) {
33
+ throw new Error(`Task ${taskId} not found`);
34
+ }
35
+
36
+ if (!task.githubIssue) {
37
+ console.warn(`Task ${taskId} not synced to GitHub. Skipping subtask sync.`);
38
+ return;
39
+ }
40
+
41
+ // 2. Get current issue
42
+ const issue = await this.client.getIssue(task.githubIssue);
43
+
44
+ // 3. Update subtask checkbox in issue body
45
+ const updatedBody = this.updateSubtaskCheckbox(
46
+ issue.body,
47
+ subtaskId,
48
+ completed
49
+ );
50
+
51
+ // 4. Update GitHub issue
52
+ await this.client.updateIssueBody(task.githubIssue, updatedBody);
53
+
54
+ // 5. Check if all subtasks done
55
+ const allDone = this.areAllSubtasksDone(updatedBody);
56
+ if (allDone) {
57
+ await this.client.addComment(
58
+ task.githubIssue,
59
+ '✅ All subtasks completed!'
60
+ );
61
+ }
62
+
63
+ console.log(`✅ Updated subtask ${subtaskId} in GitHub issue #${task.githubIssue}`);
64
+ }
65
+
66
+ /**
67
+ * Sync all subtasks for a task
68
+ */
69
+ async syncAllSubtasks(taskId: string): Promise<void> {
70
+ const tasks = TaskParser.parseTasksFile(this.incrementPath);
71
+ const task = tasks.find(t => t.id === taskId);
72
+
73
+ if (!task || !task.githubIssue || !task.subtasks) {
74
+ return;
75
+ }
76
+
77
+ const issue = await this.client.getIssue(task.githubIssue);
78
+ let updatedBody = issue.body;
79
+
80
+ // Update all subtasks
81
+ for (const subtask of task.subtasks) {
82
+ updatedBody = this.updateSubtaskCheckbox(
83
+ updatedBody,
84
+ subtask.id,
85
+ subtask.completed
86
+ );
87
+ }
88
+
89
+ await this.client.updateIssueBody(task.githubIssue, updatedBody);
90
+ console.log(`✅ Synced all subtasks for ${taskId} to GitHub issue #${task.githubIssue}`);
91
+ }
92
+
93
+ /**
94
+ * Update checkbox in issue body
95
+ */
96
+ private updateSubtaskCheckbox(
97
+ body: string,
98
+ subtaskId: string,
99
+ completed: boolean
100
+ ): string {
101
+ const checkbox = completed ? '[x]' : '[ ]';
102
+
103
+ // Try to find by subtask ID
104
+ const idPattern = new RegExp(`^(- \\[[ x]\\]\\s+${this.escapeRegex(subtaskId)}:.+)$`, 'm');
105
+ if (idPattern.test(body)) {
106
+ return body.replace(idPattern, (match) => {
107
+ return match.replace(/\[[ x]\]/, checkbox);
108
+ });
109
+ }
110
+
111
+ // Fallback: try to find by description (less reliable)
112
+ // This is a basic approach - could be enhanced
113
+ return body;
114
+ }
115
+
116
+ /**
117
+ * Check if all subtasks are done
118
+ */
119
+ private areAllSubtasksDone(body: string): boolean {
120
+ const subtaskLines = body.match(/^- \[[ x]\] S-\d+-\d+:.+$/gm);
121
+ if (!subtaskLines || subtaskLines.length === 0) {
122
+ return false;
123
+ }
124
+
125
+ return subtaskLines.every(line => line.includes('[x]'));
126
+ }
127
+
128
+ /**
129
+ * Escape special regex characters
130
+ */
131
+ private escapeRegex(str: string): string {
132
+ return str.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
133
+ }
134
+
135
+ /**
136
+ * Post task completion comment to GitHub issue
137
+ */
138
+ async postTaskCompletionComment(
139
+ taskId: string,
140
+ stats: {
141
+ filesModified?: number;
142
+ linesAdded?: number;
143
+ linesDeleted?: number;
144
+ testsAdded?: number;
145
+ actualDuration?: string;
146
+ estimatedDuration?: string;
147
+ summary?: string;
148
+ nextTask?: string;
149
+ progress?: { completed: number; total: number };
150
+ }
151
+ ): Promise<void> {
152
+ const tasks = TaskParser.parseTasksFile(this.incrementPath);
153
+ const task = tasks.find(t => t.id === taskId);
154
+
155
+ if (!task || !task.githubIssue) {
156
+ return;
157
+ }
158
+
159
+ const {
160
+ filesModified = 0,
161
+ linesAdded = 0,
162
+ linesDeleted = 0,
163
+ testsAdded = 0,
164
+ actualDuration = 'Unknown',
165
+ estimatedDuration = task.estimate,
166
+ summary = 'No summary provided',
167
+ nextTask = 'None',
168
+ progress
169
+ } = stats;
170
+
171
+ const comment = `✅ **Task Completed**
172
+
173
+ **Files Modified**: ${filesModified} files (+${linesAdded}/-${linesDeleted} lines)
174
+ **Tests**: ${testsAdded > 0 ? `All passing (${testsAdded} new tests)` : 'All passing'}
175
+ **Duration**: ${actualDuration} (estimated: ${estimatedDuration})
176
+
177
+ **What Changed**:
178
+ ${summary}
179
+
180
+ **Next Task**: ${nextTask}
181
+
182
+ ---
183
+ ${progress ? `Progress: ${progress.completed}/${progress.total} tasks (${Math.round(progress.completed / progress.total * 100)}%)` : ''}
184
+ 🤖 Posted by SpecWeave`;
185
+
186
+ await this.client.addComment(task.githubIssue, comment);
187
+ console.log(`✅ Posted completion comment to issue #${task.githubIssue}`);
188
+ }
189
+
190
+ /**
191
+ * Update epic issue progress
192
+ */
193
+ async updateEpicProgress(epicIssueNumber: number, completed: number, total: number): Promise<void> {
194
+ const epic = await this.client.getIssue(epicIssueNumber);
195
+
196
+ // Update checkboxes in epic body
197
+ const tasks = TaskParser.parseTasksFile(this.incrementPath);
198
+ let updatedBody = epic.body;
199
+
200
+ for (const task of tasks) {
201
+ if (task.status === 'completed') {
202
+ // Find and check the checkbox for this task
203
+ const taskPattern = new RegExp(`^(- \\[[ x]\\] \\[${this.escapeRegex(task.id)}\\].+)$`, 'm');
204
+ if (taskPattern.test(updatedBody)) {
205
+ updatedBody = updatedBody.replace(taskPattern, (match) => {
206
+ return match.replace(/\[[ x]\]/, '[x]');
207
+ });
208
+ }
209
+ }
210
+ }
211
+
212
+ await this.client.updateIssueBody(epicIssueNumber, updatedBody);
213
+
214
+ // Post progress comment
215
+ const progressComment = `📊 **Progress Update**
216
+
217
+ ${completed}/${total} tasks completed (${Math.round(completed / total * 100)}%)
218
+
219
+ ---
220
+ 🤖 Updated by SpecWeave`;
221
+
222
+ await this.client.addComment(epicIssueNumber, progressComment);
223
+ console.log(`✅ Updated epic issue #${epicIssueNumber} progress`);
224
+ }
225
+ }