gsd-pi 2.74.0-dev.2b524c3 → 2.74.0-dev.703eabc
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.js +85 -0
- package/dist/headless-query.js +4 -1
- package/dist/help-text.js +23 -0
- package/dist/resources/extensions/gsd/activity-log.js +16 -0
- package/dist/resources/extensions/gsd/auto/detect-stuck.js +11 -4
- package/dist/resources/extensions/gsd/auto/loop.js +147 -10
- package/dist/resources/extensions/gsd/auto/phases.js +158 -4
- package/dist/resources/extensions/gsd/auto/session.js +10 -0
- package/dist/resources/extensions/gsd/auto-dispatch.js +11 -1
- package/dist/resources/extensions/gsd/auto-model-selection.js +51 -5
- package/dist/resources/extensions/gsd/auto-post-unit.js +220 -17
- package/dist/resources/extensions/gsd/auto-prompts.js +12 -0
- package/dist/resources/extensions/gsd/auto-unit-closeout.js +18 -0
- package/dist/resources/extensions/gsd/auto-verification.js +100 -2
- package/dist/resources/extensions/gsd/auto.js +36 -4
- package/dist/resources/extensions/gsd/bootstrap/register-extension.js +30 -8
- package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +45 -4
- package/dist/resources/extensions/gsd/commands/catalog.js +26 -1
- package/dist/resources/extensions/gsd/commands/handlers/ops.js +25 -0
- package/dist/resources/extensions/gsd/commands/handlers/workflow.js +68 -9
- package/dist/resources/extensions/gsd/commands-add-tests.js +111 -0
- package/dist/resources/extensions/gsd/commands-backlog.js +140 -0
- package/dist/resources/extensions/gsd/commands-do.js +79 -0
- package/dist/resources/extensions/gsd/commands-extract-learnings.js +225 -0
- package/dist/resources/extensions/gsd/commands-maintenance.js +6 -6
- package/dist/resources/extensions/gsd/commands-pr-branch.js +180 -0
- package/dist/resources/extensions/gsd/commands-prefs-wizard.js +1 -1
- package/dist/resources/extensions/gsd/commands-session-report.js +82 -0
- package/dist/resources/extensions/gsd/commands-ship.js +187 -0
- package/dist/resources/extensions/gsd/db-writer.js +3 -5
- package/dist/resources/extensions/gsd/docs/preferences-reference.md +14 -1
- package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +144 -0
- package/dist/resources/extensions/gsd/ecosystem/loader.js +145 -0
- package/dist/resources/extensions/gsd/git-service.js +49 -1
- package/dist/resources/extensions/gsd/graph-context.js +157 -0
- package/dist/resources/extensions/gsd/gsd-db.js +581 -2
- package/dist/resources/extensions/gsd/guided-flow.js +23 -0
- package/dist/resources/extensions/gsd/index.js +15 -2
- package/dist/resources/extensions/gsd/init-wizard.js +1 -0
- package/dist/resources/extensions/gsd/journal.js +27 -0
- package/dist/resources/extensions/gsd/md-importer.js +3 -4
- package/dist/resources/extensions/gsd/memory-store.js +19 -51
- package/dist/resources/extensions/gsd/metrics.js +19 -0
- package/dist/resources/extensions/gsd/milestone-validation-gates.js +13 -12
- package/dist/resources/extensions/gsd/native-git-bridge.js +7 -4
- package/dist/resources/extensions/gsd/parallel-orchestrator.js +33 -1
- package/dist/resources/extensions/gsd/preferences-models.js +20 -3
- package/dist/resources/extensions/gsd/preferences-types.js +1 -0
- package/dist/resources/extensions/gsd/preferences-validation.js +108 -2
- package/dist/resources/extensions/gsd/preferences.js +26 -0
- package/dist/resources/extensions/gsd/prompts/add-tests.md +35 -0
- package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +12 -2
- package/dist/resources/extensions/gsd/state.js +5 -1
- package/dist/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
- package/dist/resources/extensions/gsd/tools/complete-slice.js +20 -0
- package/dist/resources/extensions/gsd/tools/validate-milestone.js +39 -4
- package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +3 -14
- package/dist/resources/extensions/gsd/triage-resolution.js +2 -5
- package/dist/resources/extensions/gsd/unit-ownership.js +1 -1
- package/dist/resources/extensions/gsd/uok/audit-toggle.js +7 -0
- package/dist/resources/extensions/gsd/uok/audit.js +40 -0
- package/dist/resources/extensions/gsd/uok/contracts.js +1 -0
- package/dist/resources/extensions/gsd/uok/execution-graph.js +179 -0
- package/dist/resources/extensions/gsd/uok/flags.js +29 -0
- package/dist/resources/extensions/gsd/uok/gate-runner.js +109 -0
- package/dist/resources/extensions/gsd/uok/gitops.js +53 -0
- package/dist/resources/extensions/gsd/uok/kernel.js +80 -0
- package/dist/resources/extensions/gsd/uok/loop-adapter.js +133 -0
- package/dist/resources/extensions/gsd/uok/model-policy.js +66 -0
- package/dist/resources/extensions/gsd/uok/plan-v2.js +132 -0
- package/dist/resources/extensions/gsd/workflow-logger.js +22 -0
- package/dist/resources/extensions/gsd/workflow-manifest.js +8 -69
- package/dist/resources/extensions/gsd/workflow-migration.js +21 -22
- package/dist/resources/extensions/gsd/workflow-projections.js +4 -1
- package/dist/resources/extensions/gsd/workflow-reconcile.js +14 -11
- package/dist/resources/extensions/ttsr/ttsr-manager.js +3 -1
- package/dist/tsconfig.extensions.tsbuildinfo +1 -0
- package/dist/web/standalone/.next/BUILD_ID +1 -1
- package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
- package/dist/web/standalone/.next/build-manifest.json +2 -2
- package/dist/web/standalone/.next/prerender-manifest.json +3 -3
- 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/onboarding/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
- package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +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 +12 -12
- package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
- package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
- package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
- 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/package.json +3 -2
- package/packages/daemon/package.json +2 -2
- package/packages/mcp-server/dist/index.d.ts +3 -0
- package/packages/mcp-server/dist/index.d.ts.map +1 -1
- package/packages/mcp-server/dist/index.js +3 -0
- package/packages/mcp-server/dist/index.js.map +1 -1
- package/packages/mcp-server/dist/readers/graph.d.ts +87 -0
- package/packages/mcp-server/dist/readers/graph.d.ts.map +1 -0
- package/packages/mcp-server/dist/readers/graph.js +655 -0
- package/packages/mcp-server/dist/readers/graph.js.map +1 -0
- package/packages/mcp-server/dist/readers/index.d.ts +2 -0
- package/packages/mcp-server/dist/readers/index.d.ts.map +1 -1
- package/packages/mcp-server/dist/readers/index.js +1 -0
- package/packages/mcp-server/dist/readers/index.js.map +1 -1
- package/packages/mcp-server/dist/server.d.ts.map +1 -1
- package/packages/mcp-server/dist/server.js +65 -0
- package/packages/mcp-server/dist/server.js.map +1 -1
- package/packages/mcp-server/package.json +2 -2
- package/packages/mcp-server/src/index.ts +15 -0
- package/packages/mcp-server/src/readers/graph.test.ts +604 -0
- package/packages/mcp-server/src/readers/graph.ts +855 -0
- package/packages/mcp-server/src/readers/index.ts +12 -0
- package/packages/mcp-server/src/server.ts +83 -0
- package/packages/mcp-server/tsconfig.json +1 -0
- package/packages/mcp-server/tsconfig.tsbuildinfo +1 -0
- package/packages/native/package.json +2 -2
- package/packages/native/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-agent-core/package.json +1 -1
- package/packages/pi-agent-core/tsconfig.json +1 -0
- package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-ai/dist/index.d.ts +1 -9
- package/packages/pi-ai/dist/index.d.ts.map +1 -1
- package/packages/pi-ai/dist/index.js +1 -9
- package/packages/pi-ai/dist/index.js.map +1 -1
- package/packages/pi-ai/dist/models/capability-patches.d.ts +19 -0
- package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/capability-patches.js +36 -0
- package/packages/pi-ai/dist/models/capability-patches.js.map +1 -0
- package/packages/pi-ai/dist/{models.custom.d.ts → models/custom.d.ts} +1 -1
- package/packages/pi-ai/dist/models/custom.d.ts.map +1 -0
- package/packages/pi-ai/dist/{models.custom.js → models/custom.js} +4 -4
- package/packages/pi-ai/dist/models/custom.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts +1482 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.js +1484 -0
- package/packages/pi-ai/dist/models/generated/amazon-bedrock.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/anthropic.d.ts +377 -0
- package/packages/pi-ai/dist/models/generated/anthropic.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/anthropic.js +379 -0
- package/packages/pi-ai/dist/models/generated/anthropic.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts +700 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.js +702 -0
- package/packages/pi-ai/dist/models/generated/azure-openai-responses.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/cerebras.d.ts +71 -0
- package/packages/pi-ai/dist/models/generated/cerebras.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/cerebras.js +73 -0
- package/packages/pi-ai/dist/models/generated/cerebras.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.d.ts +590 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.js +444 -0
- package/packages/pi-ai/dist/models/generated/github-copilot.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts +156 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.js +158 -0
- package/packages/pi-ai/dist/models/generated/google-antigravity.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts +105 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.js +107 -0
- package/packages/pi-ai/dist/models/generated/google-gemini-cli.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.d.ts +207 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.js +209 -0
- package/packages/pi-ai/dist/models/generated/google-vertex.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/google.d.ts +462 -0
- package/packages/pi-ai/dist/models/generated/google.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/google.js +464 -0
- package/packages/pi-ai/dist/models/generated/google.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/groq.d.ts +309 -0
- package/packages/pi-ai/dist/models/generated/groq.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/groq.js +311 -0
- package/packages/pi-ai/dist/models/generated/groq.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/huggingface.d.ts +383 -0
- package/packages/pi-ai/dist/models/generated/huggingface.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/huggingface.js +347 -0
- package/packages/pi-ai/dist/models/generated/huggingface.js.map +1 -0
- package/packages/pi-ai/dist/{models.generated.d.ts → models/generated/index.d.ts} +1 -1
- package/packages/pi-ai/dist/{models.generated.d.ts.map → models/generated/index.d.ts.map} +1 -1
- package/packages/pi-ai/dist/models/generated/index.js +51 -0
- package/packages/pi-ai/dist/models/generated/index.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts +37 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.js +39 -0
- package/packages/pi-ai/dist/models/generated/kimi-coding.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts +105 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.js +107 -0
- package/packages/pi-ai/dist/models/generated/minimax-cn.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax.d.ts +105 -0
- package/packages/pi-ai/dist/models/generated/minimax.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/minimax.js +107 -0
- package/packages/pi-ai/dist/models/generated/minimax.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/mistral.d.ts +445 -0
- package/packages/pi-ai/dist/models/generated/mistral.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/mistral.js +447 -0
- package/packages/pi-ai/dist/models/generated/mistral.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +139 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.js +141 -0
- package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai.d.ts +700 -0
- package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/openai.js +702 -0
- package/packages/pi-ai/dist/models/generated/openai.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.d.ts +122 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.js +124 -0
- package/packages/pi-ai/dist/models/generated/opencode-go.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode.d.ts +530 -0
- package/packages/pi-ai/dist/models/generated/opencode.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/opencode.js +532 -0
- package/packages/pi-ai/dist/models/generated/opencode.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/openrouter.d.ts +4270 -0
- package/packages/pi-ai/dist/models/generated/openrouter.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/openrouter.js +4272 -0
- package/packages/pi-ai/dist/models/generated/openrouter.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts +2604 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js +2606 -0
- package/packages/pi-ai/dist/models/generated/vercel-ai-gateway.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/xai.d.ts +411 -0
- package/packages/pi-ai/dist/models/generated/xai.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/xai.js +413 -0
- package/packages/pi-ai/dist/models/generated/xai.js.map +1 -0
- package/packages/pi-ai/dist/models/generated/zai.d.ts +276 -0
- package/packages/pi-ai/dist/models/generated/zai.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/generated/zai.js +239 -0
- package/packages/pi-ai/dist/models/generated/zai.js.map +1 -0
- package/packages/pi-ai/dist/models/index.d.ts +27 -0
- package/packages/pi-ai/dist/models/index.d.ts.map +1 -0
- package/packages/pi-ai/dist/models/index.js +80 -0
- package/packages/pi-ai/dist/models/index.js.map +1 -0
- package/packages/pi-ai/dist/models.d.ts +1 -36
- package/packages/pi-ai/dist/models.d.ts.map +1 -1
- package/packages/pi-ai/dist/models.generated.test.js +1 -2
- package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
- package/packages/pi-ai/dist/models.js +3 -112
- package/packages/pi-ai/dist/models.js.map +1 -1
- package/packages/pi-ai/dist/models.test.js +6 -5
- package/packages/pi-ai/dist/models.test.js.map +1 -1
- package/packages/pi-ai/package.json +1 -1
- package/packages/pi-ai/scripts/generate-models.ts +74 -40
- package/packages/pi-ai/src/index.ts +1 -9
- package/packages/pi-ai/src/models/capability-patches.ts +40 -0
- package/packages/pi-ai/src/{models.custom.ts → models/custom.ts} +4 -4
- package/packages/pi-ai/src/models/generated/amazon-bedrock.ts +1486 -0
- package/packages/pi-ai/src/models/generated/anthropic.ts +381 -0
- package/packages/pi-ai/src/models/generated/azure-openai-responses.ts +704 -0
- package/packages/pi-ai/src/models/generated/cerebras.ts +75 -0
- package/packages/pi-ai/src/models/generated/github-copilot.ts +446 -0
- package/packages/pi-ai/src/models/generated/google-antigravity.ts +160 -0
- package/packages/pi-ai/src/models/generated/google-gemini-cli.ts +109 -0
- package/packages/pi-ai/src/models/generated/google-vertex.ts +211 -0
- package/packages/pi-ai/src/models/generated/google.ts +466 -0
- package/packages/pi-ai/src/models/generated/groq.ts +313 -0
- package/packages/pi-ai/src/models/generated/huggingface.ts +349 -0
- package/packages/pi-ai/src/models/generated/index.ts +52 -0
- package/packages/pi-ai/src/models/generated/kimi-coding.ts +41 -0
- package/packages/pi-ai/src/models/generated/minimax-cn.ts +109 -0
- package/packages/pi-ai/src/models/generated/minimax.ts +109 -0
- package/packages/pi-ai/src/models/generated/mistral.ts +449 -0
- package/packages/pi-ai/src/models/generated/openai-codex.ts +143 -0
- package/packages/pi-ai/src/models/generated/openai.ts +704 -0
- package/packages/pi-ai/src/models/generated/opencode-go.ts +126 -0
- package/packages/pi-ai/src/models/generated/opencode.ts +534 -0
- package/packages/pi-ai/src/models/generated/openrouter.ts +4274 -0
- package/packages/pi-ai/src/models/generated/vercel-ai-gateway.ts +2608 -0
- package/packages/pi-ai/src/models/generated/xai.ts +415 -0
- package/packages/pi-ai/src/models/generated/zai.ts +241 -0
- package/packages/pi-ai/src/models/index.ts +106 -0
- package/packages/pi-ai/src/models.generated.test.ts +1 -2
- package/packages/pi-ai/src/models.test.ts +6 -5
- package/packages/pi-ai/src/models.ts +3 -153
- package/packages/pi-ai/tsconfig.json +1 -0
- package/packages/pi-ai/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/agent-session.js +8 -2
- package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js +472 -0
- package/packages/pi-coding-agent/dist/core/chat-controller-ordering.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js +52 -0
- package/packages/pi-coding-agent/dist/core/model-registry-env-fallback.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/core/model-registry.js +2 -2
- package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +11 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +23 -9
- package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +11 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +47 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +51 -8
- package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +22 -22
- package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +232 -18
- package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts +2 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.d.ts.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js +38 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-ordering.test.js.map +1 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +13 -0
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +53 -6
- package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
- package/packages/pi-coding-agent/src/core/agent-session.ts +12 -6
- package/packages/pi-coding-agent/src/core/chat-controller-ordering.test.ts +612 -0
- package/packages/pi-coding-agent/src/core/model-registry-env-fallback.test.ts +59 -0
- package/packages/pi-coding-agent/src/core/model-registry.ts +2 -1
- package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +19 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +25 -10
- package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +67 -0
- package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +66 -7
- package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +23 -26
- package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +298 -41
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-ordering.test.ts +44 -0
- package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +73 -6
- package/packages/pi-coding-agent/src/types/ambient-modules.d.ts +69 -0
- package/packages/pi-coding-agent/tsconfig.json +3 -2
- package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -0
- package/packages/pi-tui/package.json +1 -1
- package/packages/pi-tui/tsconfig.json +1 -0
- package/packages/pi-tui/tsconfig.tsbuildinfo +1 -0
- package/packages/rpc-client/package.json +1 -1
- package/packages/rpc-client/tsconfig.json +1 -0
- package/packages/rpc-client/tsconfig.tsbuildinfo +1 -0
- package/src/resources/extensions/gsd/activity-log.ts +21 -0
- package/src/resources/extensions/gsd/auto/detect-stuck.ts +12 -4
- package/src/resources/extensions/gsd/auto/loop-deps.ts +10 -0
- package/src/resources/extensions/gsd/auto/loop.ts +159 -10
- package/src/resources/extensions/gsd/auto/phases.ts +191 -4
- package/src/resources/extensions/gsd/auto/session.ts +10 -0
- package/src/resources/extensions/gsd/auto-dispatch.ts +16 -6
- package/src/resources/extensions/gsd/auto-model-selection.ts +66 -5
- package/src/resources/extensions/gsd/auto-post-unit.ts +238 -18
- package/src/resources/extensions/gsd/auto-prompts.ts +13 -0
- package/src/resources/extensions/gsd/auto-unit-closeout.ts +25 -1
- package/src/resources/extensions/gsd/auto-verification.ts +129 -2
- package/src/resources/extensions/gsd/auto.ts +41 -2
- package/src/resources/extensions/gsd/bootstrap/register-extension.ts +38 -8
- package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +56 -3
- package/src/resources/extensions/gsd/commands/catalog.ts +26 -1
- package/src/resources/extensions/gsd/commands/handlers/ops.ts +25 -0
- package/src/resources/extensions/gsd/commands/handlers/workflow.ts +74 -9
- package/src/resources/extensions/gsd/commands-add-tests.ts +137 -0
- package/src/resources/extensions/gsd/commands-backlog.ts +182 -0
- package/src/resources/extensions/gsd/commands-do.ts +109 -0
- package/src/resources/extensions/gsd/commands-extract-learnings.ts +304 -0
- package/src/resources/extensions/gsd/commands-maintenance.ts +6 -6
- package/src/resources/extensions/gsd/commands-pr-branch.ts +234 -0
- package/src/resources/extensions/gsd/commands-prefs-wizard.ts +1 -1
- package/src/resources/extensions/gsd/commands-session-report.ts +101 -0
- package/src/resources/extensions/gsd/commands-ship.ts +219 -0
- package/src/resources/extensions/gsd/db-writer.ts +3 -5
- package/src/resources/extensions/gsd/docs/preferences-reference.md +14 -1
- package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +228 -0
- package/src/resources/extensions/gsd/ecosystem/loader.ts +201 -0
- package/src/resources/extensions/gsd/git-service.ts +68 -0
- package/src/resources/extensions/gsd/graph-context.ts +212 -0
- package/src/resources/extensions/gsd/gsd-db.ts +788 -3
- package/src/resources/extensions/gsd/guided-flow.ts +32 -0
- package/src/resources/extensions/gsd/index.ts +18 -2
- package/src/resources/extensions/gsd/init-wizard.ts +3 -2
- package/src/resources/extensions/gsd/journal.ts +30 -0
- package/src/resources/extensions/gsd/md-importer.ts +3 -5
- package/src/resources/extensions/gsd/memory-store.ts +31 -62
- package/src/resources/extensions/gsd/metrics.ts +26 -0
- package/src/resources/extensions/gsd/milestone-validation-gates.ts +13 -14
- package/src/resources/extensions/gsd/native-git-bridge.ts +11 -12
- package/src/resources/extensions/gsd/parallel-orchestrator.ts +40 -1
- package/src/resources/extensions/gsd/preferences-models.ts +20 -3
- package/src/resources/extensions/gsd/preferences-types.ts +32 -0
- package/src/resources/extensions/gsd/preferences-validation.ts +107 -2
- package/src/resources/extensions/gsd/preferences.ts +28 -0
- package/src/resources/extensions/gsd/prompts/add-tests.md +35 -0
- package/src/resources/extensions/gsd/session-lock.ts +14 -2
- package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +20 -1
- package/src/resources/extensions/gsd/state.ts +9 -2
- package/src/resources/extensions/gsd/templates/PREFERENCES.md +18 -0
- package/src/resources/extensions/gsd/tests/auto-loop.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +20 -0
- package/src/resources/extensions/gsd/tests/auto-project-root-env.test.ts +7 -3
- package/src/resources/extensions/gsd/tests/cold-resume-db-reopen.test.ts +6 -2
- package/src/resources/extensions/gsd/tests/commands-backlog.test.ts +158 -0
- package/src/resources/extensions/gsd/tests/commands-do.test.ts +127 -0
- package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +340 -0
- package/src/resources/extensions/gsd/tests/commands-pr-branch.test.ts +68 -0
- package/src/resources/extensions/gsd/tests/commands-session-report.test.ts +82 -0
- package/src/resources/extensions/gsd/tests/commands-ship.test.ts +71 -0
- package/src/resources/extensions/gsd/tests/commands-workflow-custom.test.ts +14 -0
- package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
- package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +154 -0
- package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +10 -7
- package/src/resources/extensions/gsd/tests/graph-context.test.ts +337 -0
- package/src/resources/extensions/gsd/tests/gsd-db.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/health-widget.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/journal-integration.test.ts +68 -1
- package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -2
- package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -3
- package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +140 -0
- package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +79 -1
- package/src/resources/extensions/gsd/tests/post-unit-state-rebuild.test.ts +2 -1
- package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +40 -1
- package/src/resources/extensions/gsd/tests/register-hooks-depth-verification.test.ts +1 -1
- package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +180 -0
- package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -5
- package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +101 -0
- package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +85 -0
- package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +69 -0
- package/src/resources/extensions/gsd/tests/uok-flags.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +70 -0
- package/src/resources/extensions/gsd/tests/uok-gitops-turn-action.test.ts +85 -0
- package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +35 -0
- package/src/resources/extensions/gsd/tests/uok-model-policy.test.ts +89 -0
- package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +167 -0
- package/src/resources/extensions/gsd/tests/uok-preferences.test.ts +42 -0
- package/src/resources/extensions/gsd/tests/validate-milestone-write-order.test.ts +39 -0
- package/src/resources/extensions/gsd/tests/workflow-logger-wiring.test.ts +223 -0
- package/src/resources/extensions/gsd/tools/complete-slice.ts +26 -0
- package/src/resources/extensions/gsd/tools/validate-milestone.ts +48 -3
- package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +3 -11
- package/src/resources/extensions/gsd/triage-resolution.ts +2 -7
- package/src/resources/extensions/gsd/types.ts +14 -1
- package/src/resources/extensions/gsd/unit-ownership.ts +2 -2
- package/src/resources/extensions/gsd/uok/audit-toggle.ts +9 -0
- package/src/resources/extensions/gsd/uok/audit.ts +51 -0
- package/src/resources/extensions/gsd/uok/contracts.ts +135 -0
- package/src/resources/extensions/gsd/uok/execution-graph.ts +241 -0
- package/src/resources/extensions/gsd/uok/flags.ts +45 -0
- package/src/resources/extensions/gsd/uok/gate-runner.ts +146 -0
- package/src/resources/extensions/gsd/uok/gitops.ts +75 -0
- package/src/resources/extensions/gsd/uok/kernel.ts +105 -0
- package/src/resources/extensions/gsd/uok/loop-adapter.ts +162 -0
- package/src/resources/extensions/gsd/uok/model-policy.ts +112 -0
- package/src/resources/extensions/gsd/uok/plan-v2.ts +156 -0
- package/src/resources/extensions/gsd/workflow-logger.ts +27 -1
- package/src/resources/extensions/gsd/workflow-manifest.ts +9 -104
- package/src/resources/extensions/gsd/workflow-migration.ts +21 -29
- package/src/resources/extensions/gsd/workflow-projections.ts +8 -1
- package/src/resources/extensions/gsd/workflow-reconcile.ts +15 -15
- package/src/resources/extensions/ttsr/ttsr-manager.ts +10 -5
- package/packages/pi-ai/dist/models.custom.d.ts.map +0 -1
- package/packages/pi-ai/dist/models.custom.js.map +0 -1
- package/packages/pi-ai/dist/models.generated.js +0 -14343
- package/packages/pi-ai/dist/models.generated.js.map +0 -1
- package/packages/pi-ai/src/models.generated.ts +0 -14345
- /package/dist/web/standalone/.next/static/{YzIEI9sxJy4t5xgClF08g → 3U-oZ5FT59BM7sm2GInic}/_buildManifest.js +0 -0
- /package/dist/web/standalone/.next/static/{YzIEI9sxJy4t5xgClF08g → 3U-oZ5FT59BM7sm2GInic}/_ssgManifest.js +0 -0
|
@@ -4,6 +4,21 @@
|
|
|
4
4
|
//
|
|
5
5
|
// Exposes a unified sync API for decisions and requirements storage.
|
|
6
6
|
// Schema is initialized on first open with WAL mode for file-backed DBs.
|
|
7
|
+
//
|
|
8
|
+
// ─── Single-writer invariant ─────────────────────────────────────────────
|
|
9
|
+
// This file is the ONLY place in the codebase that issues write SQL
|
|
10
|
+
// (INSERT / UPDATE / DELETE / REPLACE / BEGIN-COMMIT transactions) against
|
|
11
|
+
// the engine database at `.gsd/gsd.db`. All other modules must call the
|
|
12
|
+
// typed wrappers exported here. The structural test
|
|
13
|
+
// `tests/single-writer-invariant.test.ts` fails CI if a new bypass appears.
|
|
14
|
+
//
|
|
15
|
+
// `_getAdapter()` is retained for read-only SELECTs in query modules
|
|
16
|
+
// (context-store, memory-store queries, doctor checks, projections).
|
|
17
|
+
// Do NOT use it for writes — add a wrapper here instead.
|
|
18
|
+
//
|
|
19
|
+
// The separate `.gsd/unit-claims.db` managed by `unit-ownership.ts` is an
|
|
20
|
+
// intentionally independent store for cross-worktree claim races and is
|
|
21
|
+
// excluded from this invariant.
|
|
7
22
|
import { createRequire } from "node:module";
|
|
8
23
|
import { existsSync, copyFileSync, mkdirSync, realpathSync } from "node:fs";
|
|
9
24
|
import { dirname } from "node:path";
|
|
@@ -16,7 +31,7 @@ let providerModule = null;
|
|
|
16
31
|
let loadAttempted = false;
|
|
17
32
|
function suppressSqliteWarning() {
|
|
18
33
|
const origEmit = process.emit;
|
|
19
|
-
//
|
|
34
|
+
// Override via loose cast: Node's overloaded emit signature is not directly assignable.
|
|
20
35
|
process.emit = function (event, ...args) {
|
|
21
36
|
if (event === "warning" &&
|
|
22
37
|
args[0] &&
|
|
@@ -120,7 +135,7 @@ function openRawDb(path) {
|
|
|
120
135
|
const Database = providerModule;
|
|
121
136
|
return new Database(path);
|
|
122
137
|
}
|
|
123
|
-
const SCHEMA_VERSION =
|
|
138
|
+
const SCHEMA_VERSION = 15;
|
|
124
139
|
function indexExists(db, name) {
|
|
125
140
|
return !!db.prepare("SELECT 1 as present FROM sqlite_master WHERE type = 'index' AND name = ?").get(name);
|
|
126
141
|
}
|
|
@@ -368,6 +383,66 @@ function initSchema(db, fileBacked) {
|
|
|
368
383
|
FOREIGN KEY (milestone_id, slice_id) REFERENCES slices(milestone_id, id),
|
|
369
384
|
FOREIGN KEY (milestone_id, depends_on_slice_id) REFERENCES slices(milestone_id, id)
|
|
370
385
|
)
|
|
386
|
+
`);
|
|
387
|
+
db.exec(`
|
|
388
|
+
CREATE TABLE IF NOT EXISTS gate_runs (
|
|
389
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
390
|
+
trace_id TEXT NOT NULL,
|
|
391
|
+
turn_id TEXT NOT NULL,
|
|
392
|
+
gate_id TEXT NOT NULL,
|
|
393
|
+
gate_type TEXT NOT NULL DEFAULT '',
|
|
394
|
+
unit_type TEXT DEFAULT NULL,
|
|
395
|
+
unit_id TEXT DEFAULT NULL,
|
|
396
|
+
milestone_id TEXT DEFAULT NULL,
|
|
397
|
+
slice_id TEXT DEFAULT NULL,
|
|
398
|
+
task_id TEXT DEFAULT NULL,
|
|
399
|
+
outcome TEXT NOT NULL DEFAULT 'pass',
|
|
400
|
+
failure_class TEXT NOT NULL DEFAULT 'none',
|
|
401
|
+
rationale TEXT NOT NULL DEFAULT '',
|
|
402
|
+
findings TEXT NOT NULL DEFAULT '',
|
|
403
|
+
attempt INTEGER NOT NULL DEFAULT 1,
|
|
404
|
+
max_attempts INTEGER NOT NULL DEFAULT 1,
|
|
405
|
+
retryable INTEGER NOT NULL DEFAULT 0,
|
|
406
|
+
evaluated_at TEXT NOT NULL DEFAULT ''
|
|
407
|
+
)
|
|
408
|
+
`);
|
|
409
|
+
db.exec(`
|
|
410
|
+
CREATE TABLE IF NOT EXISTS turn_git_transactions (
|
|
411
|
+
trace_id TEXT NOT NULL,
|
|
412
|
+
turn_id TEXT NOT NULL,
|
|
413
|
+
unit_type TEXT DEFAULT NULL,
|
|
414
|
+
unit_id TEXT DEFAULT NULL,
|
|
415
|
+
stage TEXT NOT NULL DEFAULT 'turn-start',
|
|
416
|
+
action TEXT NOT NULL DEFAULT 'status-only',
|
|
417
|
+
push INTEGER NOT NULL DEFAULT 0,
|
|
418
|
+
status TEXT NOT NULL DEFAULT 'ok',
|
|
419
|
+
error TEXT DEFAULT NULL,
|
|
420
|
+
metadata_json TEXT NOT NULL DEFAULT '{}',
|
|
421
|
+
updated_at TEXT NOT NULL DEFAULT '',
|
|
422
|
+
PRIMARY KEY (trace_id, turn_id, stage)
|
|
423
|
+
)
|
|
424
|
+
`);
|
|
425
|
+
db.exec(`
|
|
426
|
+
CREATE TABLE IF NOT EXISTS audit_events (
|
|
427
|
+
event_id TEXT PRIMARY KEY,
|
|
428
|
+
trace_id TEXT NOT NULL,
|
|
429
|
+
turn_id TEXT DEFAULT NULL,
|
|
430
|
+
caused_by TEXT DEFAULT NULL,
|
|
431
|
+
category TEXT NOT NULL,
|
|
432
|
+
type TEXT NOT NULL,
|
|
433
|
+
ts TEXT NOT NULL,
|
|
434
|
+
payload_json TEXT NOT NULL DEFAULT '{}'
|
|
435
|
+
)
|
|
436
|
+
`);
|
|
437
|
+
db.exec(`
|
|
438
|
+
CREATE TABLE IF NOT EXISTS audit_turn_index (
|
|
439
|
+
trace_id TEXT NOT NULL,
|
|
440
|
+
turn_id TEXT NOT NULL,
|
|
441
|
+
first_ts TEXT NOT NULL,
|
|
442
|
+
last_ts TEXT NOT NULL,
|
|
443
|
+
event_count INTEGER NOT NULL DEFAULT 0,
|
|
444
|
+
PRIMARY KEY (trace_id, turn_id)
|
|
445
|
+
)
|
|
371
446
|
`);
|
|
372
447
|
db.exec("CREATE INDEX IF NOT EXISTS idx_memories_active ON memories(superseded_by)");
|
|
373
448
|
db.exec("CREATE INDEX IF NOT EXISTS idx_replan_history_milestone ON replan_history(milestone_id, created_at)");
|
|
@@ -380,6 +455,11 @@ function initSchema(db, fileBacked) {
|
|
|
380
455
|
ensureVerificationEvidenceDedupIndex(db);
|
|
381
456
|
// v14 index — slice dependency lookups
|
|
382
457
|
db.exec("CREATE INDEX IF NOT EXISTS idx_slice_deps_target ON slice_dependencies(milestone_id, depends_on_slice_id)");
|
|
458
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_gate_runs_turn ON gate_runs(trace_id, turn_id)");
|
|
459
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_gate_runs_lookup ON gate_runs(milestone_id, slice_id, task_id, gate_id)");
|
|
460
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_turn_git_tx_turn ON turn_git_transactions(trace_id, turn_id)");
|
|
461
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_audit_events_trace ON audit_events(trace_id, ts)");
|
|
462
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_audit_events_turn ON audit_events(trace_id, turn_id, ts)");
|
|
383
463
|
db.exec(`CREATE VIEW IF NOT EXISTS active_decisions AS SELECT * FROM decisions WHERE superseded_by IS NULL`);
|
|
384
464
|
db.exec(`CREATE VIEW IF NOT EXISTS active_requirements AS SELECT * FROM requirements WHERE superseded_by IS NULL`);
|
|
385
465
|
db.exec(`CREATE VIEW IF NOT EXISTS active_memories AS SELECT * FROM memories WHERE superseded_by IS NULL`);
|
|
@@ -710,6 +790,77 @@ function migrateSchema(db) {
|
|
|
710
790
|
":applied_at": new Date().toISOString(),
|
|
711
791
|
});
|
|
712
792
|
}
|
|
793
|
+
if (currentVersion < 15) {
|
|
794
|
+
db.exec(`
|
|
795
|
+
CREATE TABLE IF NOT EXISTS gate_runs (
|
|
796
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
797
|
+
trace_id TEXT NOT NULL,
|
|
798
|
+
turn_id TEXT NOT NULL,
|
|
799
|
+
gate_id TEXT NOT NULL,
|
|
800
|
+
gate_type TEXT NOT NULL DEFAULT '',
|
|
801
|
+
unit_type TEXT DEFAULT NULL,
|
|
802
|
+
unit_id TEXT DEFAULT NULL,
|
|
803
|
+
milestone_id TEXT DEFAULT NULL,
|
|
804
|
+
slice_id TEXT DEFAULT NULL,
|
|
805
|
+
task_id TEXT DEFAULT NULL,
|
|
806
|
+
outcome TEXT NOT NULL DEFAULT 'pass',
|
|
807
|
+
failure_class TEXT NOT NULL DEFAULT 'none',
|
|
808
|
+
rationale TEXT NOT NULL DEFAULT '',
|
|
809
|
+
findings TEXT NOT NULL DEFAULT '',
|
|
810
|
+
attempt INTEGER NOT NULL DEFAULT 1,
|
|
811
|
+
max_attempts INTEGER NOT NULL DEFAULT 1,
|
|
812
|
+
retryable INTEGER NOT NULL DEFAULT 0,
|
|
813
|
+
evaluated_at TEXT NOT NULL DEFAULT ''
|
|
814
|
+
)
|
|
815
|
+
`);
|
|
816
|
+
db.exec(`
|
|
817
|
+
CREATE TABLE IF NOT EXISTS turn_git_transactions (
|
|
818
|
+
trace_id TEXT NOT NULL,
|
|
819
|
+
turn_id TEXT NOT NULL,
|
|
820
|
+
unit_type TEXT DEFAULT NULL,
|
|
821
|
+
unit_id TEXT DEFAULT NULL,
|
|
822
|
+
stage TEXT NOT NULL DEFAULT 'turn-start',
|
|
823
|
+
action TEXT NOT NULL DEFAULT 'status-only',
|
|
824
|
+
push INTEGER NOT NULL DEFAULT 0,
|
|
825
|
+
status TEXT NOT NULL DEFAULT 'ok',
|
|
826
|
+
error TEXT DEFAULT NULL,
|
|
827
|
+
metadata_json TEXT NOT NULL DEFAULT '{}',
|
|
828
|
+
updated_at TEXT NOT NULL DEFAULT '',
|
|
829
|
+
PRIMARY KEY (trace_id, turn_id, stage)
|
|
830
|
+
)
|
|
831
|
+
`);
|
|
832
|
+
db.exec(`
|
|
833
|
+
CREATE TABLE IF NOT EXISTS audit_events (
|
|
834
|
+
event_id TEXT PRIMARY KEY,
|
|
835
|
+
trace_id TEXT NOT NULL,
|
|
836
|
+
turn_id TEXT DEFAULT NULL,
|
|
837
|
+
caused_by TEXT DEFAULT NULL,
|
|
838
|
+
category TEXT NOT NULL,
|
|
839
|
+
type TEXT NOT NULL,
|
|
840
|
+
ts TEXT NOT NULL,
|
|
841
|
+
payload_json TEXT NOT NULL DEFAULT '{}'
|
|
842
|
+
)
|
|
843
|
+
`);
|
|
844
|
+
db.exec(`
|
|
845
|
+
CREATE TABLE IF NOT EXISTS audit_turn_index (
|
|
846
|
+
trace_id TEXT NOT NULL,
|
|
847
|
+
turn_id TEXT NOT NULL,
|
|
848
|
+
first_ts TEXT NOT NULL,
|
|
849
|
+
last_ts TEXT NOT NULL,
|
|
850
|
+
event_count INTEGER NOT NULL DEFAULT 0,
|
|
851
|
+
PRIMARY KEY (trace_id, turn_id)
|
|
852
|
+
)
|
|
853
|
+
`);
|
|
854
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_gate_runs_turn ON gate_runs(trace_id, turn_id)");
|
|
855
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_gate_runs_lookup ON gate_runs(milestone_id, slice_id, task_id, gate_id)");
|
|
856
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_turn_git_tx_turn ON turn_git_transactions(trace_id, turn_id)");
|
|
857
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_audit_events_trace ON audit_events(trace_id, ts)");
|
|
858
|
+
db.exec("CREATE INDEX IF NOT EXISTS idx_audit_events_turn ON audit_events(trace_id, turn_id, ts)");
|
|
859
|
+
db.prepare("INSERT INTO schema_version (version, applied_at) VALUES (:version, :applied_at)").run({
|
|
860
|
+
":version": 15,
|
|
861
|
+
":applied_at": new Date().toISOString(),
|
|
862
|
+
});
|
|
863
|
+
}
|
|
713
864
|
db.exec("COMMIT");
|
|
714
865
|
}
|
|
715
866
|
catch (err) {
|
|
@@ -863,6 +1014,50 @@ export function transaction(fn) {
|
|
|
863
1014
|
_txDepth--;
|
|
864
1015
|
}
|
|
865
1016
|
}
|
|
1017
|
+
/**
|
|
1018
|
+
* Wrap a block of reads in a DEFERRED transaction so that all SELECTs observe
|
|
1019
|
+
* a consistent snapshot of the DB even if a concurrent writer commits between
|
|
1020
|
+
* them. Use this for multi-query read flows (e.g. tool executors that query
|
|
1021
|
+
* milestone + slices + counts and want one snapshot). Re-entrant — if already
|
|
1022
|
+
* inside a transaction, runs fn() without starting a nested one.
|
|
1023
|
+
*/
|
|
1024
|
+
export function readTransaction(fn) {
|
|
1025
|
+
if (!currentDb)
|
|
1026
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
1027
|
+
if (_txDepth > 0) {
|
|
1028
|
+
_txDepth++;
|
|
1029
|
+
try {
|
|
1030
|
+
return fn();
|
|
1031
|
+
}
|
|
1032
|
+
finally {
|
|
1033
|
+
_txDepth--;
|
|
1034
|
+
}
|
|
1035
|
+
}
|
|
1036
|
+
_txDepth++;
|
|
1037
|
+
currentDb.exec("BEGIN DEFERRED");
|
|
1038
|
+
try {
|
|
1039
|
+
const result = fn();
|
|
1040
|
+
currentDb.exec("COMMIT");
|
|
1041
|
+
return result;
|
|
1042
|
+
}
|
|
1043
|
+
catch (err) {
|
|
1044
|
+
try {
|
|
1045
|
+
currentDb.exec("ROLLBACK");
|
|
1046
|
+
}
|
|
1047
|
+
catch (rollbackErr) {
|
|
1048
|
+
// A failed ROLLBACK after a failed read is a split-brain signal —
|
|
1049
|
+
// the transaction is in an indeterminate state. Surface it via the
|
|
1050
|
+
// logger instead of swallowing it.
|
|
1051
|
+
logError("db", "snapshotState ROLLBACK failed", {
|
|
1052
|
+
error: rollbackErr.message,
|
|
1053
|
+
});
|
|
1054
|
+
}
|
|
1055
|
+
throw err;
|
|
1056
|
+
}
|
|
1057
|
+
finally {
|
|
1058
|
+
_txDepth--;
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
866
1061
|
export function insertDecision(d) {
|
|
867
1062
|
if (!currentDb)
|
|
868
1063
|
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
@@ -1880,6 +2075,7 @@ export function deleteMilestone(milestoneId) {
|
|
|
1880
2075
|
transaction(() => {
|
|
1881
2076
|
currentDb.prepare(`DELETE FROM verification_evidence WHERE milestone_id = :mid`).run({ ":mid": milestoneId });
|
|
1882
2077
|
currentDb.prepare(`DELETE FROM quality_gates WHERE milestone_id = :mid`).run({ ":mid": milestoneId });
|
|
2078
|
+
currentDb.prepare(`DELETE FROM gate_runs WHERE milestone_id = :mid`).run({ ":mid": milestoneId });
|
|
1883
2079
|
currentDb.prepare(`DELETE FROM tasks WHERE milestone_id = :mid`).run({ ":mid": milestoneId });
|
|
1884
2080
|
currentDb.prepare(`DELETE FROM slice_dependencies WHERE milestone_id = :mid`).run({ ":mid": milestoneId });
|
|
1885
2081
|
currentDb.prepare(`DELETE FROM slices WHERE milestone_id = :mid`).run({ ":mid": milestoneId });
|
|
@@ -1965,6 +2161,28 @@ export function saveGateResult(g) {
|
|
|
1965
2161
|
":findings": g.findings,
|
|
1966
2162
|
":evaluated_at": new Date().toISOString(),
|
|
1967
2163
|
});
|
|
2164
|
+
const outcome = g.verdict === "pass"
|
|
2165
|
+
? "pass"
|
|
2166
|
+
: g.verdict === "omitted"
|
|
2167
|
+
? "manual-attention"
|
|
2168
|
+
: "fail";
|
|
2169
|
+
insertGateRun({
|
|
2170
|
+
traceId: `quality-gate:${g.milestoneId}:${g.sliceId}`,
|
|
2171
|
+
turnId: `gate:${g.gateId}:${g.taskId ?? "slice"}`,
|
|
2172
|
+
gateId: g.gateId,
|
|
2173
|
+
gateType: "quality-gate",
|
|
2174
|
+
milestoneId: g.milestoneId,
|
|
2175
|
+
sliceId: g.sliceId,
|
|
2176
|
+
taskId: g.taskId ?? undefined,
|
|
2177
|
+
outcome,
|
|
2178
|
+
failureClass: outcome === "fail" ? "verification" : outcome === "manual-attention" ? "manual-attention" : "none",
|
|
2179
|
+
rationale: g.rationale,
|
|
2180
|
+
findings: g.findings,
|
|
2181
|
+
attempt: 1,
|
|
2182
|
+
maxAttempts: 1,
|
|
2183
|
+
retryable: false,
|
|
2184
|
+
evaluatedAt: new Date().toISOString(),
|
|
2185
|
+
});
|
|
1968
2186
|
}
|
|
1969
2187
|
export function getPendingGates(milestoneId, sliceId, scope) {
|
|
1970
2188
|
if (!currentDb)
|
|
@@ -2045,3 +2263,364 @@ export function getPendingGatesForTurn(milestoneId, sliceId, turn, taskId) {
|
|
|
2045
2263
|
export function getPendingGateCountForTurn(milestoneId, sliceId, turn) {
|
|
2046
2264
|
return getPendingGatesForTurn(milestoneId, sliceId, turn).length;
|
|
2047
2265
|
}
|
|
2266
|
+
export function insertGateRun(entry) {
|
|
2267
|
+
if (!currentDb)
|
|
2268
|
+
return;
|
|
2269
|
+
currentDb.prepare(`INSERT INTO gate_runs (
|
|
2270
|
+
trace_id, turn_id, gate_id, gate_type, unit_type, unit_id, milestone_id, slice_id, task_id,
|
|
2271
|
+
outcome, failure_class, rationale, findings, attempt, max_attempts, retryable, evaluated_at
|
|
2272
|
+
) VALUES (
|
|
2273
|
+
:trace_id, :turn_id, :gate_id, :gate_type, :unit_type, :unit_id, :milestone_id, :slice_id, :task_id,
|
|
2274
|
+
:outcome, :failure_class, :rationale, :findings, :attempt, :max_attempts, :retryable, :evaluated_at
|
|
2275
|
+
)`).run({
|
|
2276
|
+
":trace_id": entry.traceId,
|
|
2277
|
+
":turn_id": entry.turnId,
|
|
2278
|
+
":gate_id": entry.gateId,
|
|
2279
|
+
":gate_type": entry.gateType,
|
|
2280
|
+
":unit_type": entry.unitType ?? null,
|
|
2281
|
+
":unit_id": entry.unitId ?? null,
|
|
2282
|
+
":milestone_id": entry.milestoneId ?? null,
|
|
2283
|
+
":slice_id": entry.sliceId ?? null,
|
|
2284
|
+
":task_id": entry.taskId ?? null,
|
|
2285
|
+
":outcome": entry.outcome,
|
|
2286
|
+
":failure_class": entry.failureClass,
|
|
2287
|
+
":rationale": entry.rationale ?? "",
|
|
2288
|
+
":findings": entry.findings ?? "",
|
|
2289
|
+
":attempt": entry.attempt,
|
|
2290
|
+
":max_attempts": entry.maxAttempts,
|
|
2291
|
+
":retryable": entry.retryable ? 1 : 0,
|
|
2292
|
+
":evaluated_at": entry.evaluatedAt,
|
|
2293
|
+
});
|
|
2294
|
+
}
|
|
2295
|
+
export function upsertTurnGitTransaction(entry) {
|
|
2296
|
+
if (!currentDb)
|
|
2297
|
+
return;
|
|
2298
|
+
currentDb.prepare(`INSERT OR REPLACE INTO turn_git_transactions (
|
|
2299
|
+
trace_id, turn_id, unit_type, unit_id, stage, action, push, status, error, metadata_json, updated_at
|
|
2300
|
+
) VALUES (
|
|
2301
|
+
:trace_id, :turn_id, :unit_type, :unit_id, :stage, :action, :push, :status, :error, :metadata_json, :updated_at
|
|
2302
|
+
)`).run({
|
|
2303
|
+
":trace_id": entry.traceId,
|
|
2304
|
+
":turn_id": entry.turnId,
|
|
2305
|
+
":unit_type": entry.unitType ?? null,
|
|
2306
|
+
":unit_id": entry.unitId ?? null,
|
|
2307
|
+
":stage": entry.stage,
|
|
2308
|
+
":action": entry.action,
|
|
2309
|
+
":push": entry.push ? 1 : 0,
|
|
2310
|
+
":status": entry.status,
|
|
2311
|
+
":error": entry.error ?? null,
|
|
2312
|
+
":metadata_json": JSON.stringify(entry.metadata ?? {}),
|
|
2313
|
+
":updated_at": entry.updatedAt,
|
|
2314
|
+
});
|
|
2315
|
+
}
|
|
2316
|
+
export function insertAuditEvent(entry) {
|
|
2317
|
+
if (!currentDb)
|
|
2318
|
+
return;
|
|
2319
|
+
transaction(() => {
|
|
2320
|
+
currentDb.prepare(`INSERT OR IGNORE INTO audit_events (
|
|
2321
|
+
event_id, trace_id, turn_id, caused_by, category, type, ts, payload_json
|
|
2322
|
+
) VALUES (
|
|
2323
|
+
:event_id, :trace_id, :turn_id, :caused_by, :category, :type, :ts, :payload_json
|
|
2324
|
+
)`).run({
|
|
2325
|
+
":event_id": entry.eventId,
|
|
2326
|
+
":trace_id": entry.traceId,
|
|
2327
|
+
":turn_id": entry.turnId ?? null,
|
|
2328
|
+
":caused_by": entry.causedBy ?? null,
|
|
2329
|
+
":category": entry.category,
|
|
2330
|
+
":type": entry.type,
|
|
2331
|
+
":ts": entry.ts,
|
|
2332
|
+
":payload_json": JSON.stringify(entry.payload ?? {}),
|
|
2333
|
+
});
|
|
2334
|
+
if (entry.turnId) {
|
|
2335
|
+
const row = currentDb.prepare(`SELECT event_count, first_ts, last_ts
|
|
2336
|
+
FROM audit_turn_index
|
|
2337
|
+
WHERE trace_id = :trace_id AND turn_id = :turn_id`).get({
|
|
2338
|
+
":trace_id": entry.traceId,
|
|
2339
|
+
":turn_id": entry.turnId,
|
|
2340
|
+
});
|
|
2341
|
+
if (row) {
|
|
2342
|
+
currentDb.prepare(`UPDATE audit_turn_index
|
|
2343
|
+
SET first_ts = CASE WHEN :ts < first_ts THEN :ts ELSE first_ts END,
|
|
2344
|
+
last_ts = CASE WHEN :ts > last_ts THEN :ts ELSE last_ts END,
|
|
2345
|
+
event_count = event_count + 1
|
|
2346
|
+
WHERE trace_id = :trace_id AND turn_id = :turn_id`).run({
|
|
2347
|
+
":trace_id": entry.traceId,
|
|
2348
|
+
":turn_id": entry.turnId,
|
|
2349
|
+
":ts": entry.ts,
|
|
2350
|
+
});
|
|
2351
|
+
}
|
|
2352
|
+
else {
|
|
2353
|
+
currentDb.prepare(`INSERT INTO audit_turn_index (trace_id, turn_id, first_ts, last_ts, event_count)
|
|
2354
|
+
VALUES (:trace_id, :turn_id, :first_ts, :last_ts, :event_count)`).run({
|
|
2355
|
+
":trace_id": entry.traceId,
|
|
2356
|
+
":turn_id": entry.turnId,
|
|
2357
|
+
":first_ts": entry.ts,
|
|
2358
|
+
":last_ts": entry.ts,
|
|
2359
|
+
":event_count": 1,
|
|
2360
|
+
});
|
|
2361
|
+
}
|
|
2362
|
+
}
|
|
2363
|
+
});
|
|
2364
|
+
}
|
|
2365
|
+
// ─── Single-writer bypass wrappers ───────────────────────────────────────
|
|
2366
|
+
// These wrappers exist so modules outside this file never need to call
|
|
2367
|
+
// `_getAdapter()` for writes. Each one is a byte-equivalent replacement for
|
|
2368
|
+
// a raw prepare/run previously issued from another module. Keep them
|
|
2369
|
+
// minimal and direct — they exist to hold SQL text in one place, not to
|
|
2370
|
+
// add new behavior.
|
|
2371
|
+
/** Delete a decision row by id. Used by db-writer.ts rollback on disk-write failure. */
|
|
2372
|
+
export function deleteDecisionById(id) {
|
|
2373
|
+
if (!currentDb)
|
|
2374
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2375
|
+
currentDb.prepare("DELETE FROM decisions WHERE id = :id").run({ ":id": id });
|
|
2376
|
+
}
|
|
2377
|
+
/** Delete a requirement row by id. Used by db-writer.ts rollback on disk-write failure. */
|
|
2378
|
+
export function deleteRequirementById(id) {
|
|
2379
|
+
if (!currentDb)
|
|
2380
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2381
|
+
currentDb.prepare("DELETE FROM requirements WHERE id = :id").run({ ":id": id });
|
|
2382
|
+
}
|
|
2383
|
+
/** Delete an artifact row by path. Used by db-writer.ts rollback on disk-write failure. */
|
|
2384
|
+
export function deleteArtifactByPath(path) {
|
|
2385
|
+
if (!currentDb)
|
|
2386
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2387
|
+
currentDb.prepare("DELETE FROM artifacts WHERE path = :path").run({ ":path": path });
|
|
2388
|
+
}
|
|
2389
|
+
/**
|
|
2390
|
+
* Drop all rows from tasks/slices/milestones in dependency order inside a
|
|
2391
|
+
* transaction. Used by `gsd recover` to rebuild engine state from markdown.
|
|
2392
|
+
*/
|
|
2393
|
+
export function clearEngineHierarchy() {
|
|
2394
|
+
if (!currentDb)
|
|
2395
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2396
|
+
transaction(() => {
|
|
2397
|
+
currentDb.exec("DELETE FROM tasks");
|
|
2398
|
+
currentDb.exec("DELETE FROM slices");
|
|
2399
|
+
currentDb.exec("DELETE FROM milestones");
|
|
2400
|
+
});
|
|
2401
|
+
}
|
|
2402
|
+
/**
|
|
2403
|
+
* INSERT OR IGNORE a slice during event replay (workflow-reconcile.ts).
|
|
2404
|
+
* Strict insert-or-ignore semantics are required here to avoid the
|
|
2405
|
+
* `insertSlice` ON CONFLICT path that could downgrade an already-completed
|
|
2406
|
+
* slice back to 'pending'.
|
|
2407
|
+
*/
|
|
2408
|
+
export function insertOrIgnoreSlice(args) {
|
|
2409
|
+
if (!currentDb)
|
|
2410
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2411
|
+
currentDb.prepare(`INSERT OR IGNORE INTO slices (milestone_id, id, title, status, created_at)
|
|
2412
|
+
VALUES (:mid, :sid, :title, 'pending', :ts)`).run({
|
|
2413
|
+
":mid": args.milestoneId,
|
|
2414
|
+
":sid": args.sliceId,
|
|
2415
|
+
":title": args.title,
|
|
2416
|
+
":ts": args.createdAt,
|
|
2417
|
+
});
|
|
2418
|
+
}
|
|
2419
|
+
/**
|
|
2420
|
+
* INSERT OR IGNORE a task during event replay (workflow-reconcile.ts).
|
|
2421
|
+
* Same rationale as `insertOrIgnoreSlice`.
|
|
2422
|
+
*/
|
|
2423
|
+
export function insertOrIgnoreTask(args) {
|
|
2424
|
+
if (!currentDb)
|
|
2425
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2426
|
+
currentDb.prepare(`INSERT OR IGNORE INTO tasks (milestone_id, slice_id, id, title, status, created_at)
|
|
2427
|
+
VALUES (:mid, :sid, :tid, :title, 'pending', :ts)`).run({
|
|
2428
|
+
":mid": args.milestoneId,
|
|
2429
|
+
":sid": args.sliceId,
|
|
2430
|
+
":tid": args.taskId,
|
|
2431
|
+
":title": args.title,
|
|
2432
|
+
":ts": args.createdAt,
|
|
2433
|
+
});
|
|
2434
|
+
}
|
|
2435
|
+
/**
|
|
2436
|
+
* Stamp the `replan_triggered_at` column on a slice. Used by triage-resolution
|
|
2437
|
+
* when a user capture requests a replan so the dispatcher can detect the
|
|
2438
|
+
* trigger via DB in addition to the on-disk REPLAN-TRIGGER.md marker.
|
|
2439
|
+
*/
|
|
2440
|
+
export function setSliceReplanTriggeredAt(milestoneId, sliceId, ts) {
|
|
2441
|
+
if (!currentDb)
|
|
2442
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2443
|
+
currentDb.prepare("UPDATE slices SET replan_triggered_at = :ts WHERE milestone_id = :mid AND id = :sid").run({ ":ts": ts, ":mid": milestoneId, ":sid": sliceId });
|
|
2444
|
+
}
|
|
2445
|
+
/**
|
|
2446
|
+
* INSERT OR REPLACE a quality_gates row. Used by milestone-validation-gates.ts
|
|
2447
|
+
* to persist milestone-level (MV*) gate outcomes after validate-milestone runs.
|
|
2448
|
+
*/
|
|
2449
|
+
export function upsertQualityGate(g) {
|
|
2450
|
+
if (!currentDb)
|
|
2451
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2452
|
+
currentDb.prepare(`INSERT OR REPLACE INTO quality_gates
|
|
2453
|
+
(milestone_id, slice_id, gate_id, scope, task_id, status, verdict, rationale, findings, evaluated_at)
|
|
2454
|
+
VALUES (:mid, :sid, :gid, :scope, :tid, :status, :verdict, :rationale, :findings, :evaluated_at)`).run({
|
|
2455
|
+
":mid": g.milestoneId,
|
|
2456
|
+
":sid": g.sliceId,
|
|
2457
|
+
":gid": g.gateId,
|
|
2458
|
+
":scope": g.scope,
|
|
2459
|
+
":tid": g.taskId,
|
|
2460
|
+
":status": g.status,
|
|
2461
|
+
":verdict": g.verdict,
|
|
2462
|
+
":rationale": g.rationale,
|
|
2463
|
+
":findings": g.findings,
|
|
2464
|
+
":evaluated_at": g.evaluatedAt,
|
|
2465
|
+
});
|
|
2466
|
+
}
|
|
2467
|
+
/**
|
|
2468
|
+
* Atomically replace all workflow state from a manifest. Lifted verbatim from
|
|
2469
|
+
* workflow-manifest.ts so the single-writer invariant holds. Only touches
|
|
2470
|
+
* engine tables + decisions. Does NOT modify artifacts or memories.
|
|
2471
|
+
*/
|
|
2472
|
+
export function restoreManifest(manifest) {
|
|
2473
|
+
if (!currentDb)
|
|
2474
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2475
|
+
const db = currentDb;
|
|
2476
|
+
transaction(() => {
|
|
2477
|
+
// Clear engine tables (order matters for foreign-key-like consistency)
|
|
2478
|
+
db.exec("DELETE FROM verification_evidence");
|
|
2479
|
+
db.exec("DELETE FROM tasks");
|
|
2480
|
+
db.exec("DELETE FROM slices");
|
|
2481
|
+
db.exec("DELETE FROM milestones");
|
|
2482
|
+
db.exec("DELETE FROM decisions WHERE 1=1");
|
|
2483
|
+
// Restore milestones
|
|
2484
|
+
const msStmt = db.prepare(`INSERT INTO milestones (id, title, status, depends_on, created_at, completed_at,
|
|
2485
|
+
vision, success_criteria, key_risks, proof_strategy,
|
|
2486
|
+
verification_contract, verification_integration, verification_operational, verification_uat,
|
|
2487
|
+
definition_of_done, requirement_coverage, boundary_map_markdown)
|
|
2488
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2489
|
+
for (const m of manifest.milestones) {
|
|
2490
|
+
msStmt.run(m.id, m.title, m.status, JSON.stringify(m.depends_on), m.created_at, m.completed_at, m.vision, JSON.stringify(m.success_criteria), JSON.stringify(m.key_risks), JSON.stringify(m.proof_strategy), m.verification_contract, m.verification_integration, m.verification_operational, m.verification_uat, JSON.stringify(m.definition_of_done), m.requirement_coverage, m.boundary_map_markdown);
|
|
2491
|
+
}
|
|
2492
|
+
// Restore slices
|
|
2493
|
+
const slStmt = db.prepare(`INSERT INTO slices (milestone_id, id, title, status, risk, depends, demo,
|
|
2494
|
+
created_at, completed_at, full_summary_md, full_uat_md,
|
|
2495
|
+
goal, success_criteria, proof_level, integration_closure, observability_impact,
|
|
2496
|
+
sequence, replan_triggered_at)
|
|
2497
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2498
|
+
for (const s of manifest.slices) {
|
|
2499
|
+
slStmt.run(s.milestone_id, s.id, s.title, s.status, s.risk, JSON.stringify(s.depends), s.demo, s.created_at, s.completed_at, s.full_summary_md, s.full_uat_md, s.goal, s.success_criteria, s.proof_level, s.integration_closure, s.observability_impact, s.sequence, s.replan_triggered_at);
|
|
2500
|
+
}
|
|
2501
|
+
// Restore tasks
|
|
2502
|
+
const tkStmt = db.prepare(`INSERT INTO tasks (milestone_id, slice_id, id, title, status,
|
|
2503
|
+
one_liner, narrative, verification_result, duration, completed_at,
|
|
2504
|
+
blocker_discovered, deviations, known_issues, key_files, key_decisions,
|
|
2505
|
+
full_summary_md, description, estimate, files, verify,
|
|
2506
|
+
inputs, expected_output, observability_impact, sequence)
|
|
2507
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2508
|
+
for (const t of manifest.tasks) {
|
|
2509
|
+
tkStmt.run(t.milestone_id, t.slice_id, t.id, t.title, t.status, t.one_liner, t.narrative, t.verification_result, t.duration, t.completed_at, t.blocker_discovered ? 1 : 0, t.deviations, t.known_issues, JSON.stringify(t.key_files), JSON.stringify(t.key_decisions), t.full_summary_md, t.description, t.estimate, JSON.stringify(t.files), t.verify, JSON.stringify(t.inputs), JSON.stringify(t.expected_output), t.observability_impact, t.sequence);
|
|
2510
|
+
}
|
|
2511
|
+
// Restore decisions
|
|
2512
|
+
const dcStmt = db.prepare(`INSERT INTO decisions (seq, id, when_context, scope, decision, choice, rationale, revisable, made_by, superseded_by)
|
|
2513
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2514
|
+
for (const d of manifest.decisions) {
|
|
2515
|
+
dcStmt.run(d.seq, d.id, d.when_context, d.scope, d.decision, d.choice, d.rationale, d.revisable, d.made_by, d.superseded_by);
|
|
2516
|
+
}
|
|
2517
|
+
// Restore verification evidence
|
|
2518
|
+
const evStmt = db.prepare(`INSERT INTO verification_evidence (task_id, slice_id, milestone_id, command, exit_code, verdict, duration_ms, created_at)
|
|
2519
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
2520
|
+
for (const e of manifest.verification_evidence) {
|
|
2521
|
+
evStmt.run(e.task_id, e.slice_id, e.milestone_id, e.command, e.exit_code, e.verdict, e.duration_ms, e.created_at);
|
|
2522
|
+
}
|
|
2523
|
+
});
|
|
2524
|
+
}
|
|
2525
|
+
/**
|
|
2526
|
+
* Bulk delete + insert a legacy milestone hierarchy for markdown → DB migration.
|
|
2527
|
+
* Used by workflow-migration.ts to populate engine tables from parsed ROADMAP/PLAN
|
|
2528
|
+
* files. All operations run inside a single transaction.
|
|
2529
|
+
*/
|
|
2530
|
+
export function bulkInsertLegacyHierarchy(payload) {
|
|
2531
|
+
if (!currentDb)
|
|
2532
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2533
|
+
const db = currentDb;
|
|
2534
|
+
const { milestones, slices, tasks, clearMilestoneIds, createdAt } = payload;
|
|
2535
|
+
if (clearMilestoneIds.length === 0)
|
|
2536
|
+
return;
|
|
2537
|
+
const placeholders = clearMilestoneIds.map(() => "?").join(",");
|
|
2538
|
+
transaction(() => {
|
|
2539
|
+
db.prepare(`DELETE FROM tasks WHERE milestone_id IN (${placeholders})`).run(...clearMilestoneIds);
|
|
2540
|
+
db.prepare(`DELETE FROM slices WHERE milestone_id IN (${placeholders})`).run(...clearMilestoneIds);
|
|
2541
|
+
db.prepare(`DELETE FROM milestones WHERE id IN (${placeholders})`).run(...clearMilestoneIds);
|
|
2542
|
+
const insertMilestone = db.prepare("INSERT INTO milestones (id, title, status, created_at) VALUES (?, ?, ?, ?)");
|
|
2543
|
+
for (const m of milestones) {
|
|
2544
|
+
insertMilestone.run(m.id, m.title, m.status, createdAt);
|
|
2545
|
+
}
|
|
2546
|
+
const insertSliceStmt = db.prepare("INSERT INTO slices (id, milestone_id, title, status, risk, depends, sequence, created_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?)");
|
|
2547
|
+
for (const s of slices) {
|
|
2548
|
+
insertSliceStmt.run(s.id, s.milestoneId, s.title, s.status, s.risk, "[]", s.sequence, createdAt);
|
|
2549
|
+
}
|
|
2550
|
+
const insertTaskStmt = db.prepare("INSERT INTO tasks (id, slice_id, milestone_id, title, description, status, estimate, files, sequence) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)");
|
|
2551
|
+
for (const t of tasks) {
|
|
2552
|
+
insertTaskStmt.run(t.id, t.sliceId, t.milestoneId, t.title, "", t.status, "", "[]", t.sequence);
|
|
2553
|
+
}
|
|
2554
|
+
});
|
|
2555
|
+
}
|
|
2556
|
+
// ─── Memory store writers ────────────────────────────────────────────────
|
|
2557
|
+
// All memory writes go through gsd-db.ts so the single-writer invariant
|
|
2558
|
+
// holds. These are direct pass-throughs to the SQL previously in
|
|
2559
|
+
// memory-store.ts — same bindings, same behavior.
|
|
2560
|
+
export function insertMemoryRow(args) {
|
|
2561
|
+
if (!currentDb)
|
|
2562
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2563
|
+
currentDb.prepare(`INSERT INTO memories (id, category, content, confidence, source_unit_type, source_unit_id, created_at, updated_at)
|
|
2564
|
+
VALUES (:id, :category, :content, :confidence, :source_unit_type, :source_unit_id, :created_at, :updated_at)`).run({
|
|
2565
|
+
":id": args.id,
|
|
2566
|
+
":category": args.category,
|
|
2567
|
+
":content": args.content,
|
|
2568
|
+
":confidence": args.confidence,
|
|
2569
|
+
":source_unit_type": args.sourceUnitType,
|
|
2570
|
+
":source_unit_id": args.sourceUnitId,
|
|
2571
|
+
":created_at": args.createdAt,
|
|
2572
|
+
":updated_at": args.updatedAt,
|
|
2573
|
+
});
|
|
2574
|
+
}
|
|
2575
|
+
export function rewriteMemoryId(placeholderId, realId) {
|
|
2576
|
+
if (!currentDb)
|
|
2577
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2578
|
+
currentDb.prepare("UPDATE memories SET id = :real_id WHERE id = :placeholder").run({
|
|
2579
|
+
":real_id": realId,
|
|
2580
|
+
":placeholder": placeholderId,
|
|
2581
|
+
});
|
|
2582
|
+
}
|
|
2583
|
+
export function updateMemoryContentRow(id, content, confidence, updatedAt) {
|
|
2584
|
+
if (!currentDb)
|
|
2585
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2586
|
+
if (confidence != null) {
|
|
2587
|
+
currentDb.prepare("UPDATE memories SET content = :content, confidence = :confidence, updated_at = :updated_at WHERE id = :id").run({ ":content": content, ":confidence": confidence, ":updated_at": updatedAt, ":id": id });
|
|
2588
|
+
}
|
|
2589
|
+
else {
|
|
2590
|
+
currentDb.prepare("UPDATE memories SET content = :content, updated_at = :updated_at WHERE id = :id").run({ ":content": content, ":updated_at": updatedAt, ":id": id });
|
|
2591
|
+
}
|
|
2592
|
+
}
|
|
2593
|
+
export function incrementMemoryHitCount(id, updatedAt) {
|
|
2594
|
+
if (!currentDb)
|
|
2595
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2596
|
+
currentDb.prepare("UPDATE memories SET hit_count = hit_count + 1, updated_at = :updated_at WHERE id = :id").run({ ":updated_at": updatedAt, ":id": id });
|
|
2597
|
+
}
|
|
2598
|
+
export function supersedeMemoryRow(oldId, newId, updatedAt) {
|
|
2599
|
+
if (!currentDb)
|
|
2600
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2601
|
+
currentDb.prepare("UPDATE memories SET superseded_by = :new_id, updated_at = :updated_at WHERE id = :old_id").run({ ":new_id": newId, ":updated_at": updatedAt, ":old_id": oldId });
|
|
2602
|
+
}
|
|
2603
|
+
export function markMemoryUnitProcessed(unitKey, activityFile, processedAt) {
|
|
2604
|
+
if (!currentDb)
|
|
2605
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2606
|
+
currentDb.prepare(`INSERT OR IGNORE INTO memory_processed_units (unit_key, activity_file, processed_at)
|
|
2607
|
+
VALUES (:key, :file, :at)`).run({ ":key": unitKey, ":file": activityFile, ":at": processedAt });
|
|
2608
|
+
}
|
|
2609
|
+
export function decayMemoriesBefore(cutoffTs, now) {
|
|
2610
|
+
if (!currentDb)
|
|
2611
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2612
|
+
currentDb.prepare(`UPDATE memories
|
|
2613
|
+
SET confidence = MAX(0.1, confidence - 0.1), updated_at = :now
|
|
2614
|
+
WHERE superseded_by IS NULL AND updated_at < :cutoff AND confidence > 0.1`).run({ ":now": now, ":cutoff": cutoffTs });
|
|
2615
|
+
}
|
|
2616
|
+
export function supersedeLowestRankedMemories(limit, now) {
|
|
2617
|
+
if (!currentDb)
|
|
2618
|
+
throw new GSDError(GSD_STALE_STATE, "gsd-db: No database open");
|
|
2619
|
+
currentDb.prepare(`UPDATE memories SET superseded_by = 'CAP_EXCEEDED', updated_at = :now
|
|
2620
|
+
WHERE id IN (
|
|
2621
|
+
SELECT id FROM memories
|
|
2622
|
+
WHERE superseded_by IS NULL
|
|
2623
|
+
ORDER BY (confidence * (1.0 + hit_count * 0.1)) ASC
|
|
2624
|
+
LIMIT :limit
|
|
2625
|
+
)`).run({ ":now": now, ":limit": limit });
|
|
2626
|
+
}
|