@shipit-ai/cli 1.166.2 → 1.167.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (506) hide show
  1. package/README.md +26 -5
  2. package/apis/json-schema/AgentConfig.yaml +3 -0
  3. package/apis/json-schema/AgentPermissionSettings.yaml +23 -0
  4. package/apis/json-schema/AgentType.yaml +0 -1
  5. package/apis/json-schema/ClaudeCodePermissionMode.yaml +9 -0
  6. package/apis/json-schema/CodexPermissionMode.yaml +8 -0
  7. package/apis/json-schema/CopilotPermissionMode.yaml +8 -0
  8. package/apis/json-schema/CursorPermissionMode.yaml +7 -0
  9. package/apis/json-schema/Feature.yaml +3 -0
  10. package/apis/json-schema/GeminiPermissionMode.yaml +8 -0
  11. package/apis/json-schema/RovoDevPermissionMode.yaml +8 -0
  12. package/dist/packages/core/src/application/ports/output/agents/agent-executor.interface.d.ts +8 -0
  13. package/dist/packages/core/src/application/ports/output/agents/agent-executor.interface.d.ts.map +1 -1
  14. package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts +1 -0
  15. package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts.map +1 -1
  16. package/dist/packages/core/src/application/ports/output/agents/interactive-agent-executor.interface.d.ts +3 -0
  17. package/dist/packages/core/src/application/ports/output/agents/interactive-agent-executor.interface.d.ts.map +1 -1
  18. package/dist/packages/core/src/application/ports/output/services/index.d.ts +1 -0
  19. package/dist/packages/core/src/application/ports/output/services/index.d.ts.map +1 -1
  20. package/dist/packages/core/src/application/ports/output/services/settings-reader.interface.d.ts +13 -0
  21. package/dist/packages/core/src/application/ports/output/services/settings-reader.interface.d.ts.map +1 -0
  22. package/dist/packages/core/src/application/ports/output/services/settings-reader.interface.js +1 -0
  23. package/dist/packages/core/src/application/use-cases/agents/configure-agent.use-case.d.ts.map +1 -1
  24. package/dist/packages/core/src/application/use-cases/agents/configure-agent.use-case.js +4 -6
  25. package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.d.ts.map +1 -1
  26. package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.js +1 -0
  27. package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.d.ts.map +1 -1
  28. package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.js +2 -0
  29. package/dist/packages/core/src/application/use-cases/features/create/types.d.ts +2 -0
  30. package/dist/packages/core/src/application/use-cases/features/create/types.d.ts.map +1 -1
  31. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.d.ts.map +1 -1
  32. package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.js +1 -0
  33. package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.d.ts.map +1 -1
  34. package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.js +1 -0
  35. package/dist/packages/core/src/application/use-cases/settings/complete-onboarding.use-case.d.ts +2 -0
  36. package/dist/packages/core/src/application/use-cases/settings/complete-onboarding.use-case.d.ts.map +1 -1
  37. package/dist/packages/core/src/application/use-cases/settings/complete-onboarding.use-case.js +23 -0
  38. package/dist/packages/core/src/domain/factories/settings-defaults.factory.d.ts.map +1 -1
  39. package/dist/packages/core/src/domain/factories/settings-defaults.factory.js +9 -1
  40. package/dist/packages/core/src/domain/generated/output.d.ts +68 -2
  41. package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
  42. package/dist/packages/core/src/domain/generated/output.js +36 -1
  43. package/dist/packages/core/src/infrastructure/di/modules/agents.module.d.ts.map +1 -1
  44. package/dist/packages/core/src/infrastructure/di/modules/agents.module.js +4 -2
  45. package/dist/packages/core/src/infrastructure/di/modules/services.module.d.ts.map +1 -1
  46. package/dist/packages/core/src/infrastructure/di/modules/services.module.js +2 -0
  47. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.d.ts +1 -0
  48. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.d.ts.map +1 -1
  49. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.js +4 -0
  50. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +6 -0
  51. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
  52. package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +31 -0
  53. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/052-add-agent-permission-modes.d.ts +21 -0
  54. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/052-add-agent-permission-modes.d.ts.map +1 -0
  55. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/052-add-agent-permission-modes.js +35 -0
  56. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-feature-permission-mode.d.ts +14 -0
  57. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-feature-permission-mode.d.ts.map +1 -0
  58. package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-feature-permission-mode.js +19 -0
  59. package/dist/packages/core/src/infrastructure/services/agents/analyze-repo/analyze-repository-graph.d.ts +3 -1
  60. package/dist/packages/core/src/infrastructure/services/agents/analyze-repo/analyze-repository-graph.d.ts.map +1 -1
  61. package/dist/packages/core/src/infrastructure/services/agents/analyze-repo/analyze-repository-graph.js +18 -7
  62. package/dist/packages/core/src/infrastructure/services/agents/common/agent-executor-factory.service.d.ts +1 -1
  63. package/dist/packages/core/src/infrastructure/services/agents/common/agent-executor-factory.service.d.ts.map +1 -1
  64. package/dist/packages/core/src/infrastructure/services/agents/common/agent-executor-factory.service.js +1 -6
  65. package/dist/packages/core/src/infrastructure/services/agents/common/agent-permissions.d.ts +21 -0
  66. package/dist/packages/core/src/infrastructure/services/agents/common/agent-permissions.d.ts.map +1 -0
  67. package/dist/packages/core/src/infrastructure/services/agents/common/agent-permissions.js +49 -0
  68. package/dist/packages/core/src/infrastructure/services/agents/common/agent-runner.service.d.ts +3 -1
  69. package/dist/packages/core/src/infrastructure/services/agents/common/agent-runner.service.d.ts.map +1 -1
  70. package/dist/packages/core/src/infrastructure/services/agents/common/agent-runner.service.js +4 -3
  71. package/dist/packages/core/src/infrastructure/services/agents/common/agent-validator.service.d.ts.map +1 -1
  72. package/dist/packages/core/src/infrastructure/services/agents/common/agent-validator.service.js +0 -3
  73. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.d.ts.map +1 -1
  74. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.js +11 -0
  75. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-interactive-executor.service.d.ts.map +1 -1
  76. package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-interactive-executor.service.js +1 -1
  77. package/dist/packages/core/src/infrastructure/services/agents/common/executors/codex-cli-executor.service.d.ts.map +1 -1
  78. package/dist/packages/core/src/infrastructure/services/agents/common/executors/codex-cli-executor.service.js +4 -1
  79. package/dist/packages/core/src/infrastructure/services/agents/common/executors/copilot-cli-executor.service.d.ts.map +1 -1
  80. package/dist/packages/core/src/infrastructure/services/agents/common/executors/copilot-cli-executor.service.js +11 -4
  81. package/dist/packages/core/src/infrastructure/services/agents/common/executors/cursor-executor.service.d.ts.map +1 -1
  82. package/dist/packages/core/src/infrastructure/services/agents/common/executors/cursor-executor.service.js +11 -1
  83. package/dist/packages/core/src/infrastructure/services/agents/common/executors/gemini-cli-executor.service.d.ts.map +1 -1
  84. package/dist/packages/core/src/infrastructure/services/agents/common/executors/gemini-cli-executor.service.js +2 -1
  85. package/dist/packages/core/src/infrastructure/services/agents/common/executors/rovo-dev-executor.service.d.ts.map +1 -1
  86. package/dist/packages/core/src/infrastructure/services/agents/common/executors/rovo-dev-executor.service.js +11 -4
  87. package/dist/packages/core/src/infrastructure/services/agents/common/structured-agent-caller.service.d.ts +3 -1
  88. package/dist/packages/core/src/infrastructure/services/agents/common/structured-agent-caller.service.d.ts.map +1 -1
  89. package/dist/packages/core/src/infrastructure/services/agents/common/structured-agent-caller.service.js +13 -6
  90. package/dist/packages/core/src/infrastructure/services/agents/conflict-resolution/conflict-resolution.service.d.ts +3 -1
  91. package/dist/packages/core/src/infrastructure/services/agents/conflict-resolution/conflict-resolution.service.d.ts.map +1 -1
  92. package/dist/packages/core/src/infrastructure/services/agents/conflict-resolution/conflict-resolution.service.js +12 -3
  93. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts +5 -0
  94. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts.map +1 -1
  95. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts +18 -1
  96. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts.map +1 -1
  97. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts +1 -0
  98. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts.map +1 -1
  99. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.js +3 -0
  100. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts +1 -0
  101. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts.map +1 -1
  102. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.js +8 -0
  103. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/evidence.node.d.ts +3 -1
  104. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/evidence.node.d.ts.map +1 -1
  105. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/evidence.node.js +3 -2
  106. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/ci-watch-fix-loop.d.ts +3 -0
  107. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/ci-watch-fix-loop.d.ts.map +1 -1
  108. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/ci-watch-fix-loop.js +1 -1
  109. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.d.ts +3 -0
  110. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.d.ts.map +1 -1
  111. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.js +2 -1
  112. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts +11 -3
  113. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts.map +1 -1
  114. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.js +20 -5
  115. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/repair.node.d.ts.map +1 -1
  116. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/repair.node.js +6 -0
  117. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts +1 -0
  118. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts.map +1 -1
  119. package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.js +4 -0
  120. package/dist/packages/core/src/infrastructure/services/settings-reader.service.d.ts +7 -0
  121. package/dist/packages/core/src/infrastructure/services/settings-reader.service.d.ts.map +1 -0
  122. package/dist/packages/core/src/infrastructure/services/settings-reader.service.js +25 -0
  123. package/dist/src/presentation/cli/commands/feat/new.command.d.ts.map +1 -1
  124. package/dist/src/presentation/cli/commands/feat/new.command.js +18 -0
  125. package/dist/src/presentation/cli/commands/feat/show.command.d.ts.map +1 -1
  126. package/dist/src/presentation/cli/commands/feat/show.command.js +2 -1
  127. package/dist/src/presentation/cli/commands/settings/agent.command.js +2 -2
  128. package/dist/src/presentation/cli/commands/settings/index.d.ts.map +1 -1
  129. package/dist/src/presentation/cli/commands/settings/index.js +3 -1
  130. package/dist/src/presentation/cli/commands/settings/permission-modes.d.ts +19 -0
  131. package/dist/src/presentation/cli/commands/settings/permission-modes.d.ts.map +1 -0
  132. package/dist/src/presentation/cli/commands/settings/permission-modes.js +38 -0
  133. package/dist/src/presentation/cli/commands/settings/permissions.command.d.ts +16 -0
  134. package/dist/src/presentation/cli/commands/settings/permissions.command.d.ts.map +1 -0
  135. package/dist/src/presentation/cli/commands/settings/permissions.command.js +147 -0
  136. package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts +4 -10
  137. package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts.map +1 -1
  138. package/dist/src/presentation/tui/prompts/agent-select.prompt.js +8 -13
  139. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts +5 -3
  140. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts.map +1 -1
  141. package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.js +10 -5
  142. package/dist/src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.d.ts +17 -0
  143. package/dist/src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.d.ts.map +1 -0
  144. package/dist/src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.js +48 -0
  145. package/dist/src/presentation/tui/wizards/onboarding/types.d.ts +2 -0
  146. package/dist/src/presentation/tui/wizards/onboarding/types.d.ts.map +1 -1
  147. package/dist/src/presentation/web/app/actions/agent-permissions.d.ts +14 -0
  148. package/dist/src/presentation/web/app/actions/agent-permissions.d.ts.map +1 -0
  149. package/dist/src/presentation/web/app/actions/agent-permissions.js +181 -0
  150. package/dist/src/presentation/web/app/actions/check-agent-auth.d.ts.map +1 -1
  151. package/dist/src/presentation/web/app/actions/check-agent-auth.js +2 -5
  152. package/dist/src/presentation/web/app/actions/check-agent-tool.js +1 -1
  153. package/dist/src/presentation/web/app/actions/get-all-agent-models.d.ts.map +1 -1
  154. package/dist/src/presentation/web/app/actions/get-all-agent-models.js +2 -17
  155. package/dist/src/presentation/web/app/actions/get-merge-review-data.d.ts.map +1 -1
  156. package/dist/src/presentation/web/app/actions/get-merge-review-data.js +5 -0
  157. package/dist/src/presentation/web/app/actions/open-shell.d.ts.map +1 -1
  158. package/dist/src/presentation/web/app/actions/open-shell.js +5 -0
  159. package/dist/src/presentation/web/components/common/base-drawer/base-drawer.d.ts.map +1 -1
  160. package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +43 -9
  161. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
  162. package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +1 -1
  163. package/dist/src/presentation/web/components/common/feature-create-drawer/types.d.ts +2 -0
  164. package/dist/src/presentation/web/components/common/feature-create-drawer/types.d.ts.map +1 -1
  165. package/dist/src/presentation/web/components/common/feature-create-drawer/use-feature-create-form.d.ts +2 -0
  166. package/dist/src/presentation/web/components/common/feature-create-drawer/use-feature-create-form.d.ts.map +1 -1
  167. package/dist/src/presentation/web/components/common/feature-create-drawer/use-feature-create-form.js +6 -0
  168. package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.d.ts +7 -1
  169. package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.d.ts.map +1 -1
  170. package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.js +24 -3
  171. package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.stories.d.ts.map +1 -1
  172. package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.stories.js +3 -0
  173. package/dist/src/presentation/web/components/common/feature-list-item/feature-list-item.stories.js +2 -2
  174. package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.d.ts +2 -2
  175. package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.d.ts.map +1 -1
  176. package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.js +4 -11
  177. package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.stories.d.ts +1 -1
  178. package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.stories.d.ts.map +1 -1
  179. package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.stories.js +5 -6
  180. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +2 -0
  181. package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
  182. package/dist/src/presentation/web/components/common/feature-node/feature-node.d.ts.map +1 -1
  183. package/dist/src/presentation/web/components/common/feature-node/feature-node.js +2 -2
  184. package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.js +10 -10
  185. package/dist/src/presentation/web/components/features/control-center/control-center.stories.js +1 -1
  186. package/dist/src/presentation/web/components/features/features-canvas/features-canvas.stories.js +2 -2
  187. package/dist/src/presentation/web/components/features/settings/AgentModelPicker/AgentModelPicker.stories.d.ts +1 -1
  188. package/dist/src/presentation/web/components/features/settings/AgentModelPicker/AgentModelPicker.stories.d.ts.map +1 -1
  189. package/dist/src/presentation/web/components/features/settings/AgentModelPicker/AgentModelPicker.stories.js +3 -3
  190. package/dist/src/presentation/web/components/features/settings/agent-permission-picker.d.ts +8 -0
  191. package/dist/src/presentation/web/components/features/settings/agent-permission-picker.d.ts.map +1 -0
  192. package/dist/src/presentation/web/components/features/settings/agent-permission-picker.js +33 -0
  193. package/dist/src/presentation/web/components/features/settings/agent-permission-picker.stories.d.ts +15 -0
  194. package/dist/src/presentation/web/components/features/settings/agent-permission-picker.stories.d.ts.map +1 -0
  195. package/dist/src/presentation/web/components/features/settings/agent-permission-picker.stories.js +75 -0
  196. package/dist/src/presentation/web/components/features/settings/agent-settings-section.d.ts.map +1 -1
  197. package/dist/src/presentation/web/components/features/settings/agent-settings-section.js +32 -4
  198. package/dist/src/presentation/web/components/features/settings/agent-settings-section.stories.d.ts +1 -1
  199. package/dist/src/presentation/web/components/features/settings/agent-settings-section.stories.d.ts.map +1 -1
  200. package/dist/src/presentation/web/components/features/settings/agent-settings-section.stories.js +2 -2
  201. package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.stories.js +2 -2
  202. package/dist/src/presentation/web/lib/path-sanitizers.d.ts.map +1 -1
  203. package/dist/src/presentation/web/lib/path-sanitizers.js +5 -0
  204. package/dist/translations/ar/cli.json +16 -0
  205. package/dist/translations/ar/tui.json +12 -10
  206. package/dist/translations/ar/web.json +15 -0
  207. package/dist/translations/de/cli.json +16 -0
  208. package/dist/translations/de/tui.json +13 -5
  209. package/dist/translations/de/web.json +15 -0
  210. package/dist/translations/en/cli.json +16 -0
  211. package/dist/translations/en/tui.json +12 -10
  212. package/dist/translations/en/web.json +15 -0
  213. package/dist/translations/es/cli.json +16 -0
  214. package/dist/translations/es/tui.json +12 -10
  215. package/dist/translations/es/web.json +15 -0
  216. package/dist/translations/fr/cli.json +16 -0
  217. package/dist/translations/fr/tui.json +12 -10
  218. package/dist/translations/fr/web.json +15 -0
  219. package/dist/translations/he/cli.json +16 -0
  220. package/dist/translations/he/tui.json +12 -10
  221. package/dist/translations/he/web.json +15 -0
  222. package/dist/translations/pt/cli.json +16 -0
  223. package/dist/translations/pt/tui.json +12 -10
  224. package/dist/translations/pt/web.json +15 -0
  225. package/dist/translations/ru/cli.json +16 -0
  226. package/dist/translations/ru/tui.json +12 -10
  227. package/dist/translations/ru/web.json +15 -0
  228. package/dist/tsconfig.build.tsbuildinfo +1 -1
  229. package/package.json +1 -1
  230. package/web/.next/BUILD_ID +1 -1
  231. package/web/.next/build-manifest.json +3 -3
  232. package/web/.next/fallback-build-manifest.json +3 -3
  233. package/web/.next/prerender-manifest.json +3 -3
  234. package/web/.next/required-server-files.js +2 -2
  235. package/web/.next/required-server-files.json +2 -2
  236. package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +29 -29
  237. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +2 -3
  238. package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
  239. package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
  240. package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +27 -27
  241. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js +2 -3
  242. package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
  243. package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
  244. package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +72 -60
  245. package/web/.next/server/app/(dashboard)/@drawer/create/page.js +3 -3
  246. package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
  247. package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
  248. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +37 -37
  249. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +3 -4
  250. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  251. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  252. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +37 -37
  253. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +3 -4
  254. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
  255. package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
  256. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +28 -28
  257. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js +2 -3
  258. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  259. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  260. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +28 -28
  261. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +2 -3
  262. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
  263. package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  264. package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +27 -27
  265. package/web/.next/server/app/(dashboard)/chat/page.js +2 -3
  266. package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
  267. package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
  268. package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +72 -60
  269. package/web/.next/server/app/(dashboard)/create/page.js +3 -3
  270. package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
  271. package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
  272. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +37 -37
  273. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +3 -4
  274. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
  275. package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
  276. package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +37 -37
  277. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +3 -4
  278. package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
  279. package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
  280. package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +27 -27
  281. package/web/.next/server/app/(dashboard)/page.js +2 -3
  282. package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
  283. package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
  284. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +28 -28
  285. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js +2 -3
  286. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
  287. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
  288. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +28 -28
  289. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +2 -3
  290. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
  291. package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
  292. package/web/.next/server/app/_global-error.html +1 -1
  293. package/web/.next/server/app/_global-error.rsc +1 -1
  294. package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  295. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  296. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  297. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  298. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  299. package/web/.next/server/app/_not-found/page/server-reference-manifest.json +6 -6
  300. package/web/.next/server/app/_not-found/page.js +2 -3
  301. package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
  302. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  303. package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
  304. package/web/.next/server/app/api/dialog/pick-files/route.js.nft.json +1 -1
  305. package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
  306. package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
  307. package/web/.next/server/app/api/interactive/chat/[featureId]/messages/route.js.nft.json +1 -1
  308. package/web/.next/server/app/settings/page/server-reference-manifest.json +11 -11
  309. package/web/.next/server/app/settings/page.js +3 -4
  310. package/web/.next/server/app/settings/page.js.nft.json +1 -1
  311. package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  312. package/web/.next/server/app/skills/page/server-reference-manifest.json +11 -11
  313. package/web/.next/server/app/skills/page.js +3 -3
  314. package/web/.next/server/app/skills/page.js.nft.json +1 -1
  315. package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
  316. package/web/.next/server/app/tools/page/server-reference-manifest.json +11 -11
  317. package/web/.next/server/app/tools/page.js +3 -3
  318. package/web/.next/server/app/tools/page.js.nft.json +1 -1
  319. package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
  320. package/web/.next/server/app/version/page/server-reference-manifest.json +6 -6
  321. package/web/.next/server/app/version/page.js +2 -3
  322. package/web/.next/server/app/version/page.js.nft.json +1 -1
  323. package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
  324. package/web/.next/server/chunks/11es_next_dist_esm_build_templates_app-route_067cwst.js +1 -1
  325. package/web/.next/server/chunks/11es_next_dist_esm_build_templates_app-route_067cwst.js.map +1 -1
  326. package/web/.next/server/chunks/[root-of-the-server]__0_-chcy._.js.map +1 -1
  327. package/web/.next/server/chunks/[root-of-the-server]__0e9p7em._.js.map +1 -1
  328. package/web/.next/server/chunks/[root-of-the-server]__0tb~wwk._.js +1 -1
  329. package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_create-drawer-client_tsx_0g70fc5._.js +1 -1
  330. package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_create-drawer-client_tsx_0g70fc5._.js.map +1 -1
  331. package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_feature-drawer-client_tsx_104cna.._.js +2 -2
  332. package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_feature-drawer-client_tsx_104cna.._.js.map +1 -1
  333. package/web/.next/server/chunks/ssr/0ukq_presentation_web_components_features_settings_settings-page-client_tsx_0j1uius._.js +1 -1
  334. package/web/.next/server/chunks/ssr/0ukq_presentation_web_components_features_settings_settings-page-client_tsx_0j1uius._.js.map +1 -1
  335. package/web/.next/server/chunks/ssr/{_01mq~sm._.js → 11es_next_0q-kz~8._.js} +2 -2
  336. package/web/.next/server/chunks/ssr/11es_next_0q-kz~8._.js.map +1 -0
  337. package/web/.next/server/chunks/ssr/11y9_components_common_control-center-drawer_repository-drawer-client_tsx_09z.znp._.js +1 -1
  338. package/web/.next/server/chunks/ssr/11y9_components_common_control-center-drawer_repository-drawer-client_tsx_09z.znp._.js.map +1 -1
  339. package/web/.next/server/chunks/ssr/[root-of-the-server]__02.89uf._.js +4 -0
  340. package/web/.next/server/chunks/ssr/[root-of-the-server]__02.89uf._.js.map +1 -0
  341. package/web/.next/server/chunks/ssr/[root-of-the-server]__04rq9lr._.js +4 -0
  342. package/web/.next/server/chunks/ssr/[root-of-the-server]__04rq9lr._.js.map +1 -0
  343. package/web/.next/server/chunks/ssr/[root-of-the-server]__05_qc0n._.js +4 -0
  344. package/web/.next/server/chunks/ssr/[root-of-the-server]__05_qc0n._.js.map +1 -0
  345. package/web/.next/server/chunks/ssr/[root-of-the-server]__0c0xoi_._.js +3 -0
  346. package/web/.next/server/chunks/ssr/[root-of-the-server]__0c0xoi_._.js.map +1 -0
  347. package/web/.next/server/chunks/ssr/[root-of-the-server]__0r5zhk.._.js +4 -0
  348. package/web/.next/server/chunks/ssr/[root-of-the-server]__0r5zhk.._.js.map +1 -0
  349. package/web/.next/server/chunks/ssr/[root-of-the-server]__0rv1gci._.js +1 -1
  350. package/web/.next/server/chunks/ssr/[root-of-the-server]__0rvrr1j._.js +4 -0
  351. package/web/.next/server/chunks/ssr/[root-of-the-server]__0rvrr1j._.js.map +1 -0
  352. package/web/.next/server/chunks/ssr/[root-of-the-server]__0tq2syh._.js +4 -0
  353. package/web/.next/server/chunks/ssr/[root-of-the-server]__0tq2syh._.js.map +1 -0
  354. package/web/.next/server/chunks/ssr/[root-of-the-server]__0uy_5rw._.js +4 -0
  355. package/web/.next/server/chunks/ssr/[root-of-the-server]__0uy_5rw._.js.map +1 -0
  356. package/web/.next/server/chunks/ssr/[root-of-the-server]__12j29w-._.js +4 -0
  357. package/web/.next/server/chunks/ssr/[root-of-the-server]__12j29w-._.js.map +1 -0
  358. package/web/.next/server/chunks/ssr/{_04rrcmm._.js → _0-.ckn5._.js} +2 -2
  359. package/web/.next/server/chunks/ssr/_0-.ckn5._.js.map +1 -0
  360. package/web/.next/server/chunks/ssr/_00k65h-._.js.map +1 -1
  361. package/web/.next/server/chunks/ssr/_01sesw0._.js +1 -1
  362. package/web/.next/server/chunks/ssr/_01sesw0._.js.map +1 -1
  363. package/web/.next/server/chunks/ssr/_069y.js._.js +6 -0
  364. package/web/.next/server/chunks/ssr/_069y.js._.js.map +1 -0
  365. package/web/.next/server/chunks/ssr/_0__4si~._.js +4 -0
  366. package/web/.next/server/chunks/ssr/_0__4si~._.js.map +1 -0
  367. package/web/.next/server/chunks/ssr/_0_m17kl._.js +4 -0
  368. package/web/.next/server/chunks/ssr/_0_m17kl._.js.map +1 -0
  369. package/web/.next/server/chunks/ssr/_0aaotn-._.js +3 -0
  370. package/web/.next/server/chunks/ssr/_0aaotn-._.js.map +1 -0
  371. package/web/.next/server/chunks/ssr/_0d4miu.._.js +4 -0
  372. package/web/.next/server/chunks/ssr/_0d4miu.._.js.map +1 -0
  373. package/web/.next/server/chunks/ssr/_0e8ern9._.js +4 -0
  374. package/web/.next/server/chunks/ssr/_0e8ern9._.js.map +1 -0
  375. package/web/.next/server/chunks/ssr/{_109n-y4._.js → _0n.magx._.js} +2 -2
  376. package/web/.next/server/chunks/ssr/_0n.magx._.js.map +1 -0
  377. package/web/.next/server/chunks/ssr/_0p3~u8u._.js +6 -0
  378. package/web/.next/server/chunks/ssr/_0p3~u8u._.js.map +1 -0
  379. package/web/.next/server/chunks/ssr/_0r.3n~3._.js +4 -0
  380. package/web/.next/server/chunks/ssr/_0r.3n~3._.js.map +1 -0
  381. package/web/.next/server/chunks/ssr/_0t59q8r._.js +4 -0
  382. package/web/.next/server/chunks/ssr/_0t59q8r._.js.map +1 -0
  383. package/web/.next/server/chunks/ssr/_0tcccbb._.js +3 -0
  384. package/web/.next/server/chunks/ssr/_0tcccbb._.js.map +1 -0
  385. package/web/.next/server/chunks/ssr/_0vyfc4b._.js +1 -1
  386. package/web/.next/server/chunks/ssr/_0vyfc4b._.js.map +1 -1
  387. package/web/.next/server/chunks/ssr/_0w-_hww._.js +1 -1
  388. package/web/.next/server/chunks/ssr/_0w-_hww._.js.map +1 -1
  389. package/web/.next/server/chunks/ssr/_0zk-h5w._.js +4 -0
  390. package/web/.next/server/chunks/ssr/_0zk-h5w._.js.map +1 -0
  391. package/web/.next/server/chunks/ssr/_0~7lwu_._.js +1 -1
  392. package/web/.next/server/chunks/ssr/_0~7lwu_._.js.map +1 -1
  393. package/web/.next/server/chunks/ssr/_1161g9x._.js +4 -0
  394. package/web/.next/server/chunks/ssr/_1161g9x._.js.map +1 -0
  395. package/web/.next/server/chunks/ssr/{_0c497sr._.js → _138qywk._.js} +2 -2
  396. package/web/.next/server/chunks/ssr/{_0c497sr._.js.map → _138qywk._.js.map} +1 -1
  397. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_05m2q~u.js +3 -0
  398. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_05m2q~u.js.map +1 -0
  399. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_0.6zk.t.js +3 -0
  400. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_0.6zk.t.js.map +1 -0
  401. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_approve-feature_ts_0pjb_re._.js +1 -1
  402. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_approve-feature_ts_0pjb_re._.js.map +1 -1
  403. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_0w2wqvu._.js +1 -1
  404. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_0w2wqvu._.js.map +1 -1
  405. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_0l3oxx9._.js +1 -1
  406. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_0l3oxx9._.js.map +1 -1
  407. package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_0aji.op._.js +1 -1
  408. package/web/.next/server/middleware-build-manifest.js +3 -3
  409. package/web/.next/server/pages/500.html +1 -1
  410. package/web/.next/server/server-reference-manifest.js +1 -1
  411. package/web/.next/server/server-reference-manifest.json +127 -109
  412. package/web/.next/static/chunks/0-woqr2brccx_.js +3 -0
  413. package/web/.next/static/chunks/{0ex35-_jtxyjc.js → 022nrd6snse79.js} +1 -1
  414. package/web/.next/static/chunks/{0t_6hx6ul7umb.js → 02phgt~f2c-2q.js} +1 -1
  415. package/web/.next/static/chunks/{0whez3wju~9ok.js → 03s7z6w1lj0w~.js} +1 -1
  416. package/web/.next/static/chunks/04~sw.nhpwy6s.css +1 -0
  417. package/web/.next/static/chunks/05enics63g._-.js +7 -0
  418. package/web/.next/static/chunks/08611baheit.t.js +1 -0
  419. package/web/.next/static/chunks/0_9k2ybutuphq.js +1 -0
  420. package/web/.next/static/chunks/{0oq-cvtg8rjjp.js → 0j.wph28jrce1.js} +1 -1
  421. package/web/.next/static/chunks/{0k~55i.ofbdeb.js → 0ls0v8h_qbctm.js} +1 -1
  422. package/web/.next/static/chunks/0ma7k9iohb3bb.js +1 -0
  423. package/web/.next/static/chunks/0ps5sykbi-z5-.js +1 -0
  424. package/web/.next/static/chunks/{0c_bi0dck80dt.js → 0q7ohuqneuur4.js} +1 -1
  425. package/web/.next/static/chunks/{07gx-h_y91lay.js → 0q8ax~44oybo2.js} +2 -2
  426. package/web/.next/static/chunks/15rbgqykl.er8.js +1 -0
  427. package/web/.next/static/chunks/{04xk1iouwcfcq.js → 17z2sq7c5z8cr.js} +3 -3
  428. package/dist/packages/core/src/infrastructure/services/agents/common/executors/dev-executor.service.d.ts +0 -12
  429. package/dist/packages/core/src/infrastructure/services/agents/common/executors/dev-executor.service.d.ts.map +0 -1
  430. package/dist/packages/core/src/infrastructure/services/agents/common/executors/dev-executor.service.js +0 -233
  431. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/plan.fixture.d.ts +0 -8
  432. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/plan.fixture.d.ts.map +0 -1
  433. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/plan.fixture.js +0 -94
  434. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/research.fixture.d.ts +0 -8
  435. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/research.fixture.d.ts.map +0 -1
  436. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/research.fixture.js +0 -140
  437. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-analyze.fixture.d.ts +0 -8
  438. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-analyze.fixture.d.ts.map +0 -1
  439. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-analyze.fixture.js +0 -81
  440. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-requirements.fixture.d.ts +0 -8
  441. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-requirements.fixture.d.ts.map +0 -1
  442. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-requirements.fixture.js +0 -131
  443. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/tasks.fixture.d.ts +0 -6
  444. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/tasks.fixture.d.ts.map +0 -1
  445. package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/tasks.fixture.js +0 -146
  446. package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_adopt_page_actions_00~eq5i.js +0 -3
  447. package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_adopt_page_actions_00~eq5i.js.map +0 -1
  448. package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_chat_page_actions_0979_c..js +0 -3
  449. package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_chat_page_actions_0979_c..js.map +0 -1
  450. package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_chat_page_actions_0dqll_1.js +0 -3
  451. package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_chat_page_actions_0dqll_1.js.map +0 -1
  452. package/web/.next/server/chunks/ssr/[root-of-the-server]__04nnbmc._.js +0 -3
  453. package/web/.next/server/chunks/ssr/[root-of-the-server]__04nnbmc._.js.map +0 -1
  454. package/web/.next/server/chunks/ssr/[root-of-the-server]__07740t6._.js +0 -3
  455. package/web/.next/server/chunks/ssr/[root-of-the-server]__07740t6._.js.map +0 -1
  456. package/web/.next/server/chunks/ssr/[root-of-the-server]__0l~puw4._.js +0 -3
  457. package/web/.next/server/chunks/ssr/[root-of-the-server]__0l~puw4._.js.map +0 -1
  458. package/web/.next/server/chunks/ssr/[root-of-the-server]__0o3qggc._.js +0 -3
  459. package/web/.next/server/chunks/ssr/[root-of-the-server]__0o3qggc._.js.map +0 -1
  460. package/web/.next/server/chunks/ssr/[root-of-the-server]__0vwjc_m._.js +0 -3
  461. package/web/.next/server/chunks/ssr/[root-of-the-server]__0vwjc_m._.js.map +0 -1
  462. package/web/.next/server/chunks/ssr/[root-of-the-server]__0w4__yd._.js +0 -4
  463. package/web/.next/server/chunks/ssr/[root-of-the-server]__0w4__yd._.js.map +0 -1
  464. package/web/.next/server/chunks/ssr/_0.rsra~._.js +0 -3
  465. package/web/.next/server/chunks/ssr/_0.rsra~._.js.map +0 -1
  466. package/web/.next/server/chunks/ssr/_01mq~sm._.js.map +0 -1
  467. package/web/.next/server/chunks/ssr/_04rrcmm._.js.map +0 -1
  468. package/web/.next/server/chunks/ssr/_0c741v_._.js +0 -3
  469. package/web/.next/server/chunks/ssr/_0c741v_._.js.map +0 -1
  470. package/web/.next/server/chunks/ssr/_0jpbsh_._.js +0 -4
  471. package/web/.next/server/chunks/ssr/_0jpbsh_._.js.map +0 -1
  472. package/web/.next/server/chunks/ssr/_109n-y4._.js.map +0 -1
  473. package/web/.next/server/chunks/ssr/src_presentation_web_0.e4~xc._.js +0 -3
  474. package/web/.next/server/chunks/ssr/src_presentation_web_0.e4~xc._.js.map +0 -1
  475. package/web/.next/server/chunks/ssr/src_presentation_web_00dvh.m._.js +0 -3
  476. package/web/.next/server/chunks/ssr/src_presentation_web_00dvh.m._.js.map +0 -1
  477. package/web/.next/server/chunks/ssr/src_presentation_web_06b6~lt._.js +0 -5
  478. package/web/.next/server/chunks/ssr/src_presentation_web_06b6~lt._.js.map +0 -1
  479. package/web/.next/server/chunks/ssr/src_presentation_web_08fy2mf._.js +0 -3
  480. package/web/.next/server/chunks/ssr/src_presentation_web_08fy2mf._.js.map +0 -1
  481. package/web/.next/server/chunks/ssr/src_presentation_web_0f~udu1._.js +0 -3
  482. package/web/.next/server/chunks/ssr/src_presentation_web_0f~udu1._.js.map +0 -1
  483. package/web/.next/server/chunks/ssr/src_presentation_web_0qys821._.js +0 -5
  484. package/web/.next/server/chunks/ssr/src_presentation_web_0qys821._.js.map +0 -1
  485. package/web/.next/server/chunks/ssr/src_presentation_web_0q~dt0o._.js +0 -3
  486. package/web/.next/server/chunks/ssr/src_presentation_web_0q~dt0o._.js.map +0 -1
  487. package/web/.next/server/chunks/ssr/src_presentation_web_11jrkxt._.js +0 -3
  488. package/web/.next/server/chunks/ssr/src_presentation_web_11jrkxt._.js.map +0 -1
  489. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_(dashboard)_page_actions_1199d3x.js +0 -3
  490. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_(dashboard)_page_actions_1199d3x.js.map +0 -1
  491. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app__not-found_page_actions_0m2jqxx.js +0 -3
  492. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app__not-found_page_actions_0m2jqxx.js.map +0 -1
  493. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_version_page_actions_0krkh_0.js +0 -3
  494. package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_version_page_actions_0krkh_0.js.map +0 -1
  495. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_load-settings_ts_0b8f3pf._.js +0 -3
  496. package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_load-settings_ts_0b8f3pf._.js.map +0 -1
  497. package/web/.next/static/chunks/0-fy~80ui.5os.js +0 -7
  498. package/web/.next/static/chunks/039ic1ygq-to3.js +0 -1
  499. package/web/.next/static/chunks/07a4jt64wdipb.js +0 -1
  500. package/web/.next/static/chunks/0_imq4rg3q.fe.js +0 -3
  501. package/web/.next/static/chunks/0i084mozx131g.js +0 -1
  502. package/web/.next/static/chunks/0j_0i2qsrwh-c.js +0 -1
  503. package/web/.next/static/chunks/0r5dju6f1-i38.css +0 -1
  504. /package/web/.next/static/{ynyh_sSxbFA995FRvBUxs → GSG_c1emY-f_AA00vD56y}/_buildManifest.js +0 -0
  505. /package/web/.next/static/{ynyh_sSxbFA995FRvBUxs → GSG_c1emY-f_AA00vD56y}/_clientMiddlewareManifest.js +0 -0
  506. /package/web/.next/static/{ynyh_sSxbFA995FRvBUxs → GSG_c1emY-f_AA00vD56y}/_ssgManifest.js +0 -0
@@ -0,0 +1,25 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { injectable } from 'tsyringe';
8
+ import { getSettings, hasSettings } from './settings.service.js';
9
+ let SettingsReaderService = class SettingsReaderService {
10
+ hasSettings() {
11
+ return hasSettings();
12
+ }
13
+ getSettings() {
14
+ try {
15
+ return getSettings();
16
+ }
17
+ catch {
18
+ return undefined;
19
+ }
20
+ }
21
+ };
22
+ SettingsReaderService = __decorate([
23
+ injectable()
24
+ ], SettingsReaderService);
25
+ export { SettingsReaderService };
@@ -1 +1 @@
1
- {"version":3,"file":"new.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/new.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAwEpC;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,OAAO,CAoK1C"}
1
+ {"version":3,"file":"new.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/new.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AA0EpC;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,OAAO,CAwL1C"}
@@ -21,6 +21,7 @@ import { getCliI18n } from '../../i18n.js';
21
21
  import { getShipitAiHomeDir } from '../../../../../packages/core/src/infrastructure/services/filesystem/shipit-ai-directory.service.js';
22
22
  import { getSettings, hasSettings } from '../../../../../packages/core/src/infrastructure/services/settings.service.js';
23
23
  import { CheckOnboardingStatusUseCase } from '../../../../../packages/core/src/application/use-cases/settings/check-onboarding-status.use-case.js';
24
+ import { getValidModesForAgent } from '../settings/permission-modes.js';
24
25
  import { onboardingWizard } from '../../../tui/wizards/onboarding/onboarding.wizard.js';
25
26
  /** Commander collect pattern for repeatable options. */
26
27
  function collect(value, previous) {
@@ -71,6 +72,7 @@ export function createNewCommand() {
71
72
  .option('--model <model>', t('cli:commands.feat.new.modelOption'))
72
73
  .option('--no-rebase', t('cli:commands.feat.new.noRebaseOption'))
73
74
  .option('--attach <path>', t('cli:commands.feat.new.attachOption'), collect, [])
75
+ .option('--permission-mode <mode>', t('cli:commands.feat.new.permissionModeOption'))
74
76
  .action(async (description, options) => {
75
77
  try {
76
78
  // First-run onboarding gate — only for interactive terminals
@@ -121,6 +123,21 @@ export function createNewCommand() {
121
123
  }
122
124
  }
123
125
  const fast = options.fast ?? defaults.fast;
126
+ // Validate --permission-mode against configured agent's valid modes
127
+ if (options.permissionMode !== undefined) {
128
+ const settings = getSettings();
129
+ const agentType = settings.agent.type;
130
+ const validModes = getValidModesForAgent(agentType);
131
+ if (!validModes.includes(options.permissionMode)) {
132
+ messages.error(t('cli:commands.settings.permissions.invalidMode', {
133
+ mode: options.permissionMode,
134
+ agent: agentType,
135
+ validModes: validModes.join(', '),
136
+ }));
137
+ process.exitCode = 1;
138
+ return;
139
+ }
140
+ }
124
141
  const result = await spinner(t('cli:commands.feat.new.spinnerText'), () => useCase.execute({
125
142
  userInput: description,
126
143
  repositoryPath: repoPath,
@@ -132,6 +149,7 @@ export function createNewCommand() {
132
149
  ...(fast && { fast: true }),
133
150
  ...(options.model !== undefined && { model: options.model }),
134
151
  ...(attachmentPaths.length > 0 && { attachmentPaths }),
152
+ ...(options.permissionMode !== undefined && { permissionMode: options.permissionMode }),
135
153
  rebaseBeforeBranch: options.rebase,
136
154
  }));
137
155
  const { feature, warning } = result;
@@ -1 +1 @@
1
- {"version":3,"file":"show.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/show.command.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,OAAO,KAAK,EAEV,QAAQ,EACR,WAAW,EACX,sBAAsB,EACvB,MAAM,8BAA8B,CAAC;AA4OtC;;;GAGG;AACH,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,WAAW,EAAE,EACtB,UAAU,EAAE,QAAQ,GAAG,IAAI,EAC3B,UAAU,GAAE,sBAAsB,EAAO,GACxC,MAAM,EAAE,CAkJV;AAED,wBAAgB,iBAAiB,IAAI,OAAO,CAgO3C"}
1
+ {"version":3,"file":"show.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/feat/show.command.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMpC,OAAO,KAAK,EAEV,QAAQ,EACR,WAAW,EACX,sBAAsB,EACvB,MAAM,8BAA8B,CAAC;AA6OtC;;;GAGG;AACH,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,WAAW,EAAE,EACtB,UAAU,EAAE,QAAQ,GAAG,IAAI,EAC3B,UAAU,GAAE,sBAAsB,EAAO,GACxC,MAAM,EAAE,CAkJV;AAED,wBAAgB,iBAAiB,IAAI,OAAO,CAgO3C"}
@@ -18,9 +18,10 @@ import { computeWorktreePath } from '../../../../../packages/core/src/infrastruc
18
18
  const AGENT_LABELS = {
19
19
  'claude-code': 'Claude Code',
20
20
  'codex-cli': 'Codex CLI',
21
+ 'copilot-cli': 'GitHub Copilot CLI',
21
22
  cursor: 'Cursor CLI',
22
23
  'gemini-cli': 'Gemini CLI',
23
- dev: 'Demo',
24
+ 'rovo-dev': 'Rovo Dev CLI',
24
25
  };
25
26
  /** Map graph node names to human-readable phase labels (active). */
26
27
  const NODE_TO_PHASE = {
@@ -34,8 +34,8 @@ Examples:
34
34
  const isNonInteractive = options.agent !== undefined;
35
35
  let input;
36
36
  if (isNonInteractive) {
37
- // Non-interactive: require --auth when --agent is provided (dev type defaults to session)
38
- if (!options.auth && options.agent !== 'dev') {
37
+ // Non-interactive: require --auth when --agent is provided
38
+ if (!options.auth) {
39
39
  messages.error(getCliI18n().t('cli:commands.settings.agent.authRequired'));
40
40
  process.exitCode = 1;
41
41
  return;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/settings/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAYpC;;GAEG;AACH,wBAAgB,qBAAqB,IAAI,OAAO,CAuB/C"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/settings/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAapC;;GAEG;AACH,wBAAgB,qBAAqB,IAAI,OAAO,CAwB/C"}
@@ -22,6 +22,7 @@ import { createIdeCommand } from './ide.command.js';
22
22
  import { createWorkflowCommand } from './workflow.command.js';
23
23
  import { createModelCommand } from './model.command.js';
24
24
  import { createLanguageCommand } from './language.command.js';
25
+ import { createPermissionsCommand } from './permissions.command.js';
25
26
  import { onboardingWizard } from '../../../tui/wizards/onboarding/onboarding.wizard.js';
26
27
  import { messages } from '../../ui/index.js';
27
28
  import { getCliI18n } from '../../i18n.js';
@@ -37,7 +38,8 @@ export function createSettingsCommand() {
37
38
  .addCommand(createIdeCommand())
38
39
  .addCommand(createWorkflowCommand())
39
40
  .addCommand(createModelCommand())
40
- .addCommand(createLanguageCommand());
41
+ .addCommand(createLanguageCommand())
42
+ .addCommand(createPermissionsCommand());
41
43
  // Default action: launch the full setup wizard when no subcommand is given
42
44
  cmd.action(async () => {
43
45
  try {
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Agent Permission Mode Validation Helpers
3
+ *
4
+ * Maps agent types to their valid permission mode strings.
5
+ * Used by both the `settings permissions` command and the
6
+ * `feat new --permission-mode` flag for validation.
7
+ */
8
+ import type { AgentPermissionSettings } from '../../../../../packages/core/src/domain/generated/output.js';
9
+ /**
10
+ * Maps AgentType string values to their corresponding key in AgentPermissionSettings.
11
+ * Re-exported from the resolver module for use by the command layer.
12
+ */
13
+ export declare const SETTINGS_KEY_BY_AGENT: Record<string, keyof AgentPermissionSettings>;
14
+ /**
15
+ * Returns the valid permission mode strings for a given agent type.
16
+ * Returns an empty array for unknown agent types.
17
+ */
18
+ export declare function getValidModesForAgent(agentType: string): string[];
19
+ //# sourceMappingURL=permission-modes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permission-modes.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/settings/permission-modes.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAUH,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAc5E;;;GAGG;AACH,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,uBAAuB,CAO/E,CAAC;AAEF;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,EAAE,CAEjE"}
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Agent Permission Mode Validation Helpers
3
+ *
4
+ * Maps agent types to their valid permission mode strings.
5
+ * Used by both the `settings permissions` command and the
6
+ * `feat new --permission-mode` flag for validation.
7
+ */
8
+ import { ClaudeCodePermissionMode, CursorPermissionMode, GeminiPermissionMode, CodexPermissionMode, CopilotPermissionMode, RovoDevPermissionMode, } from '../../../../../packages/core/src/domain/generated/output.js';
9
+ /**
10
+ * Valid permission modes per agent type, derived from TypeSpec-generated enums.
11
+ */
12
+ const VALID_MODES = {
13
+ 'claude-code': Object.values(ClaudeCodePermissionMode),
14
+ cursor: Object.values(CursorPermissionMode),
15
+ 'gemini-cli': Object.values(GeminiPermissionMode),
16
+ 'codex-cli': Object.values(CodexPermissionMode),
17
+ 'copilot-cli': Object.values(CopilotPermissionMode),
18
+ 'rovo-dev': Object.values(RovoDevPermissionMode),
19
+ };
20
+ /**
21
+ * Maps AgentType string values to their corresponding key in AgentPermissionSettings.
22
+ * Re-exported from the resolver module for use by the command layer.
23
+ */
24
+ export const SETTINGS_KEY_BY_AGENT = {
25
+ 'claude-code': 'claudeCode',
26
+ cursor: 'cursor',
27
+ 'gemini-cli': 'geminiCli',
28
+ 'codex-cli': 'codexCli',
29
+ 'copilot-cli': 'copilotCli',
30
+ 'rovo-dev': 'rovoDev',
31
+ };
32
+ /**
33
+ * Returns the valid permission mode strings for a given agent type.
34
+ * Returns an empty array for unknown agent types.
35
+ */
36
+ export function getValidModesForAgent(agentType) {
37
+ return VALID_MODES[agentType] ?? [];
38
+ }
@@ -0,0 +1,16 @@
1
+ /**
2
+ * Permissions Configuration Command
3
+ *
4
+ * Configures the permission mode for the currently configured AI coding agent.
5
+ *
6
+ * Usage:
7
+ * shipit-ai settings permissions # Interactive wizard
8
+ * shipit-ai settings permissions --agent claude-code --mode plan # Non-interactive
9
+ * shipit-ai settings permissions --agent claude-code --reset # Reset to default
10
+ */
11
+ import { Command } from 'commander';
12
+ /**
13
+ * Create the permissions configuration command.
14
+ */
15
+ export declare function createPermissionsCommand(): Command;
16
+ //# sourceMappingURL=permissions.command.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permissions.command.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/cli/commands/settings/permissions.command.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAapC;;GAEG;AACH,wBAAgB,wBAAwB,IAAI,OAAO,CA4JlD"}
@@ -0,0 +1,147 @@
1
+ /**
2
+ * Permissions Configuration Command
3
+ *
4
+ * Configures the permission mode for the currently configured AI coding agent.
5
+ *
6
+ * Usage:
7
+ * shipit-ai settings permissions # Interactive wizard
8
+ * shipit-ai settings permissions --agent claude-code --mode plan # Non-interactive
9
+ * shipit-ai settings permissions --agent claude-code --reset # Reset to default
10
+ */
11
+ import { Command } from 'commander';
12
+ import { select } from '@inquirer/prompts';
13
+ import { container } from '../../../../../packages/core/src/infrastructure/di/container.js';
14
+ import { UpdateSettingsUseCase } from '../../../../../packages/core/src/application/use-cases/settings/update-settings.use-case.js';
15
+ import { getSettings, resetSettings, initializeSettings, } from '../../../../../packages/core/src/infrastructure/services/settings.service.js';
16
+ import { messages } from '../../ui/index.js';
17
+ import { getCliI18n } from '../../i18n.js';
18
+ import { getValidModesForAgent, SETTINGS_KEY_BY_AGENT } from './permission-modes.js';
19
+ /**
20
+ * Create the permissions configuration command.
21
+ */
22
+ export function createPermissionsCommand() {
23
+ const t = getCliI18n().t;
24
+ return new Command('permissions')
25
+ .description(t('cli:commands.settings.permissions.description'))
26
+ .option('--agent <type>', t('cli:commands.settings.permissions.agentOption'))
27
+ .option('--mode <mode>', t('cli:commands.settings.permissions.modeOption'))
28
+ .option('--reset', t('cli:commands.settings.permissions.resetOption'))
29
+ .addHelpText('after', `
30
+ Examples:
31
+ $ shipit-ai settings permissions Interactive wizard
32
+ $ shipit-ai settings permissions --agent claude-code --mode plan Non-interactive
33
+ $ shipit-ai settings permissions --agent claude-code --reset Reset to default`)
34
+ .action(async (options) => {
35
+ try {
36
+ const settings = getSettings();
37
+ const isNonInteractive = options.agent !== undefined || options.mode !== undefined;
38
+ if (options.reset) {
39
+ // Reset mode: clear the override for the specified agent (or current agent)
40
+ const agentType = options.agent ?? settings.agent.type;
41
+ const settingsKey = SETTINGS_KEY_BY_AGENT[agentType];
42
+ if (!settingsKey) {
43
+ const validModes = getValidModesForAgent(agentType);
44
+ messages.error(t('cli:commands.settings.permissions.invalidMode', {
45
+ mode: agentType,
46
+ agent: 'agent',
47
+ validModes: validModes.join(', '),
48
+ }));
49
+ process.exitCode = 1;
50
+ return;
51
+ }
52
+ // Clear the permission override
53
+ if (settings.agent.permissions) {
54
+ settings.agent.permissions[settingsKey] = undefined;
55
+ }
56
+ const useCase = container.resolve(UpdateSettingsUseCase);
57
+ const updatedSettings = await useCase.execute(settings);
58
+ resetSettings();
59
+ initializeSettings(updatedSettings);
60
+ messages.success(t('cli:commands.settings.permissions.reset'));
61
+ return;
62
+ }
63
+ if (isNonInteractive) {
64
+ // Non-interactive mode: both --agent and --mode are required
65
+ const agentType = options.agent ?? settings.agent.type;
66
+ if (!options.mode) {
67
+ messages.error(t('cli:commands.settings.permissions.modeRequired'));
68
+ process.exitCode = 1;
69
+ return;
70
+ }
71
+ const validModes = getValidModesForAgent(agentType);
72
+ if (validModes.length === 0) {
73
+ messages.error(t('cli:commands.settings.permissions.invalidMode', {
74
+ mode: options.mode,
75
+ agent: agentType,
76
+ validModes: 'none (unknown agent)',
77
+ }));
78
+ process.exitCode = 1;
79
+ return;
80
+ }
81
+ if (!validModes.includes(options.mode)) {
82
+ messages.error(t('cli:commands.settings.permissions.invalidMode', {
83
+ mode: options.mode,
84
+ agent: agentType,
85
+ validModes: validModes.join(', '),
86
+ }));
87
+ process.exitCode = 1;
88
+ return;
89
+ }
90
+ // Persist
91
+ const settingsKey = SETTINGS_KEY_BY_AGENT[agentType];
92
+ settings.agent.permissions ??= {};
93
+ settings.agent.permissions[settingsKey] = options.mode;
94
+ const useCase = container.resolve(UpdateSettingsUseCase);
95
+ const updatedSettings = await useCase.execute(settings);
96
+ resetSettings();
97
+ initializeSettings(updatedSettings);
98
+ messages.success(t('cli:commands.settings.permissions.updated', { mode: options.mode }));
99
+ }
100
+ else {
101
+ // Interactive mode
102
+ const agentType = settings.agent.type;
103
+ const validModes = getValidModesForAgent(agentType);
104
+ if (validModes.length === 0) {
105
+ messages.error(t('cli:commands.settings.permissions.invalidMode', {
106
+ mode: 'none',
107
+ agent: agentType,
108
+ validModes: 'none (unknown agent)',
109
+ }));
110
+ process.exitCode = 1;
111
+ return;
112
+ }
113
+ // Show current state
114
+ const settingsKey = SETTINGS_KEY_BY_AGENT[agentType];
115
+ const currentMode = settingsKey && settings.agent.permissions
116
+ ? settings.agent.permissions[settingsKey]
117
+ : undefined;
118
+ messages.info(t('cli:commands.settings.permissions.currentAgent', { agent: agentType }));
119
+ messages.info(t('cli:commands.settings.permissions.currentMode', {
120
+ mode: currentMode ?? 'default',
121
+ }));
122
+ const selectedMode = await select({
123
+ message: t('cli:commands.settings.permissions.selectMode', { agent: agentType }),
124
+ choices: validModes.map((m) => ({ name: m, value: m })),
125
+ default: currentMode,
126
+ });
127
+ // Persist
128
+ settings.agent.permissions ??= {};
129
+ settings.agent.permissions[settingsKey] = selectedMode;
130
+ const useCase = container.resolve(UpdateSettingsUseCase);
131
+ const updatedSettings = await useCase.execute(settings);
132
+ resetSettings();
133
+ initializeSettings(updatedSettings);
134
+ messages.success(t('cli:commands.settings.permissions.updated', { mode: selectedMode }));
135
+ }
136
+ }
137
+ catch (error) {
138
+ const err = error instanceof Error ? error : new Error(String(error));
139
+ if (err.message.includes('force closed') || err.message.includes('User force closed')) {
140
+ messages.info(t('cli:commands.settings.permissions.cancelled'));
141
+ return;
142
+ }
143
+ messages.error(t('cli:commands.settings.permissions.failed'), err);
144
+ process.exitCode = 1;
145
+ }
146
+ });
147
+ }
@@ -8,22 +8,16 @@ import { AgentType } from '../../../../packages/core/src/domain/generated/output
8
8
  /**
9
9
  * Creates the @inquirer/select configuration for selecting an AI coding agent.
10
10
  *
11
- * Active agents are selectable. Agents not yet implemented are shown
12
- * as disabled with a "Coming Soon" badge.
11
+ * Only production-ready agents are listed. Deprecated and experimental
12
+ * agents (dev, aider, continue) are excluded from the UI.
13
13
  */
14
14
  export declare function createAgentSelectConfig(): {
15
15
  message: string;
16
- choices: ({
16
+ choices: {
17
17
  name: string;
18
18
  value: AgentType;
19
19
  description: string;
20
- disabled?: undefined;
21
- } | {
22
- name: string;
23
- value: AgentType;
24
- disabled: string;
25
- description?: undefined;
26
- })[];
20
+ }[];
27
21
  theme: {
28
22
  readonly prefix: {
29
23
  readonly idle: string;
@@ -1 +1 @@
1
- {"version":3,"file":"agent-select.prompt.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/tui/prompts/agent-select.prompt.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAIzD;;;;;GAKG;AACH,wBAAgB,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;EA2CtC"}
1
+ {"version":3,"file":"agent-select.prompt.d.ts","sourceRoot":"","sources":["../../../../../src/presentation/tui/prompts/agent-select.prompt.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAIzD;;;;;GAKG;AACH,wBAAgB,uBAAuB;;;;;;;;;;;;;;;;;EAsCtC"}
@@ -10,8 +10,8 @@ import { shipitAiTheme } from '../themes/shipit-ai.theme.js';
10
10
  /**
11
11
  * Creates the @inquirer/select configuration for selecting an AI coding agent.
12
12
  *
13
- * Active agents are selectable. Agents not yet implemented are shown
14
- * as disabled with a "Coming Soon" badge.
13
+ * Only production-ready agents are listed. Deprecated and experimental
14
+ * agents (dev, aider, continue) are excluded from the UI.
15
15
  */
16
16
  export function createAgentSelectConfig() {
17
17
  const t = getTuiI18n().t;
@@ -39,19 +39,14 @@ export function createAgentSelectConfig() {
39
39
  description: t('tui:prompts.selectAgent.choices.cursor.description'),
40
40
  },
41
41
  {
42
- name: t('tui:prompts.selectAgent.choices.devMock.name'),
43
- value: AgentType.Dev,
44
- description: t('tui:prompts.selectAgent.choices.devMock.description'),
42
+ name: t('tui:prompts.selectAgent.choices.copilotCli.name'),
43
+ value: AgentType.CopilotCli,
44
+ description: t('tui:prompts.selectAgent.choices.copilotCli.description'),
45
45
  },
46
46
  {
47
- name: t('tui:prompts.selectAgent.choices.aider.name'),
48
- value: AgentType.Aider,
49
- disabled: t('tui:prompts.selectAgent.choices.aider.disabled'),
50
- },
51
- {
52
- name: t('tui:prompts.selectAgent.choices.continue.name'),
53
- value: AgentType.Continue,
54
- disabled: t('tui:prompts.selectAgent.choices.continue.disabled'),
47
+ name: t('tui:prompts.selectAgent.choices.rovoDev.name'),
48
+ value: AgentType.RovoDev,
49
+ description: t('tui:prompts.selectAgent.choices.rovoDev.description'),
55
50
  },
56
51
  ],
57
52
  theme: shipitAiTheme,
@@ -6,16 +6,18 @@
6
6
  * and refreshes the in-memory settings singleton.
7
7
  */
8
8
  import type { AgentConfigResult } from '../agent-config.wizard.js';
9
+ import type { AgentType } from '../../../../../packages/core/src/domain/generated/output.js';
9
10
  import type { WorkflowDefaultsResult } from './types.js';
10
11
  /**
11
12
  * Runs the first-run onboarding wizard.
12
13
  *
13
14
  * Steps:
14
15
  * 1. Agent configuration (type + auth)
15
- * 2. IDE selection
16
- * 3. Workflow defaults (checkboxes)
16
+ * 2. Permission mode selection for chosen agent
17
+ * 3. IDE selection
18
+ * 4. Workflow defaults (checkboxes)
17
19
  *
18
20
  * Step functions are injectable via parameters for testability.
19
21
  */
20
- export declare function onboardingWizard(agentStep?: () => Promise<AgentConfigResult>, ideStep?: () => Promise<string>, workflowStep?: () => Promise<WorkflowDefaultsResult>): Promise<void>;
22
+ export declare function onboardingWizard(agentStep?: () => Promise<AgentConfigResult>, permissionsStep?: (agentType: AgentType) => Promise<string | undefined>, ideStep?: () => Promise<string>, workflowStep?: () => Promise<WorkflowDefaultsResult>): Promise<void>;
21
23
  //# sourceMappingURL=onboarding.wizard.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"onboarding.wizard.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/tui/wizards/onboarding/onboarding.wizard.ts"],"names":[],"mappings":"AACA;;;;;;GAMG;AAUH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAuBzD;;;;;;;;;GASG;AACH,wBAAsB,gBAAgB,CACpC,SAAS,GAAE,MAAM,OAAO,CAAC,iBAAiB,CAAgB,EAC1D,OAAO,GAAE,MAAM,OAAO,CAAC,MAAM,CAAc,EAC3C,YAAY,GAAE,MAAM,OAAO,CAAC,sBAAsB,CAA2B,GAC5E,OAAO,CAAC,IAAI,CAAC,CAoCf"}
1
+ {"version":3,"file":"onboarding.wizard.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/tui/wizards/onboarding/onboarding.wizard.ts"],"names":[],"mappings":"AACA;;;;;;GAMG;AAWH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACnE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AAuBzD;;;;;;;;;;GAUG;AACH,wBAAsB,gBAAgB,CACpC,SAAS,GAAE,MAAM,OAAO,CAAC,iBAAiB,CAAgB,EAC1D,eAAe,GAAE,CAAC,SAAS,EAAE,SAAS,KAAK,OAAO,CAAC,MAAM,GAAG,SAAS,CAA2B,EAChG,OAAO,GAAE,MAAM,OAAO,CAAC,MAAM,CAAc,EAC3C,YAAY,GAAE,MAAM,OAAO,CAAC,sBAAsB,CAA2B,GAC5E,OAAO,CAAC,IAAI,CAAC,CAwCf"}
@@ -12,6 +12,7 @@ import { CompleteOnboardingUseCase } from '../../../../../packages/core/src/appl
12
12
  import { resetSettings, initializeSettings } from '../../../../../packages/core/src/infrastructure/services/settings.service.js';
13
13
  import { getTuiI18n } from '../../i18n.js';
14
14
  import { runAgentStep } from './steps/agent.step.js';
15
+ import { runAgentPermissionsStep } from './steps/agent-permissions.step.js';
15
16
  import { runIdeStep } from './steps/ide.step.js';
16
17
  import { runWorkflowDefaultsStep } from './steps/workflow-defaults.step.js';
17
18
  /**
@@ -35,24 +36,28 @@ function showWelcomeBanner() {
35
36
  *
36
37
  * Steps:
37
38
  * 1. Agent configuration (type + auth)
38
- * 2. IDE selection
39
- * 3. Workflow defaults (checkboxes)
39
+ * 2. Permission mode selection for chosen agent
40
+ * 3. IDE selection
41
+ * 4. Workflow defaults (checkboxes)
40
42
  *
41
43
  * Step functions are injectable via parameters for testability.
42
44
  */
43
- export async function onboardingWizard(agentStep = runAgentStep, ideStep = runIdeStep, workflowStep = runWorkflowDefaultsStep) {
45
+ export async function onboardingWizard(agentStep = runAgentStep, permissionsStep = runAgentPermissionsStep, ideStep = runIdeStep, workflowStep = runWorkflowDefaultsStep) {
44
46
  try {
45
47
  showWelcomeBanner();
46
48
  // Step 1: Agent configuration
47
49
  const agent = await agentStep();
48
- // Step 2: IDE selection
50
+ // Step 2: Permission mode for chosen agent
51
+ const permissionMode = await permissionsStep(agent.type);
52
+ // Step 3: IDE selection
49
53
  const ide = await ideStep();
50
- // Step 3: Workflow defaults
54
+ // Step 4: Workflow defaults
51
55
  const workflowDefaults = await workflowStep();
52
56
  // Persist all wizard results atomically
53
57
  const useCase = container.resolve(CompleteOnboardingUseCase);
54
58
  const updatedSettings = await useCase.execute({
55
59
  agent,
60
+ permissionMode,
56
61
  ide,
57
62
  workflowDefaults,
58
63
  });
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Onboarding Step 1B: Agent Permission Mode
3
+ *
4
+ * After the user selects an agent, prompts for the permission mode
5
+ * that controls how ShipIT runs that agent. Provides a "Skip" option
6
+ * that keeps the factory default (most-permissive mode per agent).
7
+ */
8
+ import type { AgentType } from '../../../../../../packages/core/src/domain/generated/output.js';
9
+ /**
10
+ * Runs the permission mode selection step for the given agent.
11
+ *
12
+ * @param agentType - The agent type value selected in the previous step
13
+ * (e.g. 'claude-code', 'cursor')
14
+ * @returns The selected permission mode string, or `undefined` if skipped
15
+ */
16
+ export declare function runAgentPermissionsStep(agentType: AgentType): Promise<string | undefined>;
17
+ //# sourceMappingURL=agent-permissions.step.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-permissions.step.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAQ9D;;;;;;GAMG;AACH,wBAAsB,uBAAuB,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAgC/F"}
@@ -0,0 +1,48 @@
1
+ /**
2
+ * Onboarding Step 1B: Agent Permission Mode
3
+ *
4
+ * After the user selects an agent, prompts for the permission mode
5
+ * that controls how ShipIT runs that agent. Provides a "Skip" option
6
+ * that keeps the factory default (most-permissive mode per agent).
7
+ */
8
+ import { select } from '@inquirer/prompts';
9
+ import { getValidModesForAgent } from '../../../../../presentation/cli/commands/settings/permission-modes.js';
10
+ import { getTuiI18n } from '../../../i18n.js';
11
+ import { shipitAiTheme } from '../../../themes/shipit-ai.theme.js';
12
+ /** Sentinel returned when the user chooses to skip. */
13
+ const SKIP_VALUE = '__skip__';
14
+ /**
15
+ * Runs the permission mode selection step for the given agent.
16
+ *
17
+ * @param agentType - The agent type value selected in the previous step
18
+ * (e.g. 'claude-code', 'cursor')
19
+ * @returns The selected permission mode string, or `undefined` if skipped
20
+ */
21
+ export async function runAgentPermissionsStep(agentType) {
22
+ const t = getTuiI18n().t;
23
+ const modes = getValidModesForAgent(agentType);
24
+ // If no modes are defined for this agent, silently skip
25
+ if (modes.length === 0) {
26
+ return undefined;
27
+ }
28
+ const agentLabel = agentType;
29
+ const choices = [
30
+ ...modes.map((mode) => ({
31
+ name: mode,
32
+ value: mode,
33
+ })),
34
+ {
35
+ name: t('tui:wizards.permissions.skip'),
36
+ value: SKIP_VALUE,
37
+ },
38
+ ];
39
+ const answer = await select({
40
+ message: t('tui:wizards.permissions.title', { agent: agentLabel }),
41
+ choices,
42
+ theme: shipitAiTheme,
43
+ });
44
+ if (answer === SKIP_VALUE) {
45
+ return undefined;
46
+ }
47
+ return answer;
48
+ }
@@ -19,6 +19,8 @@ export interface WorkflowDefaultsResult {
19
19
  */
20
20
  export interface OnboardingResult {
21
21
  agent: AgentConfigResult;
22
+ /** Permission mode selected for the agent, or undefined if skipped */
23
+ permissionMode?: string;
22
24
  ide: string;
23
25
  workflowDefaults: WorkflowDefaultsResult;
24
26
  }
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/tui/wizards/onboarding/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAEnE;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,4BAA4B,EAAE,OAAO,CAAC;IACtC,8BAA8B,EAAE,OAAO,CAAC;CACzC;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,iBAAiB,CAAC;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,gBAAgB,EAAE,sBAAsB,CAAC;CAC1C"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/tui/wizards/onboarding/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAEnE;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,4BAA4B,EAAE,OAAO,CAAC;IACtC,8BAA8B,EAAE,OAAO,CAAC;CACzC;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,iBAAiB,CAAC;IACzB,sEAAsE;IACtE,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,gBAAgB,EAAE,sBAAsB,CAAC;CAC1C"}
@@ -0,0 +1,14 @@
1
+ export interface PermissionOption {
2
+ value: string;
3
+ label: string;
4
+ description: string;
5
+ batchSafe: boolean;
6
+ }
7
+ export declare function getAgentPermissionOptions(agentType: string): Promise<PermissionOption[]>;
8
+ export declare function getCurrentAgentPermissionMode(agentType: string): Promise<string | undefined>;
9
+ export interface SetPermissionResult {
10
+ success: boolean;
11
+ error?: string;
12
+ }
13
+ export declare function setAgentPermissionMode(agentType: string, mode: string): Promise<SetPermissionResult>;
14
+ //# sourceMappingURL=agent-permissions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-permissions.d.ts","sourceRoot":"","sources":["../../../../../../src/presentation/web/app/actions/agent-permissions.ts"],"names":[],"mappings":"AAkBA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;CACpB;AAuID,wBAAsB,yBAAyB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAE9F;AAED,wBAAsB,6BAA6B,CACjD,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAM7B;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAsB,sBAAsB,CAC1C,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,GACX,OAAO,CAAC,mBAAmB,CAAC,CAuC9B"}