@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.
- package/README.md +26 -5
- package/apis/json-schema/AgentConfig.yaml +3 -0
- package/apis/json-schema/AgentPermissionSettings.yaml +23 -0
- package/apis/json-schema/AgentType.yaml +0 -1
- package/apis/json-schema/ClaudeCodePermissionMode.yaml +9 -0
- package/apis/json-schema/CodexPermissionMode.yaml +8 -0
- package/apis/json-schema/CopilotPermissionMode.yaml +8 -0
- package/apis/json-schema/CursorPermissionMode.yaml +7 -0
- package/apis/json-schema/Feature.yaml +3 -0
- package/apis/json-schema/GeminiPermissionMode.yaml +8 -0
- package/apis/json-schema/RovoDevPermissionMode.yaml +8 -0
- package/dist/packages/core/src/application/ports/output/agents/agent-executor.interface.d.ts +8 -0
- package/dist/packages/core/src/application/ports/output/agents/agent-executor.interface.d.ts.map +1 -1
- package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts +1 -0
- package/dist/packages/core/src/application/ports/output/agents/feature-agent-process.interface.d.ts.map +1 -1
- package/dist/packages/core/src/application/ports/output/agents/interactive-agent-executor.interface.d.ts +3 -0
- package/dist/packages/core/src/application/ports/output/agents/interactive-agent-executor.interface.d.ts.map +1 -1
- package/dist/packages/core/src/application/ports/output/services/index.d.ts +1 -0
- package/dist/packages/core/src/application/ports/output/services/index.d.ts.map +1 -1
- package/dist/packages/core/src/application/ports/output/services/settings-reader.interface.d.ts +13 -0
- package/dist/packages/core/src/application/ports/output/services/settings-reader.interface.d.ts.map +1 -0
- package/dist/packages/core/src/application/ports/output/services/settings-reader.interface.js +1 -0
- package/dist/packages/core/src/application/use-cases/agents/configure-agent.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/agents/configure-agent.use-case.js +4 -6
- package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/check-and-unblock-features.use-case.js +1 -0
- package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/create/create-feature.use-case.js +2 -0
- package/dist/packages/core/src/application/use-cases/features/create/types.d.ts +2 -0
- package/dist/packages/core/src/application/use-cases/features/create/types.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/resume-feature.use-case.js +1 -0
- package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/features/start-feature.use-case.js +1 -0
- package/dist/packages/core/src/application/use-cases/settings/complete-onboarding.use-case.d.ts +2 -0
- package/dist/packages/core/src/application/use-cases/settings/complete-onboarding.use-case.d.ts.map +1 -1
- package/dist/packages/core/src/application/use-cases/settings/complete-onboarding.use-case.js +23 -0
- package/dist/packages/core/src/domain/factories/settings-defaults.factory.d.ts.map +1 -1
- package/dist/packages/core/src/domain/factories/settings-defaults.factory.js +9 -1
- package/dist/packages/core/src/domain/generated/output.d.ts +68 -2
- package/dist/packages/core/src/domain/generated/output.d.ts.map +1 -1
- package/dist/packages/core/src/domain/generated/output.js +36 -1
- package/dist/packages/core/src/infrastructure/di/modules/agents.module.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/di/modules/agents.module.js +4 -2
- package/dist/packages/core/src/infrastructure/di/modules/services.module.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/di/modules/services.module.js +2 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.d.ts +1 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/feature.mapper.js +4 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts +6 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/persistence/sqlite/mappers/settings.mapper.js +31 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/052-add-agent-permission-modes.d.ts +21 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/052-add-agent-permission-modes.d.ts.map +1 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/052-add-agent-permission-modes.js +35 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-feature-permission-mode.d.ts +14 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-feature-permission-mode.d.ts.map +1 -0
- package/dist/packages/core/src/infrastructure/persistence/sqlite/migrations/053-add-feature-permission-mode.js +19 -0
- package/dist/packages/core/src/infrastructure/services/agents/analyze-repo/analyze-repository-graph.d.ts +3 -1
- package/dist/packages/core/src/infrastructure/services/agents/analyze-repo/analyze-repository-graph.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/analyze-repo/analyze-repository-graph.js +18 -7
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-executor-factory.service.d.ts +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-executor-factory.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-executor-factory.service.js +1 -6
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-permissions.d.ts +21 -0
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-permissions.d.ts.map +1 -0
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-permissions.js +49 -0
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-runner.service.d.ts +3 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-runner.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-runner.service.js +4 -3
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-validator.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/agent-validator.service.js +0 -3
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-executor.service.js +11 -0
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-interactive-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/claude-code-interactive-executor.service.js +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/codex-cli-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/codex-cli-executor.service.js +4 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/copilot-cli-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/copilot-cli-executor.service.js +11 -4
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/cursor-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/cursor-executor.service.js +11 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/gemini-cli-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/gemini-cli-executor.service.js +2 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/rovo-dev-executor.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/rovo-dev-executor.service.js +11 -4
- package/dist/packages/core/src/infrastructure/services/agents/common/structured-agent-caller.service.d.ts +3 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/structured-agent-caller.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/structured-agent-caller.service.js +13 -6
- package/dist/packages/core/src/infrastructure/services/agents/conflict-resolution/conflict-resolution.service.d.ts +3 -1
- package/dist/packages/core/src/infrastructure/services/agents/conflict-resolution/conflict-resolution.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/conflict-resolution/conflict-resolution.service.js +12 -3
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts +5 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/fast-feature-agent-graph.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts +18 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-graph.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts +1 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-process.service.js +3 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts +1 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/feature-agent-worker.js +8 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/evidence.node.d.ts +3 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/evidence.node.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/evidence.node.js +3 -2
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/ci-watch-fix-loop.d.ts +3 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/ci-watch-fix-loop.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/ci-watch-fix-loop.js +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.d.ts +3 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/merge/merge.node.js +2 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts +11 -3
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/node-helpers.js +20 -5
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/repair.node.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/nodes/repair.node.js +6 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts +1 -0
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.d.ts.map +1 -1
- package/dist/packages/core/src/infrastructure/services/agents/feature-agent/state.js +4 -0
- package/dist/packages/core/src/infrastructure/services/settings-reader.service.d.ts +7 -0
- package/dist/packages/core/src/infrastructure/services/settings-reader.service.d.ts.map +1 -0
- package/dist/packages/core/src/infrastructure/services/settings-reader.service.js +25 -0
- package/dist/src/presentation/cli/commands/feat/new.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/new.command.js +18 -0
- package/dist/src/presentation/cli/commands/feat/show.command.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/feat/show.command.js +2 -1
- package/dist/src/presentation/cli/commands/settings/agent.command.js +2 -2
- package/dist/src/presentation/cli/commands/settings/index.d.ts.map +1 -1
- package/dist/src/presentation/cli/commands/settings/index.js +3 -1
- package/dist/src/presentation/cli/commands/settings/permission-modes.d.ts +19 -0
- package/dist/src/presentation/cli/commands/settings/permission-modes.d.ts.map +1 -0
- package/dist/src/presentation/cli/commands/settings/permission-modes.js +38 -0
- package/dist/src/presentation/cli/commands/settings/permissions.command.d.ts +16 -0
- package/dist/src/presentation/cli/commands/settings/permissions.command.d.ts.map +1 -0
- package/dist/src/presentation/cli/commands/settings/permissions.command.js +147 -0
- package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts +4 -10
- package/dist/src/presentation/tui/prompts/agent-select.prompt.d.ts.map +1 -1
- package/dist/src/presentation/tui/prompts/agent-select.prompt.js +8 -13
- package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts +5 -3
- package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.d.ts.map +1 -1
- package/dist/src/presentation/tui/wizards/onboarding/onboarding.wizard.js +10 -5
- package/dist/src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.d.ts +17 -0
- package/dist/src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.d.ts.map +1 -0
- package/dist/src/presentation/tui/wizards/onboarding/steps/agent-permissions.step.js +48 -0
- package/dist/src/presentation/tui/wizards/onboarding/types.d.ts +2 -0
- package/dist/src/presentation/tui/wizards/onboarding/types.d.ts.map +1 -1
- package/dist/src/presentation/web/app/actions/agent-permissions.d.ts +14 -0
- package/dist/src/presentation/web/app/actions/agent-permissions.d.ts.map +1 -0
- package/dist/src/presentation/web/app/actions/agent-permissions.js +181 -0
- package/dist/src/presentation/web/app/actions/check-agent-auth.d.ts.map +1 -1
- package/dist/src/presentation/web/app/actions/check-agent-auth.js +2 -5
- package/dist/src/presentation/web/app/actions/check-agent-tool.js +1 -1
- package/dist/src/presentation/web/app/actions/get-all-agent-models.d.ts.map +1 -1
- package/dist/src/presentation/web/app/actions/get-all-agent-models.js +2 -17
- package/dist/src/presentation/web/app/actions/get-merge-review-data.d.ts.map +1 -1
- package/dist/src/presentation/web/app/actions/get-merge-review-data.js +5 -0
- package/dist/src/presentation/web/app/actions/open-shell.d.ts.map +1 -1
- package/dist/src/presentation/web/app/actions/open-shell.js +5 -0
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +43 -9
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/types.d.ts +2 -0
- package/dist/src/presentation/web/components/common/feature-create-drawer/types.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/use-feature-create-form.d.ts +2 -0
- package/dist/src/presentation/web/components/common/feature-create-drawer/use-feature-create-form.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/use-feature-create-form.js +6 -0
- package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.d.ts +7 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.js +24 -3
- package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/workflow-options-section.stories.js +3 -0
- package/dist/src/presentation/web/components/common/feature-list-item/feature-list-item.stories.js +2 -2
- package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.d.ts +2 -2
- package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.js +4 -11
- package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.stories.d.ts +1 -1
- package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/agent-type-icons.stories.js +5 -6
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +2 -0
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node.js +2 -2
- package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.js +10 -10
- package/dist/src/presentation/web/components/features/control-center/control-center.stories.js +1 -1
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.stories.js +2 -2
- package/dist/src/presentation/web/components/features/settings/AgentModelPicker/AgentModelPicker.stories.d.ts +1 -1
- package/dist/src/presentation/web/components/features/settings/AgentModelPicker/AgentModelPicker.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/settings/AgentModelPicker/AgentModelPicker.stories.js +3 -3
- package/dist/src/presentation/web/components/features/settings/agent-permission-picker.d.ts +8 -0
- package/dist/src/presentation/web/components/features/settings/agent-permission-picker.d.ts.map +1 -0
- package/dist/src/presentation/web/components/features/settings/agent-permission-picker.js +33 -0
- package/dist/src/presentation/web/components/features/settings/agent-permission-picker.stories.d.ts +15 -0
- package/dist/src/presentation/web/components/features/settings/agent-permission-picker.stories.d.ts.map +1 -0
- package/dist/src/presentation/web/components/features/settings/agent-permission-picker.stories.js +75 -0
- package/dist/src/presentation/web/components/features/settings/agent-settings-section.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/settings/agent-settings-section.js +32 -4
- package/dist/src/presentation/web/components/features/settings/agent-settings-section.stories.d.ts +1 -1
- package/dist/src/presentation/web/components/features/settings/agent-settings-section.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/settings/agent-settings-section.stories.js +2 -2
- package/dist/src/presentation/web/components/layouts/app-sidebar/app-sidebar.stories.js +2 -2
- package/dist/src/presentation/web/lib/path-sanitizers.d.ts.map +1 -1
- package/dist/src/presentation/web/lib/path-sanitizers.js +5 -0
- package/dist/translations/ar/cli.json +16 -0
- package/dist/translations/ar/tui.json +12 -10
- package/dist/translations/ar/web.json +15 -0
- package/dist/translations/de/cli.json +16 -0
- package/dist/translations/de/tui.json +13 -5
- package/dist/translations/de/web.json +15 -0
- package/dist/translations/en/cli.json +16 -0
- package/dist/translations/en/tui.json +12 -10
- package/dist/translations/en/web.json +15 -0
- package/dist/translations/es/cli.json +16 -0
- package/dist/translations/es/tui.json +12 -10
- package/dist/translations/es/web.json +15 -0
- package/dist/translations/fr/cli.json +16 -0
- package/dist/translations/fr/tui.json +12 -10
- package/dist/translations/fr/web.json +15 -0
- package/dist/translations/he/cli.json +16 -0
- package/dist/translations/he/tui.json +12 -10
- package/dist/translations/he/web.json +15 -0
- package/dist/translations/pt/cli.json +16 -0
- package/dist/translations/pt/tui.json +12 -10
- package/dist/translations/pt/web.json +15 -0
- package/dist/translations/ru/cli.json +16 -0
- package/dist/translations/ru/tui.json +12 -10
- package/dist/translations/ru/web.json +15 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/web/.next/BUILD_ID +1 -1
- package/web/.next/build-manifest.json +3 -3
- package/web/.next/fallback-build-manifest.json +3 -3
- package/web/.next/prerender-manifest.json +3 -3
- package/web/.next/required-server-files.js +2 -2
- package/web/.next/required-server-files.json +2 -2
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page/server-reference-manifest.json +29 -29
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js +2 -3
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/adopt/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/chat/page/server-reference-manifest.json +27 -27
- package/web/.next/server/app/(dashboard)/@drawer/chat/page.js +2 -3
- package/web/.next/server/app/(dashboard)/@drawer/chat/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/chat/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/create/page/server-reference-manifest.json +72 -60
- package/web/.next/server/app/(dashboard)/@drawer/create/page.js +3 -3
- package/web/.next/server/app/(dashboard)/@drawer/create/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/create/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page/server-reference-manifest.json +37 -37
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js +3 -4
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page/server-reference-manifest.json +37 -37
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js +3 -4
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/feature/[featureId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +28 -28
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js +2 -3
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page/server-reference-manifest.json +28 -28
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js +2 -3
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/@drawer/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/chat/page/server-reference-manifest.json +27 -27
- package/web/.next/server/app/(dashboard)/chat/page.js +2 -3
- package/web/.next/server/app/(dashboard)/chat/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/chat/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/create/page/server-reference-manifest.json +72 -60
- package/web/.next/server/app/(dashboard)/create/page.js +3 -3
- package/web/.next/server/app/(dashboard)/create/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/create/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page/server-reference-manifest.json +37 -37
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js +3 -4
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page/server-reference-manifest.json +37 -37
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js +3 -4
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/feature/[featureId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/page/server-reference-manifest.json +27 -27
- package/web/.next/server/app/(dashboard)/page.js +2 -3
- package/web/.next/server/app/(dashboard)/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page/server-reference-manifest.json +28 -28
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js +2 -3
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/[tab]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page/server-reference-manifest.json +28 -28
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js +2 -3
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page.js.nft.json +1 -1
- package/web/.next/server/app/(dashboard)/repository/[repositoryId]/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/_global-error.html +1 -1
- package/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/server/app/_not-found/page/server-reference-manifest.json +6 -6
- package/web/.next/server/app/_not-found/page.js +2 -3
- package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/api/attachments/preview/route.js.nft.json +1 -1
- package/web/.next/server/app/api/dialog/pick-files/route.js.nft.json +1 -1
- package/web/.next/server/app/api/evidence/route.js.nft.json +1 -1
- package/web/.next/server/app/api/graph-data/route.js.nft.json +1 -1
- package/web/.next/server/app/api/interactive/chat/[featureId]/messages/route.js.nft.json +1 -1
- package/web/.next/server/app/settings/page/server-reference-manifest.json +11 -11
- package/web/.next/server/app/settings/page.js +3 -4
- package/web/.next/server/app/settings/page.js.nft.json +1 -1
- package/web/.next/server/app/settings/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/skills/page/server-reference-manifest.json +11 -11
- package/web/.next/server/app/skills/page.js +3 -3
- package/web/.next/server/app/skills/page.js.nft.json +1 -1
- package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/tools/page/server-reference-manifest.json +11 -11
- package/web/.next/server/app/tools/page.js +3 -3
- package/web/.next/server/app/tools/page.js.nft.json +1 -1
- package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/version/page/server-reference-manifest.json +6 -6
- package/web/.next/server/app/version/page.js +2 -3
- package/web/.next/server/app/version/page.js.nft.json +1 -1
- package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
- package/web/.next/server/chunks/11es_next_dist_esm_build_templates_app-route_067cwst.js +1 -1
- package/web/.next/server/chunks/11es_next_dist_esm_build_templates_app-route_067cwst.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__0_-chcy._.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__0e9p7em._.js.map +1 -1
- package/web/.next/server/chunks/[root-of-the-server]__0tb~wwk._.js +1 -1
- package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_create-drawer-client_tsx_0g70fc5._.js +1 -1
- package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_create-drawer-client_tsx_0g70fc5._.js.map +1 -1
- package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_feature-drawer-client_tsx_104cna.._.js +2 -2
- package/web/.next/server/chunks/ssr/0j.8_web_components_common_control-center-drawer_feature-drawer-client_tsx_104cna.._.js.map +1 -1
- package/web/.next/server/chunks/ssr/0ukq_presentation_web_components_features_settings_settings-page-client_tsx_0j1uius._.js +1 -1
- package/web/.next/server/chunks/ssr/0ukq_presentation_web_components_features_settings_settings-page-client_tsx_0j1uius._.js.map +1 -1
- package/web/.next/server/chunks/ssr/{_01mq~sm._.js → 11es_next_0q-kz~8._.js} +2 -2
- package/web/.next/server/chunks/ssr/11es_next_0q-kz~8._.js.map +1 -0
- package/web/.next/server/chunks/ssr/11y9_components_common_control-center-drawer_repository-drawer-client_tsx_09z.znp._.js +1 -1
- package/web/.next/server/chunks/ssr/11y9_components_common_control-center-drawer_repository-drawer-client_tsx_09z.znp._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__02.89uf._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__02.89uf._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__04rq9lr._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__04rq9lr._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__05_qc0n._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__05_qc0n._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0c0xoi_._.js +3 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0c0xoi_._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0r5zhk.._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0r5zhk.._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0rv1gci._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0rvrr1j._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0rvrr1j._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0tq2syh._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0tq2syh._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0uy_5rw._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0uy_5rw._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__12j29w-._.js +4 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__12j29w-._.js.map +1 -0
- package/web/.next/server/chunks/ssr/{_04rrcmm._.js → _0-.ckn5._.js} +2 -2
- package/web/.next/server/chunks/ssr/_0-.ckn5._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_00k65h-._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_01sesw0._.js +1 -1
- package/web/.next/server/chunks/ssr/_01sesw0._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_069y.js._.js +6 -0
- package/web/.next/server/chunks/ssr/_069y.js._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0__4si~._.js +4 -0
- package/web/.next/server/chunks/ssr/_0__4si~._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0_m17kl._.js +4 -0
- package/web/.next/server/chunks/ssr/_0_m17kl._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0aaotn-._.js +3 -0
- package/web/.next/server/chunks/ssr/_0aaotn-._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0d4miu.._.js +4 -0
- package/web/.next/server/chunks/ssr/_0d4miu.._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0e8ern9._.js +4 -0
- package/web/.next/server/chunks/ssr/_0e8ern9._.js.map +1 -0
- package/web/.next/server/chunks/ssr/{_109n-y4._.js → _0n.magx._.js} +2 -2
- package/web/.next/server/chunks/ssr/_0n.magx._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0p3~u8u._.js +6 -0
- package/web/.next/server/chunks/ssr/_0p3~u8u._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0r.3n~3._.js +4 -0
- package/web/.next/server/chunks/ssr/_0r.3n~3._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0t59q8r._.js +4 -0
- package/web/.next/server/chunks/ssr/_0t59q8r._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0tcccbb._.js +3 -0
- package/web/.next/server/chunks/ssr/_0tcccbb._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0vyfc4b._.js +1 -1
- package/web/.next/server/chunks/ssr/_0vyfc4b._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_0w-_hww._.js +1 -1
- package/web/.next/server/chunks/ssr/_0w-_hww._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_0zk-h5w._.js +4 -0
- package/web/.next/server/chunks/ssr/_0zk-h5w._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_0~7lwu_._.js +1 -1
- package/web/.next/server/chunks/ssr/_0~7lwu_._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_1161g9x._.js +4 -0
- package/web/.next/server/chunks/ssr/_1161g9x._.js.map +1 -0
- package/web/.next/server/chunks/ssr/{_0c497sr._.js → _138qywk._.js} +2 -2
- package/web/.next/server/chunks/ssr/{_0c497sr._.js.map → _138qywk._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_05m2q~u.js +3 -0
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_skills_page_actions_05m2q~u.js.map +1 -0
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_0.6zk.t.js +3 -0
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_tools_page_actions_0.6zk.t.js.map +1 -0
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_approve-feature_ts_0pjb_re._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_approve-feature_ts_0pjb_re._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_0w2wqvu._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_open-ide_ts_0w2wqvu._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_0l3oxx9._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_control-center_0l3oxx9._.js.map +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_features_tools_tools-page-client_tsx_0aji.op._.js +1 -1
- package/web/.next/server/middleware-build-manifest.js +3 -3
- package/web/.next/server/pages/500.html +1 -1
- package/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/server/server-reference-manifest.json +127 -109
- package/web/.next/static/chunks/0-woqr2brccx_.js +3 -0
- package/web/.next/static/chunks/{0ex35-_jtxyjc.js → 022nrd6snse79.js} +1 -1
- package/web/.next/static/chunks/{0t_6hx6ul7umb.js → 02phgt~f2c-2q.js} +1 -1
- package/web/.next/static/chunks/{0whez3wju~9ok.js → 03s7z6w1lj0w~.js} +1 -1
- package/web/.next/static/chunks/04~sw.nhpwy6s.css +1 -0
- package/web/.next/static/chunks/05enics63g._-.js +7 -0
- package/web/.next/static/chunks/08611baheit.t.js +1 -0
- package/web/.next/static/chunks/0_9k2ybutuphq.js +1 -0
- package/web/.next/static/chunks/{0oq-cvtg8rjjp.js → 0j.wph28jrce1.js} +1 -1
- package/web/.next/static/chunks/{0k~55i.ofbdeb.js → 0ls0v8h_qbctm.js} +1 -1
- package/web/.next/static/chunks/0ma7k9iohb3bb.js +1 -0
- package/web/.next/static/chunks/0ps5sykbi-z5-.js +1 -0
- package/web/.next/static/chunks/{0c_bi0dck80dt.js → 0q7ohuqneuur4.js} +1 -1
- package/web/.next/static/chunks/{07gx-h_y91lay.js → 0q8ax~44oybo2.js} +2 -2
- package/web/.next/static/chunks/15rbgqykl.er8.js +1 -0
- package/web/.next/static/chunks/{04xk1iouwcfcq.js → 17z2sq7c5z8cr.js} +3 -3
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/dev-executor.service.d.ts +0 -12
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/dev-executor.service.d.ts.map +0 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/dev-executor.service.js +0 -233
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/plan.fixture.d.ts +0 -8
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/plan.fixture.d.ts.map +0 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/plan.fixture.js +0 -94
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/research.fixture.d.ts +0 -8
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/research.fixture.d.ts.map +0 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/research.fixture.js +0 -140
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-analyze.fixture.d.ts +0 -8
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-analyze.fixture.d.ts.map +0 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-analyze.fixture.js +0 -81
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-requirements.fixture.d.ts +0 -8
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-requirements.fixture.d.ts.map +0 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/spec-requirements.fixture.js +0 -131
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/tasks.fixture.d.ts +0 -6
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/tasks.fixture.d.ts.map +0 -1
- package/dist/packages/core/src/infrastructure/services/agents/common/executors/fixtures/tasks.fixture.js +0 -146
- package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_adopt_page_actions_00~eq5i.js +0 -3
- package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_adopt_page_actions_00~eq5i.js.map +0 -1
- package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_chat_page_actions_0979_c..js +0 -3
- package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_@drawer_chat_page_actions_0979_c..js.map +0 -1
- package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_chat_page_actions_0dqll_1.js +0 -3
- package/web/.next/server/chunks/ssr/0j.8_web__next-internal_server_app_(dashboard)_chat_page_actions_0dqll_1.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__04nnbmc._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__04nnbmc._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__07740t6._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__07740t6._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0l~puw4._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0l~puw4._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0o3qggc._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0o3qggc._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0vwjc_m._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0vwjc_m._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0w4__yd._.js +0 -4
- package/web/.next/server/chunks/ssr/[root-of-the-server]__0w4__yd._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_0.rsra~._.js +0 -3
- package/web/.next/server/chunks/ssr/_0.rsra~._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_01mq~sm._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_04rrcmm._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_0c741v_._.js +0 -3
- package/web/.next/server/chunks/ssr/_0c741v_._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_0jpbsh_._.js +0 -4
- package/web/.next/server/chunks/ssr/_0jpbsh_._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_109n-y4._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_0.e4~xc._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_0.e4~xc._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_00dvh.m._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_00dvh.m._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_06b6~lt._.js +0 -5
- package/web/.next/server/chunks/ssr/src_presentation_web_06b6~lt._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_08fy2mf._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_08fy2mf._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_0f~udu1._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_0f~udu1._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_0qys821._.js +0 -5
- package/web/.next/server/chunks/ssr/src_presentation_web_0qys821._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_0q~dt0o._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_0q~dt0o._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_11jrkxt._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_11jrkxt._.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_(dashboard)_page_actions_1199d3x.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_(dashboard)_page_actions_1199d3x.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app__not-found_page_actions_0m2jqxx.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app__not-found_page_actions_0m2jqxx.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_version_page_actions_0krkh_0.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web__next-internal_server_app_version_page_actions_0krkh_0.js.map +0 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_load-settings_ts_0b8f3pf._.js +0 -3
- package/web/.next/server/chunks/ssr/src_presentation_web_app_actions_load-settings_ts_0b8f3pf._.js.map +0 -1
- package/web/.next/static/chunks/0-fy~80ui.5os.js +0 -7
- package/web/.next/static/chunks/039ic1ygq-to3.js +0 -1
- package/web/.next/static/chunks/07a4jt64wdipb.js +0 -1
- package/web/.next/static/chunks/0_imq4rg3q.fe.js +0 -3
- package/web/.next/static/chunks/0i084mozx131g.js +0 -1
- package/web/.next/static/chunks/0j_0i2qsrwh-c.js +0 -1
- package/web/.next/static/chunks/0r5dju6f1-i38.css +0 -1
- /package/web/.next/static/{ynyh_sSxbFA995FRvBUxs → GSG_c1emY-f_AA00vD56y}/_buildManifest.js +0 -0
- /package/web/.next/static/{ynyh_sSxbFA995FRvBUxs → GSG_c1emY-f_AA00vD56y}/_clientMiddlewareManifest.js +0 -0
- /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;
|
|
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;
|
|
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: '
|
|
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
|
|
38
|
-
if (!options.auth
|
|
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;
|
|
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
|
-
*
|
|
12
|
-
*
|
|
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
|
-
|
|
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
|
|
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
|
-
*
|
|
14
|
-
*
|
|
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.
|
|
43
|
-
value: AgentType.
|
|
44
|
-
description: t('tui:prompts.selectAgent.choices.
|
|
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.
|
|
48
|
-
value: AgentType.
|
|
49
|
-
|
|
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.
|
|
16
|
-
* 3.
|
|
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;
|
|
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.
|
|
39
|
-
* 3.
|
|
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:
|
|
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
|
|
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"}
|