@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,706 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `cf decisions` — manage decision lifecycle (decision-flow-overhaul 2026-05-28)
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* cf decisions list [--status <s>] [--session-id <id>] [--json]
|
|
6
|
+
* List decisions, optionally filtered by status / session.
|
|
7
|
+
*
|
|
8
|
+
* cf decisions show <id> [--json]
|
|
9
|
+
* Show full detail for a single decision row.
|
|
10
|
+
*
|
|
11
|
+
* cf decisions update --id <id> [--options-json <json>] [--recommendation <text>]
|
|
12
|
+
* [--risks-json <json>] [--open-questions-json <json>]
|
|
13
|
+
* [--doc <path>] [--json]
|
|
14
|
+
* Called by decision-maker agent after writing the decision doc.
|
|
15
|
+
* Fills back options/recommendation/risks/open_questions into the DB.
|
|
16
|
+
*
|
|
17
|
+
* cf decisions approve <id> [--json]
|
|
18
|
+
* Mark a decision resolved (status='resolved'). Can also be triggered
|
|
19
|
+
* from the Web UI.
|
|
20
|
+
*
|
|
21
|
+
* cf decisions outcome <id> --result <success|failed|partial> [--note <text>] [--json]
|
|
22
|
+
* cf decisions outcome --list-pending [--json]
|
|
23
|
+
* (decision-maker optimization Batch 1.2, decision a5d5a85b) Back-fill the
|
|
24
|
+
* implementation outcome of an already-approved (status='resolved')
|
|
25
|
+
* decision, or list resolved decisions whose outcome is not yet filled.
|
|
26
|
+
*
|
|
27
|
+
* cf decisions register --doc <path> [--session-id <id>] [--source <s>]
|
|
28
|
+
* [--project-path <path>] [--json]
|
|
29
|
+
* (C1 Phase 2, spec 0854) Register an existing spec file as a kind='spec'
|
|
30
|
+
* decisions row so the user can short-circuit approve it with bare `批准
|
|
31
|
+
* <token>`. Absorbs the retired `cf spec register` semantics.
|
|
32
|
+
*
|
|
33
|
+
* Design:
|
|
34
|
+
* - Session id resolution: --session-id flag > $CLAUDE_SESSION_ID env > DB lookup
|
|
35
|
+
* - JSON output mode for agent / scripting callers
|
|
36
|
+
* - Exit 0 on all success/no-op paths; exit 1 on error
|
|
37
|
+
*/
|
|
38
|
+
import path from 'node:path';
|
|
39
|
+
import { existsSync } from 'node:fs';
|
|
40
|
+
import { createHash } from 'node:crypto';
|
|
41
|
+
import { SQLiteStorage } from '../../core/storage/sqlite.js';
|
|
42
|
+
import { ConfigManager } from '../../core/config.js';
|
|
43
|
+
import { expandPath } from '../../core/utils/path.js';
|
|
44
|
+
import { resolveSessionId } from '../utils/resolve-session.js';
|
|
45
|
+
import { DECISION_OUTCOMES } from '../../core/storage/decisions.js';
|
|
46
|
+
import { isAgentSpawnToolName } from '../../daemon/services/decision-hint.js';
|
|
47
|
+
function resolveIo(io) {
|
|
48
|
+
return {
|
|
49
|
+
log: io.log ?? ((m) => console.log(m)),
|
|
50
|
+
warn: io.warn ?? ((m) => console.error(m)),
|
|
51
|
+
error: io.error ?? ((m) => console.error(m)),
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
function openStorage(injected) {
|
|
55
|
+
if (injected)
|
|
56
|
+
return { storage: injected, own: false };
|
|
57
|
+
const config = new ConfigManager().get();
|
|
58
|
+
const dbPath = expandPath(config.storage.path);
|
|
59
|
+
return { storage: new SQLiteStorage(dbPath), own: true };
|
|
60
|
+
}
|
|
61
|
+
// ── Command registration ─────────────────────────────────────────────────
|
|
62
|
+
export function register(program) {
|
|
63
|
+
const cmd = program
|
|
64
|
+
.command('decisions')
|
|
65
|
+
.description('Manage decision lifecycle (decision-flow-overhaul 2026-05-28)');
|
|
66
|
+
// ── list ─────────────────────────────────────────────────────────────
|
|
67
|
+
cmd
|
|
68
|
+
.command('list')
|
|
69
|
+
.description('List decisions')
|
|
70
|
+
.option('--status <status>', 'Filter by status (advisory|pending|resolved|bypassed|expired)')
|
|
71
|
+
.option('--session-id <id>', 'Filter by session id')
|
|
72
|
+
.option('--json', 'Output JSON')
|
|
73
|
+
.action((opts) => {
|
|
74
|
+
process.exitCode = runList(opts);
|
|
75
|
+
});
|
|
76
|
+
// ── show ─────────────────────────────────────────────────────────────
|
|
77
|
+
cmd
|
|
78
|
+
.command('show <id>')
|
|
79
|
+
.description('Show a single decision by id')
|
|
80
|
+
.option('--json', 'Output JSON')
|
|
81
|
+
.action((id, opts) => {
|
|
82
|
+
process.exitCode = runShow(id, opts);
|
|
83
|
+
});
|
|
84
|
+
// ── update ────────────────────────────────────────────────────────────
|
|
85
|
+
cmd
|
|
86
|
+
.command('update')
|
|
87
|
+
.description('Fill back decision content (called by decision-maker agent)')
|
|
88
|
+
.requiredOption('--id <id>', 'Decision id (8-char)')
|
|
89
|
+
.option('--options-json <json>', 'JSON array of options [{name,what,pros,cons,loc,risk}]')
|
|
90
|
+
.option('--recommendation <text>', 'Recommended option + rationale')
|
|
91
|
+
.option('--risks-json <json>', 'JSON array of risk strings')
|
|
92
|
+
.option('--open-questions-json <json>', 'JSON array of open question strings')
|
|
93
|
+
.option('--doc <path>', 'Relative path to the decision doc under docs/design/')
|
|
94
|
+
.option('--recommended-agents <agents>', 'Comma-separated agent ids recommended by decision-maker')
|
|
95
|
+
.option('--recommended-skills <skills>', 'Comma-separated skill ids recommended by decision-maker')
|
|
96
|
+
.option('--json', 'Output JSON')
|
|
97
|
+
.action((opts) => {
|
|
98
|
+
process.exitCode = runUpdate(opts);
|
|
99
|
+
});
|
|
100
|
+
// ── approve ───────────────────────────────────────────────────────────
|
|
101
|
+
cmd
|
|
102
|
+
.command('approve <id>')
|
|
103
|
+
.description('Approve a decision (status → resolved)')
|
|
104
|
+
.option('--reason <text>', 'Justification for the approve. REQUIRED when no decision-maker spawn ' +
|
|
105
|
+
'trace exists within ±5min of the approve — this is the Option B ' +
|
|
106
|
+
'(decision b95e0956) self-aware bypass gate.')
|
|
107
|
+
.option('--json', 'Output JSON')
|
|
108
|
+
.action((id, opts) => {
|
|
109
|
+
process.exitCode = runApprove(id, opts);
|
|
110
|
+
});
|
|
111
|
+
// ── outcome (decision-maker optimization Batch 1.2, decision a5d5a85b) ──
|
|
112
|
+
// Back-fill the implementation outcome of an already-approved decision, or
|
|
113
|
+
// list resolved decisions whose outcome is not yet filled (--list-pending).
|
|
114
|
+
cmd
|
|
115
|
+
.command('outcome [id]')
|
|
116
|
+
.description('Back-fill a decision implementation outcome, or list those pending back-fill')
|
|
117
|
+
.option('--result <result>', `Outcome: ${DECISION_OUTCOMES.join(' | ')}`)
|
|
118
|
+
.option('--note <text>', 'Free-text note about the outcome (not persisted; logged only)')
|
|
119
|
+
.option('--list-pending', 'List resolved decisions whose outcome is not yet filled')
|
|
120
|
+
.option('--json', 'Output JSON')
|
|
121
|
+
.action((id, opts) => {
|
|
122
|
+
process.exitCode = runOutcome({ ...opts, id });
|
|
123
|
+
});
|
|
124
|
+
// ── register (C1 Phase 2, spec 0854) ───────────────────────────────────
|
|
125
|
+
// Register an existing spec file as a decisions kind='spec' row so users
|
|
126
|
+
// can short-circuit approve it with bare `批准 <token>`. Absorbs the old
|
|
127
|
+
// `cf spec register` semantics into the decisions subsystem.
|
|
128
|
+
cmd
|
|
129
|
+
.command('register')
|
|
130
|
+
.description('Register a spec file in decisions (kind=spec) for bare 批准 approval')
|
|
131
|
+
.requiredOption('--doc <path>', 'Path to the spec file (relative to project or absolute)')
|
|
132
|
+
.option('--session-id <id>', 'Session id to attach the spec to (defaults to $CLAUDE_SESSION_ID env var)')
|
|
133
|
+
.option('--source <source>', `Origin: 'planner' | 'manual' | 'decision' (default 'manual')`, 'manual')
|
|
134
|
+
.option('--project-path <path>', 'Project root used to resolve the doc path (defaults to cwd)')
|
|
135
|
+
.option('--json', 'Output JSON instead of human-readable text')
|
|
136
|
+
.action((opts) => {
|
|
137
|
+
process.exitCode = runRegisterSpec(opts);
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
// ── runList ──────────────────────────────────────────────────────────────
|
|
141
|
+
export function runList(opts, io = {}, injectedStorage) {
|
|
142
|
+
const { log, error } = resolveIo(io);
|
|
143
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
144
|
+
try {
|
|
145
|
+
const filter = {};
|
|
146
|
+
if (opts.status)
|
|
147
|
+
filter.status = opts.status;
|
|
148
|
+
if (opts.sessionId)
|
|
149
|
+
filter.session_id = opts.sessionId;
|
|
150
|
+
const rows = storage.listDecisions(filter);
|
|
151
|
+
if (opts.json) {
|
|
152
|
+
log(JSON.stringify(rows));
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
if (rows.length === 0) {
|
|
156
|
+
log('No decisions found.');
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
for (const r of rows) {
|
|
160
|
+
log(`${r.id} ${r.status.padEnd(8)} ` +
|
|
161
|
+
`${r.session_id.slice(0, 8)}... ${r.created_at}`);
|
|
162
|
+
if (r.recommendation)
|
|
163
|
+
log(` recommendation: ${r.recommendation.slice(0, 80)}`);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
return 0;
|
|
168
|
+
}
|
|
169
|
+
catch (err) {
|
|
170
|
+
error(`Error: ${err}`);
|
|
171
|
+
return 1;
|
|
172
|
+
}
|
|
173
|
+
finally {
|
|
174
|
+
if (own)
|
|
175
|
+
storage.close();
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
// ── runShow ──────────────────────────────────────────────────────────────
|
|
179
|
+
export function runShow(id, opts, io = {}, injectedStorage) {
|
|
180
|
+
const { log, error } = resolveIo(io);
|
|
181
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
182
|
+
try {
|
|
183
|
+
const row = storage.getDecision(id);
|
|
184
|
+
if (!row) {
|
|
185
|
+
error(`Decision not found: ${id}`);
|
|
186
|
+
return 1;
|
|
187
|
+
}
|
|
188
|
+
if (opts.json) {
|
|
189
|
+
log(JSON.stringify(row));
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
log(`id: ${row.id}`);
|
|
193
|
+
log(`status: ${row.status}`);
|
|
194
|
+
log(`session_id: ${row.session_id}`);
|
|
195
|
+
log(`project_path: ${row.project_path}`);
|
|
196
|
+
log(`suggested_agent: ${row.suggested_agent ?? '(none)'}`);
|
|
197
|
+
log(`created_at: ${row.created_at}`);
|
|
198
|
+
log(`expires_at: ${row.expires_at}`);
|
|
199
|
+
if (row.approved_at)
|
|
200
|
+
log(`approved_at: ${row.approved_at} (by ${row.approved_by})`);
|
|
201
|
+
if (row.decision_doc_path)
|
|
202
|
+
log(`doc: ${row.decision_doc_path}`);
|
|
203
|
+
log('');
|
|
204
|
+
log(`trigger_prompt: ${row.trigger_prompt}`);
|
|
205
|
+
log('');
|
|
206
|
+
if (row.options_json) {
|
|
207
|
+
log('options:');
|
|
208
|
+
try {
|
|
209
|
+
const opts2 = JSON.parse(row.options_json);
|
|
210
|
+
for (const o of opts2)
|
|
211
|
+
log(` - ${o.name}`);
|
|
212
|
+
}
|
|
213
|
+
catch {
|
|
214
|
+
log(` (raw) ${row.options_json}`);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
if (row.recommendation)
|
|
218
|
+
log(`\nrecommendation: ${row.recommendation}`);
|
|
219
|
+
if (row.risks_json) {
|
|
220
|
+
log('\nrisks:');
|
|
221
|
+
try {
|
|
222
|
+
const risks = JSON.parse(row.risks_json);
|
|
223
|
+
for (const r2 of risks)
|
|
224
|
+
log(` - ${r2}`);
|
|
225
|
+
}
|
|
226
|
+
catch {
|
|
227
|
+
log(` (raw) ${row.risks_json}`);
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
if (row.open_questions_json) {
|
|
231
|
+
log('\nopen questions:');
|
|
232
|
+
try {
|
|
233
|
+
const oqs = JSON.parse(row.open_questions_json);
|
|
234
|
+
for (const q of oqs)
|
|
235
|
+
log(` - ${q}`);
|
|
236
|
+
}
|
|
237
|
+
catch {
|
|
238
|
+
log(` (raw) ${row.open_questions_json}`);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
return 0;
|
|
243
|
+
}
|
|
244
|
+
catch (err) {
|
|
245
|
+
error(`Error: ${err}`);
|
|
246
|
+
return 1;
|
|
247
|
+
}
|
|
248
|
+
finally {
|
|
249
|
+
if (own)
|
|
250
|
+
storage.close();
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
// ── runUpdate ─────────────────────────────────────────────────────────────
|
|
254
|
+
export function runUpdate(opts, io = {}, injectedStorage) {
|
|
255
|
+
const { log, error } = resolveIo(io);
|
|
256
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
257
|
+
try {
|
|
258
|
+
const existing = storage.getDecision(opts.id);
|
|
259
|
+
if (!existing) {
|
|
260
|
+
error(`Decision not found: ${opts.id}`);
|
|
261
|
+
return 1;
|
|
262
|
+
}
|
|
263
|
+
// Validate JSON fields if provided
|
|
264
|
+
for (const [label, val] of [
|
|
265
|
+
['--options-json', opts.optionsJson],
|
|
266
|
+
['--risks-json', opts.risksJson],
|
|
267
|
+
['--open-questions-json', opts.openQuestionsJson],
|
|
268
|
+
]) {
|
|
269
|
+
if (val !== undefined) {
|
|
270
|
+
try {
|
|
271
|
+
JSON.parse(val);
|
|
272
|
+
}
|
|
273
|
+
catch {
|
|
274
|
+
error(`Error: ${label} is not valid JSON`);
|
|
275
|
+
return 1;
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
storage.updateDecision(opts.id, {
|
|
280
|
+
options_json: opts.optionsJson ?? undefined,
|
|
281
|
+
recommendation: opts.recommendation ?? undefined,
|
|
282
|
+
risks_json: opts.risksJson ?? undefined,
|
|
283
|
+
open_questions_json: opts.openQuestionsJson ?? undefined,
|
|
284
|
+
decision_doc_path: opts.doc ?? undefined,
|
|
285
|
+
recommended_agents: opts.recommendedAgents ?? undefined,
|
|
286
|
+
recommended_skills: opts.recommendedSkills ?? undefined,
|
|
287
|
+
});
|
|
288
|
+
if (opts.json) {
|
|
289
|
+
log(JSON.stringify({ ok: true, id: opts.id }));
|
|
290
|
+
}
|
|
291
|
+
else {
|
|
292
|
+
log(`Decision ${opts.id} updated.`);
|
|
293
|
+
}
|
|
294
|
+
return 0;
|
|
295
|
+
}
|
|
296
|
+
catch (err) {
|
|
297
|
+
error(`Error: ${err}`);
|
|
298
|
+
return 1;
|
|
299
|
+
}
|
|
300
|
+
finally {
|
|
301
|
+
if (own)
|
|
302
|
+
storage.close();
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
// ── runApprove ────────────────────────────────────────────────────────────
|
|
306
|
+
/**
|
|
307
|
+
* Option B (decision b95e0956, 2026-05-29) — window for the "decision-maker
|
|
308
|
+
* spawn trace" lookup. Approves with a Task spawn of subagent_type='decision-maker'
|
|
309
|
+
* within ±MAKER_TRACE_WINDOW_MS of `now` are auto-tagged
|
|
310
|
+
* `bypass_reason='via decision-maker'`; everything else REQUIRES `--reason`.
|
|
311
|
+
*/
|
|
312
|
+
export const MAKER_TRACE_WINDOW_MS = 5 * 60 * 1000; // ±5 min
|
|
313
|
+
/**
|
|
314
|
+
* Look for a recent PreToolUse Task event whose tool_input.subagent_type is
|
|
315
|
+
* 'decision-maker' within ±MAKER_TRACE_WINDOW_MS of `nowMs` for the given
|
|
316
|
+
* session. Returns true when found (i.e. the approve is NOT a bypass).
|
|
317
|
+
*
|
|
318
|
+
* Optional `session_id` filter limits scope to the row's session; omitting it
|
|
319
|
+
* is a safety fallback for legacy approves that don't know which session
|
|
320
|
+
* spawned them (rare — Web UI always knows; CLI usually does too).
|
|
321
|
+
*/
|
|
322
|
+
export function findRecentDecisionMakerSpawn(storage, session_id, nowMs = Date.now()) {
|
|
323
|
+
if (!session_id)
|
|
324
|
+
return false;
|
|
325
|
+
const sinceIso = new Date(nowMs - MAKER_TRACE_WINDOW_MS).toISOString();
|
|
326
|
+
try {
|
|
327
|
+
const rows = storage.queryEvents({
|
|
328
|
+
session_id,
|
|
329
|
+
hook_type: 'PreToolUse',
|
|
330
|
+
since: sinceIso,
|
|
331
|
+
limit: 200,
|
|
332
|
+
});
|
|
333
|
+
for (const ev of rows) {
|
|
334
|
+
// Bug P1 (decision e888352d, 2026-06-10) — accept both 'Agent' (current
|
|
335
|
+
// Claude Code) and 'Task' (legacy CC) so this approve-trace lookup does
|
|
336
|
+
// not silently miss every real spawn. Shared helper keeps it in lock-step
|
|
337
|
+
// with the daemon cooldown gate.
|
|
338
|
+
if (!isAgentSpawnToolName(ev.tool_name))
|
|
339
|
+
continue;
|
|
340
|
+
const input = (ev.tool_input ?? {});
|
|
341
|
+
const sub = typeof input['subagent_type'] === 'string' ? input['subagent_type'] : '';
|
|
342
|
+
if (sub === 'decision-maker')
|
|
343
|
+
return true;
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
catch {
|
|
347
|
+
// Fail-silent — if storage lookup blows up we degrade to "no trace found"
|
|
348
|
+
// which forces an explicit --reason. Safer than auto-allowing.
|
|
349
|
+
}
|
|
350
|
+
return false;
|
|
351
|
+
}
|
|
352
|
+
export function runApprove(id, opts, io = {}, injectedStorage) {
|
|
353
|
+
const { log, error } = resolveIo(io);
|
|
354
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
355
|
+
try {
|
|
356
|
+
const existing = storage.getDecision(id);
|
|
357
|
+
if (!existing) {
|
|
358
|
+
error(`Decision not found: ${id}`);
|
|
359
|
+
return 1;
|
|
360
|
+
}
|
|
361
|
+
if (existing.status === 'resolved') {
|
|
362
|
+
if (opts.json) {
|
|
363
|
+
log(JSON.stringify({ ok: true, id, already_approved: true }));
|
|
364
|
+
}
|
|
365
|
+
else {
|
|
366
|
+
log(`Decision ${id} is already approved.`);
|
|
367
|
+
}
|
|
368
|
+
return 0;
|
|
369
|
+
}
|
|
370
|
+
// Option B (decision b95e0956) — bypass governance gate.
|
|
371
|
+
//
|
|
372
|
+
// Look for a decision-maker spawn trace in the row's session within ±5 min.
|
|
373
|
+
// If found → auto-fill bypass_reason='via decision-maker', flag=0.
|
|
374
|
+
// If NOT found → --reason is REQUIRED; otherwise abort with code 1.
|
|
375
|
+
const sawMakerSpawn = findRecentDecisionMakerSpawn(storage, existing.session_id);
|
|
376
|
+
let bypass_flag;
|
|
377
|
+
let bypass_reason;
|
|
378
|
+
if (sawMakerSpawn) {
|
|
379
|
+
bypass_flag = 0;
|
|
380
|
+
bypass_reason = opts.reason?.trim() || 'via decision-maker';
|
|
381
|
+
}
|
|
382
|
+
else {
|
|
383
|
+
const reason = opts.reason?.trim();
|
|
384
|
+
if (!reason) {
|
|
385
|
+
error('Error: --reason <text> is required when approving without a ' +
|
|
386
|
+
'decision-maker spawn trace (Option B / decision b95e0956). ' +
|
|
387
|
+
'Either spawn decision-maker first, or pass `--reason "<why>"` ' +
|
|
388
|
+
'to record an explicit self-aware bypass justification.');
|
|
389
|
+
return 1;
|
|
390
|
+
}
|
|
391
|
+
bypass_flag = 1;
|
|
392
|
+
bypass_reason = reason;
|
|
393
|
+
}
|
|
394
|
+
storage.approveDecision(id, 'user', undefined, { bypass_flag, bypass_reason });
|
|
395
|
+
if (opts.json) {
|
|
396
|
+
log(JSON.stringify({
|
|
397
|
+
ok: true,
|
|
398
|
+
id,
|
|
399
|
+
approved: true,
|
|
400
|
+
bypass_flag,
|
|
401
|
+
bypass_reason,
|
|
402
|
+
}));
|
|
403
|
+
}
|
|
404
|
+
else {
|
|
405
|
+
log(`Decision ${id} approved (status=resolved, bypass_flag=${bypass_flag}, ` +
|
|
406
|
+
`reason="${bypass_reason}").`);
|
|
407
|
+
}
|
|
408
|
+
return 0;
|
|
409
|
+
}
|
|
410
|
+
catch (err) {
|
|
411
|
+
error(`Error: ${err}`);
|
|
412
|
+
return 1;
|
|
413
|
+
}
|
|
414
|
+
finally {
|
|
415
|
+
if (own)
|
|
416
|
+
storage.close();
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
// ── runOutcome (decision-maker optimization Batch 1.2, decision a5d5a85b) ────
|
|
420
|
+
/**
|
|
421
|
+
* Back-fill the implementation outcome of an already-approved decision, or list
|
|
422
|
+
* resolved decisions whose outcome is not yet filled.
|
|
423
|
+
*
|
|
424
|
+
* Two mutually-exclusive modes:
|
|
425
|
+
* - `--list-pending`: list decisions with status='resolved' AND outcome IS
|
|
426
|
+
* NULL (id is ignored). Supports --json.
|
|
427
|
+
* - back-fill: requires `id` + `--result <success|failed|partial>`. The
|
|
428
|
+
* decision must exist and be status='resolved' (back-fill only makes sense
|
|
429
|
+
* for approved decisions). `--result` is validated against
|
|
430
|
+
* DECISION_OUTCOMES (single source of truth). `--note` is accepted for UX
|
|
431
|
+
* but NOT persisted (no storage field) — only echoed in the confirmation.
|
|
432
|
+
*
|
|
433
|
+
* Neither mode satisfied (no id and no --list-pending) → usage error, exit 1.
|
|
434
|
+
*
|
|
435
|
+
* Exported for unit tests; returns exit code instead of process.exit.
|
|
436
|
+
*/
|
|
437
|
+
export function runOutcome(opts, io = {}, injectedStorage) {
|
|
438
|
+
const { log, error } = resolveIo(io);
|
|
439
|
+
// ── --list-pending mode ──────────────────────────────────────────────
|
|
440
|
+
if (opts.listPending) {
|
|
441
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
442
|
+
try {
|
|
443
|
+
// Storage has no outcome-is-null filter; pull resolved rows then filter.
|
|
444
|
+
const resolved = storage.listDecisions({ status: 'resolved' });
|
|
445
|
+
const pending = resolved.filter((r) => r.outcome === null);
|
|
446
|
+
if (opts.json) {
|
|
447
|
+
log(JSON.stringify(pending));
|
|
448
|
+
}
|
|
449
|
+
else if (pending.length === 0) {
|
|
450
|
+
log('No resolved decisions awaiting outcome back-fill.');
|
|
451
|
+
}
|
|
452
|
+
else {
|
|
453
|
+
for (const r of pending) {
|
|
454
|
+
log(`${r.id} resolved ` +
|
|
455
|
+
`${r.session_id.slice(0, 8)}... ${r.created_at}`);
|
|
456
|
+
if (r.recommendation)
|
|
457
|
+
log(` recommendation: ${r.recommendation.slice(0, 80)}`);
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
return 0;
|
|
461
|
+
}
|
|
462
|
+
catch (err) {
|
|
463
|
+
error(`Error: ${err}`);
|
|
464
|
+
return 1;
|
|
465
|
+
}
|
|
466
|
+
finally {
|
|
467
|
+
if (own)
|
|
468
|
+
storage.close();
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
// ── back-fill mode ───────────────────────────────────────────────────
|
|
472
|
+
if (!opts.id) {
|
|
473
|
+
error('Error: usage — provide an <id> with --result <result> to back-fill, ' +
|
|
474
|
+
'or --list-pending to list resolved decisions awaiting an outcome.');
|
|
475
|
+
return 1;
|
|
476
|
+
}
|
|
477
|
+
if (!opts.result) {
|
|
478
|
+
error(`Error: --result <${DECISION_OUTCOMES.join('|')}> is required`);
|
|
479
|
+
return 1;
|
|
480
|
+
}
|
|
481
|
+
if (!DECISION_OUTCOMES.includes(opts.result)) {
|
|
482
|
+
error(`Error: invalid --result "${opts.result}" — must be one of ` +
|
|
483
|
+
`${DECISION_OUTCOMES.join(', ')}`);
|
|
484
|
+
return 1;
|
|
485
|
+
}
|
|
486
|
+
const result = opts.result;
|
|
487
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
488
|
+
try {
|
|
489
|
+
const existing = storage.getDecision(opts.id);
|
|
490
|
+
if (!existing) {
|
|
491
|
+
error(`Decision not found: ${opts.id}`);
|
|
492
|
+
return 1;
|
|
493
|
+
}
|
|
494
|
+
// Bug P0 (decision e888352d, 2026-06-10) — outcome back-fill now also
|
|
495
|
+
// accepts 'advisory' decisions, not just 'resolved'. Advisory is the
|
|
496
|
+
// default mint status for daemon-minted kind='decision' rows (decision
|
|
497
|
+
// 93e8fff1); audit/advisory decisions (e.g. the full-link audit itself)
|
|
498
|
+
// are never explicitly chat-approved, so requiring status='resolved'
|
|
499
|
+
// left them with no way to record a closed-loop outcome — pure 空转.
|
|
500
|
+
//
|
|
501
|
+
// 'pending' (legacy open), 'bypassed', and 'expired' are still rejected:
|
|
502
|
+
// a bypassed/expired decision was deliberately abandoned and recording an
|
|
503
|
+
// implementation outcome on it is meaningless.
|
|
504
|
+
if (existing.status !== 'resolved' && existing.status !== 'advisory') {
|
|
505
|
+
error(`Error: decision ${opts.id} has status='${existing.status}' — outcome ` +
|
|
506
|
+
`back-fill is only valid for approved (status='resolved') or ` +
|
|
507
|
+
`advisory (daemon-minted) decisions.`);
|
|
508
|
+
return 1;
|
|
509
|
+
}
|
|
510
|
+
storage.writeDecisionOutcome(opts.id, result);
|
|
511
|
+
// When the decision was still 'advisory', recording an implementation
|
|
512
|
+
// outcome means it has been acted on — transition it to 'resolved' so the
|
|
513
|
+
// lifecycle stays coherent (no row left in 'advisory' with a non-null
|
|
514
|
+
// outcome) and `--list-pending` / outcome-nudge accounting stays correct.
|
|
515
|
+
// approveDecision is idempotent and only flips rows that are not already
|
|
516
|
+
// resolved, so a row that was already resolved is untouched here.
|
|
517
|
+
let advisoryResolved = false;
|
|
518
|
+
if (existing.status === 'advisory') {
|
|
519
|
+
storage.approveDecision(opts.id, 'outcome-backfill', undefined, {
|
|
520
|
+
bypass_flag: 0,
|
|
521
|
+
bypass_reason: 'resolved via outcome back-fill (advisory decision)',
|
|
522
|
+
});
|
|
523
|
+
advisoryResolved = true;
|
|
524
|
+
}
|
|
525
|
+
if (opts.json) {
|
|
526
|
+
log(JSON.stringify({
|
|
527
|
+
ok: true,
|
|
528
|
+
id: opts.id,
|
|
529
|
+
outcome: result,
|
|
530
|
+
...(advisoryResolved ? { resolved_from_advisory: true } : {}),
|
|
531
|
+
}));
|
|
532
|
+
}
|
|
533
|
+
else {
|
|
534
|
+
const noteSuffix = opts.note ? ` (note: ${opts.note})` : '';
|
|
535
|
+
const advisorySuffix = advisoryResolved
|
|
536
|
+
? ' (advisory → resolved)'
|
|
537
|
+
: '';
|
|
538
|
+
log(`Decision ${opts.id} outcome set to '${result}'.${advisorySuffix}${noteSuffix}`);
|
|
539
|
+
}
|
|
540
|
+
return 0;
|
|
541
|
+
}
|
|
542
|
+
catch (err) {
|
|
543
|
+
error(`Error: ${err}`);
|
|
544
|
+
return 1;
|
|
545
|
+
}
|
|
546
|
+
finally {
|
|
547
|
+
if (own)
|
|
548
|
+
storage.close();
|
|
549
|
+
}
|
|
550
|
+
}
|
|
551
|
+
// ── runRegisterSpec (C1 Phase 2, spec 0854) ─────────────────────────────────
|
|
552
|
+
/** Valid `--source` values for `cf decisions register` (no 'auto'; that was a
|
|
553
|
+
* dead SpecGenerator origin and is not a valid manual/agent source here). */
|
|
554
|
+
const VALID_SPEC_SOURCES = new Set(['planner', 'manual', 'decision']);
|
|
555
|
+
/**
|
|
556
|
+
* Register an existing spec file as a decisions kind='spec' row.
|
|
557
|
+
*
|
|
558
|
+
* Mints the SAME 8-hex SHA1 token shape as `cf spec register`
|
|
559
|
+
* (createHash('sha1')...slice(0,8)) so the `批准 <token>` regex/UX never
|
|
560
|
+
* changes. Idempotent on spec_path: a second register of the same doc returns
|
|
561
|
+
* exit 0 + already_registered=true (Q5: never hard-fail — planner Step 4.5).
|
|
562
|
+
*
|
|
563
|
+
* Exported for unit tests; returns exit code instead of process.exit.
|
|
564
|
+
*/
|
|
565
|
+
export function runRegisterSpec(opts, io = {}, injectedStorage) {
|
|
566
|
+
const { log, warn, error } = resolveIo(io);
|
|
567
|
+
// ── Validate inputs ──────────────────────────────────────────────────
|
|
568
|
+
if (!opts.doc) {
|
|
569
|
+
error('Error: --doc is required');
|
|
570
|
+
return 1;
|
|
571
|
+
}
|
|
572
|
+
const source = (opts.source ?? 'manual').toLowerCase();
|
|
573
|
+
if (!VALID_SPEC_SOURCES.has(source)) {
|
|
574
|
+
error(`Error: invalid --source "${opts.source}" (must be 'planner' | 'manual' | 'decision')`);
|
|
575
|
+
return 1;
|
|
576
|
+
}
|
|
577
|
+
const projectPath = opts.projectPath ?? process.cwd();
|
|
578
|
+
const absDocPath = path.isAbsolute(opts.doc)
|
|
579
|
+
? opts.doc
|
|
580
|
+
: path.resolve(projectPath, opts.doc);
|
|
581
|
+
if (!existsSync(absDocPath)) {
|
|
582
|
+
error(`Error: spec file not found at ${absDocPath}`);
|
|
583
|
+
return 1;
|
|
584
|
+
}
|
|
585
|
+
// Store project-relative so the approval message displays a clean path.
|
|
586
|
+
const relDocPath = path.isAbsolute(opts.doc)
|
|
587
|
+
? path.relative(projectPath, absDocPath)
|
|
588
|
+
: opts.doc;
|
|
589
|
+
const { storage, own } = openStorage(injectedStorage);
|
|
590
|
+
try {
|
|
591
|
+
// ── Session id: shared flag → env → DB lookup fallback (Q3). ───────
|
|
592
|
+
const resolved = resolveSessionId(storage, {
|
|
593
|
+
sessionId: opts.sessionId,
|
|
594
|
+
projectPath,
|
|
595
|
+
});
|
|
596
|
+
if (!resolved.sessionId) {
|
|
597
|
+
error(`Error: no active session found for project ${projectPath} — ` +
|
|
598
|
+
`pass --session-id explicitly or set CLAUDE_SESSION_ID env var`);
|
|
599
|
+
return 1;
|
|
600
|
+
}
|
|
601
|
+
const sessionId = resolved.sessionId;
|
|
602
|
+
// ── Idempotency: probe by spec_path (decision_doc_path). ───────────
|
|
603
|
+
const existing = storage.findSpecByPath(relDocPath);
|
|
604
|
+
if (existing) {
|
|
605
|
+
if (opts.json) {
|
|
606
|
+
log(JSON.stringify({
|
|
607
|
+
ok: true,
|
|
608
|
+
already_registered: true,
|
|
609
|
+
token: existing.approval_token,
|
|
610
|
+
spec_path: existing.decision_doc_path,
|
|
611
|
+
source: existing.spec_source,
|
|
612
|
+
id: existing.id,
|
|
613
|
+
kind: 'spec',
|
|
614
|
+
}));
|
|
615
|
+
}
|
|
616
|
+
else {
|
|
617
|
+
warn(`Spec already registered: ${relDocPath} ` +
|
|
618
|
+
`(token=${existing.approval_token}, source=${existing.spec_source})`);
|
|
619
|
+
}
|
|
620
|
+
return 0;
|
|
621
|
+
}
|
|
622
|
+
// ── Mint 8-hex SHA1 token (same algorithm as `cf spec register`). ──
|
|
623
|
+
const token = createHash('sha1')
|
|
624
|
+
.update(`${absDocPath}:${new Date().toISOString()}:${process.pid}`)
|
|
625
|
+
.digest('hex')
|
|
626
|
+
.slice(0, 8);
|
|
627
|
+
const intentJson = JSON.stringify({
|
|
628
|
+
source: 'cli-decisions-register',
|
|
629
|
+
suggested_agent: source === 'decision' ? 'decision-maker' : 'planner',
|
|
630
|
+
});
|
|
631
|
+
try {
|
|
632
|
+
const id = storage.registerSpec({
|
|
633
|
+
session_id: sessionId,
|
|
634
|
+
project_path: projectPath,
|
|
635
|
+
prompt_text: '(registered via `cf decisions register`)',
|
|
636
|
+
spec_path: relDocPath,
|
|
637
|
+
approval_token: token,
|
|
638
|
+
spec_source: source,
|
|
639
|
+
spec_intent_json: intentJson,
|
|
640
|
+
});
|
|
641
|
+
const summary = {
|
|
642
|
+
ok: true,
|
|
643
|
+
already_registered: false,
|
|
644
|
+
id,
|
|
645
|
+
token,
|
|
646
|
+
spec_path: relDocPath,
|
|
647
|
+
source,
|
|
648
|
+
kind: 'spec',
|
|
649
|
+
session_id: sessionId,
|
|
650
|
+
session_id_source: resolved.source,
|
|
651
|
+
};
|
|
652
|
+
if (opts.json) {
|
|
653
|
+
log(JSON.stringify(summary));
|
|
654
|
+
}
|
|
655
|
+
else {
|
|
656
|
+
log(`✓ Registered spec @ ${relDocPath}\n` +
|
|
657
|
+
` token: ${token}\n` +
|
|
658
|
+
` session_id: ${sessionId} (from ${resolved.source})\n` +
|
|
659
|
+
` source: ${source}\n` +
|
|
660
|
+
` id: ${id}\n` +
|
|
661
|
+
` kind: spec\n` +
|
|
662
|
+
`\nUser can now reply '批准' / '同意' / 'approve ${token}' to short-circuit.`);
|
|
663
|
+
}
|
|
664
|
+
return 0;
|
|
665
|
+
}
|
|
666
|
+
catch (err) {
|
|
667
|
+
// UNIQUE constraint race (between findSpecByPath probe and INSERT on the
|
|
668
|
+
// partial-unique approval_token index). Q5: still don't hard-fail — warn
|
|
669
|
+
// and exit 0 so the agent continues. Re-probe to surface the live token.
|
|
670
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
671
|
+
if (msg.includes('UNIQUE constraint failed')) {
|
|
672
|
+
const re = storage.findSpecByPath(relDocPath);
|
|
673
|
+
if (re) {
|
|
674
|
+
if (opts.json) {
|
|
675
|
+
log(JSON.stringify({
|
|
676
|
+
ok: true,
|
|
677
|
+
already_registered: true,
|
|
678
|
+
token: re.approval_token,
|
|
679
|
+
spec_path: re.decision_doc_path,
|
|
680
|
+
source: re.spec_source,
|
|
681
|
+
id: re.id,
|
|
682
|
+
kind: 'spec',
|
|
683
|
+
race: true,
|
|
684
|
+
}));
|
|
685
|
+
}
|
|
686
|
+
else {
|
|
687
|
+
warn(`Spec already registered (UNIQUE race): ${relDocPath} ` +
|
|
688
|
+
`(token=${re.approval_token})`);
|
|
689
|
+
}
|
|
690
|
+
return 0;
|
|
691
|
+
}
|
|
692
|
+
}
|
|
693
|
+
error(`Error: failed to register spec — ${msg}`);
|
|
694
|
+
return 1;
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
catch (err) {
|
|
698
|
+
error(`Error: ${err}`);
|
|
699
|
+
return 1;
|
|
700
|
+
}
|
|
701
|
+
finally {
|
|
702
|
+
if (own)
|
|
703
|
+
storage.close();
|
|
704
|
+
}
|
|
705
|
+
}
|
|
706
|
+
//# sourceMappingURL=decisions.js.map
|