@winspan/claude-forge 8.54.4 → 9.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/DEVELOPMENT.md +723 -46
- package/README.md +166 -21
- package/dist/catalogs/agents.json +67 -0
- package/dist/catalogs/skills.json +306 -0
- package/dist/claudemd/claudemd-generator.d.ts +45 -45
- package/dist/claudemd/claudemd-generator.d.ts.map +1 -1
- package/dist/claudemd/claudemd-generator.js +128 -449
- package/dist/claudemd/claudemd-generator.js.map +1 -1
- package/dist/claudemd/index.d.ts +14 -4
- package/dist/claudemd/index.d.ts.map +1 -1
- package/dist/claudemd/index.js +15 -4
- package/dist/claudemd/index.js.map +1 -1
- package/dist/claudemd/resume-manager.d.ts.map +1 -1
- package/dist/claudemd/resume-manager.js +37 -9
- package/dist/claudemd/resume-manager.js.map +1 -1
- package/dist/claudemd/templates/swarm-protocol.md +35 -186
- package/dist/claudemd/violations-manager.d.ts +40 -0
- package/dist/claudemd/violations-manager.d.ts.map +1 -0
- package/dist/claudemd/violations-manager.js +106 -0
- package/dist/claudemd/violations-manager.js.map +1 -0
- package/dist/cli/commands/admin.d.ts +15 -0
- package/dist/cli/commands/admin.d.ts.map +1 -0
- package/dist/cli/commands/admin.js +177 -0
- package/dist/cli/commands/admin.js.map +1 -0
- package/dist/cli/commands/agent.d.ts +169 -0
- package/dist/cli/commands/agent.d.ts.map +1 -0
- package/dist/cli/commands/agent.js +690 -0
- package/dist/cli/commands/agent.js.map +1 -0
- package/dist/cli/commands/agents.d.ts +18 -0
- package/dist/cli/commands/agents.d.ts.map +1 -0
- package/dist/cli/commands/agents.js +160 -0
- package/dist/cli/commands/agents.js.map +1 -0
- package/dist/cli/commands/bypass.d.ts +18 -0
- package/dist/cli/commands/bypass.d.ts.map +1 -0
- package/dist/cli/commands/bypass.js +87 -0
- package/dist/cli/commands/bypass.js.map +1 -0
- package/dist/cli/commands/claudemd.d.ts +60 -0
- package/dist/cli/commands/claudemd.d.ts.map +1 -1
- package/dist/cli/commands/claudemd.js +174 -37
- package/dist/cli/commands/claudemd.js.map +1 -1
- package/dist/cli/commands/codegraph.d.ts +17 -0
- package/dist/cli/commands/codegraph.d.ts.map +1 -0
- package/dist/cli/commands/codegraph.js +263 -0
- package/dist/cli/commands/codegraph.js.map +1 -0
- package/dist/cli/commands/config.d.ts.map +1 -1
- package/dist/cli/commands/config.js +94 -1
- package/dist/cli/commands/config.js.map +1 -1
- package/dist/cli/commands/daemon.d.ts +39 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -1
- package/dist/cli/commands/daemon.js +167 -20
- package/dist/cli/commands/daemon.js.map +1 -1
- package/dist/cli/commands/decisions.d.ts +129 -0
- package/dist/cli/commands/decisions.d.ts.map +1 -0
- package/dist/cli/commands/decisions.js +706 -0
- package/dist/cli/commands/decisions.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +29 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +124 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/entropy.d.ts +35 -0
- package/dist/cli/commands/entropy.d.ts.map +1 -0
- package/dist/cli/commands/entropy.js +121 -0
- package/dist/cli/commands/entropy.js.map +1 -0
- package/dist/cli/commands/executions.d.ts +1 -0
- package/dist/cli/commands/executions.d.ts.map +1 -1
- package/dist/cli/commands/executions.js +12 -2
- package/dist/cli/commands/executions.js.map +1 -1
- package/dist/cli/commands/fix.d.ts +31 -0
- package/dist/cli/commands/fix.d.ts.map +1 -0
- package/dist/cli/commands/fix.js +108 -0
- package/dist/cli/commands/fix.js.map +1 -0
- package/dist/cli/commands/governance.d.ts +21 -0
- package/dist/cli/commands/governance.d.ts.map +1 -0
- package/dist/cli/commands/governance.js +60 -0
- package/dist/cli/commands/governance.js.map +1 -0
- package/dist/cli/commands/init.d.ts +27 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +158 -146
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/insights-goal-check.d.ts +54 -0
- package/dist/cli/commands/insights-goal-check.d.ts.map +1 -0
- package/dist/cli/commands/insights-goal-check.js +318 -0
- package/dist/cli/commands/insights-goal-check.js.map +1 -0
- package/dist/cli/commands/insights.d.ts +15 -0
- package/dist/cli/commands/insights.d.ts.map +1 -0
- package/dist/cli/commands/insights.js +127 -0
- package/dist/cli/commands/insights.js.map +1 -0
- package/dist/cli/commands/knowledge.d.ts +117 -0
- package/dist/cli/commands/knowledge.d.ts.map +1 -0
- package/dist/cli/commands/knowledge.js +1070 -0
- package/dist/cli/commands/knowledge.js.map +1 -0
- package/dist/cli/commands/loop.d.ts +95 -0
- package/dist/cli/commands/loop.d.ts.map +1 -0
- package/dist/cli/commands/loop.js +408 -0
- package/dist/cli/commands/loop.js.map +1 -0
- package/dist/cli/commands/maintenance.d.ts +33 -0
- package/dist/cli/commands/maintenance.d.ts.map +1 -0
- package/dist/cli/commands/maintenance.js +75 -0
- package/dist/cli/commands/maintenance.js.map +1 -0
- package/dist/cli/commands/mcp.d.ts +22 -11
- package/dist/cli/commands/mcp.d.ts.map +1 -1
- package/dist/cli/commands/mcp.js +93 -5
- package/dist/cli/commands/mcp.js.map +1 -1
- package/dist/cli/commands/menu.d.ts.map +1 -1
- package/dist/cli/commands/menu.js +10 -184
- package/dist/cli/commands/menu.js.map +1 -1
- package/dist/cli/commands/project.d.ts +98 -0
- package/dist/cli/commands/project.d.ts.map +1 -0
- package/dist/cli/commands/project.js +382 -0
- package/dist/cli/commands/project.js.map +1 -0
- package/dist/cli/commands/skills.d.ts +131 -0
- package/dist/cli/commands/skills.d.ts.map +1 -1
- package/dist/cli/commands/skills.js +404 -118
- package/dist/cli/commands/skills.js.map +1 -1
- package/dist/cli/commands/spec.d.ts +40 -0
- package/dist/cli/commands/spec.d.ts.map +1 -0
- package/dist/cli/commands/spec.js +49 -0
- package/dist/cli/commands/spec.js.map +1 -0
- package/dist/cli/commands/stats.d.ts.map +1 -1
- package/dist/cli/commands/stats.js +11 -3
- package/dist/cli/commands/stats.js.map +1 -1
- package/dist/cli/commands/status.d.ts.map +1 -1
- package/dist/cli/commands/status.js +17 -2
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/trace.d.ts.map +1 -1
- package/dist/cli/commands/trace.js +4 -9
- package/dist/cli/commands/trace.js.map +1 -1
- package/dist/cli/commands/violations.d.ts +14 -0
- package/dist/cli/commands/violations.d.ts.map +1 -0
- package/dist/cli/commands/violations.js +43 -0
- package/dist/cli/commands/violations.js.map +1 -0
- package/dist/cli/index.js +34 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/init/hook-manager.d.ts +1 -1
- package/dist/cli/init/hook-manager.d.ts.map +1 -1
- package/dist/cli/init/hook-manager.js +6 -0
- package/dist/cli/init/hook-manager.js.map +1 -1
- package/dist/cli/utils/resolve-session.d.ts +32 -0
- package/dist/cli/utils/resolve-session.d.ts.map +1 -0
- package/dist/cli/utils/resolve-session.js +39 -0
- package/dist/cli/utils/resolve-session.js.map +1 -0
- package/dist/core/config.d.ts +4 -1
- package/dist/core/config.d.ts.map +1 -1
- package/dist/core/config.js +11 -23
- package/dist/core/config.js.map +1 -1
- package/dist/core/constants.d.ts +51 -13
- package/dist/core/constants.d.ts.map +1 -1
- package/dist/core/constants.js +63 -13
- package/dist/core/constants.js.map +1 -1
- package/dist/core/diagnostics/checks.d.ts +151 -0
- package/dist/core/diagnostics/checks.d.ts.map +1 -0
- package/dist/core/diagnostics/checks.js +766 -0
- package/dist/core/diagnostics/checks.js.map +1 -0
- package/dist/core/diagnostics/daemon-status.d.ts +77 -0
- package/dist/core/diagnostics/daemon-status.d.ts.map +1 -0
- package/dist/core/diagnostics/daemon-status.js +113 -0
- package/dist/core/diagnostics/daemon-status.js.map +1 -0
- package/dist/core/diagnostics/entropy-checks.d.ts +83 -0
- package/dist/core/diagnostics/entropy-checks.d.ts.map +1 -0
- package/dist/core/diagnostics/entropy-checks.js +400 -0
- package/dist/core/diagnostics/entropy-checks.js.map +1 -0
- package/dist/core/diagnostics/fix-runner.d.ts +54 -0
- package/dist/core/diagnostics/fix-runner.d.ts.map +1 -0
- package/dist/core/diagnostics/fix-runner.js +90 -0
- package/dist/core/diagnostics/fix-runner.js.map +1 -0
- package/dist/core/diagnostics/heartbeat-reader.d.ts +28 -0
- package/dist/core/diagnostics/heartbeat-reader.d.ts.map +1 -0
- package/dist/core/diagnostics/heartbeat-reader.js +50 -0
- package/dist/core/diagnostics/heartbeat-reader.js.map +1 -0
- package/dist/core/diagnostics/knip-runner.d.ts +49 -0
- package/dist/core/diagnostics/knip-runner.d.ts.map +1 -0
- package/dist/core/diagnostics/knip-runner.js +100 -0
- package/dist/core/diagnostics/knip-runner.js.map +1 -0
- package/dist/core/diagnostics/markers.d.ts +96 -0
- package/dist/core/diagnostics/markers.d.ts.map +1 -0
- package/dist/core/diagnostics/markers.js +153 -0
- package/dist/core/diagnostics/markers.js.map +1 -0
- package/dist/core/event-fields.d.ts +27 -0
- package/dist/core/event-fields.d.ts.map +1 -1
- package/dist/core/event-fields.js +43 -0
- package/dist/core/event-fields.js.map +1 -1
- package/dist/core/governance/global-inject.d.ts +90 -0
- package/dist/core/governance/global-inject.d.ts.map +1 -0
- package/dist/core/governance/global-inject.js +184 -0
- package/dist/core/governance/global-inject.js.map +1 -0
- package/dist/core/insights/agent-anchor-guard.d.ts +77 -0
- package/dist/core/insights/agent-anchor-guard.d.ts.map +1 -0
- package/dist/core/insights/agent-anchor-guard.js +119 -0
- package/dist/core/insights/agent-anchor-guard.js.map +1 -0
- package/dist/core/insights/agent-distill-context.d.ts +55 -0
- package/dist/core/insights/agent-distill-context.d.ts.map +1 -0
- package/dist/core/insights/agent-distill-context.js +146 -0
- package/dist/core/insights/agent-distill-context.js.map +1 -0
- package/dist/core/insights/agent-distill-spawn.d.ts +56 -0
- package/dist/core/insights/agent-distill-spawn.d.ts.map +1 -0
- package/dist/core/insights/agent-distill-spawn.js +179 -0
- package/dist/core/insights/agent-distill-spawn.js.map +1 -0
- package/dist/core/insights/agent-drift.d.ts +66 -0
- package/dist/core/insights/agent-drift.d.ts.map +1 -0
- package/dist/core/insights/agent-drift.js +109 -0
- package/dist/core/insights/agent-drift.js.map +1 -0
- package/dist/core/insights/agent-evolution-sources.d.ts +21 -0
- package/dist/core/insights/agent-evolution-sources.d.ts.map +1 -0
- package/dist/core/insights/agent-evolution-sources.js +36 -0
- package/dist/core/insights/agent-evolution-sources.js.map +1 -0
- package/dist/core/insights/agent-health.d.ts +142 -0
- package/dist/core/insights/agent-health.d.ts.map +1 -0
- package/dist/core/insights/agent-health.js +296 -0
- package/dist/core/insights/agent-health.js.map +1 -0
- package/dist/core/insights/agent-patch-apply.d.ts +45 -0
- package/dist/core/insights/agent-patch-apply.d.ts.map +1 -0
- package/dist/core/insights/agent-patch-apply.js +165 -0
- package/dist/core/insights/agent-patch-apply.js.map +1 -0
- package/dist/core/insights/agent-suggest.d.ts +128 -0
- package/dist/core/insights/agent-suggest.d.ts.map +1 -0
- package/dist/core/insights/agent-suggest.js +284 -0
- package/dist/core/insights/agent-suggest.js.map +1 -0
- package/dist/core/insights/coverage-tiers.d.ts +46 -0
- package/dist/core/insights/coverage-tiers.d.ts.map +1 -0
- package/dist/core/insights/coverage-tiers.js +95 -0
- package/dist/core/insights/coverage-tiers.js.map +1 -0
- package/dist/core/insights/experience-extractor.d.ts +60 -0
- package/dist/core/insights/experience-extractor.d.ts.map +1 -0
- package/dist/core/insights/experience-extractor.js +319 -0
- package/dist/core/insights/experience-extractor.js.map +1 -0
- package/dist/core/insights/violation-reporter.d.ts +149 -0
- package/dist/core/insights/violation-reporter.d.ts.map +1 -0
- package/dist/core/insights/violation-reporter.js +391 -0
- package/dist/core/insights/violation-reporter.js.map +1 -0
- package/dist/core/loop/loop-engine.d.ts +140 -0
- package/dist/core/loop/loop-engine.d.ts.map +1 -0
- package/dist/core/loop/loop-engine.js +266 -0
- package/dist/core/loop/loop-engine.js.map +1 -0
- package/dist/core/queue/index.d.ts +16 -3
- package/dist/core/queue/index.d.ts.map +1 -1
- package/dist/core/queue/index.js +16 -4
- package/dist/core/queue/index.js.map +1 -1
- package/dist/core/storage/base.d.ts +317 -0
- package/dist/core/storage/base.d.ts.map +1 -1
- package/dist/core/storage/base.js +1093 -0
- package/dist/core/storage/base.js.map +1 -1
- package/dist/core/storage/codec/tool-input-codec.d.ts +93 -0
- package/dist/core/storage/codec/tool-input-codec.d.ts.map +1 -0
- package/dist/core/storage/codec/tool-input-codec.js +159 -0
- package/dist/core/storage/codec/tool-input-codec.js.map +1 -0
- package/dist/core/storage/codegraph-types.d.ts +79 -0
- package/dist/core/storage/codegraph-types.d.ts.map +1 -0
- package/dist/core/storage/codegraph-types.js +14 -0
- package/dist/core/storage/codegraph-types.js.map +1 -0
- package/dist/core/storage/codegraph.d.ts +186 -0
- package/dist/core/storage/codegraph.d.ts.map +1 -0
- package/dist/core/storage/codegraph.js +452 -0
- package/dist/core/storage/codegraph.js.map +1 -0
- package/dist/core/storage/decisions.d.ts +387 -0
- package/dist/core/storage/decisions.d.ts.map +1 -0
- package/dist/core/storage/decisions.js +534 -0
- package/dist/core/storage/decisions.js.map +1 -0
- package/dist/core/storage/events.d.ts +239 -8
- package/dist/core/storage/events.d.ts.map +1 -1
- package/dist/core/storage/events.js +705 -39
- package/dist/core/storage/events.js.map +1 -1
- package/dist/core/storage/feedback.d.ts +111 -0
- package/dist/core/storage/feedback.d.ts.map +1 -0
- package/dist/core/storage/feedback.js +186 -0
- package/dist/core/storage/feedback.js.map +1 -0
- package/dist/core/storage/forge-config.d.ts +40 -0
- package/dist/core/storage/forge-config.d.ts.map +1 -0
- package/dist/core/storage/forge-config.js +65 -0
- package/dist/core/storage/forge-config.js.map +1 -0
- package/dist/core/storage/injections.d.ts +68 -0
- package/dist/core/storage/injections.d.ts.map +1 -1
- package/dist/core/storage/injections.js +131 -5
- package/dist/core/storage/injections.js.map +1 -1
- package/dist/core/storage/knowledge.d.ts +332 -0
- package/dist/core/storage/knowledge.d.ts.map +1 -0
- package/dist/core/storage/knowledge.js +589 -0
- package/dist/core/storage/knowledge.js.map +1 -0
- package/dist/core/storage/maintenance.d.ts +36 -9
- package/dist/core/storage/maintenance.d.ts.map +1 -1
- package/dist/core/storage/maintenance.js +56 -24
- package/dist/core/storage/maintenance.js.map +1 -1
- package/dist/core/storage/pipeline-rollup.d.ts +111 -0
- package/dist/core/storage/pipeline-rollup.d.ts.map +1 -0
- package/dist/core/storage/pipeline-rollup.js +432 -0
- package/dist/core/storage/pipeline-rollup.js.map +1 -0
- package/dist/core/storage/routing.d.ts +50 -3
- package/dist/core/storage/routing.d.ts.map +1 -1
- package/dist/core/storage/routing.js +131 -10
- package/dist/core/storage/routing.js.map +1 -1
- package/dist/core/storage/rows.d.ts +31 -8
- package/dist/core/storage/rows.d.ts.map +1 -1
- package/dist/core/storage/schema.sql +367 -23
- package/dist/core/storage/sessions.d.ts +136 -0
- package/dist/core/storage/sessions.d.ts.map +1 -1
- package/dist/core/storage/sessions.js +352 -15
- package/dist/core/storage/sessions.js.map +1 -1
- package/dist/core/storage/skills.d.ts +160 -0
- package/dist/core/storage/skills.d.ts.map +1 -1
- package/dist/core/storage/skills.js +368 -7
- package/dist/core/storage/skills.js.map +1 -1
- package/dist/core/storage/sqlite.d.ts +309 -20
- package/dist/core/storage/sqlite.d.ts.map +1 -1
- package/dist/core/storage/sqlite.js +523 -16
- package/dist/core/storage/sqlite.js.map +1 -1
- package/dist/core/storage/tasks.d.ts +744 -2
- package/dist/core/storage/tasks.d.ts.map +1 -1
- package/dist/core/storage/tasks.js +1691 -17
- package/dist/core/storage/tasks.js.map +1 -1
- package/dist/core/storage/tool-intercepts.d.ts +69 -0
- package/dist/core/storage/tool-intercepts.d.ts.map +1 -0
- package/dist/core/storage/tool-intercepts.js +116 -0
- package/dist/core/storage/tool-intercepts.js.map +1 -0
- package/dist/core/types.d.ts +136 -18
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/types.js +10 -0
- package/dist/core/types.js.map +1 -1
- package/dist/core/utils/backup.d.ts +81 -0
- package/dist/core/utils/backup.d.ts.map +1 -0
- package/dist/core/utils/backup.js +98 -0
- package/dist/core/utils/backup.js.map +1 -0
- package/dist/core/utils/binary-paths.d.ts +124 -0
- package/dist/core/utils/binary-paths.d.ts.map +1 -0
- package/dist/core/utils/binary-paths.js +218 -0
- package/dist/core/utils/binary-paths.js.map +1 -0
- package/dist/core/utils/bypass-token.d.ts +75 -0
- package/dist/core/utils/bypass-token.d.ts.map +1 -0
- package/dist/core/utils/bypass-token.js +133 -0
- package/dist/core/utils/bypass-token.js.map +1 -0
- package/dist/core/utils/cc-builtin-agents.d.ts +3 -0
- package/dist/core/utils/cc-builtin-agents.d.ts.map +1 -0
- package/dist/core/utils/cc-builtin-agents.js +29 -0
- package/dist/core/utils/cc-builtin-agents.js.map +1 -0
- package/dist/core/utils/claude-cli-resolver.d.ts +26 -0
- package/dist/core/utils/claude-cli-resolver.d.ts.map +1 -0
- package/dist/core/utils/claude-cli-resolver.js +115 -0
- package/dist/core/utils/claude-cli-resolver.js.map +1 -0
- package/dist/core/utils/claude-cli-spawn.d.ts +106 -0
- package/dist/core/utils/claude-cli-spawn.d.ts.map +1 -0
- package/dist/core/utils/claude-cli-spawn.js +219 -0
- package/dist/core/utils/claude-cli-spawn.js.map +1 -0
- package/dist/core/utils/forge-resume-block.d.ts.map +1 -1
- package/dist/core/utils/forge-resume-block.js +3 -2
- package/dist/core/utils/forge-resume-block.js.map +1 -1
- package/dist/core/utils/logger.d.ts +15 -3
- package/dist/core/utils/logger.d.ts.map +1 -1
- package/dist/core/utils/logger.js +20 -2
- package/dist/core/utils/logger.js.map +1 -1
- package/dist/core/utils/noise-prompt.d.ts +97 -0
- package/dist/core/utils/noise-prompt.d.ts.map +1 -0
- package/dist/core/utils/noise-prompt.js +127 -0
- package/dist/core/utils/noise-prompt.js.map +1 -0
- package/dist/core/utils/path.d.ts +0 -4
- package/dist/core/utils/path.d.ts.map +1 -1
- package/dist/core/utils/path.js +0 -7
- package/dist/core/utils/path.js.map +1 -1
- package/dist/core/utils/time.d.ts +67 -0
- package/dist/core/utils/time.d.ts.map +1 -1
- package/dist/core/utils/time.js +147 -0
- package/dist/core/utils/time.js.map +1 -1
- package/dist/daemon/agent-sync.d.ts +24 -0
- package/dist/daemon/agent-sync.d.ts.map +1 -0
- package/dist/daemon/agent-sync.js +114 -0
- package/dist/daemon/agent-sync.js.map +1 -0
- package/dist/daemon/config-store.d.ts +55 -0
- package/dist/daemon/config-store.d.ts.map +1 -0
- package/dist/daemon/config-store.js +146 -0
- package/dist/daemon/config-store.js.map +1 -0
- package/dist/daemon/event-parser.d.ts +22 -0
- package/dist/daemon/event-parser.d.ts.map +1 -1
- package/dist/daemon/event-parser.js +54 -3
- package/dist/daemon/event-parser.js.map +1 -1
- package/dist/daemon/handlers/history-exporter.d.ts.map +1 -1
- package/dist/daemon/handlers/history-exporter.js +9 -8
- package/dist/daemon/handlers/history-exporter.js.map +1 -1
- package/dist/daemon/handlers/post-tool-use.d.ts +66 -4
- package/dist/daemon/handlers/post-tool-use.d.ts.map +1 -1
- package/dist/daemon/handlers/post-tool-use.js +221 -8
- package/dist/daemon/handlers/post-tool-use.js.map +1 -1
- package/dist/daemon/handlers/pre-tool-use.d.ts +181 -0
- package/dist/daemon/handlers/pre-tool-use.d.ts.map +1 -0
- package/dist/daemon/handlers/pre-tool-use.js +618 -0
- package/dist/daemon/handlers/pre-tool-use.js.map +1 -0
- package/dist/daemon/handlers/stop.d.ts +55 -7
- package/dist/daemon/handlers/stop.d.ts.map +1 -1
- package/dist/daemon/handlers/stop.js +245 -8
- package/dist/daemon/handlers/stop.js.map +1 -1
- package/dist/daemon/handlers/user-prompt.d.ts +51 -14
- package/dist/daemon/handlers/user-prompt.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt.js +223 -95
- package/dist/daemon/handlers/user-prompt.js.map +1 -1
- package/dist/daemon/handlers/violation-content-backfill.d.ts +76 -0
- package/dist/daemon/handlers/violation-content-backfill.d.ts.map +1 -0
- package/dist/daemon/handlers/violation-content-backfill.js +167 -0
- package/dist/daemon/handlers/violation-content-backfill.js.map +1 -0
- package/dist/daemon/hook-sync.d.ts.map +1 -1
- package/dist/daemon/hook-sync.js +2 -1
- package/dist/daemon/hook-sync.js.map +1 -1
- package/dist/daemon/index.d.ts +19 -0
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +439 -86
- package/dist/daemon/index.js.map +1 -1
- package/dist/daemon/lifecycle.d.ts +48 -1
- package/dist/daemon/lifecycle.d.ts.map +1 -1
- package/dist/daemon/lifecycle.js +98 -2
- package/dist/daemon/lifecycle.js.map +1 -1
- package/dist/daemon/router.d.ts +4 -1
- package/dist/daemon/router.d.ts.map +1 -1
- package/dist/daemon/router.js +4 -2
- package/dist/daemon/router.js.map +1 -1
- package/dist/daemon/rules/defaults.d.ts +20 -0
- package/dist/daemon/rules/defaults.d.ts.map +1 -0
- package/dist/daemon/rules/defaults.js +779 -0
- package/dist/daemon/rules/defaults.js.map +1 -0
- package/dist/daemon/rules/registry.d.ts +47 -0
- package/dist/daemon/rules/registry.d.ts.map +1 -0
- package/dist/daemon/rules/registry.js +84 -0
- package/dist/daemon/rules/registry.js.map +1 -0
- package/dist/daemon/rules/types.d.ts +176 -0
- package/dist/daemon/rules/types.d.ts.map +1 -0
- package/dist/daemon/rules/types.js +15 -0
- package/dist/daemon/rules/types.js.map +1 -0
- package/dist/daemon/rules/whitelist.d.ts +101 -0
- package/dist/daemon/rules/whitelist.d.ts.map +1 -0
- package/dist/daemon/rules/whitelist.js +210 -0
- package/dist/daemon/rules/whitelist.js.map +1 -0
- package/dist/daemon/rules/workflow-defaults.d.ts +52 -0
- package/dist/daemon/rules/workflow-defaults.d.ts.map +1 -0
- package/dist/daemon/rules/workflow-defaults.js +521 -0
- package/dist/daemon/rules/workflow-defaults.js.map +1 -0
- package/dist/daemon/server.d.ts +11 -1
- package/dist/daemon/server.d.ts.map +1 -1
- package/dist/daemon/server.js +7 -1
- package/dist/daemon/server.js.map +1 -1
- package/dist/daemon/services/codegraph-sync.d.ts +94 -0
- package/dist/daemon/services/codegraph-sync.d.ts.map +1 -0
- package/dist/daemon/services/codegraph-sync.js +159 -0
- package/dist/daemon/services/codegraph-sync.js.map +1 -0
- package/dist/daemon/services/context-injector.d.ts +34 -0
- package/dist/daemon/services/context-injector.d.ts.map +1 -0
- package/dist/daemon/services/context-injector.js +61 -0
- package/dist/daemon/services/context-injector.js.map +1 -0
- package/dist/daemon/services/decision-hint.d.ts +240 -0
- package/dist/daemon/services/decision-hint.d.ts.map +1 -0
- package/dist/daemon/services/decision-hint.js +562 -0
- package/dist/daemon/services/decision-hint.js.map +1 -0
- package/dist/daemon/services/event-ttl-sweep.d.ts +86 -0
- package/dist/daemon/services/event-ttl-sweep.d.ts.map +1 -0
- package/dist/daemon/services/event-ttl-sweep.js +124 -0
- package/dist/daemon/services/event-ttl-sweep.js.map +1 -0
- package/dist/daemon/services/feedback-aggregator.d.ts +167 -0
- package/dist/daemon/services/feedback-aggregator.d.ts.map +1 -0
- package/dist/daemon/services/feedback-aggregator.js +415 -0
- package/dist/daemon/services/feedback-aggregator.js.map +1 -0
- package/dist/daemon/services/heartbeat-writer.d.ts +46 -0
- package/dist/daemon/services/heartbeat-writer.d.ts.map +1 -0
- package/dist/daemon/services/heartbeat-writer.js +82 -0
- package/dist/daemon/services/heartbeat-writer.js.map +1 -0
- package/dist/daemon/services/idle-session-sweeper.d.ts +61 -0
- package/dist/daemon/services/idle-session-sweeper.d.ts.map +1 -0
- package/dist/daemon/services/idle-session-sweeper.js +94 -0
- package/dist/daemon/services/idle-session-sweeper.js.map +1 -0
- package/dist/daemon/services/idle-task-budget.d.ts +50 -0
- package/dist/daemon/services/idle-task-budget.d.ts.map +1 -0
- package/dist/daemon/services/idle-task-budget.js +72 -0
- package/dist/daemon/services/idle-task-budget.js.map +1 -0
- package/dist/daemon/services/intercept-revive.d.ts +60 -0
- package/dist/daemon/services/intercept-revive.d.ts.map +1 -0
- package/dist/daemon/services/intercept-revive.js +86 -0
- package/dist/daemon/services/intercept-revive.js.map +1 -0
- package/dist/daemon/services/intercept-rollback-guard.d.ts +105 -0
- package/dist/daemon/services/intercept-rollback-guard.d.ts.map +1 -0
- package/dist/daemon/services/intercept-rollback-guard.js +152 -0
- package/dist/daemon/services/intercept-rollback-guard.js.map +1 -0
- package/dist/daemon/services/intercept-timeout-sweeper.d.ts +58 -0
- package/dist/daemon/services/intercept-timeout-sweeper.d.ts.map +1 -0
- package/dist/daemon/services/intercept-timeout-sweeper.js +83 -0
- package/dist/daemon/services/intercept-timeout-sweeper.js.map +1 -0
- package/dist/daemon/services/kb-injector.d.ts +57 -0
- package/dist/daemon/services/kb-injector.d.ts.map +1 -0
- package/dist/daemon/services/kb-injector.js +148 -0
- package/dist/daemon/services/kb-injector.js.map +1 -0
- package/dist/daemon/services/kb-rebuild-scheduler.d.ts +95 -0
- package/dist/daemon/services/kb-rebuild-scheduler.d.ts.map +1 -0
- package/dist/daemon/services/kb-rebuild-scheduler.js +149 -0
- package/dist/daemon/services/kb-rebuild-scheduler.js.map +1 -0
- package/dist/daemon/services/loop-hint.d.ts +139 -0
- package/dist/daemon/services/loop-hint.d.ts.map +1 -0
- package/dist/daemon/services/loop-hint.js +272 -0
- package/dist/daemon/services/loop-hint.js.map +1 -0
- package/dist/daemon/services/outcome-classification-service.d.ts +49 -0
- package/dist/daemon/services/outcome-classification-service.d.ts.map +1 -0
- package/dist/daemon/services/outcome-classification-service.js +214 -0
- package/dist/daemon/services/outcome-classification-service.js.map +1 -0
- package/dist/daemon/services/outcome-classifier.d.ts +136 -0
- package/dist/daemon/services/outcome-classifier.d.ts.map +1 -0
- package/dist/daemon/services/outcome-classifier.js +178 -0
- package/dist/daemon/services/outcome-classifier.js.map +1 -0
- package/dist/daemon/services/outcome-nudge.d.ts +107 -0
- package/dist/daemon/services/outcome-nudge.d.ts.map +1 -0
- package/dist/daemon/services/outcome-nudge.js +242 -0
- package/dist/daemon/services/outcome-nudge.js.map +1 -0
- package/dist/daemon/services/spec-approval.d.ts +127 -0
- package/dist/daemon/services/spec-approval.d.ts.map +1 -0
- package/dist/daemon/services/spec-approval.js +216 -0
- package/dist/daemon/services/spec-approval.js.map +1 -0
- package/dist/daemon/services/spec-gate.d.ts +54 -0
- package/dist/daemon/services/spec-gate.d.ts.map +1 -0
- package/dist/daemon/services/spec-gate.js +113 -0
- package/dist/daemon/services/spec-gate.js.map +1 -0
- package/dist/daemon/services/task-boundary-classifier.d.ts +78 -0
- package/dist/daemon/services/task-boundary-classifier.d.ts.map +1 -0
- package/dist/daemon/services/task-boundary-classifier.js +202 -0
- package/dist/daemon/services/task-boundary-classifier.js.map +1 -0
- package/dist/daemon/services/task-segmenter.d.ts +230 -1
- package/dist/daemon/services/task-segmenter.d.ts.map +1 -1
- package/dist/daemon/services/task-segmenter.js +527 -17
- package/dist/daemon/services/task-segmenter.js.map +1 -1
- package/dist/daemon/skill-sync.d.ts +7 -2
- package/dist/daemon/skill-sync.d.ts.map +1 -1
- package/dist/daemon/skill-sync.js +114 -9
- package/dist/daemon/skill-sync.js.map +1 -1
- package/dist/daemon/startup/maintenance-schedulers.d.ts +68 -0
- package/dist/daemon/startup/maintenance-schedulers.d.ts.map +1 -0
- package/dist/daemon/startup/maintenance-schedulers.js +294 -0
- package/dist/daemon/startup/maintenance-schedulers.js.map +1 -0
- package/dist/daemon/templates/agents/agent-retro-distiller.md +106 -0
- package/dist/daemon/templates/agents/claudemd-writer.md +102 -0
- package/dist/daemon/templates/agents/coder.md +262 -0
- package/dist/daemon/templates/agents/decision-maker.md +546 -0
- package/dist/daemon/templates/agents/doc-reviewer.md +118 -0
- package/dist/daemon/templates/agents/harness-debug-full.md +196 -0
- package/dist/daemon/templates/agents/knowledge-builder.md +120 -0
- package/dist/daemon/templates/agents/patch-applier.md +145 -0
- package/dist/daemon/templates/agents/planner.md +217 -0
- package/dist/daemon/templates/agents/safety-net-implementer.md +278 -0
- package/dist/daemon/templates/agents/skill-distiller.md +114 -0
- package/dist/daemon/templates/agents/task-boundary-classifier.md +65 -0
- package/dist/daemon/templates/agents/verify-agent.md +259 -0
- package/dist/daemon/utils/inject-block.d.ts +39 -0
- package/dist/daemon/utils/inject-block.d.ts.map +1 -0
- package/dist/daemon/utils/inject-block.js +25 -0
- package/dist/daemon/utils/inject-block.js.map +1 -0
- package/dist/hooks/hook-lib.sh +8 -0
- package/dist/hooks/notification.sh +19 -8
- package/dist/hooks/post-tool-use.sh +41 -23
- package/dist/hooks/pre-tool-use.sh +54 -23
- package/dist/hooks/session-start.sh +68 -0
- package/dist/hooks/stop.sh +31 -11
- package/dist/hooks/user-prompt-submit.sh +37 -21
- package/dist/knowledge/adapters/go-adapter.d.ts +65 -0
- package/dist/knowledge/adapters/go-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/go-adapter.js +294 -0
- package/dist/knowledge/adapters/go-adapter.js.map +1 -0
- package/dist/knowledge/adapters/index.d.ts +41 -0
- package/dist/knowledge/adapters/index.d.ts.map +1 -0
- package/dist/knowledge/adapters/index.js +71 -0
- package/dist/knowledge/adapters/index.js.map +1 -0
- package/dist/knowledge/adapters/java-adapter.d.ts +66 -0
- package/dist/knowledge/adapters/java-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/java-adapter.js +260 -0
- package/dist/knowledge/adapters/java-adapter.js.map +1 -0
- package/dist/knowledge/adapters/js-vue-adapter.d.ts +56 -0
- package/dist/knowledge/adapters/js-vue-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/js-vue-adapter.js +203 -0
- package/dist/knowledge/adapters/js-vue-adapter.js.map +1 -0
- package/dist/knowledge/adapters/kotlin-adapter.d.ts +55 -0
- package/dist/knowledge/adapters/kotlin-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/kotlin-adapter.js +209 -0
- package/dist/knowledge/adapters/kotlin-adapter.js.map +1 -0
- package/dist/knowledge/adapters/monorepo-adapter.d.ts +77 -0
- package/dist/knowledge/adapters/monorepo-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/monorepo-adapter.js +170 -0
- package/dist/knowledge/adapters/monorepo-adapter.js.map +1 -0
- package/dist/knowledge/adapters/python-adapter.d.ts +89 -0
- package/dist/knowledge/adapters/python-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/python-adapter.js +358 -0
- package/dist/knowledge/adapters/python-adapter.js.map +1 -0
- package/dist/knowledge/adapters/rust-adapter.d.ts +73 -0
- package/dist/knowledge/adapters/rust-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/rust-adapter.js +329 -0
- package/dist/knowledge/adapters/rust-adapter.js.map +1 -0
- package/dist/knowledge/adapters/types.d.ts +99 -0
- package/dist/knowledge/adapters/types.d.ts.map +1 -0
- package/dist/knowledge/adapters/types.js +17 -0
- package/dist/knowledge/adapters/types.js.map +1 -0
- package/dist/knowledge/adapters/typescript-adapter.d.ts +57 -0
- package/dist/knowledge/adapters/typescript-adapter.d.ts.map +1 -0
- package/dist/knowledge/adapters/typescript-adapter.js +171 -0
- package/dist/knowledge/adapters/typescript-adapter.js.map +1 -0
- package/dist/knowledge/audit-applier.d.ts +70 -0
- package/dist/knowledge/audit-applier.d.ts.map +1 -0
- package/dist/knowledge/audit-applier.js +251 -0
- package/dist/knowledge/audit-applier.js.map +1 -0
- package/dist/knowledge/builder.d.ts +261 -0
- package/dist/knowledge/builder.d.ts.map +1 -0
- package/dist/knowledge/builder.js +966 -0
- package/dist/knowledge/builder.js.map +1 -0
- package/dist/knowledge/cli-provider.d.ts +151 -0
- package/dist/knowledge/cli-provider.d.ts.map +1 -0
- package/dist/knowledge/cli-provider.js +313 -0
- package/dist/knowledge/cli-provider.js.map +1 -0
- package/dist/knowledge/constants.d.ts +78 -0
- package/dist/knowledge/constants.d.ts.map +1 -0
- package/dist/knowledge/constants.js +98 -0
- package/dist/knowledge/constants.js.map +1 -0
- package/dist/knowledge/cross-module.d.ts +139 -0
- package/dist/knowledge/cross-module.d.ts.map +1 -0
- package/dist/knowledge/cross-module.js +370 -0
- package/dist/knowledge/cross-module.js.map +1 -0
- package/dist/knowledge/git-hooks.d.ts +67 -0
- package/dist/knowledge/git-hooks.d.ts.map +1 -0
- package/dist/knowledge/git-hooks.js +258 -0
- package/dist/knowledge/git-hooks.js.map +1 -0
- package/dist/knowledge/graph/edge-extractor.d.ts +45 -0
- package/dist/knowledge/graph/edge-extractor.d.ts.map +1 -0
- package/dist/knowledge/graph/edge-extractor.js +242 -0
- package/dist/knowledge/graph/edge-extractor.js.map +1 -0
- package/dist/knowledge/graph/impact.d.ts +73 -0
- package/dist/knowledge/graph/impact.d.ts.map +1 -0
- package/dist/knowledge/graph/impact.js +94 -0
- package/dist/knowledge/graph/impact.js.map +1 -0
- package/dist/knowledge/graph/types.d.ts +22 -0
- package/dist/knowledge/graph/types.d.ts.map +1 -0
- package/dist/knowledge/graph/types.js +13 -0
- package/dist/knowledge/graph/types.js.map +1 -0
- package/dist/knowledge/module-hash.d.ts +88 -0
- package/dist/knowledge/module-hash.d.ts.map +1 -0
- package/dist/knowledge/module-hash.js +162 -0
- package/dist/knowledge/module-hash.js.map +1 -0
- package/dist/knowledge/project-detector.d.ts +101 -0
- package/dist/knowledge/project-detector.d.ts.map +1 -0
- package/dist/knowledge/project-detector.js +223 -0
- package/dist/knowledge/project-detector.js.map +1 -0
- package/dist/knowledge/prompt.d.ts +237 -0
- package/dist/knowledge/prompt.d.ts.map +1 -0
- package/dist/knowledge/prompt.js +416 -0
- package/dist/knowledge/prompt.js.map +1 -0
- package/dist/knowledge/query.d.ts +118 -0
- package/dist/knowledge/query.d.ts.map +1 -0
- package/dist/knowledge/query.js +438 -0
- package/dist/knowledge/query.js.map +1 -0
- package/dist/knowledge/repo-map.d.ts +97 -0
- package/dist/knowledge/repo-map.d.ts.map +1 -0
- package/dist/knowledge/repo-map.js +447 -0
- package/dist/knowledge/repo-map.js.map +1 -0
- package/dist/knowledge/tools/index.d.ts +14 -0
- package/dist/knowledge/tools/index.d.ts.map +1 -0
- package/dist/knowledge/tools/index.js +11 -0
- package/dist/knowledge/tools/index.js.map +1 -0
- package/dist/knowledge/tools/knowledge-get-page.d.ts +46 -0
- package/dist/knowledge/tools/knowledge-get-page.d.ts.map +1 -0
- package/dist/knowledge/tools/knowledge-get-page.js +101 -0
- package/dist/knowledge/tools/knowledge-get-page.js.map +1 -0
- package/dist/knowledge/tools/knowledge-query.d.ts +77 -0
- package/dist/knowledge/tools/knowledge-query.d.ts.map +1 -0
- package/dist/knowledge/tools/knowledge-query.js +104 -0
- package/dist/knowledge/tools/knowledge-query.js.map +1 -0
- package/dist/knowledge/tools/repo-map-lookup.d.ts +45 -0
- package/dist/knowledge/tools/repo-map-lookup.d.ts.map +1 -0
- package/dist/knowledge/tools/repo-map-lookup.js +82 -0
- package/dist/knowledge/tools/repo-map-lookup.js.map +1 -0
- package/dist/knowledge/types.d.ts +269 -0
- package/dist/knowledge/types.d.ts.map +1 -0
- package/dist/knowledge/types.js +10 -0
- package/dist/knowledge/types.js.map +1 -0
- package/dist/knowledge/validator.d.ts +90 -0
- package/dist/knowledge/validator.d.ts.map +1 -0
- package/dist/knowledge/validator.js +355 -0
- package/dist/knowledge/validator.js.map +1 -0
- package/dist/mcp/server.d.ts +64 -8
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +448 -12
- package/dist/mcp/server.js.map +1 -1
- package/dist/skills/builtin-skills.d.ts +35 -0
- package/dist/skills/builtin-skills.d.ts.map +1 -0
- package/dist/skills/builtin-skills.js +68 -0
- package/dist/skills/builtin-skills.js.map +1 -0
- package/dist/skills/distill/attribution.d.ts +59 -0
- package/dist/skills/distill/attribution.d.ts.map +1 -0
- package/dist/skills/distill/attribution.js +101 -0
- package/dist/skills/distill/attribution.js.map +1 -0
- package/dist/skills/distill/distiller.d.ts +161 -0
- package/dist/skills/distill/distiller.d.ts.map +1 -0
- package/dist/skills/distill/distiller.js +461 -0
- package/dist/skills/distill/distiller.js.map +1 -0
- package/dist/skills/distill/index.d.ts +223 -0
- package/dist/skills/distill/index.d.ts.map +1 -0
- package/dist/skills/distill/index.js +466 -0
- package/dist/skills/distill/index.js.map +1 -0
- package/dist/skills/distill/project-anchor-guard.d.ts +116 -0
- package/dist/skills/distill/project-anchor-guard.d.ts.map +1 -0
- package/dist/skills/distill/project-anchor-guard.js +334 -0
- package/dist/skills/distill/project-anchor-guard.js.map +1 -0
- package/dist/skills/distill/topic-deduper.d.ts +77 -0
- package/dist/skills/distill/topic-deduper.d.ts.map +1 -0
- package/dist/skills/distill/topic-deduper.js +119 -0
- package/dist/skills/distill/topic-deduper.js.map +1 -0
- package/dist/skills/distill/upstream-fetcher.d.ts +71 -0
- package/dist/skills/distill/upstream-fetcher.d.ts.map +1 -0
- package/dist/skills/distill/upstream-fetcher.js +202 -0
- package/dist/skills/distill/upstream-fetcher.js.map +1 -0
- package/dist/skills/distilled/distilled-api-design.md +495 -0
- package/dist/skills/distilled/distilled-architecture-decision.md +173 -0
- package/dist/skills/distilled/distilled-brainstorming.md +79 -0
- package/dist/skills/distilled/distilled-brand-guidelines.md +86 -0
- package/dist/skills/distilled/distilled-canvas-design.md +128 -0
- package/dist/skills/distilled/distilled-claude-api.md +185 -0
- package/dist/skills/distilled/distilled-creator.md +181 -0
- package/dist/skills/distilled/distilled-db-schema-design.md +245 -0
- package/dist/skills/distilled/distilled-dispatching-parallel-agents.md +136 -0
- package/dist/skills/distilled/distilled-doc-coauthoring.md +144 -0
- package/dist/skills/distilled/distilled-docx.md +231 -0
- package/dist/skills/distilled/distilled-executing-plans.md +148 -0
- package/dist/skills/distilled/distilled-finishing-a-development-branch.md +213 -0
- package/dist/skills/distilled/distilled-frontend-design.md +118 -0
- package/dist/skills/distilled/distilled-harness-engineering.md +242 -0
- package/dist/skills/distilled/distilled-karpathy-guidelines.md +104 -0
- package/dist/skills/distilled/distilled-performance-optimization.md +175 -0
- package/dist/skills/distilled/distilled-receiving-code-review.md +185 -0
- package/dist/skills/distilled/distilled-spec-driven-design.md +193 -0
- package/dist/skills/distilled/distilled-subagent-driven-development.md +124 -0
- package/dist/skills/distilled/distilled-systematic-debugging.md +154 -0
- package/dist/skills/distilled/distilled-test-driven-development.md +432 -0
- package/dist/skills/distilled/distilled-using-superpowers.md +134 -0
- package/dist/skills/distilled/distilled-verification-before-completion.md +213 -0
- package/dist/skills/distilled/distilled-writing-skills.md +175 -0
- package/dist/skills/registry.d.ts +55 -51
- package/dist/skills/registry.d.ts.map +1 -1
- package/dist/skills/registry.js +82 -196
- package/dist/skills/registry.js.map +1 -1
- package/dist/skills/tools/pipeline-suggest.js +14 -14
- package/dist/skills/tools/pipeline-suggest.js.map +1 -1
- package/dist/skills/tools/skill-invoke.d.ts +3 -2
- package/dist/skills/tools/skill-invoke.d.ts.map +1 -1
- package/dist/skills/tools/skill-invoke.js +4 -2
- package/dist/skills/tools/skill-invoke.js.map +1 -1
- package/dist/web/analytics/anti-pattern-detector.d.ts.map +1 -1
- package/dist/web/analytics/anti-pattern-detector.js +6 -1
- package/dist/web/analytics/anti-pattern-detector.js.map +1 -1
- package/dist/web/analytics/drift-detector.d.ts +6 -0
- package/dist/web/analytics/drift-detector.d.ts.map +1 -1
- package/dist/web/analytics/drift-detector.js +15 -8
- package/dist/web/analytics/drift-detector.js.map +1 -1
- package/dist/web/analytics/weekly-report.d.ts +13 -0
- package/dist/web/analytics/weekly-report.d.ts.map +1 -1
- package/dist/web/analytics/weekly-report.js +17 -3
- package/dist/web/analytics/weekly-report.js.map +1 -1
- package/dist/web/routes/_helpers.d.ts +31 -0
- package/dist/web/routes/_helpers.d.ts.map +1 -1
- package/dist/web/routes/_helpers.js +33 -0
- package/dist/web/routes/_helpers.js.map +1 -1
- package/dist/web/routes/agent-content.d.ts +30 -0
- package/dist/web/routes/agent-content.d.ts.map +1 -0
- package/dist/web/routes/agent-content.js +139 -0
- package/dist/web/routes/agent-content.js.map +1 -0
- package/dist/web/routes/agent-distill.d.ts +49 -0
- package/dist/web/routes/agent-distill.d.ts.map +1 -0
- package/dist/web/routes/agent-distill.js +526 -0
- package/dist/web/routes/agent-distill.js.map +1 -0
- package/dist/web/routes/config.d.ts +56 -0
- package/dist/web/routes/config.d.ts.map +1 -0
- package/dist/web/routes/config.js +243 -0
- package/dist/web/routes/config.js.map +1 -0
- package/dist/web/routes/decisions.d.ts +15 -0
- package/dist/web/routes/decisions.d.ts.map +1 -0
- package/dist/web/routes/decisions.js +181 -0
- package/dist/web/routes/decisions.js.map +1 -0
- package/dist/web/routes/diagnostics.d.ts +61 -0
- package/dist/web/routes/diagnostics.d.ts.map +1 -0
- package/dist/web/routes/diagnostics.js +203 -0
- package/dist/web/routes/diagnostics.js.map +1 -0
- package/dist/web/routes/error-handler.d.ts +0 -4
- package/dist/web/routes/error-handler.d.ts.map +1 -1
- package/dist/web/routes/error-handler.js +0 -8
- package/dist/web/routes/error-handler.js.map +1 -1
- package/dist/web/routes/events.d.ts.map +1 -1
- package/dist/web/routes/events.js +26 -1
- package/dist/web/routes/events.js.map +1 -1
- package/dist/web/routes/health.d.ts +33 -0
- package/dist/web/routes/health.d.ts.map +1 -0
- package/dist/web/routes/health.js +37 -0
- package/dist/web/routes/health.js.map +1 -0
- package/dist/web/routes/insights.d.ts +0 -5
- package/dist/web/routes/insights.d.ts.map +1 -1
- package/dist/web/routes/insights.js +0 -0
- package/dist/web/routes/insights.js.map +1 -1
- package/dist/web/routes/knowledge.d.ts +57 -0
- package/dist/web/routes/knowledge.d.ts.map +1 -0
- package/dist/web/routes/knowledge.js +772 -0
- package/dist/web/routes/knowledge.js.map +1 -0
- package/dist/web/routes/patch.d.ts +60 -1
- package/dist/web/routes/patch.d.ts.map +1 -1
- package/dist/web/routes/patch.js +170 -64
- package/dist/web/routes/patch.js.map +1 -1
- package/dist/web/routes/pipeline.d.ts +28 -0
- package/dist/web/routes/pipeline.d.ts.map +1 -0
- package/dist/web/routes/pipeline.js +145 -0
- package/dist/web/routes/pipeline.js.map +1 -0
- package/dist/web/routes/rules.d.ts.map +1 -1
- package/dist/web/routes/rules.js +26 -7
- package/dist/web/routes/rules.js.map +1 -1
- package/dist/web/routes/sessions.d.ts.map +1 -1
- package/dist/web/routes/sessions.js +17 -8
- package/dist/web/routes/sessions.js.map +1 -1
- package/dist/web/routes/skill-content.d.ts +30 -0
- package/dist/web/routes/skill-content.d.ts.map +1 -0
- package/dist/web/routes/skill-content.js +117 -0
- package/dist/web/routes/skill-content.js.map +1 -0
- package/dist/web/routes/skill-stats.d.ts.map +1 -1
- package/dist/web/routes/skill-stats.js +153 -16
- package/dist/web/routes/skill-stats.js.map +1 -1
- package/dist/web/routes/skills-distill.d.ts +29 -0
- package/dist/web/routes/skills-distill.d.ts.map +1 -0
- package/dist/web/routes/skills-distill.js +552 -0
- package/dist/web/routes/skills-distill.js.map +1 -0
- package/dist/web/routes/skills.js +7 -7
- package/dist/web/routes/skills.js.map +1 -1
- package/dist/web/routes/stats.d.ts.map +1 -1
- package/dist/web/routes/stats.js +2 -1
- package/dist/web/routes/stats.js.map +1 -1
- package/dist/web/routes/task-timeline.d.ts +178 -0
- package/dist/web/routes/task-timeline.d.ts.map +1 -0
- package/dist/web/routes/task-timeline.js +530 -0
- package/dist/web/routes/task-timeline.js.map +1 -0
- package/dist/web/routes/tasks.d.ts.map +1 -1
- package/dist/web/routes/tasks.js +377 -8
- package/dist/web/routes/tasks.js.map +1 -1
- package/dist/web/routes/trace.d.ts.map +1 -1
- package/dist/web/routes/trace.js +3 -2
- package/dist/web/routes/trace.js.map +1 -1
- package/dist/web/routes/types.d.ts +0 -4
- package/dist/web/routes/types.d.ts.map +1 -1
- package/dist/web/routes/types.js +1 -1
- package/dist/web/routes/types.js.map +1 -1
- package/dist/web/routes/violations.d.ts +14 -0
- package/dist/web/routes/violations.d.ts.map +1 -0
- package/dist/web/routes/violations.js +112 -0
- package/dist/web/routes/violations.js.map +1 -0
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web/server.js +99 -19
- package/dist/web/server.js.map +1 -1
- package/dist/web/services/agent-distill-manager.d.ts +122 -0
- package/dist/web/services/agent-distill-manager.d.ts.map +1 -0
- package/dist/web/services/agent-distill-manager.js +397 -0
- package/dist/web/services/agent-distill-manager.js.map +1 -0
- package/dist/web/services/build-manager.d.ts +72 -0
- package/dist/web/services/build-manager.d.ts.map +1 -0
- package/dist/web/services/build-manager.js +189 -0
- package/dist/web/services/build-manager.js.map +1 -0
- package/dist/web/services/distill-manager.d.ts +172 -0
- package/dist/web/services/distill-manager.d.ts.map +1 -0
- package/dist/web/services/distill-manager.js +411 -0
- package/dist/web/services/distill-manager.js.map +1 -0
- package/dist/web/static/assets/AgentDetailPage-DlUeA1sX.js +2 -0
- package/dist/web/static/assets/AgentDetailPage-DlUeA1sX.js.map +1 -0
- package/dist/web/static/assets/AgentDistillRunPage-Cybo4bii.js +3 -0
- package/dist/web/static/assets/AgentDistillRunPage-Cybo4bii.js.map +1 -0
- package/dist/web/static/assets/AgentsPage-Qd9FExLG.js +2 -0
- package/dist/web/static/assets/AgentsPage-Qd9FExLG.js.map +1 -0
- package/dist/web/static/assets/DaemonHealthPage-DTSVqtrI.js +2 -0
- package/dist/web/static/assets/DaemonHealthPage-DTSVqtrI.js.map +1 -0
- package/dist/web/static/assets/DecisionDetailPage-b4BA8dhc.js +2 -0
- package/dist/web/static/assets/DecisionDetailPage-b4BA8dhc.js.map +1 -0
- package/dist/web/static/assets/DecisionsPage-a3NRo_T7.js +2 -0
- package/dist/web/static/assets/DecisionsPage-a3NRo_T7.js.map +1 -0
- package/dist/web/static/assets/DiagnosticsPage-DIVdiIQG.js +2 -0
- package/dist/web/static/assets/DiagnosticsPage-DIVdiIQG.js.map +1 -0
- package/dist/web/static/assets/DistillDetailPage-U6a3l2iP.js +4 -0
- package/dist/web/static/assets/DistillDetailPage-U6a3l2iP.js.map +1 -0
- package/dist/web/static/assets/DistillPage-O7BHtRN8.js +2 -0
- package/dist/web/static/assets/DistillPage-O7BHtRN8.js.map +1 -0
- package/dist/web/static/assets/DistillRunPage-D1JuRWWr.js +2 -0
- package/dist/web/static/assets/DistillRunPage-D1JuRWWr.js.map +1 -0
- package/dist/web/static/assets/GlobalScopeHint-Q3wTJx3F.js +2 -0
- package/dist/web/static/assets/GlobalScopeHint-Q3wTJx3F.js.map +1 -0
- package/dist/web/static/assets/IssueDetailPage-BDfrtk2C.js +2 -0
- package/dist/web/static/assets/IssueDetailPage-BDfrtk2C.js.map +1 -0
- package/dist/web/static/assets/IssuesPage-SKmhlCrw.js +2 -0
- package/dist/web/static/assets/IssuesPage-SKmhlCrw.js.map +1 -0
- package/dist/web/static/assets/KbDetailPage-Yna86Na8.js +2 -0
- package/dist/web/static/assets/KbDetailPage-Yna86Na8.js.map +1 -0
- package/dist/web/static/assets/KbHitsPage-Cljl7H9p.js +2 -0
- package/dist/web/static/assets/KbHitsPage-Cljl7H9p.js.map +1 -0
- package/dist/web/static/assets/MarkdownRenderer-DlDQNihj.js +3 -0
- package/dist/web/static/assets/MarkdownRenderer-DlDQNihj.js.map +1 -0
- package/dist/web/static/assets/NotFound-LMzbP51V.js +2 -0
- package/dist/web/static/assets/NotFound-LMzbP51V.js.map +1 -0
- package/dist/web/static/assets/SettingsPage-DzoK4PKg.js +2 -0
- package/dist/web/static/assets/SettingsPage-DzoK4PKg.js.map +1 -0
- package/dist/web/static/assets/SkillDetailPage-BuBJJ_NX.js +2 -0
- package/dist/web/static/assets/SkillDetailPage-BuBJJ_NX.js.map +1 -0
- package/dist/web/static/assets/SkillsPage-aojkJpBc.js +2 -0
- package/dist/web/static/assets/SkillsPage-aojkJpBc.js.map +1 -0
- package/dist/web/static/assets/TaskDetailPage-1ckxnGhw.js +4 -0
- package/dist/web/static/assets/TaskDetailPage-1ckxnGhw.js.map +1 -0
- package/dist/web/static/assets/TasksHubPage-C2PLh3eg.js +6 -0
- package/dist/web/static/assets/TasksHubPage-C2PLh3eg.js.map +1 -0
- package/dist/web/static/assets/WorkplacePage-DHrp5VxS.js +2 -0
- package/dist/web/static/assets/WorkplacePage-DHrp5VxS.js.map +1 -0
- package/dist/web/static/assets/arco-DFQA6dO_.css +1 -0
- package/dist/web/static/assets/arco-DV6xCLhr.js +14 -0
- package/dist/web/static/assets/arco-DV6xCLhr.js.map +1 -0
- package/dist/web/static/assets/charts-BSV4cyC4.js +37 -0
- package/dist/web/static/assets/charts-BSV4cyC4.js.map +1 -0
- package/dist/web/static/assets/date-fns-sbWH3_uq.js +2 -0
- package/dist/web/static/assets/date-fns-sbWH3_uq.js.map +1 -0
- package/dist/web/static/assets/index-B_v_MKlb.css +1 -0
- package/dist/web/static/assets/index-DileOOE4.js +4 -0
- package/dist/web/static/assets/index-DileOOE4.js.map +1 -0
- package/dist/web/static/assets/lucide-CnlPQoG8.js +72 -0
- package/dist/web/static/assets/lucide-CnlPQoG8.js.map +1 -0
- package/dist/web/static/assets/markdown-CA7ePUts.js +30 -0
- package/dist/web/static/assets/markdown-CA7ePUts.js.map +1 -0
- package/dist/web/static/assets/outcome-BKGy9azt.js +2 -0
- package/dist/web/static/assets/outcome-BKGy9azt.js.map +1 -0
- package/dist/web/static/assets/query-CgCOpYWf.js +2 -0
- package/dist/web/static/assets/{query-C99w429o.js.map → query-CgCOpYWf.js.map} +1 -1
- package/dist/web/static/assets/{react-router-r79dBVy4.js → react-router-Cxmg8RuL.js} +3 -3
- package/dist/web/static/assets/{react-router-r79dBVy4.js.map → react-router-Cxmg8RuL.js.map} +1 -1
- package/dist/web/static/assets/react-vendor-tkvCrao7.js +57 -0
- package/dist/web/static/assets/react-vendor-tkvCrao7.js.map +1 -0
- package/dist/web/static/assets/syntax-highlighter-BDYycNja.js +6 -0
- package/dist/web/static/assets/syntax-highlighter-BDYycNja.js.map +1 -0
- package/dist/web/static/assets/useAgentStats-B-uTgqBd.js +2 -0
- package/dist/web/static/assets/useAgentStats-B-uTgqBd.js.map +1 -0
- package/dist/web/static/assets/useDecisions-D-G2Ft5T.js +2 -0
- package/dist/web/static/assets/useDecisions-D-G2Ft5T.js.map +1 -0
- package/dist/web/static/assets/useDistill-21dZkXlT.js +3 -0
- package/dist/web/static/assets/useDistill-21dZkXlT.js.map +1 -0
- package/dist/web/static/assets/useEffectiveProject-DQiyX54y.js +2 -0
- package/dist/web/static/assets/useEffectiveProject-DQiyX54y.js.map +1 -0
- package/dist/web/static/assets/useIssuesFeed-CFiyQkAL.js +2 -0
- package/dist/web/static/assets/useIssuesFeed-CFiyQkAL.js.map +1 -0
- package/dist/web/static/assets/useKbHits-xKXWgqh9.js +2 -0
- package/dist/web/static/assets/useKbHits-xKXWgqh9.js.map +1 -0
- package/dist/web/static/assets/useSkillStats-B5hbIwdf.js +2 -0
- package/dist/web/static/assets/useSkillStats-B5hbIwdf.js.map +1 -0
- package/dist/web/static/assets/vendor-DS-q4Eyc.js +36 -0
- package/dist/web/static/assets/vendor-DS-q4Eyc.js.map +1 -0
- package/dist/web/static/index.html +12 -8
- package/package.json +18 -5
- package/dist/core/ai/provider.d.ts +0 -63
- package/dist/core/ai/provider.d.ts.map +0 -1
- package/dist/core/ai/provider.js +0 -241
- package/dist/core/ai/provider.js.map +0 -1
- package/dist/core/ai/types.d.ts +0 -43
- package/dist/core/ai/types.d.ts.map +0 -1
- package/dist/core/ai/types.js +0 -5
- package/dist/core/ai/types.js.map +0 -1
- package/dist/core/storage/token-usage.d.ts +0 -36
- package/dist/core/storage/token-usage.d.ts.map +0 -1
- package/dist/core/storage/token-usage.js +0 -59
- package/dist/core/storage/token-usage.js.map +0 -1
- package/dist/core/utils/token-tracker.d.ts +0 -39
- package/dist/core/utils/token-tracker.d.ts.map +0 -1
- package/dist/core/utils/token-tracker.js +0 -69
- package/dist/core/utils/token-tracker.js.map +0 -1
- package/dist/skills/index.d.ts +0 -3
- package/dist/skills/index.d.ts.map +0 -1
- package/dist/skills/index.js +0 -3
- package/dist/skills/index.js.map +0 -1
- package/dist/skills/matcher.d.ts +0 -26
- package/dist/skills/matcher.d.ts.map +0 -1
- package/dist/skills/matcher.js +0 -113
- package/dist/skills/matcher.js.map +0 -1
- package/dist/skills/official/code-simplifier.md +0 -52
- package/dist/skills/official/find-skills.md +0 -142
- package/dist/skills/official/official-api-design.md +0 -30
- package/dist/skills/official/official-architecture-decision.md +0 -41
- package/dist/skills/official/official-bmad.md +0 -118
- package/dist/skills/official/official-db-schema-design.md +0 -34
- package/dist/skills/official/official-debug.md +0 -25
- package/dist/skills/official/official-doc-driven.md +0 -31
- package/dist/skills/official/official-harness-engineering.md +0 -108
- package/dist/skills/official/official-openspec.md +0 -89
- package/dist/skills/official/official-performance-optimization.md +0 -30
- package/dist/skills/official/official-pr-review.md +0 -35
- package/dist/skills/official/official-release-checklist.md +0 -30
- package/dist/skills/official/official-security-hardening.md +0 -32
- package/dist/skills/official/official-spec-driven-design.md +0 -31
- package/dist/skills/official/planning-with-files.md +0 -241
- package/dist/skills/official/ui-ux-pro-max.md +0 -105
- package/dist/skills/official/webapp-testing.md +0 -96
- package/dist/skills/official-skills.d.ts +0 -26
- package/dist/skills/official-skills.d.ts.map +0 -1
- package/dist/skills/official-skills.js +0 -74
- package/dist/skills/official-skills.js.map +0 -1
- package/dist/skills/semantic-matcher.d.ts +0 -60
- package/dist/skills/semantic-matcher.d.ts.map +0 -1
- package/dist/skills/semantic-matcher.js +0 -192
- package/dist/skills/semantic-matcher.js.map +0 -1
- package/dist/skills/upgrade-engine.d.ts +0 -93
- package/dist/skills/upgrade-engine.d.ts.map +0 -1
- package/dist/skills/upgrade-engine.js +0 -447
- package/dist/skills/upgrade-engine.js.map +0 -1
- package/dist/skills/upgrade-prompt.d.ts +0 -20
- package/dist/skills/upgrade-prompt.d.ts.map +0 -1
- package/dist/skills/upgrade-prompt.js +0 -75
- package/dist/skills/upgrade-prompt.js.map +0 -1
- package/dist/web/routes/ai.d.ts +0 -10
- package/dist/web/routes/ai.d.ts.map +0 -1
- package/dist/web/routes/ai.js +0 -186
- package/dist/web/routes/ai.js.map +0 -1
- package/dist/web/routes/token-usage.d.ts +0 -7
- package/dist/web/routes/token-usage.d.ts.map +0 -1
- package/dist/web/routes/token-usage.js +0 -18
- package/dist/web/routes/token-usage.js.map +0 -1
- package/dist/web/ssrf-guard.d.ts +0 -35
- package/dist/web/ssrf-guard.d.ts.map +0 -1
- package/dist/web/ssrf-guard.js +0 -93
- package/dist/web/ssrf-guard.js.map +0 -1
- package/dist/web/static/assets/AIConfig-CdDWzJyO.js +0 -2
- package/dist/web/static/assets/AIConfig-CdDWzJyO.js.map +0 -1
- package/dist/web/static/assets/Dashboard-CoEmmIDt.js +0 -2
- package/dist/web/static/assets/Dashboard-CoEmmIDt.js.map +0 -1
- package/dist/web/static/assets/Drawer-DdRTzlLB.js +0 -2
- package/dist/web/static/assets/Drawer-DdRTzlLB.js.map +0 -1
- package/dist/web/static/assets/Events-DrIq1SUS.js +0 -2
- package/dist/web/static/assets/Events-DrIq1SUS.js.map +0 -1
- package/dist/web/static/assets/Reports-DFBM3MDK.js +0 -2
- package/dist/web/static/assets/Reports-DFBM3MDK.js.map +0 -1
- package/dist/web/static/assets/SearchInput-qCj_jAcf.js +0 -2
- package/dist/web/static/assets/SearchInput-qCj_jAcf.js.map +0 -1
- package/dist/web/static/assets/SessionDetail-CCzwdoT7.js +0 -2
- package/dist/web/static/assets/SessionDetail-CCzwdoT7.js.map +0 -1
- package/dist/web/static/assets/Sessions-FfLYkAw9.js +0 -2
- package/dist/web/static/assets/Sessions-FfLYkAw9.js.map +0 -1
- package/dist/web/static/assets/Skills-C8Gvs3Qa.js +0 -2
- package/dist/web/static/assets/Skills-C8Gvs3Qa.js.map +0 -1
- package/dist/web/static/assets/TaskDetail-BS8pYhaR.js +0 -2
- package/dist/web/static/assets/TaskDetail-BS8pYhaR.js.map +0 -1
- package/dist/web/static/assets/Tasks-CyuhizG8.js +0 -2
- package/dist/web/static/assets/Tasks-CyuhizG8.js.map +0 -1
- package/dist/web/static/assets/charts-CLrM0_uM.js +0 -37
- package/dist/web/static/assets/charts-CLrM0_uM.js.map +0 -1
- package/dist/web/static/assets/date-fns-CZ_bHujz.js +0 -2
- package/dist/web/static/assets/date-fns-CZ_bHujz.js.map +0 -1
- package/dist/web/static/assets/export-L_VBD2p1.js +0 -4
- package/dist/web/static/assets/export-L_VBD2p1.js.map +0 -1
- package/dist/web/static/assets/index-CBX47X8l.js +0 -3
- package/dist/web/static/assets/index-CBX47X8l.js.map +0 -1
- package/dist/web/static/assets/index-DjIoMdoR.css +0 -1
- package/dist/web/static/assets/lucide-Bs_edTLa.js +0 -232
- package/dist/web/static/assets/lucide-Bs_edTLa.js.map +0 -1
- package/dist/web/static/assets/query-C99w429o.js +0 -2
- package/dist/web/static/assets/react-vendor-CSp-GLFF.js +0 -49
- package/dist/web/static/assets/react-vendor-CSp-GLFF.js.map +0 -1
- package/dist/web/static/assets/syntax-highlighter-44FakypI.js +0 -9
- package/dist/web/static/assets/syntax-highlighter-44FakypI.js.map +0 -1
- package/dist/web/static/assets/time-Bxuk0M-C.js +0 -2
- package/dist/web/static/assets/time-Bxuk0M-C.js.map +0 -1
- package/dist/web/static/assets/vendor-CMMjVdZs.js +0 -64
- package/dist/web/static/assets/vendor-CMMjVdZs.js.map +0 -1
|
@@ -0,0 +1,534 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DecisionsOperations — 统一批准子系统 (decision-flow-overhaul 2026-05-28;
|
|
3
|
+
* C1 convergence spec 0854, 2026-06-02).
|
|
4
|
+
*
|
|
5
|
+
* The decisions table now backs TWO row families distinguished by `kind`:
|
|
6
|
+
* - kind='decision' — daemon-minted decision-hint rows (original lifecycle).
|
|
7
|
+
* - kind='spec' — externally-registered spec files (absorbed from the
|
|
8
|
+
* retired pending_specs table) whose bare `批准 <token>`
|
|
9
|
+
* short-circuits approval. See the Spec-kind API below.
|
|
10
|
+
*
|
|
11
|
+
* Decision-kind lifecycle:
|
|
12
|
+
* 1. daemon emits [DECISION HINT] → INSERT decisions(kind='decision', status='pending')
|
|
13
|
+
* 2. decision-maker agent fills options/recommendation/risks/open_questions
|
|
14
|
+
* via `cf decisions update --id <id> ...`
|
|
15
|
+
* 3. user approves via Web UI or `cf decisions approve <id>`
|
|
16
|
+
* → status='resolved', approved_at=now
|
|
17
|
+
*
|
|
18
|
+
* Spec-kind lifecycle:
|
|
19
|
+
* 1. planner / decision-maker agent registers a spec via
|
|
20
|
+
* `cf decisions register --doc <path>` (or its `cf spec register` alias)
|
|
21
|
+
* → INSERT decisions(kind='spec', status='pending', approval_token=<8hex>)
|
|
22
|
+
* 2. user replies bare `批准` / `approve <token>` → SpecApproval flips to
|
|
23
|
+
* status='resolved'.
|
|
24
|
+
*
|
|
25
|
+
* Design notes:
|
|
26
|
+
* - id is an 8-char short UUID slice minted by the caller (daemon owns PK)
|
|
27
|
+
* - all timestamp fields are ISO 8601 strings
|
|
28
|
+
* - JSON fields (options_json, risks_json, open_questions_json) are
|
|
29
|
+
* caller-serialised; DecisionsOperations does NOT parse them
|
|
30
|
+
* - status updates are idempotent (re-approving is a no-op)
|
|
31
|
+
* - fail-silent pattern: callers should catch and swallow storage errors so
|
|
32
|
+
* the daemon never blocks on decision persistence
|
|
33
|
+
*/
|
|
34
|
+
import { randomBytes } from 'node:crypto';
|
|
35
|
+
/**
|
|
36
|
+
* Statuses that represent an un-acted-on daemon-minted decision-hint row
|
|
37
|
+
* (decision 93e8fff1). Both 'advisory' (new default) and 'pending' (legacy)
|
|
38
|
+
* must be treated as "still open" by dedup / active-skip / expiry so the
|
|
39
|
+
* governance flow keeps working across the mint-default change.
|
|
40
|
+
*/
|
|
41
|
+
export const OPEN_DECISION_STATUSES = ['advisory', 'pending'];
|
|
42
|
+
/** Valid outcome values — single source of truth for runtime validation. */
|
|
43
|
+
export const DECISION_OUTCOMES = [
|
|
44
|
+
'success',
|
|
45
|
+
'failed',
|
|
46
|
+
'partial',
|
|
47
|
+
];
|
|
48
|
+
/**
|
|
49
|
+
* Map a spec-kind DecisionRow onto the legacy SpecLikeRow shape. Pure; the
|
|
50
|
+
* Spawn-2 read path (formatApprovalMessage / rollup) consumes this so it never
|
|
51
|
+
* has to know about decisions column names. status is translated to the
|
|
52
|
+
* pending_specs vocabulary the existing formatters key off.
|
|
53
|
+
*/
|
|
54
|
+
export function toSpecLikeRow(row) {
|
|
55
|
+
const statusMap = {
|
|
56
|
+
// advisory is a decision-kind-only status; spec-kind rows never carry it,
|
|
57
|
+
// but the map must be exhaustive over DecisionStatus. Map it to the same
|
|
58
|
+
// 'generated' bucket as pending for defensiveness.
|
|
59
|
+
advisory: 'generated',
|
|
60
|
+
pending: 'generated',
|
|
61
|
+
resolved: 'approved',
|
|
62
|
+
bypassed: 'skipped',
|
|
63
|
+
expired: 'expired',
|
|
64
|
+
};
|
|
65
|
+
return {
|
|
66
|
+
id: row.id,
|
|
67
|
+
session_id: row.session_id,
|
|
68
|
+
project_path: row.project_path,
|
|
69
|
+
prompt_text: row.trigger_prompt,
|
|
70
|
+
spec_path: row.decision_doc_path ?? '',
|
|
71
|
+
token: row.approval_token ?? '',
|
|
72
|
+
intent_json: row.spec_intent_json ?? '',
|
|
73
|
+
source: row.spec_source ?? '',
|
|
74
|
+
status: statusMap[row.status] ?? row.status,
|
|
75
|
+
created_at: row.created_at,
|
|
76
|
+
approved_at: row.approved_at,
|
|
77
|
+
expires_at: row.expires_at,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
export class DecisionsOperations {
|
|
81
|
+
db;
|
|
82
|
+
constructor(db) {
|
|
83
|
+
this.db = db;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Insert a new pending decision row. Returns the auto-rowid (not the PK `id`).
|
|
87
|
+
* Callers should catch SqliteError for UNIQUE constraint on id.
|
|
88
|
+
*/
|
|
89
|
+
writeDecision(record) {
|
|
90
|
+
const result = this.db
|
|
91
|
+
.prepare(
|
|
92
|
+
// decision 93e8fff1 (2026-06-08): mint kind='decision' rows as
|
|
93
|
+
// 'advisory' (not 'pending'). In the advisory model the interceptor is
|
|
94
|
+
// gone (decision 7c924678) so this row blocks nothing; it is pure
|
|
95
|
+
// bookkeeping. The Web decisions page renders advisory as a neutral,
|
|
96
|
+
// no-approve-button status. dedup/active-skip/expiry/chat-approve all
|
|
97
|
+
// treat advisory like the legacy pending (see OPEN_DECISION_STATUSES).
|
|
98
|
+
`INSERT INTO decisions (
|
|
99
|
+
id, session_id, project_path, trigger_event_id,
|
|
100
|
+
trigger_prompt, suggested_agent,
|
|
101
|
+
kind, status
|
|
102
|
+
) VALUES (
|
|
103
|
+
@id, @session_id, @project_path, @trigger_event_id,
|
|
104
|
+
@trigger_prompt, @suggested_agent,
|
|
105
|
+
'decision', 'advisory'
|
|
106
|
+
)`)
|
|
107
|
+
.run({
|
|
108
|
+
id: record.id,
|
|
109
|
+
session_id: record.session_id,
|
|
110
|
+
project_path: record.project_path,
|
|
111
|
+
trigger_event_id: record.trigger_event_id ?? null,
|
|
112
|
+
trigger_prompt: record.trigger_prompt.slice(0, 500),
|
|
113
|
+
suggested_agent: record.suggested_agent ?? null,
|
|
114
|
+
});
|
|
115
|
+
return Number(result.lastInsertRowid);
|
|
116
|
+
}
|
|
117
|
+
/** Get a single decision row by PK. Returns null when not found. */
|
|
118
|
+
getDecision(id) {
|
|
119
|
+
const row = this.db
|
|
120
|
+
.prepare(`SELECT * FROM decisions WHERE id = ? LIMIT 1`)
|
|
121
|
+
.get(id);
|
|
122
|
+
return row ?? null;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Fill back options/recommendation/risks/open_questions from the
|
|
126
|
+
* decision-maker agent. Does NOT change status — the user still must approve.
|
|
127
|
+
*/
|
|
128
|
+
updateDecision(id, update) {
|
|
129
|
+
const fields = [];
|
|
130
|
+
const params = { id };
|
|
131
|
+
if (update.options_json !== undefined) {
|
|
132
|
+
fields.push('options_json = @options_json');
|
|
133
|
+
params['options_json'] = update.options_json;
|
|
134
|
+
}
|
|
135
|
+
if (update.recommendation !== undefined) {
|
|
136
|
+
fields.push('recommendation = @recommendation');
|
|
137
|
+
params['recommendation'] = update.recommendation;
|
|
138
|
+
}
|
|
139
|
+
if (update.risks_json !== undefined) {
|
|
140
|
+
fields.push('risks_json = @risks_json');
|
|
141
|
+
params['risks_json'] = update.risks_json;
|
|
142
|
+
}
|
|
143
|
+
if (update.open_questions_json !== undefined) {
|
|
144
|
+
fields.push('open_questions_json = @open_questions_json');
|
|
145
|
+
params['open_questions_json'] = update.open_questions_json;
|
|
146
|
+
}
|
|
147
|
+
if (update.decision_doc_path !== undefined) {
|
|
148
|
+
fields.push('decision_doc_path = @decision_doc_path');
|
|
149
|
+
params['decision_doc_path'] = update.decision_doc_path;
|
|
150
|
+
}
|
|
151
|
+
if (update.recommended_agents !== undefined) {
|
|
152
|
+
fields.push('recommended_agents = @recommended_agents');
|
|
153
|
+
params['recommended_agents'] = update.recommended_agents;
|
|
154
|
+
}
|
|
155
|
+
if (update.recommended_skills !== undefined) {
|
|
156
|
+
fields.push('recommended_skills = @recommended_skills');
|
|
157
|
+
params['recommended_skills'] = update.recommended_skills;
|
|
158
|
+
}
|
|
159
|
+
if (fields.length === 0)
|
|
160
|
+
return;
|
|
161
|
+
this.db
|
|
162
|
+
.prepare(`UPDATE decisions SET ${fields.join(', ')} WHERE id = @id`)
|
|
163
|
+
.run(params);
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Back-fill the implementation outcome of a decision (decision-maker
|
|
167
|
+
* optimization Batch 1.1, decision a5d5a85b, 2026-06-02). Writes the
|
|
168
|
+
* implementation result, INDEPENDENT of the approval `status` — does not
|
|
169
|
+
* touch status / approved_at / resolved_at.
|
|
170
|
+
*
|
|
171
|
+
* Idempotent: re-writing the same (or a different) valid outcome is a plain
|
|
172
|
+
* UPDATE. Validates `outcome` against DECISION_OUTCOMES and throws on an
|
|
173
|
+
* illegal value (the column-level CHECK only guards non-empty, so the enum
|
|
174
|
+
* gate must live here). Never auto-inferred from commits — only the
|
|
175
|
+
* implementing agent's explicit `cf decisions outcome` call reaches this.
|
|
176
|
+
*/
|
|
177
|
+
writeDecisionOutcome(id, outcome) {
|
|
178
|
+
if (!DECISION_OUTCOMES.includes(outcome)) {
|
|
179
|
+
throw new Error(`writeDecisionOutcome: invalid outcome '${outcome}' — must be one of ${DECISION_OUTCOMES.join(', ')}`);
|
|
180
|
+
}
|
|
181
|
+
this.db
|
|
182
|
+
.prepare(`UPDATE decisions SET outcome = ? WHERE id = ?`)
|
|
183
|
+
.run(outcome, id);
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Approve a decision: flip status='resolved', set approved_at + approved_by.
|
|
187
|
+
* Idempotent — re-approving an already-resolved row is a no-op.
|
|
188
|
+
*
|
|
189
|
+
* Option B (decision b95e0956, 2026-05-29): optional `bypass_flag` /
|
|
190
|
+
* `bypass_reason` are recorded alongside the approve. Callers (the `cf
|
|
191
|
+
* decisions approve` CLI in particular) use this to flag "main-thread
|
|
192
|
+
* self-approve" rows for the weekly governance scan.
|
|
193
|
+
*/
|
|
194
|
+
approveDecision(id, approved_by = 'user', approved_at_iso, options) {
|
|
195
|
+
const at = approved_at_iso ?? new Date().toISOString();
|
|
196
|
+
if (options && (options.bypass_flag !== undefined || options.bypass_reason !== undefined)) {
|
|
197
|
+
const flag = options.bypass_flag ?? 0;
|
|
198
|
+
const reason = options.bypass_reason ?? null;
|
|
199
|
+
this.db
|
|
200
|
+
.prepare(`UPDATE decisions
|
|
201
|
+
SET status = 'resolved',
|
|
202
|
+
approved_at = ?,
|
|
203
|
+
approved_by = ?,
|
|
204
|
+
resolved_at = ?,
|
|
205
|
+
bypass_flag = ?,
|
|
206
|
+
bypass_reason = ?
|
|
207
|
+
WHERE id = ? AND status != 'resolved'`)
|
|
208
|
+
.run(at, approved_by, at, flag, reason, id);
|
|
209
|
+
return;
|
|
210
|
+
}
|
|
211
|
+
this.db
|
|
212
|
+
.prepare(`UPDATE decisions
|
|
213
|
+
SET status = 'resolved',
|
|
214
|
+
approved_at = ?,
|
|
215
|
+
approved_by = ?,
|
|
216
|
+
resolved_at = ?
|
|
217
|
+
WHERE id = ? AND status != 'resolved'`)
|
|
218
|
+
.run(at, approved_by, at, id);
|
|
219
|
+
}
|
|
220
|
+
/**
|
|
221
|
+
* Option B (decision b95e0956, 2026-05-29) — continuation detection helper.
|
|
222
|
+
*
|
|
223
|
+
* Returns the most recent N resolved decisions for a session, ordered
|
|
224
|
+
* newest-first. Used by `isContinuation` in the daemon decision-hint
|
|
225
|
+
* service to decide whether a short prompt is "continuing prior work".
|
|
226
|
+
*
|
|
227
|
+
* Limit is capped at 50 to keep the query bounded; default 3 matches the
|
|
228
|
+
* Option B Q2 contract ("N=3 resolved decisions AND 30 min window").
|
|
229
|
+
*/
|
|
230
|
+
listRecentResolved(session_id, limit = 3) {
|
|
231
|
+
const lim = Math.min(Math.max(1, limit), 50);
|
|
232
|
+
return this.db
|
|
233
|
+
.prepare(
|
|
234
|
+
// R5 (C1): kind='decision' so spec-kind rows never count as resolved
|
|
235
|
+
// decisions for continuation detection.
|
|
236
|
+
`SELECT id, resolved_at, created_at FROM decisions
|
|
237
|
+
WHERE session_id = ?
|
|
238
|
+
AND kind = 'decision'
|
|
239
|
+
AND status = 'resolved'
|
|
240
|
+
ORDER BY COALESCE(resolved_at, created_at) DESC
|
|
241
|
+
LIMIT ?`)
|
|
242
|
+
.all(session_id, lim);
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* outcome-backfill soft-gate (decision 1ac6fc31, 2026-06-04) — list resolved
|
|
246
|
+
* decisions whose `outcome` has not yet been back-filled, scoped to a session
|
|
247
|
+
* (and optionally a project_path). This is the session/project-filtered
|
|
248
|
+
* variant of the `cf decisions outcome --list-pending` query
|
|
249
|
+
* (`listDecisions({status:'resolved'}).filter(outcome===null)`), pushed into
|
|
250
|
+
* SQL so the OutcomeNudge soft-gate doesn't pull every resolved row across all
|
|
251
|
+
* sessions just to filter in JS.
|
|
252
|
+
*
|
|
253
|
+
* kind='decision' so spec-kind rows (which never carry an implementation
|
|
254
|
+
* outcome) are excluded — same R5 scoping as every other decision-flow query.
|
|
255
|
+
*
|
|
256
|
+
* project_path is optional: a single Claude session can switch working dirs,
|
|
257
|
+
* so scoping by project (Phase 1 / decision 7fa0f2ab pattern) keeps another
|
|
258
|
+
* project's backlog from inflating this one's nudge count.
|
|
259
|
+
*/
|
|
260
|
+
listResolvedUnfilled(session_id, project_path) {
|
|
261
|
+
const conditions = [
|
|
262
|
+
"kind = 'decision'",
|
|
263
|
+
"status = 'resolved'",
|
|
264
|
+
'outcome IS NULL',
|
|
265
|
+
'session_id = ?',
|
|
266
|
+
];
|
|
267
|
+
const params = [session_id];
|
|
268
|
+
if (project_path !== undefined) {
|
|
269
|
+
conditions.push('project_path = ?');
|
|
270
|
+
params.push(project_path);
|
|
271
|
+
}
|
|
272
|
+
return this.db
|
|
273
|
+
.prepare(`SELECT * FROM decisions
|
|
274
|
+
WHERE ${conditions.join('\n AND ')}
|
|
275
|
+
ORDER BY COALESCE(resolved_at, created_at) ASC`)
|
|
276
|
+
.all(...params);
|
|
277
|
+
}
|
|
278
|
+
/**
|
|
279
|
+
* Mark a decision as bypassed (user used 'skip decision' keyword or
|
|
280
|
+
* decision-hint-pending rule outcome='bypassed').
|
|
281
|
+
*/
|
|
282
|
+
bypassDecision(id, approved_by = 'auto-bypass') {
|
|
283
|
+
const at = new Date().toISOString();
|
|
284
|
+
this.db
|
|
285
|
+
.prepare(
|
|
286
|
+
// decision 93e8fff1: advisory is the new open state, so bypass must
|
|
287
|
+
// accept it alongside legacy 'pending' (otherwise 'skip decision' would
|
|
288
|
+
// no-op on freshly minted rows).
|
|
289
|
+
`UPDATE decisions
|
|
290
|
+
SET status = 'bypassed',
|
|
291
|
+
approved_by = ?,
|
|
292
|
+
resolved_at = ?
|
|
293
|
+
WHERE id = ? AND status IN ('advisory','pending')`)
|
|
294
|
+
.run(approved_by, at, id);
|
|
295
|
+
}
|
|
296
|
+
/**
|
|
297
|
+
* Bulk-expire still-open (advisory|pending) decision-kind rows whose
|
|
298
|
+
* expires_at < now. Returns number of rows touched. Safe to call on every
|
|
299
|
+
* Stop hook.
|
|
300
|
+
*
|
|
301
|
+
* decision 93e8fff1 (2026-06-08): widened from `status='pending'` to
|
|
302
|
+
* `status IN ('advisory','pending')`. CRITICAL — advisory is now the default
|
|
303
|
+
* mint status, so without this advisory rows would NEVER expire and the
|
|
304
|
+
* decisions page would fill up forever (worse than the original symptom).
|
|
305
|
+
*/
|
|
306
|
+
expireOldRows(now_iso) {
|
|
307
|
+
const ref = now_iso ?? new Date().toISOString();
|
|
308
|
+
const result = this.db
|
|
309
|
+
.prepare(
|
|
310
|
+
// R5 (C1): only expire decision-kind rows; spec-kind expiry is handled
|
|
311
|
+
// by expireOldSpecs so the two lifecycles stay independent.
|
|
312
|
+
`UPDATE decisions
|
|
313
|
+
SET status = 'expired'
|
|
314
|
+
WHERE kind = 'decision'
|
|
315
|
+
AND status IN ('advisory','pending')
|
|
316
|
+
AND expires_at < ?`)
|
|
317
|
+
.run(ref);
|
|
318
|
+
return Number(result.changes);
|
|
319
|
+
}
|
|
320
|
+
/**
|
|
321
|
+
* Get the most recent pending decision for a session within the given window.
|
|
322
|
+
* Used by PreToolUseHandler to populate RuleContext.pending_decision_id.
|
|
323
|
+
*
|
|
324
|
+
* Note: uses SQLite datetime arithmetic so it works regardless of whether
|
|
325
|
+
* `created_at` was inserted as ISO-Z or bare ISO (SQLite datetime('now')
|
|
326
|
+
* produces 'YYYY-MM-DD HH:MM:SS', which compares correctly with the
|
|
327
|
+
* SQLite `datetime('now', '-N seconds')` form).
|
|
328
|
+
*
|
|
329
|
+
* global-governance Phase 1 (2026-06-04, decision 7fa0f2ab): added optional
|
|
330
|
+
* `project_path` filter. A single Claude session can switch working dirs
|
|
331
|
+
* across projects; without scoping by project, a pending decision minted in
|
|
332
|
+
* project A would leak into project B and wrongly intercept B's Edit/Write.
|
|
333
|
+
* The param is optional for backward compatibility — when omitted the query
|
|
334
|
+
* matches by session only (legacy behaviour).
|
|
335
|
+
*/
|
|
336
|
+
getMostRecentPending(session_id, within_seconds = 3600, project_path) {
|
|
337
|
+
const conditions = [
|
|
338
|
+
'session_id = ?',
|
|
339
|
+
"kind = 'decision'",
|
|
340
|
+
// decision 93e8fff1: dedup / active-skip must treat advisory (new mint
|
|
341
|
+
// default) AND legacy pending as "still open", or the daemon would
|
|
342
|
+
// re-mint a fresh row on every prompt.
|
|
343
|
+
"status IN ('advisory','pending')",
|
|
344
|
+
"created_at >= datetime('now', ? || ' seconds')",
|
|
345
|
+
];
|
|
346
|
+
const params = [session_id, `-${within_seconds}`];
|
|
347
|
+
if (project_path !== undefined) {
|
|
348
|
+
conditions.push('project_path = ?');
|
|
349
|
+
params.push(project_path);
|
|
350
|
+
}
|
|
351
|
+
const row = this.db
|
|
352
|
+
.prepare(
|
|
353
|
+
// R5 (C1) — CRITICAL: kind='decision' so a spec-kind pending row can
|
|
354
|
+
// never be returned here. PreToolUseHandler uses this to populate
|
|
355
|
+
// pending_decision_id; without the filter a registered spec would make
|
|
356
|
+
// the rule think a decision is pending and wrongly intercept the main
|
|
357
|
+
// thread's Edit/Write.
|
|
358
|
+
`SELECT * FROM decisions
|
|
359
|
+
WHERE ${conditions.join('\n AND ')}
|
|
360
|
+
ORDER BY created_at DESC
|
|
361
|
+
LIMIT 1`)
|
|
362
|
+
.get(...params);
|
|
363
|
+
return row ?? null;
|
|
364
|
+
}
|
|
365
|
+
/** Generic filter for CLI listings and Web API. */
|
|
366
|
+
listDecisions(filter = {}) {
|
|
367
|
+
// R5 (C1): always scope to decision-kind so `cf decisions list` / the Web
|
|
368
|
+
// decisions page never mix in spec-kind rows.
|
|
369
|
+
const conditions = ["kind = 'decision'"];
|
|
370
|
+
const params = [];
|
|
371
|
+
if (filter.session_id) {
|
|
372
|
+
conditions.push('session_id = ?');
|
|
373
|
+
params.push(filter.session_id);
|
|
374
|
+
}
|
|
375
|
+
if (filter.status) {
|
|
376
|
+
conditions.push('status = ?');
|
|
377
|
+
params.push(filter.status);
|
|
378
|
+
}
|
|
379
|
+
const where = conditions.length > 0 ? `WHERE ${conditions.join(' AND ')}` : '';
|
|
380
|
+
const limit = filter.limit ?? 50;
|
|
381
|
+
params.push(limit);
|
|
382
|
+
const sql = `SELECT * FROM decisions ${where} ORDER BY created_at DESC LIMIT ?`;
|
|
383
|
+
return this.db.prepare(sql).all(...params);
|
|
384
|
+
}
|
|
385
|
+
/**
|
|
386
|
+
* Count decisions created since `sinceIso`. Drives DaemonObserverBadge's
|
|
387
|
+
* `hinted_7d` field (spec 1750 § B1-3 — every row represents one daemon
|
|
388
|
+
* decision-hint emission, including those later bypassed or expired).
|
|
389
|
+
*
|
|
390
|
+
* Why `datetime(created_at) >= datetime(?)`: the column default uses
|
|
391
|
+
* SQLite's `datetime('now')` which produces 'YYYY-MM-DD HH:MM:SS' (space-
|
|
392
|
+
* separated). JavaScript's toISOString() returns 'YYYY-MM-DDTHH:MM:SS.sssZ'.
|
|
393
|
+
* Plain string compare puts ISO > SQLite-default lexically (because 'T' > ' '
|
|
394
|
+
* in ASCII), which would never match. Wrapping both sides in datetime()
|
|
395
|
+
* normalises them to compare correctly.
|
|
396
|
+
*/
|
|
397
|
+
countDecisionsSince(sinceIso) {
|
|
398
|
+
const row = this.db
|
|
399
|
+
.prepare(
|
|
400
|
+
// R5 (C1): kind='decision' so the DaemonObserverBadge hint counter
|
|
401
|
+
// (hinted_7d) does not inflate with registered spec rows.
|
|
402
|
+
`SELECT COUNT(*) AS n FROM decisions
|
|
403
|
+
WHERE kind = 'decision'
|
|
404
|
+
AND datetime(created_at) >= datetime(?)`)
|
|
405
|
+
.get(sinceIso);
|
|
406
|
+
return row?.n ?? 0;
|
|
407
|
+
}
|
|
408
|
+
// ── Spec-kind API (C1, 2026-06-02 — absorbs PendingSpecsOperations) ─────
|
|
409
|
+
//
|
|
410
|
+
// These rebuild the retired pending_specs semantics on top of the decisions
|
|
411
|
+
// table. Every method scopes `kind='spec'` so it never touches the
|
|
412
|
+
// decision-kind lifecycle. The CLI layer mints the 8-hex approval_token
|
|
413
|
+
// (createHash('sha1')...slice(0,8)) so the `批准 <8hex>` regex/UX is unchanged.
|
|
414
|
+
/**
|
|
415
|
+
* Insert a spec-kind row (status='pending', kind='spec'). The id is minted
|
|
416
|
+
* here as an 8-char hex slice (same shape as decision ids); approval_token is
|
|
417
|
+
* the caller-supplied 8-hex SHA1. spec_path lands in decision_doc_path,
|
|
418
|
+
* prompt_text in trigger_prompt, intent in spec_intent_json. Returns the
|
|
419
|
+
* minted id.
|
|
420
|
+
*
|
|
421
|
+
* Callers should catch SqliteError UNIQUE on approval_token (partial-unique
|
|
422
|
+
* index) and decide whether to surface "already registered" or retry.
|
|
423
|
+
*/
|
|
424
|
+
registerSpec(record) {
|
|
425
|
+
const id = randomBytes(4).toString('hex'); // 8-char hex, mirrors decision ids
|
|
426
|
+
this.db
|
|
427
|
+
.prepare(`INSERT INTO decisions (
|
|
428
|
+
id, session_id, project_path,
|
|
429
|
+
trigger_prompt, suggested_agent,
|
|
430
|
+
kind, status,
|
|
431
|
+
decision_doc_path, approval_token, spec_source, spec_intent_json,
|
|
432
|
+
expires_at
|
|
433
|
+
) VALUES (
|
|
434
|
+
@id, @session_id, @project_path,
|
|
435
|
+
@trigger_prompt, NULL,
|
|
436
|
+
'spec', 'pending',
|
|
437
|
+
@decision_doc_path, @approval_token, @spec_source, @spec_intent_json,
|
|
438
|
+
COALESCE(@expires_at, datetime('now','+7 days'))
|
|
439
|
+
)`)
|
|
440
|
+
.run({
|
|
441
|
+
id,
|
|
442
|
+
session_id: record.session_id,
|
|
443
|
+
project_path: record.project_path,
|
|
444
|
+
trigger_prompt: record.prompt_text.slice(0, 500),
|
|
445
|
+
decision_doc_path: record.spec_path,
|
|
446
|
+
approval_token: record.approval_token,
|
|
447
|
+
spec_source: record.spec_source,
|
|
448
|
+
spec_intent_json: record.spec_intent_json,
|
|
449
|
+
expires_at: record.expires_at ?? null,
|
|
450
|
+
});
|
|
451
|
+
return id;
|
|
452
|
+
}
|
|
453
|
+
/**
|
|
454
|
+
* Lookup a spec-kind row by (token, session_id). The session_id requirement
|
|
455
|
+
* carries over the pending_specs P0 safety fix — a token leaked across
|
|
456
|
+
* sessions must not approve someone else's spec.
|
|
457
|
+
*/
|
|
458
|
+
findSpecByTokenAndSession(token, session_id) {
|
|
459
|
+
const row = this.db
|
|
460
|
+
.prepare(`SELECT * FROM decisions
|
|
461
|
+
WHERE kind = 'spec'
|
|
462
|
+
AND approval_token = ?
|
|
463
|
+
AND session_id = ?
|
|
464
|
+
LIMIT 1`)
|
|
465
|
+
.get(token, session_id);
|
|
466
|
+
return row ?? null;
|
|
467
|
+
}
|
|
468
|
+
/**
|
|
469
|
+
* Lookup a spec-kind row by spec_path (idempotency probe for registration
|
|
470
|
+
* and the migration script). Matches against decision_doc_path.
|
|
471
|
+
*/
|
|
472
|
+
findSpecByPath(spec_path) {
|
|
473
|
+
const row = this.db
|
|
474
|
+
.prepare(`SELECT * FROM decisions
|
|
475
|
+
WHERE kind = 'spec' AND decision_doc_path = ?
|
|
476
|
+
LIMIT 1`)
|
|
477
|
+
.get(spec_path);
|
|
478
|
+
return row ?? null;
|
|
479
|
+
}
|
|
480
|
+
/**
|
|
481
|
+
* Approve a spec-kind row: status='resolved' + approved_at. Idempotent
|
|
482
|
+
* (only flips rows that are not already resolved). Scoped to kind='spec'.
|
|
483
|
+
*/
|
|
484
|
+
markSpecApproved(id, approved_at_iso) {
|
|
485
|
+
const at = approved_at_iso ?? new Date().toISOString();
|
|
486
|
+
this.db
|
|
487
|
+
.prepare(`UPDATE decisions
|
|
488
|
+
SET status = 'resolved', approved_at = ?, resolved_at = ?
|
|
489
|
+
WHERE id = ? AND kind = 'spec' AND status != 'resolved'`)
|
|
490
|
+
.run(at, at, id);
|
|
491
|
+
}
|
|
492
|
+
/**
|
|
493
|
+
* Recent pending spec-kind rows for a session — feeds the systemMessage hint
|
|
494
|
+
* when a user types `批准` without a token. Defaults to limit 5.
|
|
495
|
+
*/
|
|
496
|
+
listSpecsBySessionPending(session_id, limit = 5) {
|
|
497
|
+
return this.db
|
|
498
|
+
.prepare(`SELECT * FROM decisions
|
|
499
|
+
WHERE kind = 'spec' AND session_id = ? AND status = 'pending'
|
|
500
|
+
ORDER BY created_at DESC
|
|
501
|
+
LIMIT ?`)
|
|
502
|
+
.all(session_id, limit);
|
|
503
|
+
}
|
|
504
|
+
/**
|
|
505
|
+
* Pipeline-rollup batch helper. Pulls every spec-kind row for the given
|
|
506
|
+
* session IDs in one IN-query, ordered ASC by created_at so the rollup layer
|
|
507
|
+
* can scan forward to match prompts (mirrors the retired queryBySessions).
|
|
508
|
+
*/
|
|
509
|
+
querySpecsBySessions(sessionIds) {
|
|
510
|
+
if (sessionIds.length === 0)
|
|
511
|
+
return [];
|
|
512
|
+
const placeholders = sessionIds.map(() => '?').join(',');
|
|
513
|
+
return this.db
|
|
514
|
+
.prepare(`SELECT * FROM decisions
|
|
515
|
+
WHERE kind = 'spec' AND session_id IN (${placeholders})
|
|
516
|
+
ORDER BY created_at ASC`)
|
|
517
|
+
.all(...sessionIds);
|
|
518
|
+
}
|
|
519
|
+
/**
|
|
520
|
+
* Bulk-expire still-'pending' spec-kind rows whose expires_at < now. Returns
|
|
521
|
+
* the number of rows touched. Safe to call on every Stop hook. Independent of
|
|
522
|
+
* expireOldRows (which only touches decision-kind).
|
|
523
|
+
*/
|
|
524
|
+
expireOldSpecs(now_iso) {
|
|
525
|
+
const ref = now_iso ?? new Date().toISOString();
|
|
526
|
+
const result = this.db
|
|
527
|
+
.prepare(`UPDATE decisions
|
|
528
|
+
SET status = 'expired'
|
|
529
|
+
WHERE kind = 'spec' AND status = 'pending' AND expires_at < ?`)
|
|
530
|
+
.run(ref);
|
|
531
|
+
return Number(result.changes);
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
//# sourceMappingURL=decisions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"decisions.js","sourceRoot":"","sources":["../../../src/core/storage/decisions.ts"],"names":[],"mappings":"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"}
|