edsger 0.50.0 → 0.52.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 (470) hide show
  1. package/.claude/settings.local.json +23 -3
  2. package/.env.local +12 -0
  3. package/README.md +25 -25
  4. package/dist/api/chat.d.ts +7 -7
  5. package/dist/api/chat.js +13 -13
  6. package/dist/api/cross-product.d.ts +10 -10
  7. package/dist/api/cross-product.js +30 -30
  8. package/dist/api/github.d.ts +5 -5
  9. package/dist/api/github.js +10 -10
  10. package/dist/api/intelligence.d.ts +3 -3
  11. package/dist/api/issues/approval-checker.d.ts +20 -0
  12. package/dist/api/{features → issues}/approval-checker.js +16 -16
  13. package/dist/api/issues/get-issue.d.ts +5 -0
  14. package/dist/api/issues/get-issue.js +21 -0
  15. package/dist/api/issues/index.d.ts +8 -0
  16. package/dist/api/issues/index.js +10 -0
  17. package/dist/api/issues/issue-utils.d.ts +23 -0
  18. package/dist/api/issues/issue-utils.js +80 -0
  19. package/dist/api/issues/status-updater.d.ts +41 -0
  20. package/dist/api/{features → issues}/status-updater.js +23 -23
  21. package/dist/api/{features → issues}/test-cases.d.ts +7 -7
  22. package/dist/api/{features → issues}/test-cases.js +12 -12
  23. package/dist/api/issues/update-issue.d.ts +20 -0
  24. package/dist/api/{features/update-feature.js → issues/update-issue.js} +22 -22
  25. package/dist/api/{features → issues}/user-stories.d.ts +5 -5
  26. package/dist/api/{features → issues}/user-stories.js +8 -8
  27. package/dist/api/products.d.ts +1 -1
  28. package/dist/api/tasks.d.ts +1 -1
  29. package/dist/api/test-reports.d.ts +2 -2
  30. package/dist/api/test-reports.js +4 -4
  31. package/dist/auth/login.js +1 -1
  32. package/dist/commands/agent-workflow/chat-worker.d.ts +7 -7
  33. package/dist/commands/agent-workflow/chat-worker.js +50 -50
  34. package/dist/commands/agent-workflow/index.d.ts +2 -2
  35. package/dist/commands/agent-workflow/index.js +3 -3
  36. package/dist/commands/agent-workflow/{feature-worker.d.ts → issue-worker.d.ts} +4 -4
  37. package/dist/commands/agent-workflow/{feature-worker.js → issue-worker.js} +12 -12
  38. package/dist/commands/agent-workflow/processor.d.ts +9 -9
  39. package/dist/commands/agent-workflow/processor.js +90 -90
  40. package/dist/commands/build/index.js +2 -2
  41. package/dist/commands/find-bugs/index.d.ts +11 -0
  42. package/dist/commands/find-bugs/index.js +39 -0
  43. package/dist/commands/find-features/index.d.ts +14 -0
  44. package/dist/commands/find-features/index.js +42 -0
  45. package/dist/commands/find-smells/index.d.ts +21 -0
  46. package/dist/commands/find-smells/index.js +65 -0
  47. package/dist/commands/init/prompts.js +1 -1
  48. package/dist/commands/init/templates.d.ts +1 -1
  49. package/dist/commands/init/templates.js +4 -4
  50. package/dist/commands/workflow/config/phase-configs.js +17 -17
  51. package/dist/commands/workflow/core/index.d.ts +1 -1
  52. package/dist/commands/workflow/core/index.js +2 -2
  53. package/dist/commands/workflow/core/issue-filter.d.ts +16 -0
  54. package/dist/commands/workflow/core/issue-filter.js +47 -0
  55. package/dist/commands/workflow/core/state-manager.d.ts +10 -10
  56. package/dist/commands/workflow/core/state-manager.js +10 -10
  57. package/dist/commands/workflow/core/workflow-logger.d.ts +9 -9
  58. package/dist/commands/workflow/core/workflow-logger.js +21 -21
  59. package/dist/commands/workflow/executors/phase-executor.d.ts +2 -2
  60. package/dist/commands/workflow/executors/phase-executor.js +32 -32
  61. package/dist/commands/workflow/issue-coordinator.d.ts +18 -0
  62. package/dist/commands/workflow/{feature-coordinator.js → issue-coordinator.js} +29 -29
  63. package/dist/commands/workflow/phase-orchestrator.d.ts +2 -2
  64. package/dist/commands/workflow/phase-orchestrator.js +82 -82
  65. package/dist/commands/workflow/processor.d.ts +7 -7
  66. package/dist/commands/workflow/processor.js +44 -44
  67. package/dist/config/{feature-status.d.ts → issue-status.d.ts} +14 -14
  68. package/dist/config/{feature-status.js → issue-status.js} +14 -14
  69. package/dist/errors/index.d.ts +6 -6
  70. package/dist/errors/index.js +11 -11
  71. package/dist/index.js +90 -1
  72. package/dist/phases/app-store-generation/context.js +6 -6
  73. package/dist/phases/app-store-generation/index.js +2 -2
  74. package/dist/phases/app-store-generation/prompts.js +2 -2
  75. package/dist/phases/autonomous/index.d.ts +3 -3
  76. package/dist/phases/autonomous/index.js +37 -37
  77. package/dist/phases/autonomous/prompts.d.ts +2 -2
  78. package/dist/phases/autonomous/prompts.js +4 -4
  79. package/dist/phases/branch-planning/context.d.ts +3 -3
  80. package/dist/phases/branch-planning/context.js +12 -12
  81. package/dist/phases/branch-planning/index.d.ts +3 -3
  82. package/dist/phases/branch-planning/index.js +32 -32
  83. package/dist/phases/branch-planning/outcome.d.ts +5 -5
  84. package/dist/phases/branch-planning/outcome.js +12 -12
  85. package/dist/phases/branch-planning/prompts.d.ts +3 -3
  86. package/dist/phases/branch-planning/prompts.js +13 -13
  87. package/dist/phases/bug-fixing/analyzer.d.ts +2 -2
  88. package/dist/phases/bug-fixing/analyzer.js +13 -13
  89. package/dist/phases/bug-fixing/context-fetcher.d.ts +3 -3
  90. package/dist/phases/bug-fixing/context-fetcher.js +18 -18
  91. package/dist/phases/bug-fixing/mcp-server.js +17 -18
  92. package/dist/phases/chat-processor/context.d.ts +5 -5
  93. package/dist/phases/chat-processor/context.js +17 -17
  94. package/dist/phases/chat-processor/index.d.ts +4 -4
  95. package/dist/phases/chat-processor/index.js +17 -17
  96. package/dist/phases/chat-processor/product-context.d.ts +3 -3
  97. package/dist/phases/chat-processor/product-context.js +16 -16
  98. package/dist/phases/chat-processor/product-prompts.d.ts +1 -1
  99. package/dist/phases/chat-processor/product-prompts.js +10 -10
  100. package/dist/phases/chat-processor/product-tools.d.ts +2 -2
  101. package/dist/phases/chat-processor/product-tools.js +33 -33
  102. package/dist/phases/chat-processor/prompts.d.ts +3 -3
  103. package/dist/phases/chat-processor/prompts.js +22 -22
  104. package/dist/phases/chat-processor/tools.js +46 -46
  105. package/dist/phases/code-implementation/branch-pr-creator.d.ts +3 -3
  106. package/dist/phases/code-implementation/branch-pr-creator.js +5 -5
  107. package/dist/phases/code-implementation/context.d.ts +3 -3
  108. package/dist/phases/code-implementation/context.js +18 -18
  109. package/dist/phases/code-implementation/index.d.ts +4 -4
  110. package/dist/phases/code-implementation/index.js +88 -88
  111. package/dist/phases/code-implementation/outcome.d.ts +3 -3
  112. package/dist/phases/code-implementation/outcome.js +6 -6
  113. package/dist/phases/code-implementation/prompts.d.ts +1 -1
  114. package/dist/phases/code-implementation/prompts.js +6 -6
  115. package/dist/phases/code-implementation-verification/agent.d.ts +3 -3
  116. package/dist/phases/code-implementation-verification/agent.js +5 -5
  117. package/dist/phases/code-implementation-verification/index.d.ts +3 -3
  118. package/dist/phases/code-implementation-verification/index.js +11 -11
  119. package/dist/phases/code-implementation-verification/prompts.d.ts +3 -3
  120. package/dist/phases/code-implementation-verification/prompts.js +7 -7
  121. package/dist/phases/code-refine/context.d.ts +8 -8
  122. package/dist/phases/code-refine/context.js +29 -29
  123. package/dist/phases/code-refine/index.d.ts +2 -2
  124. package/dist/phases/code-refine/index.js +20 -20
  125. package/dist/phases/code-refine/prompts.d.ts +1 -1
  126. package/dist/phases/code-refine/prompts.js +3 -3
  127. package/dist/phases/code-refine/refine-iteration.d.ts +1 -1
  128. package/dist/phases/code-refine/refine-iteration.js +4 -4
  129. package/dist/phases/code-refine/retry-handler.js +2 -2
  130. package/dist/phases/code-refine-verification/index.js +10 -10
  131. package/dist/phases/code-refine-verification/types.d.ts +2 -2
  132. package/dist/phases/code-review/context.d.ts +8 -8
  133. package/dist/phases/code-review/context.js +25 -25
  134. package/dist/phases/code-review/diff-utils.d.ts +1 -1
  135. package/dist/phases/code-review/diff-utils.js +1 -1
  136. package/dist/phases/code-review/index.d.ts +2 -2
  137. package/dist/phases/code-review/index.js +26 -26
  138. package/dist/phases/code-testing/analyzer.d.ts +2 -2
  139. package/dist/phases/code-testing/analyzer.js +18 -18
  140. package/dist/phases/code-testing/context-fetcher.d.ts +3 -3
  141. package/dist/phases/code-testing/context-fetcher.js +16 -16
  142. package/dist/phases/code-testing/prompts.d.ts +1 -1
  143. package/dist/phases/code-testing/prompts.js +5 -5
  144. package/dist/phases/find-bugs/index.d.ts +30 -0
  145. package/dist/phases/find-bugs/index.js +216 -0
  146. package/dist/phases/find-bugs/prompts.d.ts +22 -0
  147. package/dist/phases/find-bugs/prompts.js +101 -0
  148. package/dist/phases/find-bugs/state.d.ts +19 -0
  149. package/dist/phases/find-bugs/state.js +13 -0
  150. package/dist/phases/find-bugs/types.d.ts +21 -0
  151. package/dist/phases/find-bugs/types.js +16 -0
  152. package/dist/phases/find-features/index.d.ts +40 -0
  153. package/dist/phases/find-features/index.js +279 -0
  154. package/dist/phases/find-features/prompts.d.ts +43 -0
  155. package/dist/phases/find-features/prompts.js +138 -0
  156. package/dist/phases/find-features/state.d.ts +25 -0
  157. package/dist/phases/find-features/state.js +22 -0
  158. package/dist/phases/find-features/types.d.ts +27 -0
  159. package/dist/phases/find-features/types.js +16 -0
  160. package/dist/phases/find-shared/git.d.ts +24 -0
  161. package/dist/phases/find-shared/git.js +60 -0
  162. package/dist/phases/find-shared/mcp.d.ts +33 -0
  163. package/dist/phases/find-shared/mcp.js +69 -0
  164. package/dist/phases/find-shared/scan-state.d.ts +33 -0
  165. package/dist/phases/find-shared/scan-state.js +112 -0
  166. package/dist/phases/find-smells/index.d.ts +47 -0
  167. package/dist/phases/find-smells/index.js +278 -0
  168. package/dist/phases/find-smells/prompts.d.ts +30 -0
  169. package/dist/phases/find-smells/prompts.js +129 -0
  170. package/dist/phases/find-smells/state.d.ts +21 -0
  171. package/dist/phases/find-smells/state.js +17 -0
  172. package/dist/phases/find-smells/types.d.ts +51 -0
  173. package/dist/phases/find-smells/types.js +64 -0
  174. package/dist/phases/functional-testing/analyzer.d.ts +2 -2
  175. package/dist/phases/functional-testing/analyzer.js +40 -40
  176. package/dist/phases/functional-testing/context-fetcher.d.ts +3 -3
  177. package/dist/phases/functional-testing/context-fetcher.js +16 -16
  178. package/dist/phases/functional-testing/http-fallback.d.ts +2 -2
  179. package/dist/phases/functional-testing/http-fallback.js +9 -9
  180. package/dist/phases/functional-testing/mcp-server.js +23 -24
  181. package/dist/phases/functional-testing/prompts.d.ts +1 -1
  182. package/dist/phases/functional-testing/prompts.js +4 -4
  183. package/dist/phases/functional-testing/test-report-creator.d.ts +2 -2
  184. package/dist/phases/functional-testing/test-report-creator.js +10 -10
  185. package/dist/phases/functional-testing/test-retry-handler.js +3 -3
  186. package/dist/phases/growth-analysis/context.js +6 -6
  187. package/dist/phases/growth-analysis/index.js +2 -2
  188. package/dist/phases/growth-analysis/prompts.js +2 -2
  189. package/dist/phases/intelligence-analysis/context.js +7 -7
  190. package/dist/phases/intelligence-analysis/index.js +3 -3
  191. package/dist/phases/{feature-analysis → issue-analysis}/agent.js +1 -1
  192. package/dist/phases/issue-analysis/context.d.ts +24 -0
  193. package/dist/phases/{feature-analysis → issue-analysis}/context.js +30 -30
  194. package/dist/phases/issue-analysis/index.d.ts +8 -0
  195. package/dist/phases/{feature-analysis → issue-analysis}/index.js +29 -29
  196. package/dist/phases/issue-analysis/outcome.d.ts +40 -0
  197. package/dist/phases/{feature-analysis → issue-analysis}/outcome.js +17 -17
  198. package/dist/phases/{feature-analysis → issue-analysis}/prompts.d.ts +3 -3
  199. package/dist/phases/{feature-analysis → issue-analysis}/prompts.js +12 -12
  200. package/dist/phases/{feature-analysis-verification → issue-analysis-verification}/agent.d.ts +2 -2
  201. package/dist/phases/{feature-analysis-verification → issue-analysis-verification}/agent.js +1 -1
  202. package/dist/phases/{feature-analysis-verification → issue-analysis-verification}/index.d.ts +5 -5
  203. package/dist/phases/{feature-analysis-verification → issue-analysis-verification}/index.js +9 -9
  204. package/dist/phases/{feature-analysis-verification → issue-analysis-verification}/prompts.d.ts +2 -2
  205. package/dist/phases/{feature-analysis-verification → issue-analysis-verification}/prompts.js +7 -7
  206. package/dist/phases/output-contracts.js +37 -37
  207. package/dist/phases/pr-execution/context.d.ts +3 -3
  208. package/dist/phases/pr-execution/context.js +14 -14
  209. package/dist/phases/pr-execution/index.d.ts +2 -2
  210. package/dist/phases/pr-execution/index.js +22 -22
  211. package/dist/phases/pr-execution/outcome.d.ts +4 -4
  212. package/dist/phases/pr-execution/outcome.js +6 -6
  213. package/dist/phases/pr-execution/prompts.d.ts +4 -4
  214. package/dist/phases/pr-execution/prompts.js +6 -6
  215. package/dist/phases/pr-resolve/checklist-learner.js +2 -2
  216. package/dist/phases/pr-review/index.d.ts +1 -1
  217. package/dist/phases/pr-review/index.js +1 -1
  218. package/dist/phases/pr-review/prompts.d.ts +1 -1
  219. package/dist/phases/pr-review/prompts.js +1 -1
  220. package/dist/phases/pr-shared/context.d.ts +3 -3
  221. package/dist/phases/pr-shared/context.js +3 -3
  222. package/dist/phases/pr-splitting/context.d.ts +3 -3
  223. package/dist/phases/pr-splitting/context.js +16 -16
  224. package/dist/phases/pr-splitting/index.d.ts +4 -4
  225. package/dist/phases/pr-splitting/index.js +29 -29
  226. package/dist/phases/pr-splitting/outcome.d.ts +3 -3
  227. package/dist/phases/pr-splitting/outcome.js +7 -7
  228. package/dist/phases/pr-splitting/prompts.d.ts +3 -3
  229. package/dist/phases/pr-splitting/prompts.js +11 -11
  230. package/dist/phases/pull-request/creator.d.ts +4 -4
  231. package/dist/phases/pull-request/creator.js +25 -25
  232. package/dist/phases/pull-request/handler.d.ts +3 -3
  233. package/dist/phases/pull-request/handler.js +16 -16
  234. package/dist/phases/release-sync/index.js +2 -2
  235. package/dist/phases/run-sheet/agent.js +1 -2
  236. package/dist/phases/run-sheet/index.js +3 -3
  237. package/dist/phases/smoke-test/index.js +2 -2
  238. package/dist/phases/technical-design/context.d.ts +3 -3
  239. package/dist/phases/technical-design/context.js +11 -11
  240. package/dist/phases/technical-design/index.d.ts +2 -2
  241. package/dist/phases/technical-design/index.js +27 -27
  242. package/dist/phases/technical-design/outcome.d.ts +4 -4
  243. package/dist/phases/technical-design/outcome.js +6 -6
  244. package/dist/phases/technical-design/prompts.d.ts +2 -2
  245. package/dist/phases/technical-design/prompts.js +10 -10
  246. package/dist/phases/technical-design-verification/agent.d.ts +3 -3
  247. package/dist/phases/technical-design-verification/agent.js +4 -4
  248. package/dist/phases/technical-design-verification/index.d.ts +4 -4
  249. package/dist/phases/technical-design-verification/index.js +12 -12
  250. package/dist/phases/technical-design-verification/prompts.d.ts +3 -3
  251. package/dist/phases/technical-design-verification/prompts.js +6 -6
  252. package/dist/phases/test-cases-analysis/context.d.ts +5 -5
  253. package/dist/phases/test-cases-analysis/context.js +18 -18
  254. package/dist/phases/test-cases-analysis/formatters.js +7 -7
  255. package/dist/phases/test-cases-analysis/index.d.ts +1 -1
  256. package/dist/phases/test-cases-analysis/index.js +21 -21
  257. package/dist/phases/test-cases-analysis/outcome.d.ts +7 -7
  258. package/dist/phases/test-cases-analysis/outcome.js +13 -13
  259. package/dist/phases/test-cases-analysis/prompts.d.ts +3 -3
  260. package/dist/phases/test-cases-analysis/prompts.js +6 -6
  261. package/dist/phases/user-stories-analysis/context.d.ts +5 -5
  262. package/dist/phases/user-stories-analysis/context.js +18 -18
  263. package/dist/phases/user-stories-analysis/formatters.js +7 -7
  264. package/dist/phases/user-stories-analysis/index.d.ts +1 -1
  265. package/dist/phases/user-stories-analysis/index.js +21 -21
  266. package/dist/phases/user-stories-analysis/outcome.d.ts +7 -7
  267. package/dist/phases/user-stories-analysis/outcome.js +13 -13
  268. package/dist/phases/user-stories-analysis/prompts.d.ts +3 -3
  269. package/dist/phases/user-stories-analysis/prompts.js +10 -10
  270. package/dist/services/audit-logs.d.ts +10 -10
  271. package/dist/services/audit-logs.js +12 -12
  272. package/dist/services/branches.d.ts +6 -6
  273. package/dist/services/branches.js +16 -16
  274. package/dist/services/checklist.d.ts +3 -3
  275. package/dist/services/checklist.js +11 -11
  276. package/dist/services/coaching/coaching-agent.js +2 -2
  277. package/dist/services/coaching/coaching-loop.d.ts +1 -1
  278. package/dist/services/coaching/coaching-loop.js +2 -2
  279. package/dist/services/coaching/phase-coaching.d.ts +2 -2
  280. package/dist/services/coaching/phase-coaching.js +3 -3
  281. package/dist/services/coaching/self-rating.js +1 -1
  282. package/dist/services/feedbacks.d.ts +4 -4
  283. package/dist/services/feedbacks.js +8 -8
  284. package/dist/services/phase-hooks/bindings-fetcher.d.ts +4 -4
  285. package/dist/services/phase-hooks/bindings-fetcher.js +8 -8
  286. package/dist/services/phase-hooks/hook-executor.js +1 -1
  287. package/dist/services/phase-hooks/hook-logging.d.ts +2 -2
  288. package/dist/services/phase-hooks/hook-logging.js +4 -4
  289. package/dist/services/phase-hooks/hook-runner.d.ts +1 -1
  290. package/dist/services/phase-hooks/hook-runner.js +4 -4
  291. package/dist/services/phase-hooks/types.d.ts +3 -3
  292. package/dist/services/phase-ratings.d.ts +7 -7
  293. package/dist/services/phase-ratings.js +8 -8
  294. package/dist/services/pull-requests.d.ts +4 -4
  295. package/dist/services/pull-requests.js +11 -11
  296. package/dist/services/skill-resolver.d.ts +1 -1
  297. package/dist/services/skill-resolver.js +1 -1
  298. package/dist/skills/phase/app-store-generation/SKILL.md +9 -9
  299. package/dist/skills/phase/autonomous/SKILL.md +2 -2
  300. package/dist/skills/phase/branch-planning/SKILL.md +12 -12
  301. package/dist/skills/phase/bug-fixing/SKILL.md +1 -1
  302. package/dist/skills/phase/code-implementation/SKILL.md +6 -6
  303. package/dist/skills/phase/code-implementation-verification/SKILL.md +3 -3
  304. package/dist/skills/phase/code-testing/SKILL.md +5 -5
  305. package/dist/skills/phase/functional-testing/SKILL.md +3 -3
  306. package/dist/skills/phase/growth-analysis/SKILL.md +8 -8
  307. package/dist/skills/phase/incremental-sync/SKILL.md +6 -6
  308. package/dist/skills/phase/intelligence-analysis/SKILL.md +7 -7
  309. package/dist/skills/phase/{feature-analysis → issue-analysis}/SKILL.md +8 -8
  310. package/dist/skills/phase/pr-execution/SKILL.md +7 -7
  311. package/dist/skills/phase/pr-splitting/SKILL.md +14 -14
  312. package/dist/skills/phase/smoke-test/SKILL.md +1 -1
  313. package/dist/skills/phase/technical-design/SKILL.md +5 -5
  314. package/dist/skills/phase/test-cases-analysis/SKILL.md +4 -4
  315. package/dist/skills/phase/user-stories-analysis/SKILL.md +13 -13
  316. package/dist/system/session-manager.d.ts +3 -3
  317. package/dist/system/session-manager.js +3 -3
  318. package/dist/system/sleep-notification.js +2 -2
  319. package/dist/system/sleep-prevention.js +1 -1
  320. package/dist/types/index.d.ts +21 -21
  321. package/dist/types/{features.d.ts → issues.d.ts} +3 -3
  322. package/dist/types/pipeline.d.ts +4 -4
  323. package/dist/updater/auto-updater.d.ts +2 -2
  324. package/dist/updater/auto-updater.js +3 -3
  325. package/dist/utils/conflict-resolver.d.ts +1 -1
  326. package/dist/utils/conflict-resolver.js +5 -5
  327. package/dist/utils/formatters.d.ts +4 -4
  328. package/dist/utils/formatters.js +29 -29
  329. package/dist/utils/git-branch-manager-async.d.ts +6 -6
  330. package/dist/utils/git-branch-manager-async.js +41 -41
  331. package/dist/utils/git-branch-manager.d.ts +11 -11
  332. package/dist/utils/git-branch-manager.js +42 -42
  333. package/dist/utils/image-downloader.d.ts +4 -4
  334. package/dist/utils/image-downloader.js +17 -17
  335. package/dist/utils/pipeline-logger.d.ts +1 -1
  336. package/dist/utils/pipeline-logger.js +5 -5
  337. package/dist/workspace/workspace-manager.d.ts +17 -17
  338. package/dist/workspace/workspace-manager.js +21 -21
  339. package/package.json +1 -1
  340. package/vitest.config.ts +4 -0
  341. package/dist/api/__tests__/app-store.test.d.ts +0 -7
  342. package/dist/api/__tests__/app-store.test.js +0 -60
  343. package/dist/api/__tests__/intelligence.test.d.ts +0 -11
  344. package/dist/api/__tests__/intelligence.test.js +0 -315
  345. package/dist/api/features/__tests__/feature-utils.test.d.ts +0 -4
  346. package/dist/api/features/__tests__/feature-utils.test.js +0 -370
  347. package/dist/api/features/__tests__/status-updater.test.d.ts +0 -4
  348. package/dist/api/features/__tests__/status-updater.test.js +0 -88
  349. package/dist/api/features/approval-checker.d.ts +0 -20
  350. package/dist/api/features/feature-utils.d.ts +0 -23
  351. package/dist/api/features/feature-utils.js +0 -80
  352. package/dist/api/features/get-feature.d.ts +0 -5
  353. package/dist/api/features/get-feature.js +0 -21
  354. package/dist/api/features/index.d.ts +0 -8
  355. package/dist/api/features/index.js +0 -10
  356. package/dist/api/features/status-updater.d.ts +0 -41
  357. package/dist/api/features/update-feature.d.ts +0 -20
  358. package/dist/commands/build/__tests__/build.test.d.ts +0 -5
  359. package/dist/commands/build/__tests__/build.test.js +0 -206
  360. package/dist/commands/build/__tests__/detect-project.test.d.ts +0 -6
  361. package/dist/commands/build/__tests__/detect-project.test.js +0 -160
  362. package/dist/commands/build/__tests__/run-build.test.d.ts +0 -6
  363. package/dist/commands/build/__tests__/run-build.test.js +0 -433
  364. package/dist/commands/intelligence/__tests__/command.test.d.ts +0 -4
  365. package/dist/commands/intelligence/__tests__/command.test.js +0 -48
  366. package/dist/commands/workflow/core/__tests__/feature-filter.test.d.ts +0 -5
  367. package/dist/commands/workflow/core/__tests__/feature-filter.test.js +0 -316
  368. package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.d.ts +0 -4
  369. package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.js +0 -397
  370. package/dist/commands/workflow/core/__tests__/state-manager.test.d.ts +0 -4
  371. package/dist/commands/workflow/core/__tests__/state-manager.test.js +0 -384
  372. package/dist/commands/workflow/core/feature-filter.d.ts +0 -16
  373. package/dist/commands/workflow/core/feature-filter.js +0 -47
  374. package/dist/commands/workflow/feature-coordinator.d.ts +0 -18
  375. package/dist/config/__tests__/config.test.d.ts +0 -4
  376. package/dist/config/__tests__/config.test.js +0 -286
  377. package/dist/config/__tests__/feature-status.test.d.ts +0 -4
  378. package/dist/config/__tests__/feature-status.test.js +0 -111
  379. package/dist/errors/__tests__/index.test.d.ts +0 -4
  380. package/dist/errors/__tests__/index.test.js +0 -349
  381. package/dist/phases/app-store-generation/__tests__/agent.test.d.ts +0 -5
  382. package/dist/phases/app-store-generation/__tests__/agent.test.js +0 -142
  383. package/dist/phases/app-store-generation/__tests__/context.test.d.ts +0 -4
  384. package/dist/phases/app-store-generation/__tests__/context.test.js +0 -284
  385. package/dist/phases/app-store-generation/__tests__/prompts.test.d.ts +0 -4
  386. package/dist/phases/app-store-generation/__tests__/prompts.test.js +0 -122
  387. package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.d.ts +0 -5
  388. package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.js +0 -826
  389. package/dist/phases/code-review/__tests__/diff-utils.test.js +0 -101
  390. package/dist/phases/feature-analysis/context.d.ts +0 -24
  391. package/dist/phases/feature-analysis/index.d.ts +0 -8
  392. package/dist/phases/feature-analysis/outcome.d.ts +0 -40
  393. package/dist/phases/intelligence-analysis/__tests__/context.test.d.ts +0 -4
  394. package/dist/phases/intelligence-analysis/__tests__/context.test.js +0 -192
  395. package/dist/phases/intelligence-analysis/__tests__/matching.test.d.ts +0 -13
  396. package/dist/phases/intelligence-analysis/__tests__/matching.test.js +0 -154
  397. package/dist/phases/intelligence-analysis/__tests__/orchestration.test.d.ts +0 -5
  398. package/dist/phases/intelligence-analysis/__tests__/orchestration.test.js +0 -378
  399. package/dist/phases/intelligence-analysis/__tests__/prompts.test.d.ts +0 -4
  400. package/dist/phases/intelligence-analysis/__tests__/prompts.test.js +0 -33
  401. package/dist/phases/pr-execution/__tests__/file-assigner.test.d.ts +0 -1
  402. package/dist/phases/pr-execution/__tests__/file-assigner.test.js +0 -303
  403. package/dist/phases/pr-resolve/__tests__/checklist-learner.test.d.ts +0 -1
  404. package/dist/phases/pr-resolve/__tests__/checklist-learner.test.js +0 -157
  405. package/dist/phases/pr-resolve/__tests__/prompts.test.d.ts +0 -1
  406. package/dist/phases/pr-resolve/__tests__/prompts.test.js +0 -116
  407. package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.d.ts +0 -1
  408. package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.js +0 -138
  409. package/dist/phases/pr-resolve/__tests__/types.test.d.ts +0 -1
  410. package/dist/phases/pr-resolve/__tests__/types.test.js +0 -43
  411. package/dist/phases/pr-resolve/__tests__/workspace.test.d.ts +0 -1
  412. package/dist/phases/pr-resolve/__tests__/workspace.test.js +0 -111
  413. package/dist/phases/pr-review/__tests__/prompts.test.d.ts +0 -1
  414. package/dist/phases/pr-review/__tests__/prompts.test.js +0 -49
  415. package/dist/phases/pr-review/__tests__/review-comments.test.d.ts +0 -1
  416. package/dist/phases/pr-review/__tests__/review-comments.test.js +0 -110
  417. package/dist/phases/pr-shared/__tests__/agent-utils.test.d.ts +0 -1
  418. package/dist/phases/pr-shared/__tests__/agent-utils.test.js +0 -91
  419. package/dist/phases/pr-shared/__tests__/context.test.d.ts +0 -1
  420. package/dist/phases/pr-shared/__tests__/context.test.js +0 -94
  421. package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.d.ts +0 -1
  422. package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.js +0 -331
  423. package/dist/phases/run-sheet/render.d.ts +0 -60
  424. package/dist/phases/run-sheet/render.js +0 -297
  425. package/dist/phases/smoke-test/__tests__/agent.test.d.ts +0 -4
  426. package/dist/phases/smoke-test/__tests__/agent.test.js +0 -84
  427. package/dist/phases/smoke-test/__tests__/github.test.d.ts +0 -9
  428. package/dist/phases/smoke-test/__tests__/github.test.js +0 -120
  429. package/dist/phases/smoke-test/__tests__/snapshot.test.d.ts +0 -8
  430. package/dist/phases/smoke-test/__tests__/snapshot.test.js +0 -93
  431. package/dist/phases/smoke-test/github.d.ts +0 -54
  432. package/dist/phases/smoke-test/github.js +0 -101
  433. package/dist/phases/smoke-test/snapshot.d.ts +0 -27
  434. package/dist/phases/smoke-test/snapshot.js +0 -157
  435. package/dist/services/coaching/__tests__/coaching-agent.test.d.ts +0 -1
  436. package/dist/services/coaching/__tests__/coaching-agent.test.js +0 -74
  437. package/dist/services/coaching/__tests__/coaching-loop.test.d.ts +0 -1
  438. package/dist/services/coaching/__tests__/coaching-loop.test.js +0 -59
  439. package/dist/services/coaching/__tests__/self-rating.test.d.ts +0 -1
  440. package/dist/services/coaching/__tests__/self-rating.test.js +0 -188
  441. package/dist/services/lifecycle-agent/__tests__/phase-criteria.test.d.ts +0 -4
  442. package/dist/services/lifecycle-agent/__tests__/phase-criteria.test.js +0 -133
  443. package/dist/services/lifecycle-agent/__tests__/transition-rules.test.d.ts +0 -4
  444. package/dist/services/lifecycle-agent/__tests__/transition-rules.test.js +0 -336
  445. package/dist/services/lifecycle-agent/index.d.ts +0 -24
  446. package/dist/services/lifecycle-agent/index.js +0 -25
  447. package/dist/services/lifecycle-agent/phase-criteria.d.ts +0 -57
  448. package/dist/services/lifecycle-agent/phase-criteria.js +0 -335
  449. package/dist/services/lifecycle-agent/transition-rules.d.ts +0 -60
  450. package/dist/services/lifecycle-agent/transition-rules.js +0 -184
  451. package/dist/services/lifecycle-agent/types.d.ts +0 -190
  452. package/dist/services/lifecycle-agent/types.js +0 -12
  453. package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.d.ts +0 -1
  454. package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.js +0 -122
  455. package/dist/services/phase-hooks/__tests__/hook-executor.test.d.ts +0 -1
  456. package/dist/services/phase-hooks/__tests__/hook-executor.test.js +0 -321
  457. package/dist/services/phase-hooks/__tests__/hook-runner.test.d.ts +0 -1
  458. package/dist/services/phase-hooks/__tests__/hook-runner.test.js +0 -261
  459. package/dist/services/phase-hooks/__tests__/plugin-loader.test.d.ts +0 -1
  460. package/dist/services/phase-hooks/__tests__/plugin-loader.test.js +0 -158
  461. package/dist/services/video/__tests__/video-pipeline.test.d.ts +0 -6
  462. package/dist/services/video/__tests__/video-pipeline.test.js +0 -249
  463. package/dist/types/features.js +0 -1
  464. package/dist/workspace/__tests__/workspace-manager.test.d.ts +0 -7
  465. package/dist/workspace/__tests__/workspace-manager.test.js +0 -52
  466. /package/dist/api/{features → issues}/batch-operations.d.ts +0 -0
  467. /package/dist/api/{features → issues}/batch-operations.js +0 -0
  468. /package/dist/phases/{feature-analysis → issue-analysis}/agent.d.ts +0 -0
  469. /package/dist/skills/phase/{feature-analysis-verification → issue-analysis-verification}/SKILL.md +0 -0
  470. /package/dist/{phases/code-review/__tests__/diff-utils.test.d.ts → types/issues.js} +0 -0
@@ -19,24 +19,24 @@ export function createChatMcpServer() {
19
19
  name: 'edsger-chat',
20
20
  version: '1.0.0',
21
21
  tools: [
22
- tool('update_feature_status', 'Change the feature status (e.g., back to ready_for_ai, backlog). Use when the user wants to restart or change the workflow state.', {
23
- feature_id: z.string().describe('Feature ID'),
22
+ tool('update_issue_status', 'Change the issue status (e.g., back to ready_for_ai, backlog). Use when the user wants to restart or change the workflow state.', {
23
+ issue_id: z.string().describe('Issue ID'),
24
24
  status: z.string().describe('New status value'),
25
25
  }, async (args) => {
26
- const result = await callMcpEndpoint('features/update', {
27
- feature_id: args.feature_id,
26
+ const result = await callMcpEndpoint('issues/update', {
27
+ issue_id: args.issue_id,
28
28
  status: args.status,
29
29
  });
30
30
  return {
31
31
  content: [{ type: 'text', text: JSON.stringify(result, null, 2) }],
32
32
  };
33
33
  }),
34
- tool('update_execution_mode', 'Change the feature execution mode (e.g., from_user_stories_analysis, from_code_implementation).', {
35
- feature_id: z.string().describe('Feature ID'),
34
+ tool('update_execution_mode', 'Change the issue execution mode (e.g., from_user_stories_analysis, from_code_implementation).', {
35
+ issue_id: z.string().describe('Issue ID'),
36
36
  execution_mode: z
37
37
  .enum([
38
38
  'full_pipeline',
39
- 'only_feature_analysis',
39
+ 'only_issue_analysis',
40
40
  'only_user_stories_analysis',
41
41
  'only_test_cases_analysis',
42
42
  'only_technical_design',
@@ -47,7 +47,7 @@ export function createChatMcpServer() {
47
47
  'only_functional_testing',
48
48
  'only_code_refine',
49
49
  'only_code_review',
50
- 'from_feature_analysis',
50
+ 'from_issue_analysis',
51
51
  'from_user_stories_analysis',
52
52
  'from_test_cases_analysis',
53
53
  'from_technical_design',
@@ -62,8 +62,8 @@ export function createChatMcpServer() {
62
62
  ])
63
63
  .describe('New execution mode'),
64
64
  }, async (args) => {
65
- const result = await callMcpEndpoint('features/update', {
66
- feature_id: args.feature_id,
65
+ const result = await callMcpEndpoint('issues/update', {
66
+ issue_id: args.issue_id,
67
67
  execution_mode: args.execution_mode,
68
68
  });
69
69
  return {
@@ -71,12 +71,12 @@ export function createChatMcpServer() {
71
71
  };
72
72
  }),
73
73
  tool('update_workflow', 'Modify workflow phases — reset phases to pending, skip phases, or reorder. Phase names must use snake_case (e.g., code_implementation, NOT code-implementation).', {
74
- feature_id: z.string().describe('Feature ID'),
74
+ issue_id: z.string().describe('Issue ID'),
75
75
  workflow: z
76
76
  .array(z.object({
77
77
  phase: z
78
78
  .string()
79
- .describe('Phase name in snake_case. Valid phases: feature_analysis, user_stories_analysis, test_cases_analysis, technical_design, branch_planning, code_implementation, pr_splitting, pr_execution, functional_testing, code_review, code_refine, autonomous'),
79
+ .describe('Phase name in snake_case. Valid phases: issue_analysis, user_stories_analysis, test_cases_analysis, technical_design, branch_planning, code_implementation, pr_splitting, pr_execution, functional_testing, code_review, code_refine, autonomous'),
80
80
  status: z.enum(['pending', 'completed', 'skipped']),
81
81
  }))
82
82
  .describe('Updated workflow array'),
@@ -86,8 +86,8 @@ export function createChatMcpServer() {
86
86
  ...p,
87
87
  phase: p.phase.replace(/-/g, '_'),
88
88
  }));
89
- const result = await callMcpEndpoint('features/update', {
90
- feature_id: args.feature_id,
89
+ const result = await callMcpEndpoint('issues/update', {
90
+ issue_id: args.issue_id,
91
91
  workflow: normalizedWorkflow,
92
92
  });
93
93
  return {
@@ -95,7 +95,7 @@ export function createChatMcpServer() {
95
95
  };
96
96
  }),
97
97
  tool('update_user_stories', 'Create, update, or delete user stories based on feedback. Always provide a reason explaining why the change is being made.', {
98
- feature_id: z.string().describe('Feature ID'),
98
+ issue_id: z.string().describe('Issue ID'),
99
99
  reason: z
100
100
  .string()
101
101
  .describe('Why this change is being made — e.g. user feedback, bug found, requirement changed. Required for audit trail.'),
@@ -117,7 +117,7 @@ export function createChatMcpServer() {
117
117
  try {
118
118
  if (action.action === 'create') {
119
119
  await callMcpEndpoint('user_stories/create', {
120
- feature_id: args.feature_id,
120
+ issue_id: args.issue_id,
121
121
  user_stories: [
122
122
  {
123
123
  title: action.title,
@@ -159,7 +159,7 @@ export function createChatMcpServer() {
159
159
  };
160
160
  }),
161
161
  tool('update_test_cases', 'Create, update, or delete test cases based on feedback. Always provide a reason explaining why the change is being made.', {
162
- feature_id: z.string().describe('Feature ID'),
162
+ issue_id: z.string().describe('Issue ID'),
163
163
  reason: z
164
164
  .string()
165
165
  .describe('Why this change is being made — e.g. user feedback, bug found, requirement changed. Required for audit trail.'),
@@ -189,7 +189,7 @@ export function createChatMcpServer() {
189
189
  try {
190
190
  if (action.action === 'create') {
191
191
  await callMcpEndpoint('test_cases/create', {
192
- feature_id: args.feature_id,
192
+ issue_id: args.issue_id,
193
193
  test_cases: [
194
194
  {
195
195
  name: action.name,
@@ -242,7 +242,7 @@ export function createChatMcpServer() {
242
242
  ],
243
243
  };
244
244
  }),
245
- tool('list_checklists', 'List checklists for the product this feature belongs to. Each checklist can apply to multiple phases and is assigned to a specific role. Returns checklists with their items.', {
245
+ tool('list_checklists', 'List checklists for the product this issue belongs to. Each checklist can apply to multiple phases and is assigned to a specific role. Returns checklists with their items.', {
246
246
  product_id: z.string().describe('Product ID'),
247
247
  role: z
248
248
  .string()
@@ -535,32 +535,32 @@ export function createChatMcpServer() {
535
535
  content: [{ type: 'text', text: 'Options presented to the user.' }],
536
536
  };
537
537
  }),
538
- tool('get_feature_context', 'Fetch the full current state of a feature: status, workflow, user stories, test cases.', {
539
- feature_id: z.string().describe('Feature ID'),
538
+ tool('get_issue_context', 'Fetch the full current state of an issue: status, workflow, user stories, test cases.', {
539
+ issue_id: z.string().describe('Issue ID'),
540
540
  }, async (args) => {
541
- const [featureResult, storiesResult, testCasesResult] = await Promise.all([
542
- callMcpEndpoint('features/get', {
543
- feature_id: args.feature_id,
541
+ const [issueResult, storiesResult, testCasesResult] = await Promise.all([
542
+ callMcpEndpoint('issues/get', {
543
+ issue_id: args.issue_id,
544
544
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
545
545
  }),
546
546
  callMcpEndpoint('user_stories/list', {
547
- feature_id: args.feature_id,
547
+ issue_id: args.issue_id,
548
548
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
549
549
  }),
550
550
  callMcpEndpoint('test_cases/list', {
551
- feature_id: args.feature_id,
551
+ issue_id: args.issue_id,
552
552
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
553
553
  }),
554
554
  ]);
555
- const feature = featureResult?.features?.[0] || {};
555
+ const issue = issueResult?.issues?.[0] || {};
556
556
  const result = {
557
- feature,
557
+ issue,
558
558
  user_stories: storiesResult?.user_stories || [],
559
559
  test_cases: testCasesResult?.test_cases || [],
560
560
  summary: {
561
- status: feature.status,
562
- execution_mode: feature.execution_mode,
563
- workflow_phases: (feature.workflow || []).map(
561
+ status: issue.status,
562
+ execution_mode: issue.execution_mode,
563
+ workflow_phases: (issue.workflow || []).map(
564
564
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
565
565
  (p) => `${p.phase}: ${p.status}`),
566
566
  },
@@ -609,7 +609,7 @@ export function createChatMcpServer() {
609
609
  product_id: z.string().describe('Product ID'),
610
610
  name: z
611
611
  .string()
612
- .describe('Short task name (e.g., "Review user stories for Login feature")'),
612
+ .describe('Short task name (e.g., "Review user stories for Login issue")'),
613
613
  description: z
614
614
  .string()
615
615
  .optional()
@@ -621,7 +621,7 @@ export function createChatMcpServer() {
621
621
  .string()
622
622
  .optional()
623
623
  .describe('User ID to assign to (use list_product_members to look up)'),
624
- feature_id: z.string().optional().describe('Related feature ID'),
624
+ issue_id: z.string().optional().describe('Related issue ID'),
625
625
  action_url: z
626
626
  .string()
627
627
  .optional()
@@ -639,10 +639,10 @@ export function createChatMcpServer() {
639
639
  const text = listResult?.content?.[0]?.text || '[]';
640
640
  const existingTasks = JSON.parse(text);
641
641
  const nextSequence = existingTasks.length + 1;
642
- // Use explicit action_url if provided, otherwise auto-generate from feature_id
642
+ // Use explicit action_url if provided, otherwise auto-generate from issue_id
643
643
  const actionUrl = args.action_url ||
644
- (args.feature_id
645
- ? `/products/${args.product_id}/features/${args.feature_id}`
644
+ (args.issue_id
645
+ ? `/products/${args.product_id}/issues/${args.issue_id}`
646
646
  : null);
647
647
  const result = await callMcpEndpoint('tasks/create', {
648
648
  product_id: args.product_id,
@@ -652,7 +652,7 @@ export function createChatMcpServer() {
652
652
  executor: args.executor,
653
653
  source: 'system',
654
654
  assigned_to: args.assigned_to || null,
655
- feature_id: args.feature_id || null,
655
+ issue_id: args.issue_id || null,
656
656
  action_url: actionUrl,
657
657
  priority: args.priority || (args.executor === 'human' ? 3 : 2),
658
658
  });
@@ -671,28 +671,28 @@ export function createChatMcpServer() {
671
671
  };
672
672
  }),
673
673
  tool('trigger_phase_rerun', 'Reset a workflow phase to pending so it will re-run.', {
674
- feature_id: z.string().describe('Feature ID'),
674
+ issue_id: z.string().describe('Issue ID'),
675
675
  phase: z.string().describe('Phase name to reset'),
676
676
  }, async (args) => {
677
- const featureResult = (await callMcpEndpoint('features/get', {
678
- feature_id: args.feature_id,
677
+ const issueResult = (await callMcpEndpoint('issues/get', {
678
+ issue_id: args.issue_id,
679
679
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
680
680
  }));
681
- const feature = featureResult?.features?.[0];
682
- if (!feature) {
681
+ const issue = issueResult?.issues?.[0];
682
+ if (!issue) {
683
683
  return {
684
- content: [{ type: 'text', text: 'Feature not found' }],
684
+ content: [{ type: 'text', text: 'Issue not found' }],
685
685
  isError: true,
686
686
  };
687
687
  }
688
- const workflow = feature.workflow || [];
688
+ const workflow = issue.workflow || [];
689
689
  const normalizedPhase = args.phase.replace(/-/g, '_');
690
690
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
691
691
  const updatedWorkflow = workflow.map((p) => p.phase === normalizedPhase
692
692
  ? { ...p, status: 'pending', executed_at: null }
693
693
  : p);
694
- await callMcpEndpoint('features/update', {
695
- feature_id: args.feature_id,
694
+ await callMcpEndpoint('issues/update', {
695
+ issue_id: args.issue_id,
696
696
  workflow: updatedWorkflow,
697
697
  });
698
698
  return {
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Branch PR Creator for multi-branch feature development
2
+ * Branch PR Creator for multi-branch issue development
3
3
  * Creates pull requests from dev/ branches to feat/ branches
4
4
  */
5
5
  export interface BranchPullRequestConfig {
@@ -26,6 +26,6 @@ export declare function featBranchToDevBranch(featBranchName: string): string;
26
26
  export declare function devBranchToFeatBranch(devBranchName: string): string;
27
27
  /**
28
28
  * Create a pull request from a dev/ branch to its corresponding feat/ branch
29
- * This is used after code implementation in multi-branch features
29
+ * This is used after code implementation in multi-branch issues
30
30
  */
31
- export declare function createBranchPullRequest(config: BranchPullRequestConfig, devBranchName: string, featureName: string, branchDescription: string, baseBranch?: string): Promise<BranchPullRequestResult>;
31
+ export declare function createBranchPullRequest(config: BranchPullRequestConfig, devBranchName: string, issueName: string, branchDescription: string, baseBranch?: string): Promise<BranchPullRequestResult>;
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Branch PR Creator for multi-branch feature development
2
+ * Branch PR Creator for multi-branch issue development
3
3
  * Creates pull requests from dev/ branches to feat/ branches
4
4
  */
5
5
  import { Octokit } from '@octokit/rest';
@@ -8,7 +8,7 @@ import { logError, logInfo } from '../../utils/logger.js';
8
8
  // GitHub PR title best practice: keep under 72 characters
9
9
  const MAX_PR_TITLE_LENGTH = 72;
10
10
  const PR_TITLE_PREFIX = 'feat: ';
11
- const MAX_FEATURE_NAME_LENGTH = MAX_PR_TITLE_LENGTH - PR_TITLE_PREFIX.length;
11
+ const MAX_ISSUE_NAME_LENGTH = MAX_PR_TITLE_LENGTH - PR_TITLE_PREFIX.length;
12
12
  /**
13
13
  * Truncate text to a maximum length, adding ellipsis if truncated
14
14
  */
@@ -42,9 +42,9 @@ export function devBranchToFeatBranch(devBranchName) {
42
42
  }
43
43
  /**
44
44
  * Create a pull request from a dev/ branch to its corresponding feat/ branch
45
- * This is used after code implementation in multi-branch features
45
+ * This is used after code implementation in multi-branch issues
46
46
  */
47
- export async function createBranchPullRequest(config, devBranchName, featureName, branchDescription, baseBranch = 'main') {
47
+ export async function createBranchPullRequest(config, devBranchName, issueName, branchDescription, baseBranch = 'main') {
48
48
  const { githubToken, owner, repo, verbose } = config;
49
49
  if (!devBranchName.startsWith('dev/')) {
50
50
  return {
@@ -125,7 +125,7 @@ export async function createBranchPullRequest(config, devBranchName, featureName
125
125
  };
126
126
  }
127
127
  // Generate PR title and body (truncate to keep under 72 chars, lowercase)
128
- const truncatedName = truncateText(featureName.toLowerCase(), MAX_FEATURE_NAME_LENGTH);
128
+ const truncatedName = truncateText(issueName.toLowerCase(), MAX_ISSUE_NAME_LENGTH);
129
129
  const title = `${PR_TITLE_PREFIX}${truncatedName}`;
130
130
  const body = `## Branch Implementation
131
131
 
@@ -1,7 +1,7 @@
1
1
  import { type ProductInfo } from '../../api/products.js';
2
- import type { FeatureInfo, TestCase, UserStory } from '../../types/features.js';
2
+ import type { IssueInfo, TestCase, UserStory } from '../../types/issues.js';
3
3
  export interface CodeImplementationContext {
4
- feature: FeatureInfo;
4
+ issue: IssueInfo;
5
5
  product: ProductInfo;
6
6
  user_stories: UserStory[];
7
7
  test_cases: TestCase[];
@@ -10,7 +10,7 @@ export interface CodeImplementationContext {
10
10
  /**
11
11
  * Fetch all code implementation context information via MCP endpoints
12
12
  */
13
- export declare function fetchCodeImplementationContext(featureId: string, verbose?: boolean): Promise<CodeImplementationContext>;
13
+ export declare function fetchCodeImplementationContext(issueId: string, verbose?: boolean): Promise<CodeImplementationContext>;
14
14
  /**
15
15
  * Format the context into a readable string for Claude Code
16
16
  */
@@ -1,35 +1,35 @@
1
- import { getFeature, getTestCases, getUserStories, } from '../../api/features/index.js';
1
+ import { getIssue, getTestCases, getUserStories, } from '../../api/issues/index.js';
2
2
  import { getProduct } from '../../api/products.js';
3
3
  import { logError, logInfo } from '../../utils/logger.js';
4
4
  /**
5
5
  * Fetch all code implementation context information via MCP endpoints
6
6
  */
7
- export async function fetchCodeImplementationContext(featureId, verbose) {
7
+ export async function fetchCodeImplementationContext(issueId, verbose) {
8
8
  try {
9
9
  if (verbose) {
10
- logInfo(`Fetching complete code implementation context for feature: ${featureId}`);
10
+ logInfo(`Fetching complete code implementation context for issue: ${issueId}`);
11
11
  }
12
12
  // Fetch all required data in parallel for better performance
13
- const [feature, userStories, testCases] = await Promise.all([
14
- getFeature(featureId, verbose),
15
- getUserStories(featureId, verbose),
16
- getTestCases(featureId, verbose),
13
+ const [issue, userStories, testCases] = await Promise.all([
14
+ getIssue(issueId, verbose),
15
+ getUserStories(issueId, verbose),
16
+ getTestCases(issueId, verbose),
17
17
  ]);
18
- const product = await getProduct(feature.product_id, verbose);
18
+ const product = await getProduct(issue.product_id, verbose);
19
19
  if (verbose) {
20
20
  logInfo(`✅ Code implementation context fetched successfully:`);
21
- logInfo(` Feature: ${feature.name}`);
21
+ logInfo(` Issue: ${issue.name}`);
22
22
  logInfo(` Product: ${product.name}`);
23
23
  logInfo(` User Stories: ${userStories.length}`);
24
24
  logInfo(` Test Cases: ${testCases.length}`);
25
- logInfo(` Technical Design: ${feature.technical_design ? 'Available' : 'Not available'}`);
25
+ logInfo(` Technical Design: ${issue.technical_design ? 'Available' : 'Not available'}`);
26
26
  }
27
27
  return {
28
- feature,
28
+ issue,
29
29
  product,
30
30
  user_stories: userStories,
31
31
  test_cases: testCases,
32
- technical_design: feature.technical_design,
32
+ technical_design: issue.technical_design,
33
33
  };
34
34
  }
35
35
  catch (error) {
@@ -62,11 +62,11 @@ export function formatContextForPrompt(context) {
62
62
  };
63
63
  return `# Code Implementation Context
64
64
 
65
- ## Feature Information
66
- - **ID**: ${context.feature.id}
67
- - **Name**: ${context.feature.name}
68
- - **Description**: ${context.feature.description || 'No description provided'}
69
- - **Current Status**: ${context.feature.status}
65
+ ## Issue Information
66
+ - **ID**: ${context.issue.id}
67
+ - **Name**: ${context.issue.name}
68
+ - **Description**: ${context.issue.description || 'No description provided'}
69
+ - **Current Status**: ${context.issue.status}
70
70
 
71
71
  ## Product Information
72
72
  - **Product**: ${context.product.name}
@@ -84,5 +84,5 @@ ${context.technical_design || 'No technical design available - implement based o
84
84
 
85
85
  ---
86
86
 
87
- **Implementation Instructions**: Based on the above requirements, user stories, test cases, and technical design, implement the complete feature functionality. Ensure all user stories are implemented and all test cases can pass.`;
87
+ **Implementation Instructions**: Based on the above requirements, user stories, test cases, and technical design, implement the complete issue functionality. Ensure all user stories are implemented and all test cases can pass.`;
88
88
  }
@@ -1,14 +1,14 @@
1
1
  import { type ChecklistPhaseContext } from '../../services/checklist.js';
2
2
  import { type EdsgerConfig } from '../../types/index.js';
3
3
  export interface CodeImplementationOptions {
4
- featureId: string;
4
+ issueId: string;
5
5
  verbose?: boolean;
6
6
  baseBranch?: string;
7
7
  maxVerificationIterations?: number;
8
- featureBranchId?: string;
8
+ issueBranchId?: string;
9
9
  }
10
10
  export interface CodeImplementationResult {
11
- featureId: string;
11
+ issueId: string;
12
12
  branchName: string;
13
13
  implementationSummary: string | null;
14
14
  status: 'success' | 'error';
@@ -30,4 +30,4 @@ export interface CodeImplementationResult {
30
30
  [key: string]: unknown;
31
31
  };
32
32
  }
33
- export declare const implementFeatureCode: (options: CodeImplementationOptions, config: EdsgerConfig, checklistContext?: ChecklistPhaseContext | null) => Promise<CodeImplementationResult>;
33
+ export declare const implementIssueCode: (options: CodeImplementationOptions, config: EdsgerConfig, checklistContext?: ChecklistPhaseContext | null) => Promise<CodeImplementationResult>;