@winspan/claude-forge 8.41.0 → 8.51.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/.claude/CLAUDE.md +17 -0
- package/.eslintrc.js +23 -0
- package/.prettierrc +8 -0
- package/ARCHITECTURE_ISSUES.md +249 -0
- package/CLAUDE.md +265 -0
- package/CLAUDE.md.backup +488 -0
- package/DEVELOPMENT.md +310 -0
- package/dist/claudemd/claudemd-generator.d.ts +38 -3
- package/dist/claudemd/claudemd-generator.d.ts.map +1 -1
- package/dist/claudemd/claudemd-generator.js +420 -12
- package/dist/claudemd/claudemd-generator.js.map +1 -1
- package/dist/claudemd/index.d.ts +2 -2
- package/dist/claudemd/index.d.ts.map +1 -1
- package/dist/claudemd/index.js.map +1 -1
- package/dist/claudemd/resume-manager.d.ts.map +1 -1
- package/dist/claudemd/resume-manager.js +6 -3
- package/dist/claudemd/resume-manager.js.map +1 -1
- package/dist/claudemd/tech-detector.d.ts +1 -0
- package/dist/claudemd/tech-detector.d.ts.map +1 -1
- package/dist/claudemd/tech-detector.js +53 -0
- package/dist/claudemd/tech-detector.js.map +1 -1
- package/dist/claudemd/templates/swarm-protocol.md +222 -0
- package/dist/cli/commands/claudemd.js +2 -2
- package/dist/cli/commands/claudemd.js.map +1 -1
- package/dist/cli/commands/daemon.d.ts +28 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -1
- package/dist/cli/commands/daemon.js +204 -12
- package/dist/cli/commands/daemon.js.map +1 -1
- package/dist/cli/commands/executions.d.ts.map +1 -1
- package/dist/cli/commands/executions.js +4 -3
- package/dist/cli/commands/executions.js.map +1 -1
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +5 -37
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/logs.js.map +1 -1
- package/dist/cli/commands/mcp.d.ts.map +1 -1
- package/dist/cli/commands/mcp.js +3 -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 +14 -13
- package/dist/cli/commands/menu.js.map +1 -1
- package/dist/cli/commands/skills.d.ts.map +1 -1
- package/dist/cli/commands/skills.js +8 -2
- package/dist/cli/commands/skills.js.map +1 -1
- package/dist/cli/commands/stats.d.ts.map +1 -1
- package/dist/cli/commands/stats.js +2 -20
- package/dist/cli/commands/stats.js.map +1 -1
- package/dist/cli/commands/status.js +2 -2
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/trace.d.ts +9 -0
- package/dist/cli/commands/trace.d.ts.map +1 -0
- package/dist/cli/commands/trace.js +125 -0
- package/dist/cli/commands/trace.js.map +1 -0
- package/dist/cli/index.js +2 -4
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/init/hook-manager.d.ts.map +1 -1
- package/dist/cli/init/hook-manager.js +2 -2
- package/dist/cli/init/hook-manager.js.map +1 -1
- package/dist/core/ai/provider.d.ts +10 -2
- package/dist/core/ai/provider.d.ts.map +1 -1
- package/dist/core/ai/provider.js +2 -2
- package/dist/core/ai/provider.js.map +1 -1
- package/dist/core/ai/types.d.ts +1 -19
- package/dist/core/ai/types.d.ts.map +1 -1
- package/dist/core/ai/types.js +1 -1
- package/dist/core/config.d.ts +2 -1
- package/dist/core/config.d.ts.map +1 -1
- package/dist/core/config.js +23 -6
- package/dist/core/config.js.map +1 -1
- package/dist/core/constants.d.ts +14 -3
- package/dist/core/constants.d.ts.map +1 -1
- package/dist/core/constants.js +17 -3
- package/dist/core/constants.js.map +1 -1
- package/dist/core/event-fields.d.ts +16 -0
- package/dist/core/event-fields.d.ts.map +1 -0
- package/dist/core/event-fields.js +19 -0
- package/dist/core/event-fields.js.map +1 -0
- package/dist/core/queue/index.d.ts +52 -0
- package/dist/core/queue/index.d.ts.map +1 -0
- package/dist/core/queue/index.js +175 -0
- package/dist/core/queue/index.js.map +1 -0
- package/dist/core/storage/base.d.ts +66 -0
- package/dist/core/storage/base.d.ts.map +1 -0
- package/dist/core/storage/base.js +254 -0
- package/dist/core/storage/base.js.map +1 -0
- package/dist/core/storage/events.d.ts +141 -0
- package/dist/core/storage/events.d.ts.map +1 -0
- package/dist/core/storage/events.js +348 -0
- package/dist/core/storage/events.js.map +1 -0
- package/dist/core/storage/injections.d.ts +27 -0
- package/dist/core/storage/injections.d.ts.map +1 -0
- package/dist/core/storage/injections.js +51 -0
- package/dist/core/storage/injections.js.map +1 -0
- package/dist/core/storage/maintenance.d.ts +21 -0
- package/dist/core/storage/maintenance.d.ts.map +1 -0
- package/dist/core/storage/maintenance.js +52 -0
- package/dist/core/storage/maintenance.js.map +1 -0
- package/dist/core/storage/routing.d.ts +124 -0
- package/dist/core/storage/routing.d.ts.map +1 -0
- package/dist/core/storage/routing.js +239 -0
- package/dist/core/storage/routing.js.map +1 -0
- package/dist/core/storage/rows.d.ts +0 -47
- package/dist/core/storage/rows.d.ts.map +1 -1
- package/dist/core/storage/schema.sql +85 -137
- package/dist/core/storage/sessions.d.ts +54 -0
- package/dist/core/storage/sessions.d.ts.map +1 -0
- package/dist/core/storage/sessions.js +137 -0
- package/dist/core/storage/sessions.js.map +1 -0
- package/dist/core/storage/skills.d.ts +63 -0
- package/dist/core/storage/skills.d.ts.map +1 -0
- package/dist/core/storage/skills.js +154 -0
- package/dist/core/storage/skills.js.map +1 -0
- package/dist/core/storage/sqlite.d.ts +97 -266
- package/dist/core/storage/sqlite.d.ts.map +1 -1
- package/dist/core/storage/sqlite.js +196 -764
- package/dist/core/storage/sqlite.js.map +1 -1
- package/dist/core/storage/tasks.d.ts +113 -0
- package/dist/core/storage/tasks.d.ts.map +1 -0
- package/dist/core/storage/tasks.js +276 -0
- package/dist/core/storage/tasks.js.map +1 -0
- package/dist/core/storage/token-usage.d.ts +36 -0
- package/dist/core/storage/token-usage.d.ts.map +1 -0
- package/dist/core/storage/token-usage.js +59 -0
- package/dist/core/storage/token-usage.js.map +1 -0
- package/dist/core/types.d.ts +83 -6
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/types.js +24 -1
- package/dist/core/types.js.map +1 -1
- package/dist/core/utils/error-handler.d.ts.map +1 -1
- package/dist/core/utils/error-handler.js +3 -2
- package/dist/core/utils/error-handler.js.map +1 -1
- package/dist/core/utils/format.d.ts +28 -0
- package/dist/core/utils/format.d.ts.map +1 -0
- package/dist/core/utils/format.js +68 -0
- package/dist/core/utils/format.js.map +1 -0
- package/dist/core/utils/git.d.ts +10 -0
- package/dist/core/utils/git.d.ts.map +1 -0
- package/dist/core/utils/git.js +24 -0
- package/dist/core/utils/git.js.map +1 -0
- package/dist/core/utils/logger.d.ts +6 -1
- package/dist/core/utils/logger.d.ts.map +1 -1
- package/dist/core/utils/logger.js +87 -3
- package/dist/core/utils/logger.js.map +1 -1
- package/dist/core/utils/lru-cache.d.ts +1 -0
- package/dist/core/utils/lru-cache.d.ts.map +1 -1
- package/dist/core/utils/lru-cache.js +3 -0
- package/dist/core/utils/lru-cache.js.map +1 -1
- package/dist/core/utils/session.d.ts +16 -0
- package/dist/core/utils/session.d.ts.map +1 -0
- package/dist/core/utils/session.js +25 -0
- package/dist/core/utils/session.js.map +1 -0
- package/dist/core/utils/time.d.ts +22 -0
- package/dist/core/utils/time.d.ts.map +1 -0
- package/dist/core/utils/time.js +38 -0
- package/dist/core/utils/time.js.map +1 -0
- package/dist/core/utils/token-tracker.js +1 -1
- package/dist/core/utils/token-tracker.js.map +1 -1
- package/dist/daemon/event-parser.d.ts.map +1 -1
- package/dist/daemon/event-parser.js +2 -1
- 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 +6 -4
- package/dist/daemon/handlers/history-exporter.js.map +1 -1
- package/dist/daemon/handlers/post-tool-use.d.ts +5 -12
- package/dist/daemon/handlers/post-tool-use.d.ts.map +1 -1
- package/dist/daemon/handlers/post-tool-use.js +25 -79
- package/dist/daemon/handlers/post-tool-use.js.map +1 -1
- package/dist/daemon/handlers/stop.d.ts +28 -12
- package/dist/daemon/handlers/stop.d.ts.map +1 -1
- package/dist/daemon/handlers/stop.js +129 -42
- package/dist/daemon/handlers/stop.js.map +1 -1
- package/dist/daemon/handlers/user-prompt.d.ts +18 -19
- package/dist/daemon/handlers/user-prompt.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt.js +93 -227
- package/dist/daemon/handlers/user-prompt.js.map +1 -1
- package/dist/daemon/index.d.ts +6 -2
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +97 -127
- package/dist/daemon/index.js.map +1 -1
- package/dist/daemon/launchd/com.claude-forge.daemon.plist.template +47 -0
- package/dist/daemon/launchd-installer.d.ts +61 -0
- package/dist/daemon/launchd-installer.d.ts.map +1 -0
- package/dist/daemon/launchd-installer.js +182 -0
- package/dist/daemon/launchd-installer.js.map +1 -0
- package/dist/daemon/lifecycle.d.ts +11 -0
- package/dist/daemon/lifecycle.d.ts.map +1 -1
- package/dist/daemon/lifecycle.js +47 -4
- package/dist/daemon/lifecycle.js.map +1 -1
- package/dist/daemon/router.d.ts +9 -2
- package/dist/daemon/router.d.ts.map +1 -1
- package/dist/daemon/router.js +27 -3
- package/dist/daemon/router.js.map +1 -1
- package/dist/daemon/server.d.ts +6 -4
- package/dist/daemon/server.d.ts.map +1 -1
- package/dist/daemon/server.js +80 -88
- package/dist/daemon/server.js.map +1 -1
- package/dist/{intelligence → daemon/services}/task-segmenter.d.ts +7 -1
- package/dist/daemon/services/task-segmenter.d.ts.map +1 -0
- package/dist/{intelligence → daemon/services}/task-segmenter.js +30 -7
- package/dist/daemon/services/task-segmenter.js.map +1 -0
- package/dist/hooks/hook-lib.sh +118 -0
- package/dist/hooks/notification.sh +9 -5
- package/dist/hooks/post-tool-use.sh +10 -6
- package/dist/hooks/pre-tool-use.sh +9 -6
- package/dist/hooks/stop.sh +10 -7
- package/dist/hooks/user-prompt-submit.sh +10 -11
- package/dist/mcp/server.d.ts +2 -2
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +71 -11
- package/dist/mcp/server.js.map +1 -1
- package/dist/skills/invocation-guard.d.ts +20 -0
- package/dist/skills/invocation-guard.d.ts.map +1 -1
- package/dist/skills/invocation-guard.js +63 -0
- package/dist/skills/invocation-guard.js.map +1 -1
- package/dist/skills/matcher.d.ts.map +1 -1
- package/dist/skills/matcher.js +12 -3
- package/dist/skills/matcher.js.map +1 -1
- package/dist/skills/official/code-simplifier.md +16 -0
- package/dist/skills/official/find-skills.md +23 -0
- package/dist/skills/official/official-api-design.md +17 -0
- package/dist/skills/official/official-architecture-decision.md +20 -0
- package/dist/skills/official/official-bmad.md +118 -0
- package/dist/skills/official/official-db-schema-design.md +16 -0
- package/dist/skills/official/official-debug.md +17 -0
- package/dist/skills/official/official-doc-driven.md +31 -0
- package/dist/skills/official/official-harness-engineering.md +108 -0
- package/dist/skills/official/official-performance-optimization.md +30 -0
- package/dist/skills/official/official-pr-review.md +35 -0
- package/dist/skills/official/official-release-checklist.md +30 -0
- package/dist/skills/official/official-security-hardening.md +26 -0
- package/dist/skills/official/official-spec-driven-design.md +31 -0
- package/dist/skills/official/planning-with-files.md +37 -0
- package/dist/skills/official/ui-ux-pro-max.md +18 -0
- package/dist/skills/official/webapp-testing.md +12 -0
- package/dist/skills/official-skills.d.ts +8 -4
- package/dist/skills/official-skills.d.ts.map +1 -1
- package/dist/skills/official-skills.js +48 -704
- package/dist/skills/official-skills.js.map +1 -1
- package/dist/skills/registry.d.ts +5 -0
- package/dist/skills/registry.d.ts.map +1 -1
- package/dist/skills/registry.js +48 -15
- package/dist/skills/registry.js.map +1 -1
- package/dist/skills/tools/pipeline-suggest.d.ts +30 -0
- package/dist/skills/tools/pipeline-suggest.d.ts.map +1 -0
- package/dist/skills/tools/pipeline-suggest.js +178 -0
- package/dist/skills/tools/pipeline-suggest.js.map +1 -0
- package/dist/web/analytics/anti-pattern-detector.d.ts +49 -0
- package/dist/web/analytics/anti-pattern-detector.d.ts.map +1 -0
- package/dist/web/analytics/anti-pattern-detector.js +318 -0
- package/dist/web/analytics/anti-pattern-detector.js.map +1 -0
- package/dist/web/analytics/drift-detector.d.ts +64 -0
- package/dist/web/analytics/drift-detector.d.ts.map +1 -0
- package/dist/web/analytics/drift-detector.js +198 -0
- package/dist/web/analytics/drift-detector.js.map +1 -0
- package/dist/web/analytics/weekly-report.d.ts +91 -0
- package/dist/web/analytics/weekly-report.d.ts.map +1 -0
- package/dist/web/analytics/weekly-report.js +328 -0
- package/dist/web/analytics/weekly-report.js.map +1 -0
- package/dist/web/auth-middleware.d.ts.map +1 -1
- package/dist/web/auth-middleware.js +1 -2
- package/dist/web/auth-middleware.js.map +1 -1
- package/dist/web/routes/_helpers.d.ts +16 -0
- package/dist/web/routes/_helpers.d.ts.map +1 -0
- package/dist/web/routes/_helpers.js +32 -0
- package/dist/web/routes/_helpers.js.map +1 -0
- package/dist/web/routes/ai.d.ts.map +1 -1
- package/dist/web/routes/ai.js +16 -22
- package/dist/web/routes/ai.js.map +1 -1
- package/dist/web/routes/drift.d.ts +10 -0
- package/dist/web/routes/drift.d.ts.map +1 -0
- package/dist/web/routes/drift.js +21 -0
- package/dist/web/routes/drift.js.map +1 -0
- package/dist/web/routes/error-handler.d.ts +43 -0
- package/dist/web/routes/error-handler.d.ts.map +1 -0
- package/dist/web/routes/error-handler.js +99 -0
- package/dist/web/routes/error-handler.js.map +1 -0
- package/dist/web/routes/insights.d.ts +9 -0
- package/dist/web/routes/insights.d.ts.map +1 -0
- package/dist/web/routes/insights.js +34 -0
- package/dist/web/routes/insights.js.map +1 -0
- package/dist/web/routes/patch.js +2 -2
- package/dist/web/routes/patch.js.map +1 -1
- package/dist/web/routes/reports.d.ts +10 -0
- package/dist/web/routes/reports.d.ts.map +1 -0
- package/dist/web/routes/reports.js +27 -0
- package/dist/web/routes/reports.js.map +1 -0
- package/dist/web/routes/rules.d.ts +13 -3
- package/dist/web/routes/rules.d.ts.map +1 -1
- package/dist/web/routes/rules.js +58 -97
- package/dist/web/routes/rules.js.map +1 -1
- package/dist/web/routes/sessions.d.ts +1 -2
- package/dist/web/routes/sessions.d.ts.map +1 -1
- package/dist/web/routes/sessions.js +43 -69
- package/dist/web/routes/sessions.js.map +1 -1
- package/dist/web/routes/skill-stats.d.ts +2 -0
- package/dist/web/routes/skill-stats.d.ts.map +1 -1
- package/dist/web/routes/skill-stats.js +41 -39
- package/dist/web/routes/skill-stats.js.map +1 -1
- package/dist/web/routes/skills.d.ts.map +1 -1
- package/dist/web/routes/skills.js +39 -4
- package/dist/web/routes/skills.js.map +1 -1
- package/dist/web/routes/stats.d.ts +11 -0
- package/dist/web/routes/stats.d.ts.map +1 -0
- package/dist/web/routes/stats.js +42 -0
- package/dist/web/routes/stats.js.map +1 -0
- package/dist/web/routes/status.js +1 -1
- package/dist/web/routes/status.js.map +1 -1
- package/dist/web/routes/tasks.d.ts +4 -0
- package/dist/web/routes/tasks.d.ts.map +1 -0
- package/dist/web/routes/tasks.js +156 -0
- package/dist/web/routes/tasks.js.map +1 -0
- package/dist/web/routes/trace.d.ts +10 -0
- package/dist/web/routes/trace.d.ts.map +1 -0
- package/dist/web/routes/trace.js +113 -0
- package/dist/web/routes/trace.js.map +1 -0
- package/dist/web/routes/types.d.ts +1 -14
- package/dist/web/routes/types.d.ts.map +1 -1
- package/dist/web/routes/types.js +12 -20
- package/dist/web/routes/types.js.map +1 -1
- package/dist/web/server.d.ts +1 -9
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web/server.js +28 -28
- package/dist/web/server.js.map +1 -1
- package/dist/web/static/assets/AIConfig-CdDWzJyO.js +2 -0
- package/dist/web/static/assets/AIConfig-CdDWzJyO.js.map +1 -0
- package/dist/web/static/assets/Dashboard-CoEmmIDt.js +2 -0
- package/dist/web/static/assets/Dashboard-CoEmmIDt.js.map +1 -0
- package/dist/web/static/assets/{Drawer-DcU3ln98.js → Drawer-DdRTzlLB.js} +2 -2
- package/dist/web/static/assets/{Drawer-DcU3ln98.js.map → Drawer-DdRTzlLB.js.map} +1 -1
- package/dist/web/static/assets/Events-DrIq1SUS.js +2 -0
- package/dist/web/static/assets/Events-DrIq1SUS.js.map +1 -0
- package/dist/web/static/assets/Reports-DFBM3MDK.js +2 -0
- package/dist/web/static/assets/Reports-DFBM3MDK.js.map +1 -0
- package/dist/web/static/assets/SearchInput-qCj_jAcf.js +2 -0
- package/dist/web/static/assets/SearchInput-qCj_jAcf.js.map +1 -0
- package/dist/web/static/assets/SessionDetail-CCzwdoT7.js +2 -0
- package/dist/web/static/assets/SessionDetail-CCzwdoT7.js.map +1 -0
- package/dist/web/static/assets/Sessions-FfLYkAw9.js +2 -0
- package/dist/web/static/assets/Sessions-FfLYkAw9.js.map +1 -0
- package/dist/web/static/assets/Skills-C8Gvs3Qa.js +2 -0
- package/dist/web/static/assets/Skills-C8Gvs3Qa.js.map +1 -0
- package/dist/web/static/assets/TaskDetail-BS8pYhaR.js +2 -0
- package/dist/web/static/assets/TaskDetail-BS8pYhaR.js.map +1 -0
- package/dist/web/static/assets/Tasks-CyuhizG8.js +2 -0
- package/dist/web/static/assets/Tasks-CyuhizG8.js.map +1 -0
- package/dist/web/static/assets/export-L_VBD2p1.js +4 -0
- package/dist/web/static/assets/export-L_VBD2p1.js.map +1 -0
- package/dist/web/static/assets/index-CBX47X8l.js +3 -0
- package/dist/web/static/assets/index-CBX47X8l.js.map +1 -0
- package/dist/web/static/assets/index-DjIoMdoR.css +1 -0
- package/dist/web/static/assets/{lucide-53bR2rki.js → lucide-Bs_edTLa.js} +73 -38
- package/dist/web/static/assets/lucide-Bs_edTLa.js.map +1 -0
- package/dist/web/static/assets/react-router-r79dBVy4.js +20 -0
- package/dist/web/static/assets/{react-router-I-HqunH7.js.map → react-router-r79dBVy4.js.map} +1 -1
- package/dist/web/static/assets/task-title-BhOcemuR.js +2 -0
- package/dist/web/static/assets/task-title-BhOcemuR.js.map +1 -0
- package/dist/web/static/assets/time-Bxuk0M-C.js +2 -0
- package/dist/web/static/assets/time-Bxuk0M-C.js.map +1 -0
- package/dist/web/static/index.html +4 -4
- package/docs/concurrent-agents.md +129 -0
- package/docs/design/architecture-review-20260516.md +232 -0
- package/docs/design/fix-skills-data-and-set-leak-spec-20260516-1300.md +219 -0
- package/docs/design/h1-storage-aggregation-spec-20260518-1121.md +299 -0
- package/docs/design/h2-getdatabase-encapsulation-spec-20260518-1450.md +191 -0
- package/docs/design/h3-fallback-removal-spec-20260518-1245.md +76 -0
- package/docs/design/h4-index-dedup-spec-20260518-1230.md +109 -0
- package/docs/design/h6-services-migration-spec-20260518-1355.md +82 -0
- package/docs/design/hook-failure-queue-spec-20260516-1530.md +204 -0
- package/docs/design/l1-swarm-protocol-extract-spec-20260518-1605.md +106 -0
- package/docs/design/m10-forge-paths-spec-20260518-1320.md +121 -0
- package/docs/design/m2-m3-tool-input-spec-20260518-1425.md +131 -0
- package/docs/design/m7-routing-event-association-spec-20260518-1545.md +103 -0
- package/docs/design/project-path-gitroot-spec-20260518-1715.md +134 -0
- package/docs/design/refactor-phase1-spec-20260515-1600.md +543 -0
- package/docs/design/refactor-phase2-spec-20260515-1700.md +424 -0
- package/docs/design/task-active-gc-spec-20260518-1745.md +146 -0
- package/docs/design/tasks-list-filter-pagination-spec-20260518-0930.md +208 -0
- package/docs/implementation/fix-skills-data-and-set-leak-changelog-20260516-1300.md +104 -0
- package/docs/implementation/h1-storage-aggregation-changelog-20260518-1121.md +82 -0
- package/docs/implementation/h2-final-changelog-20260518-1530.md +61 -0
- package/docs/implementation/h2-phase1-safety-net-changelog-20260518-1450.md +70 -0
- package/docs/implementation/h2-phase2-operations-changelog-20260518-1450.md +120 -0
- package/docs/implementation/h2-phase3-callsites-changelog-20260518-1450.md +71 -0
- package/docs/implementation/h3-fallback-removal-changelog-20260518-1245.md +71 -0
- package/docs/implementation/h4-index-dedup-changelog-20260518-1230.md +60 -0
- package/docs/implementation/h6-services-migration-changelog-20260518-1355.md +46 -0
- package/docs/implementation/h7-m9-defaults-changelog-20260518-1300.md +46 -0
- package/docs/implementation/hook-failure-queue-changelog-20260516-1530.md +196 -0
- package/docs/implementation/hotfix-daemon-event-reject-20260516-1430.md +56 -0
- package/docs/implementation/l1-swarm-protocol-extract-changelog-20260518-1605.md +45 -0
- package/docs/implementation/l3-l4-daemon-perf-changelog-20260518-1410.md +63 -0
- package/docs/implementation/l6-l8-final-cleanup-changelog-20260518-1640.md +38 -0
- package/docs/implementation/m1-m4-m5-l7-cleanup-changelog-20260518-1310.md +58 -0
- package/docs/implementation/m10-forge-paths-changelog-20260518-1320.md +60 -0
- package/docs/implementation/m2-m3-tool-input-changelog-20260518-1425.md +43 -0
- package/docs/implementation/m6-m8-naming-shutdown-changelog-20260518-1340.md +56 -0
- package/docs/implementation/m7-routing-association-changelog-20260518-1545.md +69 -0
- package/docs/implementation/project-path-gitroot-changelog-20260518-1715.md +63 -0
- package/docs/implementation/refactor-phase1-changelog-20260515-1630.md +354 -0
- package/docs/implementation/refactor-phase2-changelog-20260515-1705.md +421 -0
- package/docs/implementation/task-active-gc-changelog-20260518-1745.md +35 -0
- package/docs/implementation/task-title-summary-changelog-20260518-1130.md +39 -0
- package/docs/implementation/tasks-detail-back-loses-filters-changelog-20260518-1100.md +22 -0
- package/docs/implementation/tasks-list-filter-pagination-changelog-20260518-0930.md +72 -0
- package/docs/implementation/tasks-page-white-screen-hotfix-changelog-20260518-1015.md +56 -0
- package/docs/reviews/claudemd-template-sync.md +54 -0
- package/docs/reviews/task-title-summary.md +92 -0
- package/docs/reviews/tasks-detail-back-loses-filters.md +58 -0
- package/docs/reviews/tasks-filter-pagination.md +80 -0
- package/docs/reviews/tasks-page-white-screen-hotfix.md +126 -0
- package/docs/ruflo-learning-strategy.md +322 -0
- package/docs/skills-deduplication-analysis.md +83 -0
- package/docs/skills-multiformat-support.md +177 -0
- package/docs/skills-third-party.md +183 -0
- package/docs/testing/tasks-filter-pagination-test-report.md +86 -0
- package/forge +321 -0
- package/package.json +28 -62
- package/playwright.config.ts +40 -0
- package/scripts/demo-v2.ts +91 -0
- package/scripts/dev-daemon.sh +232 -0
- package/scripts/dev-web.ts +109 -0
- package/scripts/e2e-mcp-link.ts +423 -0
- package/scripts/e2e-methodology-quality.ts +253 -0
- package/scripts/e2e-routing.ts +456 -0
- package/scripts/e2e-user-methodology.ts +326 -0
- package/scripts/e2e-web-workflows.ts +299 -0
- package/scripts/migrate-legacy-to-dynamic.sql +108 -0
- package/scripts/regenerate-execution-docs.ts +116 -0
- package/scripts/sync-agent-skills.ts +193 -0
- package/scripts/test-hook.sh +71 -0
- package/scripts/verify-skill-loading.ts +62 -0
- package/src/claudemd/claudemd-generator.ts +568 -0
- package/src/claudemd/convention-extractor.ts +69 -0
- package/src/claudemd/index.ts +35 -0
- package/src/claudemd/persona-manager.ts +88 -0
- package/src/claudemd/resume-manager.ts +236 -0
- package/src/claudemd/tech-detector.ts +220 -0
- package/src/claudemd/templates/swarm-protocol.md +222 -0
- package/src/cli/commands/claudemd.ts +84 -0
- package/src/cli/commands/config.ts +46 -0
- package/src/cli/commands/daemon.ts +310 -0
- package/src/cli/commands/executions.ts +115 -0
- package/src/cli/commands/init.ts +204 -0
- package/src/cli/commands/logs.ts +181 -0
- package/src/cli/commands/mcp.ts +242 -0
- package/src/cli/commands/menu.ts +357 -0
- package/src/cli/commands/skills.ts +185 -0
- package/src/cli/commands/stats.ts +73 -0
- package/src/cli/commands/status.ts +69 -0
- package/src/cli/commands/template.ts +77 -0
- package/src/cli/commands/trace.ts +148 -0
- package/src/cli/index.ts +42 -0
- package/src/cli/init/hook-manager.ts +132 -0
- package/src/core/ai/provider.ts +308 -0
- package/src/core/ai/types.ts +51 -0
- package/src/core/config.ts +124 -0
- package/src/core/constants.ts +62 -0
- package/src/core/event-fields.ts +32 -0
- package/src/core/queue/index.ts +192 -0
- package/src/core/storage/base.ts +302 -0
- package/src/core/storage/events.ts +434 -0
- package/src/core/storage/injections.ts +78 -0
- package/src/core/storage/maintenance.ts +59 -0
- package/src/core/storage/migrations/002_add_skill_tracking.sql +6 -0
- package/src/core/storage/migrations/003_add_skill_invocations.sql +23 -0
- package/src/core/storage/performance-indexes.sql +23 -0
- package/src/core/storage/routing.ts +322 -0
- package/src/core/storage/rows.ts +112 -0
- package/src/core/storage/schema.sql +224 -0
- package/src/core/storage/sessions.ts +168 -0
- package/src/core/storage/skills.ts +233 -0
- package/src/core/storage/sqlite.ts +293 -0
- package/src/core/storage/tasks.ts +318 -0
- package/src/core/storage/token-usage.ts +93 -0
- package/src/core/types.ts +181 -0
- package/src/core/utils/error-handler.ts +257 -0
- package/src/core/utils/forge-resume-block.ts +74 -0
- package/src/core/utils/format.ts +69 -0
- package/src/core/utils/git.ts +23 -0
- package/src/core/utils/logger.ts +134 -0
- package/src/core/utils/lru-cache.ts +54 -0
- package/src/core/utils/path.ts +19 -0
- package/src/core/utils/session.ts +26 -0
- package/src/core/utils/time.ts +37 -0
- package/src/core/utils/token-tracker.ts +97 -0
- package/src/daemon/event-parser.ts +36 -0
- package/src/daemon/handlers/history-exporter.ts +117 -0
- package/src/daemon/handlers/post-tool-use.ts +54 -0
- package/src/daemon/handlers/stop.ts +208 -0
- package/src/daemon/handlers/user-prompt.ts +178 -0
- package/src/daemon/index.ts +292 -0
- package/src/daemon/launchd/com.claude-forge.daemon.plist.template +47 -0
- package/src/daemon/launchd-installer.ts +260 -0
- package/src/daemon/lifecycle.ts +128 -0
- package/src/daemon/router.ts +40 -0
- package/src/daemon/server.ts +196 -0
- package/src/daemon/services/task-segmenter.ts +112 -0
- package/src/hooks/hook-lib.sh +118 -0
- package/src/hooks/notification.sh +35 -0
- package/src/hooks/post-tool-use.sh +61 -0
- package/src/hooks/pre-tool-use.sh +63 -0
- package/src/hooks/stop.sh +43 -0
- package/src/hooks/user-prompt-submit.sh +69 -0
- package/src/mcp/server.ts +322 -0
- package/src/skills/index.ts +2 -0
- package/src/skills/invocation-guard.ts +177 -0
- package/src/skills/matcher.ts +148 -0
- package/src/skills/official/code-simplifier.md +16 -0
- package/src/skills/official/find-skills.md +23 -0
- package/src/skills/official/official-api-design.md +17 -0
- package/src/skills/official/official-architecture-decision.md +20 -0
- package/src/skills/official/official-bmad.md +118 -0
- package/src/skills/official/official-db-schema-design.md +16 -0
- package/src/skills/official/official-debug.md +17 -0
- package/src/skills/official/official-doc-driven.md +31 -0
- package/src/skills/official/official-harness-engineering.md +108 -0
- package/src/skills/official/official-performance-optimization.md +30 -0
- package/src/skills/official/official-pr-review.md +35 -0
- package/src/skills/official/official-release-checklist.md +30 -0
- package/src/skills/official/official-security-hardening.md +26 -0
- package/src/skills/official/official-spec-driven-design.md +31 -0
- package/src/skills/official/planning-with-files.md +37 -0
- package/src/skills/official/ui-ux-pro-max.md +18 -0
- package/src/skills/official/webapp-testing.md +12 -0
- package/src/skills/official-skills.ts +89 -0
- package/src/skills/registry.ts +355 -0
- package/src/skills/semantic-matcher.ts +231 -0
- package/src/skills/tools/pipeline-suggest.ts +226 -0
- package/src/skills/tools/skill-invoke.ts +168 -0
- package/src/skills/tools/skill-list.ts +59 -0
- package/src/templates/go.yaml +53 -0
- package/src/templates/python.yaml +59 -0
- package/src/templates/react.yaml +55 -0
- package/src/templates/template-manager.ts +170 -0
- package/src/web/analytics/anti-pattern-detector.ts +367 -0
- package/src/web/analytics/drift-detector.ts +219 -0
- package/src/web/analytics/weekly-report.ts +431 -0
- package/src/web/auth-middleware.ts +54 -0
- package/src/web/routes/_helpers.ts +34 -0
- package/src/web/routes/ai.ts +204 -0
- package/src/web/routes/auth.ts +22 -0
- package/src/web/routes/drift.ts +25 -0
- package/src/web/routes/error-handler.ts +120 -0
- package/src/web/routes/events.ts +47 -0
- package/src/web/routes/insights.ts +43 -0
- package/src/web/routes/patch.ts +117 -0
- package/src/web/routes/reports.ts +34 -0
- package/src/web/routes/rules.ts +76 -0
- package/src/web/routes/sessions.ts +250 -0
- package/src/web/routes/skill-stats.ts +92 -0
- package/src/web/routes/skills.ts +350 -0
- package/src/web/routes/static.ts +67 -0
- package/src/web/routes/stats.ts +50 -0
- package/src/web/routes/status.ts +30 -0
- package/src/web/routes/tasks.ts +193 -0
- package/src/web/routes/token-usage.ts +20 -0
- package/src/web/routes/trace.ts +126 -0
- package/src/web/routes/types.ts +57 -0
- package/src/web/server.ts +134 -0
- package/src/web/ssrf-guard.ts +112 -0
- package/src/web/static/index.html +3251 -0
- package/src/web/static/vendor/chart.umd.min.js +20 -0
- package/tests/e2e/dashboard.spec.ts +205 -0
- package/tests/e2e/routing-skill-e2e.test.ts +39 -0
- package/tests/helpers/mock-ai.ts +92 -0
- package/tests/helpers/mock-storage.ts +159 -0
- package/tests/integration/claudemd-generator.test.ts +90 -0
- package/tests/integration/queue-replay.integration.test.ts +193 -0
- package/tests/integration/tasks-filter.integration.test.ts +154 -0
- package/tests/integration/web-analytics.integration.test.ts +133 -0
- package/tests/integration/web-stats.integration.test.ts +135 -0
- package/tests/integration/web-trace.integration.test.ts +175 -0
- package/tests/performance/database.benchmark.ts +161 -0
- package/tests/semantic-matcher.test.ts +99 -0
- package/tests/skill-matcher.test.ts +110 -0
- package/tests/unit/ai-provider-retry.test.ts +194 -0
- package/tests/unit/ai-provider-vision.test.ts +224 -0
- package/tests/unit/claudemd-generator.test.ts +68 -0
- package/tests/unit/cli-mcp.test.ts +141 -0
- package/tests/unit/core/forge-paths.test.ts +99 -0
- package/tests/unit/daemon/post-tool-use.test.ts +121 -0
- package/tests/unit/daemon/stop-handler-behavior-summary.test.ts +202 -0
- package/tests/unit/daemon/task-segmenter-recover.test.ts +84 -0
- package/tests/unit/event-fields.test.ts +88 -0
- package/tests/unit/event-parser.test.ts +55 -0
- package/tests/unit/handlers.test.ts +171 -0
- package/tests/unit/hooks/resolve-project-path.test.ts +122 -0
- package/tests/unit/invocation-guard.test.ts +125 -0
- package/tests/unit/queue.test.ts +272 -0
- package/tests/unit/router.test.ts +138 -0
- package/tests/unit/security.test.ts +128 -0
- package/tests/unit/skill-invocations-workflow.test.ts +495 -0
- package/tests/unit/skill-registry.test.ts +94 -0
- package/tests/unit/skills/invocation-guard-ttl.test.ts +211 -0
- package/tests/unit/skills/official-skills-loader.test.ts +126 -0
- package/tests/unit/skills/registry-multiformat.test.ts +92 -0
- package/tests/unit/socket-server.test.ts +183 -0
- package/tests/unit/storage/event-operations-aggregates.test.ts +342 -0
- package/tests/unit/storage/migration-idempotent.test.ts +304 -0
- package/tests/unit/storage/routing-aggregates.test.ts +276 -0
- package/tests/unit/storage/routing.test.ts +117 -0
- package/tests/unit/storage/schema-missing.test.ts +81 -0
- package/tests/unit/storage/session-operations-aggregates.test.ts +120 -0
- package/tests/unit/storage/sessions-aggregate.test.ts +435 -0
- package/tests/unit/storage/skill-operations-counts.test.ts +106 -0
- package/tests/unit/storage/skills-aggregates.test.ts +104 -0
- package/tests/unit/storage/sqlite-refactor-harness.test.ts +314 -0
- package/tests/unit/storage/task-operations-counts.test.ts +46 -0
- package/tests/unit/storage/tasks-getById.test.ts +343 -0
- package/tests/unit/storage/tasks-stale-gc.test.ts +86 -0
- package/tests/unit/storage.test.ts +172 -0
- package/tests/unit/token-usage.test.ts +144 -0
- package/tests/unit/type-guards.test.ts +201 -0
- package/tests/unit/utils/format.test.ts +189 -0
- package/tests/unit/utils/session.test.ts +89 -0
- package/tests/unit/utils/time.test.ts +112 -0
- package/tests/unit/web/navigation-back-contract.test.ts +134 -0
- package/tests/unit/web/routes-auth.test.ts +93 -0
- package/tests/unit/web/routes-events.test.ts +101 -0
- package/tests/unit/web/routes-rules.test.ts +182 -0
- package/tests/unit/web/routes-sessions.test.ts +181 -0
- package/tests/unit/web/routes-skill-stats.test.ts +179 -0
- package/tests/unit/web/routes-stats.test.ts +92 -0
- package/tests/unit/web/routes-tasks.test.ts +385 -0
- package/tests/unit/web/task-title-contract.test.ts +210 -0
- package/tests/unit/web/tasks-component-contract.test.ts +179 -0
- package/tsconfig.json +22 -0
- package/vitest.config.ts +21 -0
- package/vitest.integration.config.ts +16 -0
- package/web/CLAUDE.md +20 -0
- package/web/index.html +13 -0
- package/web/package-lock.json +4854 -0
- package/web/package.json +35 -0
- package/web/postcss.config.js +6 -0
- package/web/src/App.tsx +110 -0
- package/web/src/components/CodeBlock.tsx +31 -0
- package/web/src/components/Confirm.tsx +96 -0
- package/web/src/components/Drawer.tsx +60 -0
- package/web/src/components/Layout.tsx +145 -0
- package/web/src/components/MarkdownRenderer.tsx +77 -0
- package/web/src/components/SearchInput.tsx +31 -0
- package/web/src/components/SessionDetailContent.tsx +157 -0
- package/web/src/components/Toast.tsx +92 -0
- package/web/src/index.css +19 -0
- package/web/src/main.tsx +31 -0
- package/web/src/pages/AIConfig.tsx +233 -0
- package/web/src/pages/Dashboard.tsx +572 -0
- package/web/src/pages/Events.tsx +271 -0
- package/web/src/pages/Reports.tsx +428 -0
- package/web/src/pages/SessionDetail.tsx +162 -0
- package/web/src/pages/Sessions.tsx +205 -0
- package/web/src/pages/Skills.tsx +180 -0
- package/web/src/pages/TaskDetail.tsx +515 -0
- package/web/src/pages/Tasks.tsx +415 -0
- package/web/src/utils/auth.ts +59 -0
- package/web/src/utils/export.ts +54 -0
- package/web/src/utils/navigation.ts +25 -0
- package/web/src/utils/task-title.ts +49 -0
- package/web/src/utils/time.ts +13 -0
- package/web/tailwind.config.js +11 -0
- package/web/tsconfig.json +21 -0
- package/web/tsconfig.node.json +10 -0
- package/web/vite.config.ts +76 -0
- package/winspan-claude-forge-8.43.0.tgz +0 -0
- package/dist/agents/definition.d.ts +0 -62
- package/dist/agents/definition.d.ts.map +0 -1
- package/dist/agents/definition.js +0 -27
- package/dist/agents/definition.js.map +0 -1
- package/dist/agents/distributor.d.ts +0 -23
- package/dist/agents/distributor.d.ts.map +0 -1
- package/dist/agents/distributor.js +0 -85
- package/dist/agents/distributor.js.map +0 -1
- package/dist/agents/index.d.ts +0 -5
- package/dist/agents/index.d.ts.map +0 -1
- package/dist/agents/index.js +0 -5
- package/dist/agents/index.js.map +0 -1
- package/dist/agents/methodologies/agent-builder.d.ts +0 -21
- package/dist/agents/methodologies/agent-builder.d.ts.map +0 -1
- package/dist/agents/methodologies/agent-builder.js +0 -149
- package/dist/agents/methodologies/agent-builder.js.map +0 -1
- package/dist/agents/methodologies/phases/bmad/analyze.d.ts +0 -3
- package/dist/agents/methodologies/phases/bmad/analyze.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/bmad/analyze.js +0 -19
- package/dist/agents/methodologies/phases/bmad/analyze.js.map +0 -1
- package/dist/agents/methodologies/phases/bmad/design.d.ts +0 -3
- package/dist/agents/methodologies/phases/bmad/design.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/bmad/design.js +0 -18
- package/dist/agents/methodologies/phases/bmad/design.js.map +0 -1
- package/dist/agents/methodologies/phases/bmad/implement.d.ts +0 -3
- package/dist/agents/methodologies/phases/bmad/implement.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/bmad/implement.js +0 -17
- package/dist/agents/methodologies/phases/bmad/implement.js.map +0 -1
- package/dist/agents/methodologies/phases/bmad/index.d.ts +0 -6
- package/dist/agents/methodologies/phases/bmad/index.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/bmad/index.js +0 -6
- package/dist/agents/methodologies/phases/bmad/index.js.map +0 -1
- package/dist/agents/methodologies/phases/bmad/review.d.ts +0 -3
- package/dist/agents/methodologies/phases/bmad/review.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/bmad/review.js +0 -17
- package/dist/agents/methodologies/phases/bmad/review.js.map +0 -1
- package/dist/agents/methodologies/phases/bmad/test.d.ts +0 -3
- package/dist/agents/methodologies/phases/bmad/test.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/bmad/test.js +0 -21
- package/dist/agents/methodologies/phases/bmad/test.js.map +0 -1
- package/dist/agents/methodologies/phases/harness/fix.d.ts +0 -3
- package/dist/agents/methodologies/phases/harness/fix.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/harness/fix.js +0 -17
- package/dist/agents/methodologies/phases/harness/fix.js.map +0 -1
- package/dist/agents/methodologies/phases/harness/index.d.ts +0 -6
- package/dist/agents/methodologies/phases/harness/index.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/harness/index.js +0 -6
- package/dist/agents/methodologies/phases/harness/index.js.map +0 -1
- package/dist/agents/methodologies/phases/harness/reproduce.d.ts +0 -3
- package/dist/agents/methodologies/phases/harness/reproduce.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/harness/reproduce.js +0 -20
- package/dist/agents/methodologies/phases/harness/reproduce.js.map +0 -1
- package/dist/agents/methodologies/phases/harness/root-cause.d.ts +0 -3
- package/dist/agents/methodologies/phases/harness/root-cause.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/harness/root-cause.js +0 -21
- package/dist/agents/methodologies/phases/harness/root-cause.js.map +0 -1
- package/dist/agents/methodologies/phases/harness/safety-net.d.ts +0 -3
- package/dist/agents/methodologies/phases/harness/safety-net.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/harness/safety-net.js +0 -17
- package/dist/agents/methodologies/phases/harness/safety-net.js.map +0 -1
- package/dist/agents/methodologies/phases/harness/verify.d.ts +0 -3
- package/dist/agents/methodologies/phases/harness/verify.d.ts.map +0 -1
- package/dist/agents/methodologies/phases/harness/verify.js +0 -22
- package/dist/agents/methodologies/phases/harness/verify.js.map +0 -1
- package/dist/agents/methodologies/presets.d.ts +0 -10
- package/dist/agents/methodologies/presets.d.ts.map +0 -1
- package/dist/agents/methodologies/presets.js +0 -79
- package/dist/agents/methodologies/presets.js.map +0 -1
- package/dist/agents/methodologies/types.d.ts +0 -45
- package/dist/agents/methodologies/types.d.ts.map +0 -1
- package/dist/agents/methodologies/types.js +0 -10
- package/dist/agents/methodologies/types.js.map +0 -1
- package/dist/agents/methodologies/user-config-loader.d.ts +0 -30
- package/dist/agents/methodologies/user-config-loader.d.ts.map +0 -1
- package/dist/agents/methodologies/user-config-loader.js +0 -159
- package/dist/agents/methodologies/user-config-loader.js.map +0 -1
- package/dist/agents/official-agents.d.ts +0 -4
- package/dist/agents/official-agents.d.ts.map +0 -1
- package/dist/agents/official-agents.js +0 -559
- package/dist/agents/official-agents.js.map +0 -1
- package/dist/agents/registry.d.ts +0 -57
- package/dist/agents/registry.d.ts.map +0 -1
- package/dist/agents/registry.js +0 -271
- package/dist/agents/registry.js.map +0 -1
- package/dist/capability/index.d.ts +0 -10
- package/dist/capability/index.d.ts.map +0 -1
- package/dist/capability/index.js +0 -10
- package/dist/capability/index.js.map +0 -1
- package/dist/capability/types.d.ts +0 -10
- package/dist/capability/types.d.ts.map +0 -1
- package/dist/capability/types.js +0 -10
- package/dist/capability/types.js.map +0 -1
- package/dist/cli/commands/agents.d.ts +0 -3
- package/dist/cli/commands/agents.d.ts.map +0 -1
- package/dist/cli/commands/agents.js +0 -62
- package/dist/cli/commands/agents.js.map +0 -1
- package/dist/cli/commands/rules.d.ts +0 -8
- package/dist/cli/commands/rules.d.ts.map +0 -1
- package/dist/cli/commands/rules.js +0 -89
- package/dist/cli/commands/rules.js.map +0 -1
- package/dist/daemon/auto-disable-scheduler.d.ts +0 -53
- package/dist/daemon/auto-disable-scheduler.d.ts.map +0 -1
- package/dist/daemon/auto-disable-scheduler.js +0 -114
- package/dist/daemon/auto-disable-scheduler.js.map +0 -1
- package/dist/daemon/handlers/pre-tool-use.d.ts +0 -39
- package/dist/daemon/handlers/pre-tool-use.d.ts.map +0 -1
- package/dist/daemon/handlers/pre-tool-use.js +0 -166
- package/dist/daemon/handlers/pre-tool-use.js.map +0 -1
- package/dist/daemon/routing-observer.d.ts +0 -42
- package/dist/daemon/routing-observer.d.ts.map +0 -1
- package/dist/daemon/routing-observer.js +0 -264
- package/dist/daemon/routing-observer.js.map +0 -1
- package/dist/daemon/routing-state.d.ts +0 -64
- package/dist/daemon/routing-state.d.ts.map +0 -1
- package/dist/daemon/routing-state.js +0 -240
- package/dist/daemon/routing-state.js.map +0 -1
- package/dist/engine/agent-router.d.ts +0 -142
- package/dist/engine/agent-router.d.ts.map +0 -1
- package/dist/engine/agent-router.js +0 -276
- package/dist/engine/agent-router.js.map +0 -1
- package/dist/engine/context-builder.d.ts +0 -23
- package/dist/engine/context-builder.d.ts.map +0 -1
- package/dist/engine/context-builder.js +0 -63
- package/dist/engine/context-builder.js.map +0 -1
- package/dist/engine/conventions/basic-security.yaml +0 -109
- package/dist/engine/conventions/code-quality.yaml +0 -123
- package/dist/engine/conventions/database-safety.yaml +0 -74
- package/dist/engine/conventions/dependency-safety.yaml +0 -132
- package/dist/engine/conventions/docker-safety.yaml +0 -69
- package/dist/engine/conventions/git-safety.yaml +0 -118
- package/dist/engine/conventions/go-best-practices.yaml +0 -84
- package/dist/engine/conventions/python-best-practices.yaml +0 -96
- package/dist/engine/conventions/react-best-practices.yaml +0 -96
- package/dist/engine/conventions/routing.yaml +0 -378
- package/dist/engine/conventions/strict-security.yaml +0 -30
- package/dist/engine/conventions/ts-quality.yaml +0 -49
- package/dist/engine/dsl/compiler.d.ts +0 -34
- package/dist/engine/dsl/compiler.d.ts.map +0 -1
- package/dist/engine/dsl/compiler.js +0 -702
- package/dist/engine/dsl/compiler.js.map +0 -1
- package/dist/engine/dsl/parser.d.ts +0 -25
- package/dist/engine/dsl/parser.d.ts.map +0 -1
- package/dist/engine/dsl/parser.js +0 -208
- package/dist/engine/dsl/parser.js.map +0 -1
- package/dist/engine/dsl/runtime.d.ts +0 -46
- package/dist/engine/dsl/runtime.d.ts.map +0 -1
- package/dist/engine/dsl/runtime.js +0 -173
- package/dist/engine/dsl/runtime.js.map +0 -1
- package/dist/engine/dsl/types.d.ts +0 -139
- package/dist/engine/dsl/types.d.ts.map +0 -1
- package/dist/engine/dsl/types.js +0 -11
- package/dist/engine/dsl/types.js.map +0 -1
- package/dist/engine/evidence-store.d.ts +0 -44
- package/dist/engine/evidence-store.d.ts.map +0 -1
- package/dist/engine/evidence-store.js +0 -109
- package/dist/engine/evidence-store.js.map +0 -1
- package/dist/engine/experiment-router.d.ts +0 -102
- package/dist/engine/experiment-router.d.ts.map +0 -1
- package/dist/engine/experiment-router.js +0 -289
- package/dist/engine/experiment-router.js.map +0 -1
- package/dist/engine/recommender.d.ts +0 -52
- package/dist/engine/recommender.d.ts.map +0 -1
- package/dist/engine/recommender.js +0 -162
- package/dist/engine/recommender.js.map +0 -1
- package/dist/engine/rule-engine.d.ts +0 -33
- package/dist/engine/rule-engine.d.ts.map +0 -1
- package/dist/engine/rule-engine.js +0 -250
- package/dist/engine/rule-engine.js.map +0 -1
- package/dist/engine/security-gates.d.ts +0 -42
- package/dist/engine/security-gates.d.ts.map +0 -1
- package/dist/engine/security-gates.js +0 -210
- package/dist/engine/security-gates.js.map +0 -1
- package/dist/intelligence/classifier.d.ts +0 -75
- package/dist/intelligence/classifier.d.ts.map +0 -1
- package/dist/intelligence/classifier.js +0 -352
- package/dist/intelligence/classifier.js.map +0 -1
- package/dist/intelligence/context-gatherer.d.ts +0 -101
- package/dist/intelligence/context-gatherer.d.ts.map +0 -1
- package/dist/intelligence/context-gatherer.js +0 -417
- package/dist/intelligence/context-gatherer.js.map +0 -1
- package/dist/intelligence/cot-classifier.d.ts +0 -95
- package/dist/intelligence/cot-classifier.d.ts.map +0 -1
- package/dist/intelligence/cot-classifier.js +0 -391
- package/dist/intelligence/cot-classifier.js.map +0 -1
- package/dist/intelligence/distiller.d.ts +0 -22
- package/dist/intelligence/distiller.d.ts.map +0 -1
- package/dist/intelligence/distiller.js +0 -108
- package/dist/intelligence/distiller.js.map +0 -1
- package/dist/intelligence/execution-doc-builder.d.ts +0 -151
- package/dist/intelligence/execution-doc-builder.d.ts.map +0 -1
- package/dist/intelligence/execution-doc-builder.js +0 -1018
- package/dist/intelligence/execution-doc-builder.js.map +0 -1
- package/dist/intelligence/intent-types.d.ts +0 -13
- package/dist/intelligence/intent-types.d.ts.map +0 -1
- package/dist/intelligence/intent-types.js +0 -19
- package/dist/intelligence/intent-types.js.map +0 -1
- package/dist/intelligence/multimodal-parser.d.ts +0 -105
- package/dist/intelligence/multimodal-parser.d.ts.map +0 -1
- package/dist/intelligence/multimodal-parser.js +0 -425
- package/dist/intelligence/multimodal-parser.js.map +0 -1
- package/dist/intelligence/quality-gate.d.ts +0 -45
- package/dist/intelligence/quality-gate.d.ts.map +0 -1
- package/dist/intelligence/quality-gate.js +0 -193
- package/dist/intelligence/quality-gate.js.map +0 -1
- package/dist/intelligence/task-segmenter.d.ts.map +0 -1
- package/dist/intelligence/task-segmenter.js.map +0 -1
- package/dist/web/routes/agents.d.ts +0 -7
- package/dist/web/routes/agents.d.ts.map +0 -1
- package/dist/web/routes/agents.js +0 -209
- package/dist/web/routes/agents.js.map +0 -1
- package/dist/web/routes/execution-trace.d.ts +0 -21
- package/dist/web/routes/execution-trace.d.ts.map +0 -1
- package/dist/web/routes/execution-trace.js +0 -353
- package/dist/web/routes/execution-trace.js.map +0 -1
- package/dist/web/routes/experiments.d.ts +0 -15
- package/dist/web/routes/experiments.d.ts.map +0 -1
- package/dist/web/routes/experiments.js +0 -187
- package/dist/web/routes/experiments.js.map +0 -1
- package/dist/web/routes/routing.d.ts +0 -17
- package/dist/web/routes/routing.d.ts.map +0 -1
- package/dist/web/routes/routing.js +0 -592
- package/dist/web/routes/routing.js.map +0 -1
- package/dist/web/routes/workflows.d.ts +0 -19
- package/dist/web/routes/workflows.d.ts.map +0 -1
- package/dist/web/routes/workflows.js +0 -86
- package/dist/web/routes/workflows.js.map +0 -1
- package/dist/web/static/assets/AIConfig-R5wZ3ZKT.js +0 -2
- package/dist/web/static/assets/AIConfig-R5wZ3ZKT.js.map +0 -1
- package/dist/web/static/assets/Agents-Beg34V1g.js +0 -2
- package/dist/web/static/assets/Agents-Beg34V1g.js.map +0 -1
- package/dist/web/static/assets/CodeBlock--H53gk46.js +0 -2
- package/dist/web/static/assets/CodeBlock--H53gk46.js.map +0 -1
- package/dist/web/static/assets/Dashboard-Cy1xsj1J.js +0 -2
- package/dist/web/static/assets/Dashboard-Cy1xsj1J.js.map +0 -1
- package/dist/web/static/assets/Events-mFhXl4zI.js +0 -2
- package/dist/web/static/assets/Events-mFhXl4zI.js.map +0 -1
- package/dist/web/static/assets/ExecutionTrace-DG901hLR.js +0 -3
- package/dist/web/static/assets/ExecutionTrace-DG901hLR.js.map +0 -1
- package/dist/web/static/assets/MarkdownRenderer-CCIz1MOz.js +0 -2
- package/dist/web/static/assets/MarkdownRenderer-CCIz1MOz.js.map +0 -1
- package/dist/web/static/assets/Routing-B7BFLfjh.js +0 -2
- package/dist/web/static/assets/Routing-B7BFLfjh.js.map +0 -1
- package/dist/web/static/assets/SessionDetail-BT0l4RrK.js +0 -2
- package/dist/web/static/assets/SessionDetail-BT0l4RrK.js.map +0 -1
- package/dist/web/static/assets/Sessions-C6J_HQ_u.js +0 -2
- package/dist/web/static/assets/Sessions-C6J_HQ_u.js.map +0 -1
- package/dist/web/static/assets/Skills-4DQWLaTv.js +0 -2
- package/dist/web/static/assets/Skills-4DQWLaTv.js.map +0 -1
- package/dist/web/static/assets/WorkflowDetail-zhNqUkBE.js +0 -2
- package/dist/web/static/assets/WorkflowDetail-zhNqUkBE.js.map +0 -1
- package/dist/web/static/assets/Workflows-Btvi-lGw.js +0 -2
- package/dist/web/static/assets/Workflows-Btvi-lGw.js.map +0 -1
- package/dist/web/static/assets/export-BQQZLaHV.js +0 -4
- package/dist/web/static/assets/export-BQQZLaHV.js.map +0 -1
- package/dist/web/static/assets/index-Cgr9qMtq.js +0 -3
- package/dist/web/static/assets/index-Cgr9qMtq.js.map +0 -1
- package/dist/web/static/assets/index-CngWb5gC.css +0 -1
- package/dist/web/static/assets/lucide-53bR2rki.js.map +0 -1
- package/dist/web/static/assets/react-router-I-HqunH7.js +0 -20
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
# H2 Phase 3 替换调用方 Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 14:50 (Phase 3)
|
|
4
|
+
**Spec**: docs/design/h2-getdatabase-encapsulation-spec-20260518-1450.md
|
|
5
|
+
**Status**: Phase 3 完成(Phase 4 待 getDatabase jsdoc)
|
|
6
|
+
|
|
7
|
+
## 完成清单
|
|
8
|
+
|
|
9
|
+
- [x] `src/web/routes/stats.ts` — 5 段 SQL → `countAllEvents` / `countAllSessions` / `aggregateToolUsage` / `aggregateDailyEventCounts` / `aggregateDailySessionCounts` / `countAllSkillInvocations`
|
|
10
|
+
- [x] `src/web/routes/trace.ts` — 3 段 SQL → `aggregateHookTypeBySession` / `aggregateAgentTypeBySession` / `queryDistinctSkillIdsBySession`
|
|
11
|
+
- [x] `src/cli/commands/trace.ts` — 3 段 SQL(同 trace.ts 模式)+ 函数签名清理(移除 db 参数)
|
|
12
|
+
- [x] `src/daemon/handlers/stop.ts` — 3 段 SQL → `aggregateToolUsageBySession` / `aggregateAgentTypeBySession` / `countSkillInvocationsBySession`
|
|
13
|
+
- [x] `src/web/analytics/drift-detector.ts` — 4 段 SQL → `countDistinctSkillsSince` / `countActiveDays` / `countSessionsByRange` / `countTasksByRange`
|
|
14
|
+
- [x] `src/web/analytics/weekly-report.ts` — 6 段 SQL → `aggregateOverviewByRange` / `queryDistinctProjects` / `countTasksByRange` / `queryEventsByTimeRange` (内存聚合 tool) / `aggregateToolFailureRate` / `queryFileEditInputs`
|
|
15
|
+
- [x] `src/web/analytics/anti-pattern-detector.ts` — 2 段 SQL → `queryEventsByTimeRange` / `querySessionsByTimeRange`,附带删除无用 `safeParse` helper
|
|
16
|
+
|
|
17
|
+
## 测试结果
|
|
18
|
+
|
|
19
|
+
| 测试套件 | 结果 |
|
|
20
|
+
|---|---|
|
|
21
|
+
| `tests/integration/web-stats.integration.test.ts` | 4/4 通过 |
|
|
22
|
+
| `tests/integration/web-trace.integration.test.ts` | 6/6 通过 |
|
|
23
|
+
| `tests/unit/daemon/stop-handler-behavior-summary.test.ts` | 5/5 通过 |
|
|
24
|
+
| `tests/integration/web-analytics.integration.test.ts` | 5/5 通过 |
|
|
25
|
+
| `npx tsc --noEmit` | 0 errors |
|
|
26
|
+
| `npm test`(全量) | 541 passed / 1 failed(pre-existing:`linkEventToTask`) |
|
|
27
|
+
|
|
28
|
+
## 残留 db.prepare 检查
|
|
29
|
+
|
|
30
|
+
`grep -rn "db\.prepare\|getDatabase().prepare" src/web/routes/ src/web/analytics/ src/cli/commands/trace.ts src/daemon/handlers/ --include="*.ts" | grep -v ".test."` 输出:
|
|
31
|
+
|
|
32
|
+
```
|
|
33
|
+
src/web/routes/stats.ts:7: * H2 Phase 3: 替换原 db.prepare 直写 SQL 为 SQLiteStorage facade 聚合方法。
|
|
34
|
+
src/web/routes/trace.ts:95: // H2 Phase 3: 改用 facade 聚合方法,消除 db.prepare 直写。
|
|
35
|
+
src/daemon/handlers/stop.ts:151: // H2 Phase 3: 改用 facade 聚合方法,消除 db.prepare 直写。
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
仅剩 3 处提到 `db.prepare` 的注释,**无实际 SQL 直写调用**。Phase 3 目标达成。
|
|
39
|
+
|
|
40
|
+
## 超出 spec 改动
|
|
41
|
+
|
|
42
|
+
1. **CLI trace 函数签名清理**:`printSessionTrace(storage, db, sessionId)` → `printSessionTrace(storage, sessionId)`,因 db 参数已无引用方。属于伴生改动,非业务逻辑变更。
|
|
43
|
+
2. **anti-pattern-detector 删除 `safeParse`**:原函数仅在 `queryEventsSince` 旧实现中使用,迁移到 `queryEventsByTimeRange` 后已不再需要(events.ts 的 `rowToEvent` 内部完成 JSON 解析)。属于死代码清理。
|
|
44
|
+
|
|
45
|
+
## Phase 2 vs 实际签名偏差(重要)
|
|
46
|
+
|
|
47
|
+
**`aggregateToolUsage` 缺 `until` 参数**:
|
|
48
|
+
- spec 设计:`aggregateToolUsage(opts: { since, until, hook_type, limit })`
|
|
49
|
+
- Phase 2 实现:`aggregateToolUsage(opts: { since?, hook_type?, limit? })`,**缺 `until`**
|
|
50
|
+
|
|
51
|
+
**影响**:`weekly-report.ts:aggregateTools` 需要 `[since, until)` 半开区间过滤(历史周不应混入下一周事件)。
|
|
52
|
+
|
|
53
|
+
**临时处理**:改用 `queryEventsByTimeRange({ since, until })` + JS 内存聚合 PreToolUse + tool_name。语义正确,但比专门聚合 SQL 多一次行映射。
|
|
54
|
+
|
|
55
|
+
**建议**:Phase 4 之后若有 H3,可考虑给 `aggregateToolUsage` 补 `until`,或新增 `aggregateToolUsageByRange`。当前不阻塞 Phase 3。
|
|
56
|
+
|
|
57
|
+
## 关键设计决策
|
|
58
|
+
|
|
59
|
+
1. **时间窗口 ISO 字符串化**:旧 SQL 用 `date('now', '-7 days')` SQLite 日期函数。新口径统一调用方计算 `new Date(Date.now() - N * 86400000).toISOString()` 后传 facade。在 `stats.ts` / `drift-detector.ts` 两处沿用此模式。
|
|
60
|
+
2. **保留响应 shape**:所有路由响应字段名(toolUsage / dailyActivity / event_breakdown 等)完全不变,只把内部 `cnt` 字段名换成 facade 返回的 `count`,前端契约 0 改动。
|
|
61
|
+
3. **failure 检测三条 LIKE 分支保留**:通过 `aggregateToolFailureRate` 内部封装 `'%"error"%' OR '%"is_error":true%' OR '%"isError":true%'`,行为与旧 SQL 完全一致。
|
|
62
|
+
|
|
63
|
+
## 已知问题
|
|
64
|
+
|
|
65
|
+
- `tests/unit/storage/sqlite-refactor-harness.test.ts > Task Operations > linkEventToTask associates events with tasks` — **pre-existing 失败**(UUID 校验问题,与 Phase 3 无关)
|
|
66
|
+
|
|
67
|
+
## Phase 4 待办
|
|
68
|
+
|
|
69
|
+
- `getDatabase()` 加 jsdoc `@internal` 警告(spec §「方案选择」与 Phase 4 计划)
|
|
70
|
+
- 跑全量 tsc + npm test 二次确认
|
|
71
|
+
- 可选:CLAUDE.md 「常见陷阱」补 1 条「越权 SQL 必须走 facade」
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
# H3 实施 Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 12:45
|
|
4
|
+
**Spec**: docs/design/h3-fallback-removal-spec-20260518-1245.md
|
|
5
|
+
**Status**: 完成
|
|
6
|
+
|
|
7
|
+
## 完成清单
|
|
8
|
+
|
|
9
|
+
- [x] `src/core/storage/base.ts` `initSchema()` 删除 inline fallback + fail-fast
|
|
10
|
+
- [x] `src/core/storage/base.ts` 文件头注释清理("或 inline fallback" → "缺失则抛错")
|
|
11
|
+
- [x] `package.json` build script 末尾追加 `test -f dist/core/storage/schema.sql` 校验
|
|
12
|
+
- [x] `tests/unit/storage/schema-missing.test.ts` 新增 2 个 case
|
|
13
|
+
|
|
14
|
+
## 关键代码定位
|
|
15
|
+
|
|
16
|
+
- `src/core/storage/base.ts:6` — 文件头注释:"加载 schema.sql(缺失则抛错)"
|
|
17
|
+
- `src/core/storage/base.ts:61-73` — `initSchema()` 重写:`existsSync` 缺失 → 抛 Error;不再有 else fallback 分支
|
|
18
|
+
- `package.json:13` — build script 末尾:`&& (test -f dist/core/storage/schema.sql || (echo '[build] FATAL: dist/core/storage/schema.sql missing' && exit 1))`
|
|
19
|
+
- `tests/unit/storage/schema-missing.test.ts:1-83` — 新测试文件
|
|
20
|
+
|
|
21
|
+
## 设计要点
|
|
22
|
+
|
|
23
|
+
### initSchema 行为变化
|
|
24
|
+
|
|
25
|
+
**旧**:
|
|
26
|
+
```ts
|
|
27
|
+
if (existsSync(schemaPath)) {
|
|
28
|
+
// 读取并 exec schema.sql
|
|
29
|
+
} else {
|
|
30
|
+
// inline fallback:只建 events 表 + 4 个旧索引
|
|
31
|
+
}
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
**新**:
|
|
35
|
+
```ts
|
|
36
|
+
if (!existsSync(schemaPath)) {
|
|
37
|
+
throw new Error('[SQLiteStorage] schema.sql not found at ${schemaPath}. ...');
|
|
38
|
+
}
|
|
39
|
+
const schema = readFileSync(schemaPath, 'utf-8');
|
|
40
|
+
this.db.exec(schema);
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
错误信息含修复建议:`Run \`npm run build\` or reinstall the package.`
|
|
44
|
+
|
|
45
|
+
### 测试 mock 策略
|
|
46
|
+
|
|
47
|
+
`tests/unit/storage/schema-missing.test.ts` case 2 使用 `vi.doMock('node:fs', ...)` + 动态 `import()`:
|
|
48
|
+
|
|
49
|
+
- 只让 `existsSync` 在路径以 `schema.sql` 结尾时返回 false
|
|
50
|
+
- 其他路径(如 mkdir 时的目录检查)保留真实行为,避免破坏构造函数的目录创建逻辑
|
|
51
|
+
- 每个 case 后 `vi.doUnmock` + `vi.resetModules` 防止跨 case 污染
|
|
52
|
+
|
|
53
|
+
### Build 校验
|
|
54
|
+
|
|
55
|
+
`(test -f dist/core/storage/schema.sql || (echo '[build] FATAL:...' && exit 1))` 在所有 cp 步骤之后跑,捕获 schema.sql 漏拷贝场景。括号子 shell 形式确保 `||` 短路 + 显式 exit 1。
|
|
56
|
+
|
|
57
|
+
## 测试结果
|
|
58
|
+
|
|
59
|
+
- 新增 `schema-missing.test.ts`:**2 / 2 passed**
|
|
60
|
+
- 现有 `tests/unit/storage/`:**60 / 61 passed**(仅 pre-existing `linkEventToTask` 失败)
|
|
61
|
+
- `npx tsc --noEmit`:**0 errors**
|
|
62
|
+
- `npm test`:**423 / 424 passed**(仅 pre-existing `linkEventToTask`)
|
|
63
|
+
- `npm run build`:**成功**(dist/core/storage/schema.sql 存在,校验通过)
|
|
64
|
+
|
|
65
|
+
## 超出 spec 改动
|
|
66
|
+
|
|
67
|
+
无。严格按 spec 改了 base.ts、package.json、新增 1 个测试文件。
|
|
68
|
+
|
|
69
|
+
## 已知问题
|
|
70
|
+
|
|
71
|
+
- `tests/unit/storage/sqlite-refactor-harness.test.ts > linkEventToTask` — pre-existing failure(事件 UUID 校验失败),与本次 H3 改动无关,spec 明确豁免
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# H4 实施 Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 12:30
|
|
4
|
+
**Spec**: docs/design/h4-index-dedup-spec-20260518-1230.md
|
|
5
|
+
**Status**: 完成
|
|
6
|
+
|
|
7
|
+
## 完成清单
|
|
8
|
+
|
|
9
|
+
- [x] schema.sql 补 2 索引:`idx_skill_invocations_workflow` / `idx_skill_invocations_feature`
|
|
10
|
+
- [x] base.ts 加 `hasTable` / `hasIndex` 工具
|
|
11
|
+
- [x] base.ts 加 `createIndexIfMissing` 私有工具(hasIndex 守护 + debug 日志)
|
|
12
|
+
- [x] `runMigrations` 拆为 `runColumnMigrations` / `runIndexMigrations` / `runPostMigrations`
|
|
13
|
+
- [x] 列 migration 提前到 `initSchema()` 之前(修复 schema.sql 索引引用未存在列的回归)
|
|
14
|
+
- [x] 索引 migration(10 处)全部用 `createIndexIfMissing` 守护
|
|
15
|
+
- [x] 新增测试 `tests/unit/storage/migration-idempotent.test.ts`(4 case)
|
|
16
|
+
|
|
17
|
+
## 关键代码定位
|
|
18
|
+
|
|
19
|
+
- `src/core/storage/schema.sql:220-222` — 新增 `idx_skill_invocations_workflow` / `idx_skill_invocations_feature`
|
|
20
|
+
- `src/core/storage/base.ts:46-60` — 构造函数调整为 `runColumnMigrations → initSchema → runIndexMigrations → runPostMigrations`
|
|
21
|
+
- `src/core/storage/base.ts:87-96` — 新增 `hasTable` 工具
|
|
22
|
+
- `src/core/storage/base.ts:107-121` — `addColumnIfMissing` 加 `hasTable` 短路(避免新库时 PRAGMA 噪音)
|
|
23
|
+
- `src/core/storage/base.ts:123-137` — `hasIndex` 工具(按 spec 第 4 节实现)
|
|
24
|
+
- `src/core/storage/base.ts:139-153` — `createIndexIfMissing` 私有工具(hasIndex 守护 + debug 日志)
|
|
25
|
+
- `src/core/storage/base.ts:155-171` — `runColumnMigrations`(7 处 addColumnIfMissing)
|
|
26
|
+
- `src/core/storage/base.ts:173-227` — `runIndexMigrations`(10 处 createIndexIfMissing)
|
|
27
|
+
- `src/core/storage/base.ts:232-244` — `runPostMigrations`(backfill + drop deprecated)
|
|
28
|
+
- `tests/unit/storage/migration-idempotent.test.ts` — 新增 4 个 case
|
|
29
|
+
|
|
30
|
+
## 测试结果
|
|
31
|
+
|
|
32
|
+
- **新增测试**:`migration-idempotent.test.ts` 4/4 passed
|
|
33
|
+
- `baseline (缺索引)`:老库缺所有 migration 索引 → 启动后全部补齐
|
|
34
|
+
- `baseline (缺列)`:老库缺 `sessions.first_prompt` → ALTER 补齐
|
|
35
|
+
- `新库无害`:完整 schema.sql 初始化后再 new SQLiteStorage → 不重复 CREATE INDEX(debug 日志为 0 次"migration created",无 warn/error)
|
|
36
|
+
- `idempotent`:连续 3 次 new SQLiteStorage → 索引/列集合完全一致
|
|
37
|
+
- **storage 全模块**:`tests/unit/storage/` 58 passed / 1 pre-existing failed
|
|
38
|
+
- **tsc**:0 errors
|
|
39
|
+
- **npm test 全量**:421 passed / 1 failed
|
|
40
|
+
- 唯一失败:`tests/unit/storage/sqlite-refactor-harness.test.ts > linkEventToTask associates events with tasks` — pre-existing,与 H4 改动无关
|
|
41
|
+
|
|
42
|
+
## 超出 spec 改动
|
|
43
|
+
|
|
44
|
+
1. **构造函数顺序调整**:`runColumnMigrations` 提到 `initSchema` 之前。
|
|
45
|
+
- **原因**:spec 第 1 步要求把 `idx_skill_invocations_workflow ON skill_invocations(workflow, phase)` 放进 schema.sql。但 base.ts 原本顺序是 `initSchema → runMigrations`,对于"老库(无 workflow 列)"场景,`initSchema` 跑 schema.sql 时 `CREATE TABLE IF NOT EXISTS skill_invocations` 跳过老表(不会补列),随后 `CREATE INDEX ... ON skill_invocations(workflow, phase)` 即报 `no such column: workflow`。
|
|
46
|
+
- **现场重现**:先暴露于新增 `migration-idempotent.test.ts` 的 baseline case,随后确认 pre-existing 测试 `skill-invocations-workflow.test.ts` 的"增量迁移"case 同样会失败。
|
|
47
|
+
- **解决**:把 `addColumnIfMissing` 调用提前。等到老表已有 workflow 列后,schema.sql 的 CREATE INDEX 才安全。
|
|
48
|
+
- **影响**:新库(空 db)下 `hasTable` 全 false,列 migration 全静默跳过;老库下列先 ALTER;已 up-to-date 库下全跳过。三种路径均通过测试。
|
|
49
|
+
|
|
50
|
+
2. **新增 `hasTable` 工具 + addColumnIfMissing 短路**:避免新库初始化时 PRAGMA 表不存在的噪音。spec 未要求但与顺序调整配套。
|
|
51
|
+
|
|
52
|
+
3. **`runMigrations` 拆为 3 个私有方法**:column / index / post。提升可读性,让"列在前、索引在后、数据迁移最后"的依赖关系显式化。spec 第 49 行只要求"runMigrations 全部改造为 has 判断守护",拆分是顺手优化。
|
|
53
|
+
|
|
54
|
+
## 已知问题
|
|
55
|
+
|
|
56
|
+
- `tests/unit/storage/sqlite-refactor-harness.test.ts > Task Operations > linkEventToTask associates events with tasks` — pre-existing failure,原因是测试数据校验失败(event tool_input 字段),与 H4 无关。H1 阶段已识别。
|
|
57
|
+
|
|
58
|
+
## inline fallback (base.ts initSchema else 分支)
|
|
59
|
+
|
|
60
|
+
按 spec 要求未动。spec 第 54 行明确说"本次 H4 不动它,仅注释 TODO",但 base.ts 现有代码无 TODO 注释,且 spec 没强制要求加,保持原状。
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
# H6 实施 Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 13:55
|
|
4
|
+
**Spec**: docs/design/h6-services-migration-spec-20260518-1355.md
|
|
5
|
+
**Status**: 完成
|
|
6
|
+
|
|
7
|
+
## 完成清单
|
|
8
|
+
- [x] safety-net: tests/integration/web-analytics.integration.test.ts(3/3 pass,迁移前后均通过)
|
|
9
|
+
- [x] git mv 3 文件到 src/web/analytics/(保留 git history)
|
|
10
|
+
- [x] 改 3 处 import 路径(drift / reports / insights routes)
|
|
11
|
+
- [x] 清理 2 处误导注释(weekly-report 的 "implemented by another agent" + anti-pattern 的 "daemon/services 既定做法")
|
|
12
|
+
- [x] task-segmenter.ts 保留原地不动
|
|
13
|
+
- [x] vitest.config.ts 加入 `tests/integration/**` 到 include(让 safety-net 能被 npm test 拾取)
|
|
14
|
+
|
|
15
|
+
## 关键代码定位
|
|
16
|
+
- 新测试文件:`tests/integration/web-analytics.integration.test.ts:1-67`
|
|
17
|
+
- 迁移后入口:`src/web/analytics/{drift-detector,weekly-report,anti-pattern-detector}.ts`
|
|
18
|
+
- import 变更:
|
|
19
|
+
- `src/web/routes/drift.ts:3` → `from '../analytics/drift-detector.js'`
|
|
20
|
+
- `src/web/routes/reports.ts:10` → `from '../analytics/weekly-report.js'`
|
|
21
|
+
- `src/web/routes/insights.ts:7` → `from '../analytics/anti-pattern-detector.js'`
|
|
22
|
+
- 注释清理:
|
|
23
|
+
- `src/web/analytics/weekly-report.ts:293-297`(aggregateAnomalies 内)
|
|
24
|
+
- `src/web/analytics/anti-pattern-detector.ts:76-81`(queryEventsSince 上方 JSDoc)
|
|
25
|
+
- vitest 配置:`vitest.config.ts:8`
|
|
26
|
+
|
|
27
|
+
## 测试结果
|
|
28
|
+
- web-analytics 集成测试:3 passed(迁移前 baseline、迁移后回归均 3/3)
|
|
29
|
+
- tsc --noEmit:0 errors
|
|
30
|
+
- npm test:455 passed / 1 failed(仅 pre-existing `linkEventToTask` 失败,与本次迁移无关)
|
|
31
|
+
- npm run build:成功(dist/web/analytics/ 产出齐全;dist/daemon/services/ 只剩 task-segmenter)
|
|
32
|
+
|
|
33
|
+
## 超出 spec 改动
|
|
34
|
+
- **vitest.config.ts 更新 include 模式**:原配置只扫描 `tests/unit/**`,导致 `tests/integration/**` 下的测试(含已有的 `tasks-filter.integration.test.ts`)从未跑过。为让 safety-net 真正生效,新增 `tests/integration/**/*.test.ts` 到 include。
|
|
35
|
+
- 副作用确认:把 `tasks-filter.integration.test.ts` 也拉进 CI,但它本就在主测试套件中通过(455 项 passed 含它)。
|
|
36
|
+
|
|
37
|
+
## 已知问题
|
|
38
|
+
- `tests/unit/storage/sqlite-refactor-harness.test.ts > linkEventToTask` 失败(pre-existing,事件 UUID 校验问题,与 H6 迁移无关)
|
|
39
|
+
|
|
40
|
+
## 迁移内文件 import 路径核查
|
|
41
|
+
3 个被迁移的文件原来用 `../../core/...` 引用 core 层。从 `src/daemon/services/` 移到 `src/web/analytics/` 后,相对深度未变(仍为 2 层向上),无需调整。grep 校验通过:
|
|
42
|
+
|
|
43
|
+
```
|
|
44
|
+
grep -rn "daemon/services/drift-detector|daemon/services/weekly-report|daemon/services/anti-pattern-detector" src/ tests/
|
|
45
|
+
→ 无任何匹配
|
|
46
|
+
```
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
# H7 + M9 实施 Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 13:00
|
|
4
|
+
**Status**: 完成
|
|
5
|
+
|
|
6
|
+
## 背景修正
|
|
7
|
+
|
|
8
|
+
原 review 误判:`claude-sonnet-4-6` 实际为合法 Sonnet 4.6 ID(非"非法")。
|
|
9
|
+
真实问题:`provider.ts` 的 `DEFAULT_MODEL` 是已过时的 `claude-sonnet-4-20250514`(Sonnet 4.0 旧 ID),应改用 constants 暴露的最新值。
|
|
10
|
+
端口侧的真实问题:`constants.ts` 的 `WEB_PORT: 3456` 是孤儿值(无人引用),而实际事实标准是 `3721`(7 个文件硬编码)。
|
|
11
|
+
|
|
12
|
+
## 完成清单
|
|
13
|
+
|
|
14
|
+
- [x] `constants.ts` `WEB_PORT: 3456` → `3721`
|
|
15
|
+
- [x] `provider.ts` 删除硬编码 `DEFAULT_MODEL`,改用 `DEFAULTS.AI_MODEL`
|
|
16
|
+
- [x] `daemon/index.ts:73` 端口 fallback 用 `DEFAULTS.WEB_PORT`
|
|
17
|
+
- [x] `cli/commands/daemon.ts:46` 同上
|
|
18
|
+
- [x] `cli/commands/init.ts:107` 同上
|
|
19
|
+
- [x] `core/utils/error-handler.ts:224` 同上 (`String(DEFAULTS.WEB_PORT)`)
|
|
20
|
+
- [x] URL 字符串改 template literal(menu.ts ×3, trace.ts ×1)
|
|
21
|
+
|
|
22
|
+
## 关键文件
|
|
23
|
+
|
|
24
|
+
- `src/core/constants.ts:44` — `WEB_PORT: 3721`
|
|
25
|
+
- `src/core/ai/provider.ts:27-29` — 移除 `DEFAULT_MODEL`,新增 `import { DEFAULTS } from '../constants.js'`
|
|
26
|
+
- `src/daemon/index.ts:73` — `?? DEFAULTS.WEB_PORT`
|
|
27
|
+
- `src/cli/commands/daemon.ts:46` — `const DEFAULT_PORT = DEFAULTS.WEB_PORT`
|
|
28
|
+
- `src/cli/commands/init.ts:107` — `let webPort: number = DEFAULTS.WEB_PORT`
|
|
29
|
+
- `src/core/utils/error-handler.ts:224` — `String(DEFAULTS.WEB_PORT)`
|
|
30
|
+
- `src/cli/commands/menu.ts:127,129,244` — template literal `http://localhost:${DEFAULTS.WEB_PORT}`
|
|
31
|
+
- `src/cli/commands/trace.ts:154` — 同上
|
|
32
|
+
|
|
33
|
+
## 测试结果
|
|
34
|
+
|
|
35
|
+
- `npx tsc --noEmit`:0 errors
|
|
36
|
+
- `npm test`:423 passed / 1 failed(pre-existing `linkEventToTask` 与本次变更无关,位于 `tests/unit/storage/sqlite-refactor-harness.test.ts`,根因在 `EventOperations.writeEvent` 校验)
|
|
37
|
+
|
|
38
|
+
## 不改的位置(理由)
|
|
39
|
+
|
|
40
|
+
无。原计划中保守保留的 URL 字符串(menu.ts / trace.ts)由于改造极轻量(template literal),一并收敛进 `DEFAULTS.WEB_PORT`,进一步消除字面量漂移风险。
|
|
41
|
+
|
|
42
|
+
## 影响面 / 风险
|
|
43
|
+
|
|
44
|
+
- 行为变更点:`constants.ts` 的 `WEB_PORT` 之前为 `3456`,但 grep 确认无实际引用,所以此值修正为 `3721` 不产生回归。
|
|
45
|
+
- `provider.ts` 默认模型从过时的 `claude-sonnet-4-20250514` 改为合法的 `claude-sonnet-4-6`:在 `config.ai.model` 未显式设置时,AI 调用将使用 Sonnet 4.6(更新、更便宜、更强)。这是预期升级。
|
|
46
|
+
- 所有端口硬编码已收敛到 `DEFAULTS.WEB_PORT`,后续调整只需改一处。
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
# Hook Failure Queue + Daemon Startup Replay — Implementation Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-16 14:30 → 15:10
|
|
4
|
+
**Spec**: `docs/design/hook-failure-queue-spec-20260516-1530.md`
|
|
5
|
+
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
## 实际改动文件清单
|
|
9
|
+
|
|
10
|
+
| 路径 | 改动类型 | 说明 |
|
|
11
|
+
|---|---|---|
|
|
12
|
+
| `src/core/queue/index.ts` | 新建 | 队列核心模块(enqueueEvent / replayQueue / pruneQueue) |
|
|
13
|
+
| `src/core/storage/events.ts` | 修改 | UNIQUE constraint 降级为 debug 日志,不再打 error |
|
|
14
|
+
| `src/daemon/index.ts` | 修改 | 新增 `replayQueue` import + `setImmediate` 调用 |
|
|
15
|
+
| `src/hooks/hook-lib.sh` | 新建 | 共享库:`send_event_or_enqueue` + `_enqueue_event_bg` |
|
|
16
|
+
| `src/hooks/user-prompt-submit.sh` | 修改 | source hook-lib.sh,改用 `send_event_or_enqueue` |
|
|
17
|
+
| `src/hooks/pre-tool-use.sh` | 修改 | 同上 |
|
|
18
|
+
| `src/hooks/post-tool-use.sh` | 修改 | 同上 |
|
|
19
|
+
| `src/hooks/notification.sh` | 修改 | 同上(spec 标注"低优先级可选",按主线程要求一并修改) |
|
|
20
|
+
| `tests/unit/queue.test.ts` | 新建 | 单元测试(9 个用例) |
|
|
21
|
+
| `tests/integration/queue-replay.integration.test.ts` | 新建 | 集成测试(3 个用例) |
|
|
22
|
+
| `vitest.integration.config.ts` | 新建 | 临时 vitest 配置,使集成测试可独立运行 |
|
|
23
|
+
|
|
24
|
+
`src/hooks/stop.sh` — 未改,与 spec 一致(Stop 事件无重放意义)。
|
|
25
|
+
|
|
26
|
+
---
|
|
27
|
+
|
|
28
|
+
## 与 Spec 偏差
|
|
29
|
+
|
|
30
|
+
### 偏差 1:hook-lib.sh 决策(主线程修正 3)
|
|
31
|
+
|
|
32
|
+
**选择**:新建 `src/hooks/hook-lib.sh`,共享 `send_event_or_enqueue` 函数。
|
|
33
|
+
|
|
34
|
+
**理由**:5 个 hook 脚本的 enqueue 逻辑完全相同。若各自独立维护 ~15 行,任何 bug 修复都需要改 4 处,容易遗漏。`hook-lib.sh` 约 60 行,每个 hook 只需 `source hook-lib.sh` + 一行调用,减少重复且保持一致性。
|
|
35
|
+
|
|
36
|
+
### 偏差 2:hook 失败判断(主线程修正 2)
|
|
37
|
+
|
|
38
|
+
**选择**:双重检查 — 先检查 `[ -S "$SOCKET_PATH" ]`,再检查 nc 的 exit code。
|
|
39
|
+
|
|
40
|
+
**macOS BSD nc 行为分析**:
|
|
41
|
+
- macOS `nc -U -w N` 对 Unix socket:连接成功 + 连接被远端关闭 → exit 0,即使响应为空字符串
|
|
42
|
+
- socket 文件不存在 → exit 1
|
|
43
|
+
- 连接被拒绝 / 超时 → exit 1
|
|
44
|
+
|
|
45
|
+
**关键约束满足**:daemon 正常返回空响应(无 systemMessage / additionalContext),此时 nc exit code = 0,`HOOK_RESPONSE` 为空字符串 → 不入队。这修复了 spec 原始方案用 `[ -z "$RESPONSE" ]` 造成的误判问题。
|
|
46
|
+
|
|
47
|
+
### 偏差 3:events.ts UNIQUE 约束处理
|
|
48
|
+
|
|
49
|
+
Spec 要求"daemon 侧 writeEvent catch UNIQUE constraint 静默跳过"。
|
|
50
|
+
|
|
51
|
+
**最终方案**:`events.ts` 对 UNIQUE constraint 降级为 debug 日志(不打 error),但**仍然 throw**。原因:`replayQueue` 依赖 throw 来区分"成功入库"(`replayed++`)和"重复"(`skipped++`)。如果 `writeEvent` 静默返回,replayQueue 无法计 skipped。
|
|
52
|
+
|
|
53
|
+
Daemon 的 `handleEvent` 中单独 catch UNIQUE constraint,以防止正常 hook 流量因竞态(极低概率)收到重放的 event_id 而崩溃。
|
|
54
|
+
|
|
55
|
+
---
|
|
56
|
+
|
|
57
|
+
## 测试结果
|
|
58
|
+
|
|
59
|
+
### 单元测试(9 个,全过)
|
|
60
|
+
|
|
61
|
+
```
|
|
62
|
+
npx vitest run tests/unit/queue.test.ts --reporter=verbose
|
|
63
|
+
|
|
64
|
+
✓ enqueueEvent 写入文件并可被 JSON.parse
|
|
65
|
+
✓ enqueueEvent 保留已有 event_id
|
|
66
|
+
✓ pruneQueue 超过 MAX_FILES 时删最旧文件
|
|
67
|
+
✓ pruneQueue 未到 MAX_FILES 时不删文件
|
|
68
|
+
✓ replayQueue 重放事件入库并删除队列文件
|
|
69
|
+
✓ replayQueue 对重复 event_id 静默跳过(skipped++)
|
|
70
|
+
✓ replayQueue 移动损坏 JSON 到 dead-letter
|
|
71
|
+
✓ replayQueue 移动 TTL 超期文件到 dead-letter
|
|
72
|
+
✓ replayQueue 队列为空时返回全零
|
|
73
|
+
|
|
74
|
+
Tests: 9 passed (9)
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
### 集成测试(3 个,全过)
|
|
78
|
+
|
|
79
|
+
```
|
|
80
|
+
npx vitest run --config vitest.integration.config.ts tests/integration/queue-replay.integration.test.ts --reporter=verbose
|
|
81
|
+
|
|
82
|
+
✓ 入队 3 个事件 → replayQueue → DB 有 3 行,队列为空
|
|
83
|
+
✓ 第二次 replayQueue → skipped=3(去重),DB 仍 3 行
|
|
84
|
+
✓ TTL 超期 + 损坏 JSON → dead-letter 2 个,重放 1 个
|
|
85
|
+
|
|
86
|
+
Tests: 3 passed (3)
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### 全量单元测试
|
|
90
|
+
|
|
91
|
+
```
|
|
92
|
+
npx vitest run --reporter=dot
|
|
93
|
+
|
|
94
|
+
Test Files: 2 failed | 25 passed (27)
|
|
95
|
+
Tests: 3 failed | 300 passed (303)
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
3 个失败均为**预存在的 bug**(`sqlite-refactor-harness.test.ts` 和 `routes-tasks.test.ts` 使用了非 UUID 格式的 event_id,如 `event-1`,不满足 Zod UUID 验证),与本次改动无关(git stash 验证确认)。
|
|
99
|
+
|
|
100
|
+
### TypeScript 类型检查
|
|
101
|
+
|
|
102
|
+
```
|
|
103
|
+
npx tsc --noEmit
|
|
104
|
+
(无输出 = 通过)
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
---
|
|
108
|
+
|
|
109
|
+
## E2E 实测证据
|
|
110
|
+
|
|
111
|
+
### 操作步骤
|
|
112
|
+
|
|
113
|
+
```bash
|
|
114
|
+
# 1. 停止 daemon
|
|
115
|
+
npm run dev:daemon:stop
|
|
116
|
+
# → "Daemon stopped"
|
|
117
|
+
|
|
118
|
+
# 2. 确认队列为空
|
|
119
|
+
find ~/.claude-forge/queue -name "*.json" | wc -l
|
|
120
|
+
# → 0
|
|
121
|
+
|
|
122
|
+
# 3. 调用 hook(daemon 停机中)
|
|
123
|
+
echo '{"prompt":"队列测试 P3-B","cwd":"/tmp","session_id":"queue-test-001"}' \
|
|
124
|
+
| node -e "const {execSync}=require('child_process');
|
|
125
|
+
execSync('cat | src/hooks/user-prompt-submit.sh', ...)"
|
|
126
|
+
# hook 退出码 0(入队后台子进程)
|
|
127
|
+
|
|
128
|
+
# 4. 验证队列文件已写入
|
|
129
|
+
find ~/.claude-forge/queue -name "*.json"
|
|
130
|
+
# → /Users/admin/.claude-forge/queue/20260516T065031-AF74BF77-D0FE-4911-B6EC-22868527E3E1.json
|
|
131
|
+
|
|
132
|
+
# 5. 启动 daemon
|
|
133
|
+
npm run dev:daemon:start
|
|
134
|
+
# → "Daemon started (PID: 5814)"
|
|
135
|
+
sleep 2
|
|
136
|
+
|
|
137
|
+
# 6. 验证队列为空(已重放)
|
|
138
|
+
find ~/.claude-forge/queue -name "*.json" | wc -l
|
|
139
|
+
# → 0
|
|
140
|
+
|
|
141
|
+
# 7. 查询数据库
|
|
142
|
+
sqlite3 ~/.claude-forge/data.db \
|
|
143
|
+
"SELECT timestamp, user_prompt FROM events WHERE session_id='queue-test-001';"
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
### 实测输出
|
|
147
|
+
|
|
148
|
+
```
|
|
149
|
+
sqlite3 query result:
|
|
150
|
+
2026-05-16T06:50:31.000Z|队列测试 P3-B
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
### Daemon 日志(grep Queue)
|
|
154
|
+
|
|
155
|
+
```
|
|
156
|
+
[2026-05-16T06:50:44.444Z] [INFO] [Queue] Replaying 1 queued event(s)…
|
|
157
|
+
[2026-05-16T06:50:44.448Z] [INFO] [Queue] Replay: 1 replayed, 0 skipped (dup), 0 dead-lettered
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
**结论**:daemon 停机期间发送的事件正确入队,daemon 启动后自动重放并写入 DB,队列清空。
|
|
161
|
+
|
|
162
|
+
---
|
|
163
|
+
|
|
164
|
+
## 关键实现细节
|
|
165
|
+
|
|
166
|
+
### send_event_or_enqueue 函数(hook-lib.sh)
|
|
167
|
+
|
|
168
|
+
```bash
|
|
169
|
+
send_event_or_enqueue() {
|
|
170
|
+
local event_json="$1"
|
|
171
|
+
local timeout_secs="${2:-10}"
|
|
172
|
+
HOOK_RESPONSE=""
|
|
173
|
+
|
|
174
|
+
if [ ! -S "$SOCKET_PATH" ]; then
|
|
175
|
+
_enqueue_event_bg "$event_json"
|
|
176
|
+
return 0
|
|
177
|
+
fi
|
|
178
|
+
|
|
179
|
+
local tmp_response
|
|
180
|
+
tmp_response=$(echo "$event_json" | nc -U -w "$timeout_secs" "$SOCKET_PATH" 2>/dev/null)
|
|
181
|
+
local nc_exit=$?
|
|
182
|
+
|
|
183
|
+
if [ $nc_exit -ne 0 ]; then
|
|
184
|
+
_enqueue_event_bg "$event_json"
|
|
185
|
+
return 0
|
|
186
|
+
fi
|
|
187
|
+
|
|
188
|
+
HOOK_RESPONSE="$tmp_response"
|
|
189
|
+
}
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
写入策略:`printf '%s' "$event_json" > "$tmp_file" && mv "$tmp_file" "$QUEUE_DIR/${filename}"` — 先写 .tmp 再 rename,保证原子性。
|
|
193
|
+
|
|
194
|
+
### replayQueue 时序
|
|
195
|
+
|
|
196
|
+
daemon 启动 → `SocketServer` 构造(listen 绑定)→ `setImmediate(replayQueue)` — 利用 setImmediate 确保 listen 回调先执行,socket 文件权限设好后再重放。
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# Hotfix: Daemon Event Rejection — 20260516-1430
|
|
2
|
+
|
|
3
|
+
## 根因摘要
|
|
4
|
+
|
|
5
|
+
Phase 1/2 重构时收紧了 `ForgeEventSchema`,将 `timestamp` 字段改为 `z.string().datetime()`(要求严格 ISO 8601 带 Z 后缀),同时 `hook_type` enum 漏加了 `Notification`。而 hook 脚本使用的是 `date -u +"%Y-%m-%dT%H:%M:%S"`(无毫秒无 Z),导致 daemon 重启后所有入站事件被 Zod 校验拦截拒收,数据库从 `2026-05-16 06:01:30` 起无新事件写入。
|
|
6
|
+
|
|
7
|
+
## 实际改动文件清单
|
|
8
|
+
|
|
9
|
+
| 文件 | 改动内容 |
|
|
10
|
+
|---|---|
|
|
11
|
+
| `src/core/storage/events.ts` | `timestamp` 从 `z.string().datetime()` 改为 `z.string().min(1)`(向后兼容历史无 Z 的 timestamp);`hook_type` enum 加入 `'Notification'` |
|
|
12
|
+
| `src/hooks/user-prompt-submit.sh` | `date` 格式从 `%H:%M:%S` 改为 `%H:%M:%S.000Z` |
|
|
13
|
+
| `src/hooks/pre-tool-use.sh` | 同上 |
|
|
14
|
+
| `src/hooks/post-tool-use.sh` | 同上 |
|
|
15
|
+
| `src/hooks/stop.sh` | 同上 |
|
|
16
|
+
| `src/hooks/notification.sh` | 同上 |
|
|
17
|
+
| `tests/unit/type-guards.test.ts` | 将 `should reject event with invalid timestamp` 更新为 `should reject event with empty timestamp`,测试用例从 `'not-a-valid-timestamp'` 改为 `''`,与新宽松策略一致 |
|
|
18
|
+
|
|
19
|
+
无其他 `datetime()` 使用点(已全文搜索确认)。
|
|
20
|
+
|
|
21
|
+
## 验证方式
|
|
22
|
+
|
|
23
|
+
### TypeScript 类型检查
|
|
24
|
+
```bash
|
|
25
|
+
npx tsc --noEmit
|
|
26
|
+
# 输出:无错误
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### 构建
|
|
30
|
+
```bash
|
|
31
|
+
npm run build
|
|
32
|
+
# 输出:正常完成,dist/ 含 hooks/*.sh
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
### 单元测试
|
|
36
|
+
```bash
|
|
37
|
+
npx vitest run tests/unit/ --reporter=dot
|
|
38
|
+
# 结果:3 failed | 291 passed(3 个失败为本次改动前已存在的预存失败,与本 hotfix 无关)
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
预存失败清单(本 hotfix 前已存在,不在本次修复范围内):
|
|
42
|
+
- `tests/unit/web/routes-tasks.test.ts` x2(使用非 UUID 的 event_id)
|
|
43
|
+
- `tests/unit/storage/sqlite-refactor-harness.test.ts` x1(同上)
|
|
44
|
+
|
|
45
|
+
## 部署步骤(用户需手动执行)
|
|
46
|
+
|
|
47
|
+
```bash
|
|
48
|
+
# 复制 hooks 到运行时位置
|
|
49
|
+
cp src/hooks/*.sh ~/.claude-forge/hooks/ && chmod +x ~/.claude-forge/hooks/*.sh
|
|
50
|
+
|
|
51
|
+
# 重启 daemon
|
|
52
|
+
./scripts/dev-daemon.sh restart
|
|
53
|
+
|
|
54
|
+
# 验证:新事件应出现在数据库
|
|
55
|
+
sqlite3 ~/.claude-forge/data.db "SELECT timestamp, hook_type FROM events ORDER BY rowid DESC LIMIT 5;"
|
|
56
|
+
```
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
# L1 实施 Changelog: SWARM_PROTOCOL 抽到 .md 文件
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 16:05
|
|
4
|
+
**Spec**: docs/design/l1-swarm-protocol-extract-spec-20260518-1605.md
|
|
5
|
+
**Status**: 完成
|
|
6
|
+
|
|
7
|
+
## 完成清单
|
|
8
|
+
|
|
9
|
+
- [x] safety-net:`tests/integration/claudemd-generator.test.ts` 建立 baseline(SWARM 段 SHA256 锚定)
|
|
10
|
+
- [x] swarm-protocol.md 抽取(223 行,5441 字符 / 7817 字节)
|
|
11
|
+
- [x] claudemd-generator.ts:`getSwarmProtocol()` 加载器 + 模块级缓存
|
|
12
|
+
- [x] package.json `build`:cp `.md` + fail-fast 校验
|
|
13
|
+
|
|
14
|
+
## 关键代码定位
|
|
15
|
+
|
|
16
|
+
- 新文件 `src/claudemd/templates/swarm-protocol.md`(223 行)
|
|
17
|
+
- `src/claudemd/claudemd-generator.ts:5-9` — import 增加 `dirname` + `fileURLToPath`
|
|
18
|
+
- `src/claudemd/claudemd-generator.ts:14-38` — `getSwarmProtocol()` 加载函数 + `_swarmProtocolCache`
|
|
19
|
+
- `src/claudemd/claudemd-generator.ts:59` — `generate()` 内 `SWARM_PROTOCOL` 引用改为 `getSwarmProtocol()`(实际行号 65)
|
|
20
|
+
- `src/claudemd/claudemd-generator.ts:568` 之后已无字面量(删除 569-804 共 236 行)
|
|
21
|
+
- `package.json:13` — build 中新增 `mkdir -p dist/claudemd/templates && cp src/claudemd/templates/*.md dist/claudemd/templates/`,末尾追加 `test -f dist/claudemd/templates/swarm-protocol.md` 校验
|
|
22
|
+
|
|
23
|
+
## 测试结果
|
|
24
|
+
|
|
25
|
+
- **safety-net SHA256(迁移前后一致)**:`260dfe1e48fdecc324419a6330428eaa3597e3fd6e6262cf66cdcf301ca32e18`
|
|
26
|
+
- **SWARM 段长度(迁移前后一致)**:5442 字节(含分隔符尾的一个 `\n`)
|
|
27
|
+
- **tsc**:0 errors
|
|
28
|
+
- **npm test**:551 / 552 通过(1 个 pre-existing `sqlite-refactor-harness.test.ts > linkEventToTask` 失败,与本次无关)
|
|
29
|
+
- **npm run build**:成功;`dist/claudemd/templates/swarm-protocol.md` 存在(7817 字节,与 src 完全一致)
|
|
30
|
+
|
|
31
|
+
## 顺手清理
|
|
32
|
+
|
|
33
|
+
- 删除 `claudemd-generator.ts` 原 547-553 两段重复的 `Core behavioral rules` 注释块(合并到新的 `getSwarmProtocol` 文档块)。
|
|
34
|
+
- 字面量 555-777(223 行)整体下线。文件总行数 805 → 569(-236)。
|
|
35
|
+
|
|
36
|
+
## 已知问题
|
|
37
|
+
|
|
38
|
+
- `tests/unit/storage/sqlite-refactor-harness.test.ts > linkEventToTask` — pre-existing 失败,未触碰。
|
|
39
|
+
|
|
40
|
+
## 兼容性确认
|
|
41
|
+
|
|
42
|
+
- dev 路径(`tsx src/`):`fileURLToPath(import.meta.url)` 解析到 `src/claudemd/`,同级 `templates/swarm-protocol.md` 存在 → 加载成功。
|
|
43
|
+
- npm install 路径:build 脚本 cp 到 `dist/claudemd/templates/`,末尾 `test -f` fail-fast 校验,CI 一旦缺失立刻报错。
|
|
44
|
+
- 缓存策略:模块级 `_swarmProtocolCache: string | null = null`,首次调用读盘后缓存;进程生命周期内 0 重复 I/O。
|
|
45
|
+
- 字节级等价:safety-net 测试通过 SHA256 哈希逐字符比对,新旧实现完全一致。
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
# L3 + L4 实施 Changelog
|
|
2
|
+
|
|
3
|
+
**Date**: 2026-05-18 14:10
|
|
4
|
+
**Status**: 完成
|
|
5
|
+
|
|
6
|
+
## 完成清单
|
|
7
|
+
|
|
8
|
+
- [x] **L4**: `stop.ts` git 调用异步化
|
|
9
|
+
- 3 个 `execFileSync` → `promisify(execFile)`
|
|
10
|
+
- `writeGitNote` 改为 `async`,主流程改为 **fire-and-forget**(`void this.writeGitNote(event)`)
|
|
11
|
+
- 内部仍按依赖串行 await(rev-parse work-tree → rev-parse HEAD → notes append),但**整体不阻塞 handler 主响应**
|
|
12
|
+
- 失败仍 catch + `logger.debug`,handler 对外契约不变(返回 `{allow: true}`)
|
|
13
|
+
|
|
14
|
+
- [x] **L3**: `server.ts` 避免 N² JSON.parse —— **方案 A(换行符分隔)**
|
|
15
|
+
- 验证 hook 端 `echo "$event_json" | nc -U`:`echo` 默认追加 `\n`,协议天然支持
|
|
16
|
+
- `data` handler 改为:仅在 `buffer.indexOf('\n') !== -1` 时切出完整消息并解析;未见换行就累积等待
|
|
17
|
+
- 抽取 `processMessage(socket, message)` 统一处理 auth 检查 + parser + handler response
|
|
18
|
+
- 兜底:监听 `socket.on('end')`,若 buffer 残留无换行内容(旧客户端)做最后一次解析尝试
|
|
19
|
+
- 删除 dead code `isCompleteJSON`(不再需要"启发式判完整",换行就是边界)
|
|
20
|
+
|
|
21
|
+
## 关键代码定位
|
|
22
|
+
|
|
23
|
+
- `src/daemon/handlers/stop.ts:19-22` —— `promisify(execFile)` 导入
|
|
24
|
+
- `src/daemon/handlers/stop.ts:84-86` —— `void this.writeGitNote(event)` 调用点
|
|
25
|
+
- `src/daemon/handlers/stop.ts:102-135` —— async `writeGitNote` 实现
|
|
26
|
+
- `src/daemon/server.ts:51-122` —— 新的 `handleConnection` + `processMessage`
|
|
27
|
+
- `tests/unit/socket-server.test.ts` —— 新增 5 个测试(4 socket + 1 EventParser sanity)
|
|
28
|
+
|
|
29
|
+
## 测试结果
|
|
30
|
+
|
|
31
|
+
- `npx tsc --noEmit`: **0 errors**
|
|
32
|
+
- `npm test`: **460 passed / 1 failed**(仅 pre-existing `linkEventToTask`)
|
|
33
|
+
- 新增 `tests/unit/socket-server.test.ts`: **5/5 passed**
|
|
34
|
+
|
|
35
|
+
新测试覆盖:
|
|
36
|
+
1. 单 chunk 完整消息(含换行)
|
|
37
|
+
2. 大消息(~50KB)分 20 个 chunk 到达 —— 断言 `JSON.parse` 调用次数 ≤ 3(远小于 chunk 数,强对比旧 N² 行为)
|
|
38
|
+
3. 600KB 无换行 oversized buffer 被丢弃
|
|
39
|
+
4. 无换行结尾消息走 `socket.on('end')` 兜底
|
|
40
|
+
5. EventParser sanity
|
|
41
|
+
|
|
42
|
+
## 实施决策
|
|
43
|
+
|
|
44
|
+
### L4:fire-and-forget + 内部串行
|
|
45
|
+
- **理由**:3 个 git 调用有严格依赖(work-tree 检查 → 拿 HEAD → 写 note),不能 `Promise.all` 并发
|
|
46
|
+
- **关键收益**:原 `execFileSync` 在 handler **主调用链路**中串行阻塞 daemon event loop(最坏 15s);改 `void` 调用后,git I/O 移到下一个 microtask,handler 立刻返回响应给 hook 客户端
|
|
47
|
+
- **副作用控制**:git 失败仍 `logger.debug`,与原行为一致;handler 主体 try/catch 已存在,async fire-and-forget 的未捕获错误已在 `writeGitNote` 内部 catch
|
|
48
|
+
|
|
49
|
+
### L3:方案 A(换行符分隔)
|
|
50
|
+
- **理由**:
|
|
51
|
+
1. 协议天然支持(验证了 `hook-lib.sh` 用 `echo`,默认带 `\n`)
|
|
52
|
+
2. O(1) 检查(`indexOf('\n')` 在 V8 高度优化);旧代码每 chunk 做一次完整 `JSON.parse(buffer)` 在 ~512KB buffer 上是真正的 N²
|
|
53
|
+
3. 单一边界标记,逻辑清晰,无需再保留 `isCompleteJSON` 启发式
|
|
54
|
+
- **兼容性**:保留 `socket.on('end')` 兜底,覆盖未来可能出现的"不带换行的客户端"
|
|
55
|
+
- **协议契约**:不变(hook 端 `echo` 不需要任何修改,服务器只是更聪明地等待 `\n`)
|
|
56
|
+
|
|
57
|
+
## 跳过项
|
|
58
|
+
|
|
59
|
+
无。
|
|
60
|
+
|
|
61
|
+
## 已知问题
|
|
62
|
+
|
|
63
|
+
- **pre-existing**: `tests/unit/storage/sqlite-refactor-harness.test.ts > linkEventToTask` 失败(与本次改动无关,schema 校验 uuid 拒绝测试 fixture 中的 `event_id`)
|