@opengsd/gsd-pi 1.2.0-dev.b1abb545 → 1.2.0-dev.e8563f58
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/dist/cli-style.d.ts +17 -0
- package/dist/cli-style.js +28 -0
- package/dist/cli.js +1 -1
- package/dist/headless-events.d.ts +4 -2
- package/dist/headless-events.js +14 -34
- package/dist/mcp-server.js +2 -1
- package/dist/models-resolver.d.ts +3 -13
- package/dist/models-resolver.js +3 -22
- package/dist/resource-loader.js +2 -14
- package/dist/resources/.managed-resources-content-hash +1 -1
- package/dist/resources/GSD-WORKFLOW.md +5 -4
- package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
- package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
- package/dist/resources/extensions/async-jobs/index.js +65 -0
- package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
- package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
- package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
- package/dist/resources/extensions/bg-shell/overlay.js +9 -6
- package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
- package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
- package/dist/resources/extensions/bg-shell/utilities.js +5 -2
- package/dist/resources/extensions/browser-tools/engine/managed-gsd-browser.js +209 -88
- package/dist/resources/extensions/browser-tools/engine/selection.js +73 -5
- package/dist/resources/extensions/browser-tools/index.js +69 -12
- package/dist/resources/extensions/claude-code-cli/models.js +9 -0
- package/dist/resources/extensions/claude-code-cli/stream-adapter.js +38 -6
- package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
- package/dist/resources/extensions/gsd/auto/dispatch-history.js +105 -0
- package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
- package/dist/resources/extensions/gsd/auto/loop.js +4 -1
- package/dist/resources/extensions/gsd/auto/orchestrator.js +122 -58
- package/dist/resources/extensions/gsd/auto/phases.js +8 -3
- package/dist/resources/extensions/gsd/auto-direct-dispatch.js +8 -32
- package/dist/resources/extensions/gsd/auto-dispatch.js +40 -57
- package/dist/resources/extensions/gsd/auto-model-selection.js +36 -13
- package/dist/resources/extensions/gsd/auto-post-unit.js +31 -14
- package/dist/resources/extensions/gsd/auto-prompts.js +81 -19
- package/dist/resources/extensions/gsd/auto-start.js +24 -26
- package/dist/resources/extensions/gsd/auto-tool-tracking.js +18 -0
- package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +12 -20
- package/dist/resources/extensions/gsd/auto-verification.js +9 -28
- package/dist/resources/extensions/gsd/auto-worktree-repair.js +10 -2
- package/dist/resources/extensions/gsd/auto-worktree.js +35 -352
- package/dist/resources/extensions/gsd/auto.js +15 -20
- package/dist/resources/extensions/gsd/blocked-models.js +28 -0
- package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +29 -8
- package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +32 -12
- package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +19 -0
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +229 -36
- package/dist/resources/extensions/gsd/bootstrap/write-gate.js +319 -71
- package/dist/resources/extensions/gsd/branch-patterns.js +2 -0
- package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
- package/dist/resources/extensions/gsd/browser-evidence.js +8 -2
- package/dist/resources/extensions/gsd/captures.js +5 -15
- package/dist/resources/extensions/gsd/closeout-recovery.js +3 -2
- package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
- package/dist/resources/extensions/gsd/commands/catalog.js +6 -62
- package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
- package/dist/resources/extensions/gsd/consent-question.js +353 -0
- package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
- package/dist/resources/extensions/gsd/constants.js +0 -2
- package/dist/resources/extensions/gsd/crash-recovery.js +4 -12
- package/dist/resources/extensions/gsd/db/engine.js +755 -0
- package/dist/resources/extensions/gsd/db/queries.js +398 -0
- package/dist/resources/extensions/gsd/db/sql-constants.js +11 -0
- package/dist/resources/extensions/gsd/db/writers/cascades.js +194 -0
- package/dist/resources/extensions/gsd/db/writers/import-restore.js +182 -0
- package/dist/resources/extensions/gsd/db/writers/memory.js +149 -0
- package/dist/resources/extensions/gsd/db/writers/reconcile.js +458 -0
- package/dist/resources/extensions/gsd/db/writers/status.js +70 -0
- package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
- package/dist/resources/extensions/gsd/doctor-environment.js +5 -11
- package/dist/resources/extensions/gsd/doctor-format.js +9 -6
- package/dist/resources/extensions/gsd/doctor-git-checks.js +6 -21
- package/dist/resources/extensions/gsd/doctor-runtime-checks.js +21 -16
- package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
- package/dist/resources/extensions/gsd/error-classifier.js +9 -0
- package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
- package/dist/resources/extensions/gsd/files.js +33 -19
- package/dist/resources/extensions/gsd/git-service.js +1 -0
- package/dist/resources/extensions/gsd/gitignore.js +3 -0
- package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
- package/dist/resources/extensions/gsd/gsd-db.js +172 -2048
- package/dist/resources/extensions/gsd/guidance.js +158 -0
- package/dist/resources/extensions/gsd/guided-flow.js +51 -5
- package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
- package/dist/resources/extensions/gsd/mcp-filter.js +2 -19
- package/dist/resources/extensions/gsd/mcp-tool-name.js +5 -13
- package/dist/resources/extensions/gsd/memory-consolidation-scanner.js +1 -1
- package/dist/resources/extensions/gsd/migrate/safety.js +20 -9
- package/dist/resources/extensions/gsd/migration-auto-check.js +24 -3
- package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
- package/dist/resources/extensions/gsd/model-cost-table.js +1 -0
- package/dist/resources/extensions/gsd/model-router.js +3 -0
- package/dist/resources/extensions/gsd/notification-store.js +11 -4
- package/dist/resources/extensions/gsd/parallel-merge.js +14 -11
- package/dist/resources/extensions/gsd/parallel-monitor-overlay.js +11 -7
- package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
- package/dist/resources/extensions/gsd/paths.js +37 -24
- package/dist/resources/extensions/gsd/pre-execution-checks.js +91 -3
- package/dist/resources/extensions/gsd/preferences-models.js +14 -48
- package/dist/resources/extensions/gsd/preferences.js +14 -0
- package/dist/resources/extensions/gsd/prompts/complete-slice.md +2 -2
- package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/dist/resources/extensions/gsd/prompts/run-uat.md +6 -4
- package/dist/resources/extensions/gsd/prompts/system.md +5 -2
- package/dist/resources/extensions/gsd/provider-error-guidance.js +1 -5
- package/dist/resources/extensions/gsd/provider-switch-observer.js +1 -1
- package/dist/resources/extensions/gsd/publication.js +87 -0
- package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
- package/dist/resources/extensions/gsd/recovery-classification.js +41 -87
- package/dist/resources/extensions/gsd/safety/destructive-confirmation.js +108 -0
- package/dist/resources/extensions/gsd/safety/evidence-collector.js +37 -4
- package/dist/resources/extensions/gsd/safety/evidence-cross-ref.js +7 -2
- package/dist/resources/extensions/gsd/safety/file-change-validator.js +10 -0
- package/dist/resources/extensions/gsd/state-transition-matrix.js +38 -0
- package/dist/resources/extensions/gsd/state.js +6 -20
- package/dist/resources/extensions/gsd/status-guards.js +56 -8
- package/dist/resources/extensions/gsd/stop-notice.js +57 -0
- package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
- package/dist/resources/extensions/gsd/tool-surface-readiness.js +56 -0
- package/dist/resources/extensions/gsd/tools/complete-slice.js +44 -53
- package/dist/resources/extensions/gsd/tools/exec-tool.js +10 -8
- package/dist/resources/extensions/gsd/tools/plan-slice.js +12 -6
- package/dist/resources/extensions/gsd/tools/reopen-milestone.js +11 -29
- package/dist/resources/extensions/gsd/tools/reopen-slice.js +14 -33
- package/dist/resources/extensions/gsd/tools/skip-slice.js +18 -36
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +67 -2
- package/dist/resources/extensions/gsd/uat-policy.js +42 -16
- package/dist/resources/extensions/gsd/undo.js +8 -7
- package/dist/resources/extensions/gsd/unit-closeout.js +138 -0
- package/dist/resources/extensions/gsd/unit-context-composer.js +74 -1
- package/dist/resources/extensions/gsd/unit-context-manifest.js +4 -27
- package/dist/resources/extensions/gsd/unit-registry.js +337 -0
- package/dist/resources/extensions/gsd/unit-tool-contracts.js +9 -182
- package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
- package/dist/resources/extensions/gsd/web-app-uat.js +45 -8
- package/dist/resources/extensions/gsd/workflow-tool-surface.js +1 -1
- package/dist/resources/extensions/gsd/worktree-git-recovery.js +293 -0
- package/dist/resources/extensions/gsd/worktree-lifecycle.js +12 -3
- package/dist/resources/extensions/gsd/worktree-manager.js +45 -28
- package/dist/resources/extensions/gsd/worktree-placement.js +59 -0
- package/dist/resources/extensions/gsd/worktree-reentry.js +12 -8
- package/dist/resources/extensions/gsd/worktree-root.js +28 -6
- package/dist/resources/extensions/gsd/worktree-safety.js +8 -5
- package/dist/resources/extensions/gsd/worktree-session-state.js +12 -11
- package/dist/resources/extensions/search-the-web/native-search.js +5 -3
- package/dist/resources/extensions/shared/browser-contract.js +59 -0
- package/dist/resources/extensions/shared/gsd-browser-cli.js +116 -6
- package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
- package/dist/resources/shared/package-manager-detection.js +1 -1
- package/dist/resources/shared/package.json +3 -0
- package/dist/resources/skills/create-skill/references/executable-code.md +1 -1
- package/dist/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/dist/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/dist/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/dist/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/dist/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/dist/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/dist/resources/skills/gsd-browser/SKILL.md +1 -1
- package/dist/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/tsconfig.extensions.tsbuildinfo +1 -1
- package/dist/update-check.d.ts +2 -0
- package/dist/update-check.js +24 -1
- package/dist/update-cmd.js +20 -3
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +8 -8
- package/dist/web/standalone/.next/build-manifest.json +3 -3
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/mcp-connections/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/shutdown/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/update/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
- package/dist/web/standalone/.next/server/app/index.html +1 -1
- package/dist/web/standalone/.next/server/app/index.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/dist/web/standalone/.next/server/app-paths-manifest.json +8 -8
- package/dist/web/standalone/.next/server/chunks/5124.js +1 -1
- package/dist/web/standalone/.next/server/chunks/{5047.js → 5942.js} +2 -2
- package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
- package/dist/web/standalone/.next/server/pages/404.html +1 -1
- package/dist/web/standalone/.next/server/pages/500.html +1 -1
- package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
- package/dist/web/standalone/.next/static/chunks/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
- package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
- package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
- package/dist/web/standalone/package.json +1 -1
- package/dist/worktree-cli.js +3 -6
- package/dist/worktree-status-banner.js +7 -11
- package/package.json +1 -1
- package/packages/cloud-mcp-gateway/package.json +2 -2
- package/packages/contracts/dist/rpc.d.ts +1 -0
- package/packages/contracts/dist/rpc.d.ts.map +1 -1
- package/packages/contracts/dist/rpc.js.map +1 -1
- package/packages/contracts/dist/workflow.d.ts +4 -0
- package/packages/contracts/dist/workflow.d.ts.map +1 -1
- package/packages/contracts/dist/workflow.js.map +1 -1
- package/packages/contracts/package.json +1 -1
- package/packages/daemon/package.json +4 -4
- package/packages/gsd-agent-core/package.json +5 -5
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +5 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +8 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
- package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
- package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
- package/packages/gsd-agent-modes/package.json +7 -7
- package/packages/mcp-server/dist/cli.js +6 -3
- package/packages/mcp-server/dist/cli.js.map +1 -1
- package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
- package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +4 -0
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.d.ts +26 -18
- package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
- package/packages/mcp-server/dist/workflow-tools.js +145 -59
- package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
- package/packages/mcp-server/package.json +5 -4
- package/packages/native/package.json +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
- package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
- package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
- package/packages/pi-agent-core/dist/index.d.ts +1 -0
- package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
- package/packages/pi-agent-core/dist/index.js +3 -0
- package/packages/pi-agent-core/dist/index.js.map +1 -1
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-ai/README.md +1 -0
- package/packages/pi-ai/dist/index.d.ts +2 -0
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +2 -0
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/models.generated.d.ts +192 -0
- package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.js +166 -0
- package/packages/pi-ai/dist/models.generated.js.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/anthropic.js +12 -7
- package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
- package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/google-shared.js +12 -3
- package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
- package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
- package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
- package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
- package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
- package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
- package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
- package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
- package/packages/pi-ai/package.json +3 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
- package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
- package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/capability-patches.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/capability-patches.js +3 -1
- package/packages/pi-coding-agent/dist/core/capability-patches.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
- package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
- package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
- package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts +1 -1
- package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/index.js +1 -1
- package/packages/pi-coding-agent/dist/index.js.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
- package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
- package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
- package/packages/pi-coding-agent/package.json +7 -7
- package/packages/pi-tui/dist/tui.d.ts.map +1 -1
- package/packages/pi-tui/dist/tui.js +9 -0
- package/packages/pi-tui/dist/tui.js.map +1 -1
- package/packages/pi-tui/package.json +2 -2
- package/packages/rpc-client/package.json +2 -2
- package/pkg/package.json +1 -1
- package/src/resources/GSD-WORKFLOW.md +5 -4
- package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
- package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
- package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
- package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
- package/src/resources/extensions/async-jobs/index.ts +79 -0
- package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
- package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
- package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
- package/src/resources/extensions/bg-shell/overlay.ts +9 -5
- package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
- package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
- package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
- package/src/resources/extensions/bg-shell/utilities.ts +5 -2
- package/src/resources/extensions/browser-tools/engine/managed-gsd-browser.ts +265 -98
- package/src/resources/extensions/browser-tools/engine/selection.ts +90 -4
- package/src/resources/extensions/browser-tools/index.ts +71 -13
- package/src/resources/extensions/browser-tools/tests/browser-engine-selection.test.mjs +83 -13
- package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +40 -1
- package/src/resources/extensions/browser-tools/tests/managed-gsd-browser-tools.test.mjs +136 -0
- package/src/resources/extensions/claude-code-cli/models.ts +9 -0
- package/src/resources/extensions/claude-code-cli/stream-adapter.ts +40 -4
- package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +28 -0
- package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
- package/src/resources/extensions/gsd/auto/dispatch-history.ts +152 -0
- package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
- package/src/resources/extensions/gsd/auto/loop-deps.ts +1 -1
- package/src/resources/extensions/gsd/auto/loop.ts +4 -1
- package/src/resources/extensions/gsd/auto/orchestrator.ts +137 -61
- package/src/resources/extensions/gsd/auto/phases.ts +12 -3
- package/src/resources/extensions/gsd/auto-direct-dispatch.ts +8 -32
- package/src/resources/extensions/gsd/auto-dispatch.ts +38 -52
- package/src/resources/extensions/gsd/auto-model-selection.ts +41 -12
- package/src/resources/extensions/gsd/auto-post-unit.ts +37 -13
- package/src/resources/extensions/gsd/auto-prompts.ts +118 -35
- package/src/resources/extensions/gsd/auto-start.ts +24 -29
- package/src/resources/extensions/gsd/auto-tool-tracking.ts +19 -0
- package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +14 -21
- package/src/resources/extensions/gsd/auto-verification.ts +8 -26
- package/src/resources/extensions/gsd/auto-worktree-repair.ts +13 -2
- package/src/resources/extensions/gsd/auto-worktree.ts +41 -364
- package/src/resources/extensions/gsd/auto.ts +28 -24
- package/src/resources/extensions/gsd/blocked-models.ts +49 -0
- package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +37 -10
- package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +33 -12
- package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +24 -0
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +270 -37
- package/src/resources/extensions/gsd/bootstrap/write-gate.ts +368 -78
- package/src/resources/extensions/gsd/branch-patterns.ts +3 -0
- package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
- package/src/resources/extensions/gsd/browser-evidence.ts +18 -2
- package/src/resources/extensions/gsd/captures.ts +5 -16
- package/src/resources/extensions/gsd/closeout-recovery.ts +2 -1
- package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
- package/src/resources/extensions/gsd/commands/catalog.ts +6 -68
- package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
- package/src/resources/extensions/gsd/consent-question.ts +431 -0
- package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
- package/src/resources/extensions/gsd/constants.ts +0 -3
- package/src/resources/extensions/gsd/crash-recovery.ts +3 -9
- package/src/resources/extensions/gsd/db/engine.ts +809 -0
- package/src/resources/extensions/gsd/db/queries.ts +490 -0
- package/src/resources/extensions/gsd/db/sql-constants.ts +12 -0
- package/src/resources/extensions/gsd/db/writers/cascades.ts +237 -0
- package/src/resources/extensions/gsd/db/writers/import-restore.ts +310 -0
- package/src/resources/extensions/gsd/db/writers/memory.ts +220 -0
- package/src/resources/extensions/gsd/db/writers/reconcile.ts +500 -0
- package/src/resources/extensions/gsd/db/writers/status.ts +88 -0
- package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
- package/src/resources/extensions/gsd/doctor-environment.ts +5 -13
- package/src/resources/extensions/gsd/doctor-format.ts +12 -7
- package/src/resources/extensions/gsd/doctor-git-checks.ts +5 -22
- package/src/resources/extensions/gsd/doctor-runtime-checks.ts +22 -17
- package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
- package/src/resources/extensions/gsd/error-classifier.ts +11 -0
- package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
- package/src/resources/extensions/gsd/files.ts +33 -12
- package/src/resources/extensions/gsd/git-service.ts +1 -0
- package/src/resources/extensions/gsd/gitignore.ts +3 -0
- package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
- package/src/resources/extensions/gsd/gsd-db.ts +176 -2375
- package/src/resources/extensions/gsd/guidance.ts +217 -0
- package/src/resources/extensions/gsd/guided-flow.ts +50 -5
- package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
- package/src/resources/extensions/gsd/mcp-filter.ts +2 -23
- package/src/resources/extensions/gsd/mcp-tool-name.ts +6 -11
- package/src/resources/extensions/gsd/memory-consolidation-scanner.ts +1 -1
- package/src/resources/extensions/gsd/migrate/safety.ts +18 -7
- package/src/resources/extensions/gsd/migration-auto-check.ts +28 -3
- package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
- package/src/resources/extensions/gsd/model-cost-table.ts +1 -0
- package/src/resources/extensions/gsd/model-router.ts +3 -0
- package/src/resources/extensions/gsd/notification-store.ts +26 -3
- package/src/resources/extensions/gsd/parallel-merge.ts +12 -9
- package/src/resources/extensions/gsd/parallel-monitor-overlay.ts +10 -7
- package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
- package/src/resources/extensions/gsd/paths.ts +42 -22
- package/src/resources/extensions/gsd/pre-execution-checks.ts +109 -3
- package/src/resources/extensions/gsd/preferences-models.ts +12 -47
- package/src/resources/extensions/gsd/preferences.ts +18 -0
- package/src/resources/extensions/gsd/prompts/complete-slice.md +2 -2
- package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
- package/src/resources/extensions/gsd/prompts/run-uat.md +6 -4
- package/src/resources/extensions/gsd/prompts/system.md +5 -2
- package/src/resources/extensions/gsd/provider-error-guidance.ts +4 -9
- package/src/resources/extensions/gsd/provider-switch-observer.ts +1 -1
- package/src/resources/extensions/gsd/publication.ts +122 -0
- package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
- package/src/resources/extensions/gsd/recovery-classification.ts +47 -88
- package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
- package/src/resources/extensions/gsd/safety/evidence-collector.ts +36 -4
- package/src/resources/extensions/gsd/safety/evidence-cross-ref.ts +7 -2
- package/src/resources/extensions/gsd/safety/file-change-validator.ts +14 -0
- package/src/resources/extensions/gsd/state-transition-matrix.ts +42 -0
- package/src/resources/extensions/gsd/state.ts +9 -21
- package/src/resources/extensions/gsd/status-guards.ts +59 -8
- package/src/resources/extensions/gsd/stop-notice.ts +75 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +123 -0
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +91 -0
- package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +198 -26
- package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/auto-post-unit-evidence-crossref-4909.test.ts +46 -0
- package/src/resources/extensions/gsd/tests/auto-worktree-registry.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/auto-worktree-repair.test.ts +4 -2
- package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
- package/src/resources/extensions/gsd/tests/browser-automation-contract-fixture.ts +39 -0
- package/src/resources/extensions/gsd/tests/browser-contract.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
- package/src/resources/extensions/gsd/tests/checkout-branch-stash-guard.test.ts +66 -1
- package/src/resources/extensions/gsd/tests/clear-stale-autostart.test.ts +44 -0
- package/src/resources/extensions/gsd/tests/commands-verdict.test.ts +8 -7
- package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
- package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
- package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +10 -10
- package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
- package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +273 -0
- package/src/resources/extensions/gsd/tests/dispatch-run-uat-browser-tools.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
- package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
- package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
- package/src/resources/extensions/gsd/tests/evidence-xref-gsd-exec.test.ts +157 -0
- package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
- package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
- package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +35 -1
- package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +33 -1
- package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
- package/src/resources/extensions/gsd/tests/guidance.test.ts +148 -0
- package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +58 -15
- package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +74 -59
- package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +3 -2
- package/src/resources/extensions/gsd/tests/integration/gsd-integration-fixture.ts +80 -0
- package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +199 -0
- package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/migration-auto-check.test.ts +85 -1
- package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
- package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
- package/src/resources/extensions/gsd/tests/notification-store.test.ts +32 -0
- package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
- package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
- package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +138 -0
- package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +193 -1
- package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
- package/src/resources/extensions/gsd/tests/provider-error-guidance.test.ts +3 -3
- package/src/resources/extensions/gsd/tests/publication.test.ts +120 -0
- package/src/resources/extensions/gsd/tests/recovery-classification-illegal-transition.test.ts +30 -0
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +248 -1
- package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +1 -0
- package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/session-switch-clears-pending-autostart.test.ts +108 -0
- package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +43 -6
- package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +36 -0
- package/src/resources/extensions/gsd/tests/status-guards.test.ts +38 -0
- package/src/resources/extensions/gsd/tests/stop-notice.test.ts +70 -0
- package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +76 -0
- package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +8 -0
- package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +155 -0
- package/src/resources/extensions/gsd/tests/uat-policy.test.ts +112 -29
- package/src/resources/extensions/gsd/tests/unit-closeout.test.ts +209 -0
- package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +67 -2
- package/src/resources/extensions/gsd/tests/unit-registry.test.ts +163 -0
- package/src/resources/extensions/gsd/tests/web-app-uat.test.ts +44 -1
- package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +275 -40
- package/src/resources/extensions/gsd/tests/worktree-lifecycle.test.ts +41 -4
- package/src/resources/extensions/gsd/tests/worktree-manager.test.ts +22 -1
- package/src/resources/extensions/gsd/tests/worktree-placement.test.ts +113 -0
- package/src/resources/extensions/gsd/tests/worktree-reentry.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +3 -1
- package/src/resources/extensions/gsd/tests/worktree-symlink-removal.test.ts +12 -6
- package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
- package/src/resources/extensions/gsd/tests/write-gate.test.ts +109 -1
- package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
- package/src/resources/extensions/gsd/tool-surface-readiness.ts +76 -0
- package/src/resources/extensions/gsd/tools/complete-slice.ts +43 -68
- package/src/resources/extensions/gsd/tools/exec-tool.ts +9 -8
- package/src/resources/extensions/gsd/tools/plan-slice.ts +12 -6
- package/src/resources/extensions/gsd/tools/reopen-milestone.ts +11 -38
- package/src/resources/extensions/gsd/tools/reopen-slice.ts +14 -42
- package/src/resources/extensions/gsd/tools/skip-slice.ts +18 -44
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
- package/src/resources/extensions/gsd/uat-policy.ts +62 -16
- package/src/resources/extensions/gsd/undo.ts +9 -8
- package/src/resources/extensions/gsd/unit-closeout.ts +201 -0
- package/src/resources/extensions/gsd/unit-context-composer.ts +111 -1
- package/src/resources/extensions/gsd/unit-context-manifest.ts +4 -28
- package/src/resources/extensions/gsd/unit-registry.ts +412 -0
- package/src/resources/extensions/gsd/unit-tool-contracts.ts +27 -192
- package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
- package/src/resources/extensions/gsd/web-app-uat.ts +51 -8
- package/src/resources/extensions/gsd/workflow-tool-surface.ts +4 -1
- package/src/resources/extensions/gsd/worktree-git-recovery.ts +314 -0
- package/src/resources/extensions/gsd/worktree-lifecycle.ts +13 -9
- package/src/resources/extensions/gsd/worktree-manager.ts +47 -28
- package/src/resources/extensions/gsd/worktree-placement.ts +63 -0
- package/src/resources/extensions/gsd/worktree-reentry.ts +10 -7
- package/src/resources/extensions/gsd/worktree-root.ts +29 -6
- package/src/resources/extensions/gsd/worktree-safety.ts +8 -5
- package/src/resources/extensions/gsd/worktree-session-state.ts +11 -11
- package/src/resources/extensions/search-the-web/native-search.ts +5 -3
- package/src/resources/extensions/shared/browser-contract.ts +66 -0
- package/src/resources/extensions/shared/gsd-browser-cli.ts +141 -6
- package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
- package/src/resources/shared/package-manager-detection.ts +1 -1
- package/src/resources/shared/package.json +3 -0
- package/src/resources/skills/create-skill/references/executable-code.md +1 -1
- package/src/resources/skills/create-skill/workflows/add-reference.md +8 -3
- package/src/resources/skills/create-skill/workflows/add-script.md +4 -2
- package/src/resources/skills/create-skill/workflows/add-template.md +3 -1
- package/src/resources/skills/create-skill/workflows/add-workflow.md +8 -3
- package/src/resources/skills/create-skill/workflows/upgrade-to-router.md +10 -5
- package/src/resources/skills/create-skill/workflows/verify-skill.md +9 -4
- package/src/resources/skills/gsd-browser/SKILL.md +1 -1
- package/src/resources/skills/spike-wrap-up/SKILL.md +9 -9
- package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
- package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
- package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
- /package/dist/web/standalone/.next/static/{3PtrU9qGPEXwNLWkIyiqk → LDHRKiRBIVZmiuMjrL1Vy}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{3PtrU9qGPEXwNLWkIyiqk → LDHRKiRBIVZmiuMjrL1Vy}/_ssgManifest.js +0 -0
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Actionable remediation hints when auto-mode pauses on provider/model errors.
|
|
3
|
+
* Render with formatGuidance from the Guidance module.
|
|
3
4
|
*/
|
|
4
5
|
/** Map auto unit types to the `models:` key in PREFERENCES.md. */
|
|
5
6
|
export function unitTypeToPrefsPhaseKey(unitType) {
|
|
@@ -91,8 +92,3 @@ export function resolveProviderErrorGuidance(input) {
|
|
|
91
92
|
steps.push("Run /gsd next to resume the paused unit.");
|
|
92
93
|
return { summary, steps };
|
|
93
94
|
}
|
|
94
|
-
/** Flatten guidance into a pause banner / notification string. */
|
|
95
|
-
export function formatProviderErrorGuidance(guidance) {
|
|
96
|
-
const numbered = guidance.steps.map((step, index) => `${index + 1}. ${step}`).join("\n");
|
|
97
|
-
return `${guidance.summary}\n\n${numbered}`;
|
|
98
|
-
}
|
|
@@ -92,7 +92,7 @@ function emitAudit(report) {
|
|
|
92
92
|
}
|
|
93
93
|
function emitNotification(report) {
|
|
94
94
|
try {
|
|
95
|
-
appendNotification(summarize(report), "warning", "workflow-logger");
|
|
95
|
+
appendNotification(summarize(report), "warning", "workflow-logger", { kind: "provider-switch" });
|
|
96
96
|
}
|
|
97
97
|
catch {
|
|
98
98
|
// Notification persistence is best-effort.
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
// Project/App: gsd-pi
|
|
2
|
+
// File Purpose: Publication module — push and draft-PR creation for a merged milestone (ADR-034).
|
|
3
|
+
//
|
|
4
|
+
// Publication is distinct from the merge verb: merging a milestone branch is a
|
|
5
|
+
// Worktree Lifecycle concern (worktree, branch, lease, stash discipline);
|
|
6
|
+
// publication needs only the resulting commit, a remote, and preferences.
|
|
7
|
+
// Extracted from the tail of `mergeMilestoneToMain` (auto-worktree.ts) so it is
|
|
8
|
+
// testable without a merge fixture and reachable from any closeout path.
|
|
9
|
+
//
|
|
10
|
+
// Publication failure is non-fatal to a completed local merge: every failure is
|
|
11
|
+
// logged and reported in the result, never thrown.
|
|
12
|
+
import { execFileSync } from "node:child_process";
|
|
13
|
+
import { buildPullRequestEvidence, createDraftPullRequestFromEvidence, } from "./pull-request-process.js";
|
|
14
|
+
import { logWarning } from "./workflow-logger.js";
|
|
15
|
+
export function gitRemoteExists(basePath, remote) {
|
|
16
|
+
try {
|
|
17
|
+
execFileSync("git", ["remote", "get-url", remote], {
|
|
18
|
+
cwd: basePath,
|
|
19
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
20
|
+
encoding: "utf-8",
|
|
21
|
+
});
|
|
22
|
+
return true;
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Publish a merged milestone per preferences: push the integration branch
|
|
30
|
+
* (auto-push, suppressed when auto-PR owns the remote interaction) and/or
|
|
31
|
+
* push the milestone branch and open a draft PR (auto-PR).
|
|
32
|
+
*/
|
|
33
|
+
export function publishMilestone(request) {
|
|
34
|
+
const result = { pushed: false, prCreated: false };
|
|
35
|
+
if (request.nothingToCommit)
|
|
36
|
+
return result;
|
|
37
|
+
const { basePath, prefs } = request;
|
|
38
|
+
const remote = prefs.remote ?? "origin";
|
|
39
|
+
if (prefs.autoPush && !prefs.autoPr && gitRemoteExists(basePath, remote)) {
|
|
40
|
+
try {
|
|
41
|
+
execFileSync("git", ["push", remote, request.integrationBranch], {
|
|
42
|
+
cwd: basePath,
|
|
43
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
44
|
+
encoding: "utf-8",
|
|
45
|
+
});
|
|
46
|
+
result.pushed = true;
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
// Push failure is non-fatal
|
|
50
|
+
logWarning("worktree", `git push failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
// #2302: PR creation is not gated on pushed/auto-push.
|
|
54
|
+
if (prefs.autoPr && gitRemoteExists(basePath, remote)) {
|
|
55
|
+
try {
|
|
56
|
+
// Push the milestone branch to remote first
|
|
57
|
+
execFileSync("git", ["push", remote, request.milestoneBranch], {
|
|
58
|
+
cwd: basePath,
|
|
59
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
60
|
+
encoding: "utf-8",
|
|
61
|
+
});
|
|
62
|
+
const prEvidence = buildPullRequestEvidence({
|
|
63
|
+
milestoneId: request.milestoneId,
|
|
64
|
+
milestoneTitle: request.milestoneTitle,
|
|
65
|
+
changeType: "feat",
|
|
66
|
+
summaries: [...request.sliceSummaries],
|
|
67
|
+
testsRun: ["Auto-created after milestone merge. Run `npm run verify:merge` before marking this draft ready."],
|
|
68
|
+
rollbackNotes: ["Close the draft PR or revert the merge commit if review finds a behavior regression."],
|
|
69
|
+
how: "Generated by git.auto_pr after the milestone branch was pushed and merged locally.",
|
|
70
|
+
});
|
|
71
|
+
const prUrl = createDraftPullRequestFromEvidence(basePath, request.milestoneId, prEvidence, {
|
|
72
|
+
head: request.milestoneBranch,
|
|
73
|
+
base: prefs.prTargetBranch ?? request.integrationBranch,
|
|
74
|
+
});
|
|
75
|
+
if (!prUrl) {
|
|
76
|
+
throw new Error("gh pr create returned no URL");
|
|
77
|
+
}
|
|
78
|
+
result.prCreated = true;
|
|
79
|
+
result.prUrl = prUrl;
|
|
80
|
+
}
|
|
81
|
+
catch (err) {
|
|
82
|
+
// PR creation failure is non-fatal — gh may not be installed or authenticated
|
|
83
|
+
logWarning("worktree", `PR creation failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
}
|
|
@@ -10,7 +10,11 @@
|
|
|
10
10
|
*/
|
|
11
11
|
import { loadFile, parseTaskPlanIO } from "./files.js";
|
|
12
12
|
import { isDbAvailable, getSliceTasks } from "./gsd-db.js";
|
|
13
|
+
// Explicit degraded-mode fallback ONLY (ADR-017): parsePlan is consulted when
|
|
14
|
+
// the DB is unavailable or has no task rows for the slice; the DB path in
|
|
15
|
+
// loadSliceTaskIO always wins when rows exist, and the fallback logs a warning.
|
|
13
16
|
import { parsePlan } from "./parsers-legacy.js";
|
|
17
|
+
import { logWarning } from "./workflow-logger.js";
|
|
14
18
|
import { resolveTasksDir, resolveTaskFiles } from "./paths.js";
|
|
15
19
|
import { join } from "node:path";
|
|
16
20
|
import { loadJsonFileOrNull, saveJsonFile } from "./json-persistence.js";
|
|
@@ -178,7 +182,10 @@ export async function loadSliceTaskIO(basePath, mid, sid) {
|
|
|
178
182
|
}
|
|
179
183
|
catch { /* fall through */ }
|
|
180
184
|
if (!taskEntries) {
|
|
181
|
-
//
|
|
185
|
+
// Degraded-mode fallback (ADR-017): no DB task rows for this slice —
|
|
186
|
+
// parse the PLAN.md projection instead. Warn so silent drift from the
|
|
187
|
+
// DB-authoritative path is visible in logs.
|
|
188
|
+
logWarning("projection", `reactive-graph: DB unavailable or no task rows for ${mid}/${sid}; falling back to PLAN.md parsing`);
|
|
182
189
|
const parsed = parsePlan(planContent);
|
|
183
190
|
if (parsed.tasks.length > 0) {
|
|
184
191
|
taskEntries = parsed.tasks.map(t => ({
|
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
// Project/App: gsd-pi
|
|
2
2
|
// File Purpose: ADR-015 Recovery Classification module for runtime failure taxonomy.
|
|
3
|
+
import { isToolUnavailableError } from "./auto-tool-tracking.js";
|
|
3
4
|
import { classifyError, isTransient } from "./error-classifier.js";
|
|
5
|
+
import { recoveryRemediation } from "./guidance.js";
|
|
4
6
|
import { ReconciliationFailedError } from "./state-reconciliation.js";
|
|
7
|
+
import { IllegalPhaseTransitionError } from "./state-transition-matrix.js";
|
|
5
8
|
export function classifyFailure(input) {
|
|
6
9
|
const message = errorMessage(input.error);
|
|
7
10
|
// ADR-017: ReconciliationFailedError is a typed throw from the State
|
|
@@ -9,96 +12,47 @@ export function classifyFailure(input) {
|
|
|
9
12
|
// failureKind so the taxonomy stays consistent.
|
|
10
13
|
const failureKind = input.error instanceof ReconciliationFailedError
|
|
11
14
|
? "reconciliation-drift"
|
|
12
|
-
: input.
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
reason: `Tool Contract failure${unitSuffix(input)}: ${message}`,
|
|
27
|
-
exitReason: "tool-contract",
|
|
28
|
-
remediation: "Fix the Unit Tool Contract or prompt so the Unit is only asked to use tools owned by its phase.",
|
|
29
|
-
};
|
|
30
|
-
case "deterministic-policy":
|
|
31
|
-
return {
|
|
32
|
-
failureKind,
|
|
33
|
-
action: "stop",
|
|
34
|
-
reason: `Deterministic policy failure${unitSuffix(input)}: ${message}`,
|
|
35
|
-
exitReason: "deterministic-policy",
|
|
36
|
-
remediation: "Resolve the policy blocker; retrying the same Unit will repeat the failure.",
|
|
37
|
-
};
|
|
38
|
-
case "lifecycle-progression":
|
|
39
|
-
return {
|
|
40
|
-
failureKind,
|
|
41
|
-
action: "stop",
|
|
42
|
-
reason: `Lifecycle progression failure${unitSuffix(input)}: ${message}`,
|
|
43
|
-
exitReason: "lifecycle-progression",
|
|
44
|
-
remediation: "Route to the required owning Unit or restore the missing artifact before advancing lifecycle state.",
|
|
45
|
-
};
|
|
46
|
-
case "stale-worker":
|
|
47
|
-
return {
|
|
48
|
-
failureKind,
|
|
49
|
-
action: "stop",
|
|
50
|
-
reason: `Stale worker failure${unitSuffix(input)}: ${message}`,
|
|
51
|
-
exitReason: "stale-worker",
|
|
52
|
-
remediation: "Clear or reconcile the stale worker before dispatching another Unit.",
|
|
53
|
-
};
|
|
54
|
-
case "worktree-invalid":
|
|
55
|
-
return {
|
|
56
|
-
failureKind,
|
|
57
|
-
action: "stop",
|
|
58
|
-
reason: `Worktree invalid${unitSuffix(input)}: ${message}`,
|
|
59
|
-
exitReason: "worktree-invalid",
|
|
60
|
-
remediation: "Repair or recreate the milestone worktree before launching source-writing Units.",
|
|
61
|
-
};
|
|
62
|
-
case "verification-drift":
|
|
63
|
-
return {
|
|
64
|
-
failureKind,
|
|
65
|
-
action: "escalate",
|
|
66
|
-
reason: `Verification drift${unitSuffix(input)}: ${message}`,
|
|
67
|
-
exitReason: "verification-drift",
|
|
68
|
-
remediation: "Inspect the verification artifact and reconcile the state snapshot before resuming.",
|
|
69
|
-
};
|
|
70
|
-
case "reconciliation-drift":
|
|
71
|
-
return {
|
|
72
|
-
failureKind,
|
|
73
|
-
action: "escalate",
|
|
74
|
-
reason: `Reconciliation drift${unitSuffix(input)}: ${message}`,
|
|
75
|
-
exitReason: "reconciliation-drift",
|
|
76
|
-
remediation: "Inspect the persistent or repair-failed drift kinds reported by the State Reconciliation Module before resuming.",
|
|
77
|
-
};
|
|
78
|
-
case "provider": {
|
|
79
|
-
const providerClass = classifyError(message, input.retryAfterMs);
|
|
80
|
-
return {
|
|
81
|
-
failureKind,
|
|
82
|
-
action: isTransient(providerClass) ? "retry" : "escalate",
|
|
83
|
-
reason: message,
|
|
84
|
-
exitReason: `provider-${providerClass.kind}`,
|
|
85
|
-
remediation: isTransient(providerClass)
|
|
86
|
-
? "Retry after the provider/network condition clears."
|
|
87
|
-
: "Inspect provider credentials, model entitlement, or request shape.",
|
|
88
|
-
providerClass: providerClass.kind,
|
|
89
|
-
};
|
|
90
|
-
}
|
|
91
|
-
case "runtime-unknown":
|
|
92
|
-
return {
|
|
93
|
-
failureKind,
|
|
94
|
-
action: "escalate",
|
|
95
|
-
reason: message,
|
|
96
|
-
exitReason: "runtime-unknown",
|
|
97
|
-
remediation: "Inspect the runtime error and add a dedicated classification if it is repeatable.",
|
|
98
|
-
};
|
|
15
|
+
: input.error instanceof IllegalPhaseTransitionError
|
|
16
|
+
? "illegal-transition"
|
|
17
|
+
: input.failureKind ?? inferFailureKind(message);
|
|
18
|
+
if (failureKind === "provider") {
|
|
19
|
+
const providerClass = classifyError(message, input.retryAfterMs);
|
|
20
|
+
const transient = isTransient(providerClass);
|
|
21
|
+
return {
|
|
22
|
+
failureKind,
|
|
23
|
+
action: transient ? "retry" : "escalate",
|
|
24
|
+
reason: message,
|
|
25
|
+
exitReason: `provider-${providerClass.kind}`,
|
|
26
|
+
remediation: recoveryRemediation(transient ? "provider-transient" : "provider-permanent"),
|
|
27
|
+
providerClass: providerClass.kind,
|
|
28
|
+
};
|
|
99
29
|
}
|
|
30
|
+
const { action, label } = FAILURE_TAXONOMY[failureKind];
|
|
31
|
+
return {
|
|
32
|
+
failureKind,
|
|
33
|
+
action,
|
|
34
|
+
reason: label ? `${label}${unitSuffix(input)}: ${message}` : message,
|
|
35
|
+
exitReason: failureKind,
|
|
36
|
+
remediation: recoveryRemediation(failureKind),
|
|
37
|
+
};
|
|
100
38
|
}
|
|
39
|
+
/** Per-kind action and reason label. Remediation lives in the Guidance module. */
|
|
40
|
+
const FAILURE_TAXONOMY = {
|
|
41
|
+
"tool-schema": { action: "stop", label: "Tool schema failure" },
|
|
42
|
+
"tool-contract": { action: "stop", label: "Tool Contract failure" },
|
|
43
|
+
"tool-unavailable": { action: "retry", label: "Tool unavailable" },
|
|
44
|
+
"deterministic-policy": { action: "stop", label: "Deterministic policy failure" },
|
|
45
|
+
"lifecycle-progression": { action: "stop", label: "Lifecycle progression failure" },
|
|
46
|
+
"stale-worker": { action: "stop", label: "Stale worker failure" },
|
|
47
|
+
"worktree-invalid": { action: "stop", label: "Worktree invalid" },
|
|
48
|
+
"verification-drift": { action: "escalate", label: "Verification drift" },
|
|
49
|
+
"reconciliation-drift": { action: "escalate", label: "Reconciliation drift" },
|
|
50
|
+
"illegal-transition": { action: "escalate", label: "Illegal phase transition" },
|
|
51
|
+
"runtime-unknown": { action: "escalate", label: null },
|
|
52
|
+
};
|
|
101
53
|
function inferFailureKind(message) {
|
|
54
|
+
if (isToolUnavailableError(message))
|
|
55
|
+
return "tool-unavailable";
|
|
102
56
|
if (/tool contract|auto-unit tool scope|phase-boundary gate|not permitted.*own/i.test(message))
|
|
103
57
|
return "tool-contract";
|
|
104
58
|
if (/lifecycle progression|required artifact|missing .*assessment|missing .*closeout|cannot legally (?:advance|progress)/i.test(message))
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* One-shot confirmation token for destructive bash commands.
|
|
3
|
+
*
|
|
4
|
+
* The destructive-command guard hard-blocks classified commands (force push,
|
|
5
|
+
* rm -rf, SQL drop, etc.) in all modes. The block instructs the model to
|
|
6
|
+
* confirm via ask_user_questions and re-issue the command. This module is the
|
|
7
|
+
* missing escape hatch: it records the user's confirmation and lets the exact
|
|
8
|
+
* confirmed command through exactly once.
|
|
9
|
+
*
|
|
10
|
+
* Design constraints:
|
|
11
|
+
* - In-memory only, never persisted. A confirmation token written to disk
|
|
12
|
+
* could silently auto-approve a destructive command in a later session —
|
|
13
|
+
* confirmation must be re-obtained every process lifetime.
|
|
14
|
+
* - One-shot. Consuming a token clears it, so a second destructive command
|
|
15
|
+
* (even an identical one) re-blocks and re-prompts.
|
|
16
|
+
* - Command-bound. The token only matches the exact (normalized) command
|
|
17
|
+
* string the user confirmed. A reworded command re-blocks, which is safe.
|
|
18
|
+
* - Per basePath, so concurrent workspaces in one process never share tokens.
|
|
19
|
+
*
|
|
20
|
+
* Copyright (c) 2026 Jeremy McSpadden <jeremy@fluxlabs.net>
|
|
21
|
+
*/
|
|
22
|
+
import { resolve } from "node:path";
|
|
23
|
+
/**
|
|
24
|
+
* Question-id substring that marks an ask_user_questions call as a
|
|
25
|
+
* destructive-command confirmation. The tool_result handler promotes the
|
|
26
|
+
* pending command to a confirmed token when an affirmative answer arrives for
|
|
27
|
+
* a question whose id contains this marker.
|
|
28
|
+
*/
|
|
29
|
+
export const DESTRUCTIVE_CONFIRM_GATE_MARKER = "destructive_confirm";
|
|
30
|
+
const statesByBasePath = new Map();
|
|
31
|
+
function stateKey(basePath) {
|
|
32
|
+
return resolve(basePath);
|
|
33
|
+
}
|
|
34
|
+
function getState(basePath) {
|
|
35
|
+
const key = stateKey(basePath);
|
|
36
|
+
let state = statesByBasePath.get(key);
|
|
37
|
+
if (!state) {
|
|
38
|
+
state = { pendingCommand: null, confirmedCommand: null };
|
|
39
|
+
statesByBasePath.set(key, state);
|
|
40
|
+
}
|
|
41
|
+
return state;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Normalize a command for stable matching across block → confirm → retry.
|
|
45
|
+
* Trims surrounding whitespace and collapses internal runs of whitespace so
|
|
46
|
+
* cosmetic reformatting of the same command still matches the token.
|
|
47
|
+
*/
|
|
48
|
+
export function normalizeDestructiveCommand(command) {
|
|
49
|
+
return command.replace(/\s+/g, " ").trim();
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Whether an ask_user_questions question id is a destructive-confirm gate.
|
|
53
|
+
*/
|
|
54
|
+
export function isDestructiveConfirmGateId(questionId) {
|
|
55
|
+
return typeof questionId === "string" && questionId.includes(DESTRUCTIVE_CONFIRM_GATE_MARKER);
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Record that a destructive command was blocked and is awaiting confirmation.
|
|
59
|
+
* Called by the guard at block time. Overwrites any prior pending command —
|
|
60
|
+
* only the most recently blocked command can be confirmed.
|
|
61
|
+
*/
|
|
62
|
+
export function requestDestructiveConfirmation(command, basePath = process.cwd()) {
|
|
63
|
+
const state = getState(basePath);
|
|
64
|
+
state.pendingCommand = normalizeDestructiveCommand(command);
|
|
65
|
+
// A fresh request invalidates any stale confirmed token for a different
|
|
66
|
+
// command so confirmation cannot leak across distinct destructive actions.
|
|
67
|
+
state.confirmedCommand = null;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Promote the pending command to a confirmed, one-shot token. Called by the
|
|
71
|
+
* tool_result handler when the user gives an affirmative answer to a
|
|
72
|
+
* destructive-confirm gate. Returns the confirmed command, or null if there
|
|
73
|
+
* was nothing pending (e.g. confirmation arrived without a preceding block).
|
|
74
|
+
*/
|
|
75
|
+
export function confirmDestructiveCommand(basePath = process.cwd()) {
|
|
76
|
+
const state = getState(basePath);
|
|
77
|
+
if (!state.pendingCommand)
|
|
78
|
+
return null;
|
|
79
|
+
state.confirmedCommand = state.pendingCommand;
|
|
80
|
+
state.pendingCommand = null;
|
|
81
|
+
return state.confirmedCommand;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Check whether the given command has been confirmed, consuming the token if
|
|
85
|
+
* so. Returns true exactly once per confirmation; subsequent calls (or a
|
|
86
|
+
* non-matching command) return false. Called by the guard before blocking.
|
|
87
|
+
*/
|
|
88
|
+
export function consumeDestructiveConfirmation(command, basePath = process.cwd()) {
|
|
89
|
+
const state = getState(basePath);
|
|
90
|
+
if (!state.confirmedCommand)
|
|
91
|
+
return false;
|
|
92
|
+
if (state.confirmedCommand !== normalizeDestructiveCommand(command))
|
|
93
|
+
return false;
|
|
94
|
+
state.confirmedCommand = null;
|
|
95
|
+
return true;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Inspect the pending command without consuming it (diagnostics/tests).
|
|
99
|
+
*/
|
|
100
|
+
export function peekPendingDestructiveCommand(basePath = process.cwd()) {
|
|
101
|
+
return getState(basePath).pendingCommand;
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Clear all destructive-confirmation state for a basePath (tests / flow reset).
|
|
105
|
+
*/
|
|
106
|
+
export function resetDestructiveConfirmation(basePath = process.cwd()) {
|
|
107
|
+
statesByBasePath.delete(stateKey(basePath));
|
|
108
|
+
}
|
|
@@ -21,9 +21,10 @@ const EXECUTION_TOOL_NAMES = new Set([
|
|
|
21
21
|
"functions.exec_command",
|
|
22
22
|
"gsd_exec",
|
|
23
23
|
"gsd_exec_search",
|
|
24
|
+
"gsd_uat_exec",
|
|
24
25
|
"powershell",
|
|
25
26
|
]);
|
|
26
|
-
const MCP_EXECUTION_TOOL_RE = /^mcp__.+
|
|
27
|
+
const MCP_EXECUTION_TOOL_RE = /^mcp__.+__gsd_(?:uat_)?exec(?:_search)?$/;
|
|
27
28
|
// ─── Module State ───────────────────────────────────────────────────────────
|
|
28
29
|
let unitEvidence = [];
|
|
29
30
|
// ─── Public API ─────────────────────────────────────────────────────────────
|
|
@@ -146,11 +147,18 @@ export function clearEvidenceFromDisk(basePath, milestoneId, sliceId, taskId) {
|
|
|
146
147
|
* Exit codes and output are filled in by recordToolResult after execution.
|
|
147
148
|
*/
|
|
148
149
|
export function recordToolCall(toolCallId, toolName, input) {
|
|
150
|
+
// Idempotent by toolCallId: native tools reach this via both
|
|
151
|
+
// tool_execution_start and tool_call; external (pre-executed) tools only
|
|
152
|
+
// via tool_execution_start. First recording wins.
|
|
153
|
+
if (unitEvidence.some(e => e.toolCallId === toolCallId))
|
|
154
|
+
return;
|
|
149
155
|
if (isExecutionToolName(toolName)) {
|
|
150
156
|
unitEvidence.push({
|
|
151
157
|
kind: "bash",
|
|
152
158
|
toolCallId,
|
|
153
|
-
|
|
159
|
+
// gsd_exec / gsd_uat_exec carry the script body in `script` (or `code`);
|
|
160
|
+
// bash-style tools use `command`/`cmd`; gsd_exec_search uses `query`.
|
|
161
|
+
command: String(input.command ?? input.script ?? input.cmd ?? input.code ?? input.query ?? ""),
|
|
154
162
|
exitCode: -1,
|
|
155
163
|
outputSnippet: "",
|
|
156
164
|
timestamp: Date.now(),
|
|
@@ -185,9 +193,34 @@ export function recordToolResult(toolCallId, toolName, result, isError) {
|
|
|
185
193
|
if (entry.kind === "bash") {
|
|
186
194
|
const text = extractResultText(result);
|
|
187
195
|
entry.outputSnippet = text.slice(0, 500);
|
|
188
|
-
|
|
189
|
-
|
|
196
|
+
entry.exitCode = resolveExitCode(text, isError);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Resolve the exit code from a tool result's text. Handles the bash tool's
|
|
201
|
+
* prose marker, the gsd_exec / gsd_uat_exec JSON envelope (`"exit_code": N`),
|
|
202
|
+
* and a last-resort read of the run's persisted `.gsd/exec/<id>.meta.json`
|
|
203
|
+
* (covers truncated result text).
|
|
204
|
+
*/
|
|
205
|
+
function resolveExitCode(text, isError) {
|
|
206
|
+
const proseMatch = text.match(/Command exited with code (\d+)/);
|
|
207
|
+
if (proseMatch)
|
|
208
|
+
return Number(proseMatch[1]);
|
|
209
|
+
const jsonMatch = text.match(/"exit_code"\s*:\s*(-?\d+)/);
|
|
210
|
+
if (jsonMatch)
|
|
211
|
+
return Number(jsonMatch[1]);
|
|
212
|
+
const metaMatch = text.match(/"meta_path"\s*:\s*"([^"]+)"/);
|
|
213
|
+
if (metaMatch) {
|
|
214
|
+
try {
|
|
215
|
+
const meta = JSON.parse(readFileSync(metaMatch[1], "utf-8"));
|
|
216
|
+
if (typeof meta.exit_code === "number")
|
|
217
|
+
return meta.exit_code;
|
|
218
|
+
}
|
|
219
|
+
catch {
|
|
220
|
+
// Fall through to the isError heuristic
|
|
221
|
+
}
|
|
190
222
|
}
|
|
223
|
+
return isError ? 1 : 0;
|
|
191
224
|
}
|
|
192
225
|
// ─── Internals ──────────────────────────────────────────────────────────────
|
|
193
226
|
function extractResultText(result) {
|
|
@@ -80,8 +80,13 @@ function findMatches(claimedCommand, bashCalls) {
|
|
|
80
80
|
const exact = bashCalls.filter(b => b.command.trim() === normalized);
|
|
81
81
|
if (exact.length > 0)
|
|
82
82
|
return exact;
|
|
83
|
-
// Substring match: claimed is contained in actual or actual in claimed
|
|
84
|
-
|
|
83
|
+
// Substring match: claimed is contained in actual or actual in claimed.
|
|
84
|
+
// A claimed verification command typically appears verbatim inside a
|
|
85
|
+
// larger gsd_exec script body (cd prefix, multi-line scripts), so
|
|
86
|
+
// script-containing-claim is the common direction. Blank-command entries
|
|
87
|
+
// must be excluded — `"x".includes("")` is true, so they'd match anything.
|
|
88
|
+
const substring = bashCalls.filter(b => b.command.trim().length > 0 &&
|
|
89
|
+
(b.command.includes(normalized) || normalized.includes(b.command)));
|
|
85
90
|
if (substring.length > 0)
|
|
86
91
|
return substring;
|
|
87
92
|
// Token match: split on whitespace and check significant overlap
|
|
@@ -17,6 +17,16 @@ import { logWarning } from "../workflow-logger.js";
|
|
|
17
17
|
const _require = createRequire(import.meta.url);
|
|
18
18
|
const picomatch = _require("picomatch");
|
|
19
19
|
// ─── Public API ─────────────────────────────────────────────────────────────
|
|
20
|
+
/**
|
|
21
|
+
* Build the effective allowlist for a unit's file-change audit.
|
|
22
|
+
*
|
|
23
|
+
* When GSD manages .gitignore (manage_gitignore unset or true), ensureGitignore()
|
|
24
|
+
* appends baseline patterns at auto-start and the edit rides into the task's
|
|
25
|
+
* auto-commit — so .gitignore changes must not be attributed to the task.
|
|
26
|
+
*/
|
|
27
|
+
export function effectiveFileChangeAllowlist(baseAllowlist, manageGitignore) {
|
|
28
|
+
return manageGitignore === false ? baseAllowlist : [...baseAllowlist, ".gitignore"];
|
|
29
|
+
}
|
|
20
30
|
/**
|
|
21
31
|
* Validate file changes after auto-commit for an execute-task unit.
|
|
22
32
|
* Returns null if task data is unavailable or DB is not loaded.
|
|
@@ -99,6 +99,44 @@ export const STATE_TRANSITION_MATRIX = [
|
|
|
99
99
|
export function findTransition(from, event) {
|
|
100
100
|
return STATE_TRANSITION_MATRIX.find((entry) => (entry.from === from || entry.from === "*") && entry.event === event);
|
|
101
101
|
}
|
|
102
|
+
/**
|
|
103
|
+
* Edge-keyed legality check for the Phase Transition Invariant (ADR-030).
|
|
104
|
+
* `advance()` derives the next Phase and asserts the (from → to) edge here.
|
|
105
|
+
*
|
|
106
|
+
* The matrix is an assertion, not a decision-maker — `deriveState` already
|
|
107
|
+
* chose the Phase. A self-edge is trivially legal (no transition to assert). An
|
|
108
|
+
* edge is legal when some matrix entry permits it, honoring the `*` wildcard
|
|
109
|
+
* rows (e.g. any → blocked via manual-block, any → executing via
|
|
110
|
+
* retryable-failure).
|
|
111
|
+
*
|
|
112
|
+
* Note: the matrix is currently a sparse hardening spec, not a complete
|
|
113
|
+
* legal-edge graph, so `advance()` consumes this in advisory mode (telemetry
|
|
114
|
+
* only). It must be expanded to cover every edge `deriveState` emits before
|
|
115
|
+
* enforcement flips on.
|
|
116
|
+
*/
|
|
117
|
+
export function isLegalEdge(from, to) {
|
|
118
|
+
if (from === to)
|
|
119
|
+
return true;
|
|
120
|
+
return STATE_TRANSITION_MATRIX.some((entry) => (entry.from === from || entry.from === "*") && entry.to === to);
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Thrown when an illegal derived Phase edge survives reconciliation. Carries
|
|
124
|
+
* both endpoints so Recovery Classification can report them. Recognized by
|
|
125
|
+
* class in `classifyFailure` and mapped to the `illegal-transition` kind.
|
|
126
|
+
*/
|
|
127
|
+
export class IllegalPhaseTransitionError extends Error {
|
|
128
|
+
// Explicit fields, not constructor parameter properties — strip-types
|
|
129
|
+
// consumers (workspace-index subprocess, integration tests) reject the
|
|
130
|
+
// parameter-property syntax with ERR_UNSUPPORTED_TYPESCRIPT_SYNTAX.
|
|
131
|
+
from;
|
|
132
|
+
to;
|
|
133
|
+
constructor(from, to) {
|
|
134
|
+
super(`Illegal phase transition ${from} -> ${to} survived reconciliation`);
|
|
135
|
+
this.name = "IllegalPhaseTransitionError";
|
|
136
|
+
this.from = from;
|
|
137
|
+
this.to = to;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
102
140
|
export function validateTransitionMatrix(requiredEvents) {
|
|
103
141
|
const seen = new Set();
|
|
104
142
|
const duplicateKeys = [];
|
|
@@ -3,6 +3,11 @@
|
|
|
3
3
|
// GSD Extension — State Derivation
|
|
4
4
|
// DB-authoritative runtime derivation with explicit legacy filesystem fallback.
|
|
5
5
|
// Pure TypeScript, zero Pi dependencies.
|
|
6
|
+
// Pre-migration fallback ONLY (ADR-017): deriveState must work on projects
|
|
7
|
+
// whose DB does not exist yet (before md-importer runs), so it parses markdown
|
|
8
|
+
// projections when `isDbAvailable()` is false or the DB has no rows. Once the
|
|
9
|
+
// DB is populated, decision reads go through gsd-db queries — these parsers
|
|
10
|
+
// must never be consulted when DB data is present.
|
|
6
11
|
import { parseRoadmap, parsePlan, } from './parsers-legacy.js';
|
|
7
12
|
import { parseSummary, loadFile, parseRequirementCounts, parseContextDependsOn, } from './files.js';
|
|
8
13
|
import { resolveMilestoneFile, resolveSlicePath, resolveSliceFile, resolveTaskFile, resolveTasksDir, resolveGsdRootFile, gsdRoot, } from './paths.js';
|
|
@@ -22,26 +27,7 @@ import { isDbAvailable, getAllMilestones, getMilestone, getMilestoneSlices, getS
|
|
|
22
27
|
import { wasWorkflowDatabaseOpenAttempted } from './db-workspace.js';
|
|
23
28
|
import { formatCompletePhaseNextAction, countUnmappedActiveRequirements } from './requirements-backlog.js';
|
|
24
29
|
import { classifyMilestoneReadiness, readinessNeedsDiscussion, } from './milestone-readiness.js';
|
|
25
|
-
|
|
26
|
-
return [
|
|
27
|
-
`Milestone ${milestoneId} is blocked because milestone validation returned needs-attention.`,
|
|
28
|
-
`Fix options:`,
|
|
29
|
-
`1. Review the validation details: \`/gsd status\``,
|
|
30
|
-
`2. If you fixed the missing evidence or issue, re-run milestone validation: \`/gsd validate-milestone\``,
|
|
31
|
-
`3. If the finding is acceptable, override it: \`/gsd verdict pass --rationale "why this is okay"\``,
|
|
32
|
-
`4. If this should wait, defer it explicitly: \`/gsd park ${milestoneId}\``,
|
|
33
|
-
`After validation or override passes, run \`/gsd auto\` to complete and merge the milestone.`,
|
|
34
|
-
].join("\n");
|
|
35
|
-
}
|
|
36
|
-
function formatNeedsRemediationBlocker(milestoneId) {
|
|
37
|
-
return [
|
|
38
|
-
`Milestone ${milestoneId} is blocked because milestone validation returned needs-remediation, but all slices are complete.`,
|
|
39
|
-
`Fix options:`,
|
|
40
|
-
`1. Run \`/gsd dispatch reassess\` to add remediation slices, then run \`/gsd auto\``,
|
|
41
|
-
`2. If the finding is acceptable, override it: \`/gsd verdict pass --rationale "why this is okay"\``,
|
|
42
|
-
`3. If this should wait, defer it explicitly: \`/gsd park ${milestoneId}\``,
|
|
43
|
-
].join("\n");
|
|
44
|
-
}
|
|
30
|
+
import { needsAttentionBlockerGuidance as formatNeedsAttentionBlocker, needsRemediationBlockerGuidance as formatNeedsRemediationBlocker, } from './guidance.js';
|
|
45
31
|
/**
|
|
46
32
|
* A "ghost" milestone directory contains only META.json (and no substantive
|
|
47
33
|
* files like CONTEXT, CONTEXT-DRAFT, ROADMAP, or SUMMARY). These appear when
|
|
@@ -1,16 +1,64 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Status predicates for GSD state-machine
|
|
2
|
+
* Status predicates and the canonical status vocabulary for GSD state-machine
|
|
3
|
+
* guards (ADR-030).
|
|
3
4
|
*
|
|
4
|
-
* The DB
|
|
5
|
-
*
|
|
6
|
-
* "closed" (legacy/imported), and
|
|
7
|
-
*
|
|
8
|
-
*
|
|
9
|
-
*
|
|
5
|
+
* The DB column is free-form `string` so legacy/imported rows still load. Three
|
|
6
|
+
* raw values besides canonical "complete"/"skipped" indicate "closed": "done"
|
|
7
|
+
* (legacy alias), "closed" (legacy/imported), and "skipped" (user-directed skip
|
|
8
|
+
* via rethink or backtrack). `RAW_CLOSED_STATUSES` is the single source for both
|
|
9
|
+
* `isClosedStatus()` and the SQL terminal-status fragment
|
|
10
|
+
* (`db/sql-constants.ts` derives `TERMINAL_STATUS_SQL` from it), replacing the
|
|
11
|
+
* prior independent definitions.
|
|
12
|
+
*
|
|
13
|
+
* `toStatus()` is the single seam where a free-form string becomes the canonical
|
|
14
|
+
* `Status` vocabulary; the Status Transition Core writes canonical, so the store
|
|
15
|
+
* converges over time without a forced migration.
|
|
16
|
+
*/
|
|
17
|
+
/**
|
|
18
|
+
* Canonical, normalized entity-status vocabulary across milestones, slices, and
|
|
19
|
+
* tasks — the single source for both the `Status` type and the runtime
|
|
20
|
+
* membership set. The in-memory domain speaks `Status`; the DB column stays
|
|
21
|
+
* free-form.
|
|
22
|
+
*/
|
|
23
|
+
export const CANONICAL_STATUSES = [
|
|
24
|
+
"pending", "queued", "active", "parked", "in_progress", "blocked", "complete", "skipped", "deferred",
|
|
25
|
+
];
|
|
26
|
+
const CANONICAL_STATUS_SET = new Set(CANONICAL_STATUSES);
|
|
27
|
+
/**
|
|
28
|
+
* Raw status values that mean a unit is closed — the single source of truth.
|
|
29
|
+
* Includes legacy/imported aliases ("done", "closed") alongside canonical
|
|
30
|
+
* "complete"/"skipped" because the DB column is free-form and older rows /
|
|
31
|
+
* imports still carry them. Order matters: `TERMINAL_STATUS_SQL` is derived
|
|
32
|
+
* from this array verbatim.
|
|
33
|
+
*/
|
|
34
|
+
export const RAW_CLOSED_STATUSES = ["complete", "done", "skipped", "closed"];
|
|
35
|
+
const RAW_CLOSED_SET = new Set(RAW_CLOSED_STATUSES);
|
|
36
|
+
/** Free-form aliases mapped to their canonical Status on read. */
|
|
37
|
+
const ALIAS_TO_CANONICAL = {
|
|
38
|
+
done: "complete",
|
|
39
|
+
closed: "complete",
|
|
40
|
+
planned: "pending",
|
|
41
|
+
"in-progress": "in_progress",
|
|
42
|
+
};
|
|
43
|
+
/**
|
|
44
|
+
* Normalize a free-form DB status string into the canonical `Status`
|
|
45
|
+
* vocabulary. Maps known aliases (done/closed → complete, planned → pending,
|
|
46
|
+
* in-progress → in_progress). An unrecognized/legacy value is **quarantined** —
|
|
47
|
+
* preserved verbatim rather than silently remapped to a wrong canonical state —
|
|
48
|
+
* so reads never fail and reconciliation/telemetry can surface it.
|
|
10
49
|
*/
|
|
50
|
+
export function toStatus(raw) {
|
|
51
|
+
const value = raw.trim();
|
|
52
|
+
if (CANONICAL_STATUS_SET.has(value))
|
|
53
|
+
return value;
|
|
54
|
+
const alias = ALIAS_TO_CANONICAL[value];
|
|
55
|
+
if (alias)
|
|
56
|
+
return alias;
|
|
57
|
+
return value;
|
|
58
|
+
}
|
|
11
59
|
/** Returns true when a milestone, slice, or task status indicates closure. */
|
|
12
60
|
export function isClosedStatus(status) {
|
|
13
|
-
return status
|
|
61
|
+
return RAW_CLOSED_SET.has(status);
|
|
14
62
|
}
|
|
15
63
|
/** Returns true when a slice status indicates it was deferred by a decision. */
|
|
16
64
|
export function isDeferredStatus(status) {
|