@winspan/claude-forge 0.2.5 → 0.2.6

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.
Files changed (72) hide show
  1. package/dist/autopilot/intent-engine.d.ts +3 -2
  2. package/dist/autopilot/intent-engine.d.ts.map +1 -1
  3. package/dist/autopilot/intent-engine.js +27 -19
  4. package/dist/autopilot/intent-engine.js.map +1 -1
  5. package/dist/autopilot/quality-gate.d.ts +1 -0
  6. package/dist/autopilot/quality-gate.d.ts.map +1 -1
  7. package/dist/autopilot/quality-gate.js +8 -4
  8. package/dist/autopilot/quality-gate.js.map +1 -1
  9. package/dist/cli/commands/logs.d.ts.map +1 -1
  10. package/dist/cli/commands/logs.js +55 -21
  11. package/dist/cli/commands/logs.js.map +1 -1
  12. package/dist/convention/convention-manager.d.ts +2 -0
  13. package/dist/convention/convention-manager.d.ts.map +1 -1
  14. package/dist/convention/convention-manager.js +51 -28
  15. package/dist/convention/convention-manager.js.map +1 -1
  16. package/dist/daemon/engine-registry/init-autopilot.d.ts.map +1 -1
  17. package/dist/daemon/engine-registry/init-autopilot.js +1 -0
  18. package/dist/daemon/engine-registry/init-autopilot.js.map +1 -1
  19. package/dist/daemon/engine-registry/init-distill.d.ts.map +1 -1
  20. package/dist/daemon/engine-registry/init-distill.js +8 -1
  21. package/dist/daemon/engine-registry/init-distill.js.map +1 -1
  22. package/dist/daemon/engine-registry/init-orchestration.d.ts.map +1 -1
  23. package/dist/daemon/engine-registry/init-orchestration.js +3 -1
  24. package/dist/daemon/engine-registry/init-orchestration.js.map +1 -1
  25. package/dist/daemon/engine-registry/init-pipeline.d.ts.map +1 -1
  26. package/dist/daemon/engine-registry/init-pipeline.js +3 -1
  27. package/dist/daemon/engine-registry/init-pipeline.js.map +1 -1
  28. package/dist/daemon/engine-registry/init-resume.d.ts.map +1 -1
  29. package/dist/daemon/engine-registry/init-resume.js +3 -1
  30. package/dist/daemon/engine-registry/init-resume.js.map +1 -1
  31. package/dist/daemon/handler-context.d.ts +8 -0
  32. package/dist/daemon/handler-context.d.ts.map +1 -1
  33. package/dist/daemon/handlers/session-cleanup.d.ts +23 -0
  34. package/dist/daemon/handlers/session-cleanup.d.ts.map +1 -0
  35. package/dist/daemon/handlers/session-cleanup.js +149 -0
  36. package/dist/daemon/handlers/session-cleanup.js.map +1 -0
  37. package/dist/daemon/handlers/stop-handler.d.ts +1 -0
  38. package/dist/daemon/handlers/stop-handler.d.ts.map +1 -1
  39. package/dist/daemon/handlers/stop-handler.js +21 -78
  40. package/dist/daemon/handlers/stop-handler.js.map +1 -1
  41. package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
  42. package/dist/daemon/handlers/user-prompt-handler.js +29 -4
  43. package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
  44. package/dist/daemon/index.d.ts.map +1 -1
  45. package/dist/daemon/index.js +7 -2
  46. package/dist/daemon/index.js.map +1 -1
  47. package/dist/distill/index.d.ts +8 -3
  48. package/dist/distill/index.d.ts.map +1 -1
  49. package/dist/distill/index.js +8 -8
  50. package/dist/distill/index.js.map +1 -1
  51. package/dist/distill/prompts.d.ts.map +1 -1
  52. package/dist/distill/prompts.js +14 -2
  53. package/dist/distill/prompts.js.map +1 -1
  54. package/dist/orchestration/index.d.ts.map +1 -1
  55. package/dist/orchestration/index.js +1 -0
  56. package/dist/orchestration/index.js.map +1 -1
  57. package/dist/pattern-engine/pattern-executor.d.ts.map +1 -1
  58. package/dist/pattern-engine/pattern-executor.js +43 -0
  59. package/dist/pattern-engine/pattern-executor.js.map +1 -1
  60. package/dist/pattern-engine/pattern-router.d.ts +2 -0
  61. package/dist/pattern-engine/pattern-router.d.ts.map +1 -1
  62. package/dist/pattern-engine/pattern-router.js +26 -4
  63. package/dist/pattern-engine/pattern-router.js.map +1 -1
  64. package/dist/storage/sqlite.d.ts +5 -0
  65. package/dist/storage/sqlite.d.ts.map +1 -1
  66. package/dist/storage/sqlite.js +40 -0
  67. package/dist/storage/sqlite.js.map +1 -1
  68. package/dist/utils/logger.d.ts +2 -0
  69. package/dist/utils/logger.d.ts.map +1 -1
  70. package/dist/utils/logger.js +21 -2
  71. package/dist/utils/logger.js.map +1 -1
  72. package/package.json +1 -1
@@ -11,7 +11,14 @@ export function initDistillEngine(config, storage, sharedApi) {
11
11
  const claudeMdEngine = config.claudemd.auto_refine
12
12
  ? new ClaudeMdEngine(sharedApi)
13
13
  : undefined;
14
- const distillEngine = new DistillEngine(storage, sharedApi, claudeMdEngine, config.claudemd.refine_interval);
14
+ const distillEngine = new DistillEngine(storage, sharedApi, {
15
+ onDistillComplete: claudeMdEngine
16
+ ? async (projectPath, content, events) => {
17
+ await claudeMdEngine.refine(projectPath, content, events);
18
+ }
19
+ : undefined,
20
+ refineInterval: config.claudemd.refine_interval,
21
+ });
15
22
  const trigger = new DistillTrigger(distillEngine, storage, config.distill.event_threshold);
16
23
  trigger.startTimer(config.distill.timer_interval_minutes * 60 * 1000);
17
24
  logger.info('蒸馏引擎已初始化(含定时器)');
@@ -1 +1 @@
1
- {"version":3,"file":"init-distill.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-distill.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAK/C,MAAM,UAAU,iBAAiB,CAC/B,MAAc,EACd,OAAsB,EACtB,SAA4B;IAE5B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC,SAAS,EAAE,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;QAClD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,CAAC;QACH,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,WAAW;YAChD,CAAC,CAAC,IAAI,cAAc,CAAC,SAAS,CAAC;YAC/B,CAAC,CAAC,SAAS,CAAC;QACd,MAAM,aAAa,GAAG,IAAI,aAAa,CACrC,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,CAAC,QAAQ,CAAC,eAAe,CACpE,CAAC;QACF,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,aAAa,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC3F,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;QACtE,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC9B,OAAO,OAAO,CAAC;IACjB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"init-distill.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-distill.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAK/C,MAAM,UAAU,iBAAiB,CAC/B,MAAc,EACd,OAAsB,EACtB,SAA4B;IAE5B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC,SAAS,EAAE,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;QAClD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,CAAC;QACH,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,WAAW;YAChD,CAAC,CAAC,IAAI,cAAc,CAAC,SAAS,CAAC;YAC/B,CAAC,CAAC,SAAS,CAAC;QAEd,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC,OAAO,EAAE,SAAS,EAAE;YAC1D,iBAAiB,EAAE,cAAc;gBAC/B,CAAC,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE;oBACrC,MAAM,cAAc,CAAC,MAAM,CAAC,WAAW,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;gBAC5D,CAAC;gBACH,CAAC,CAAC,SAAS;YACb,cAAc,EAAE,MAAM,CAAC,QAAQ,CAAC,eAAe;SAChD,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,aAAa,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC3F,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,sBAAsB,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;QACtE,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC9B,OAAO,OAAO,CAAC;IACjB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"init-orchestration.d.ts","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-orchestration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAEnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,aAAa,GACrB,mBAAmB,GAAG,IAAI,CAM5B"}
1
+ {"version":3,"file":"init-orchestration.d.ts","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-orchestration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAEnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,aAAa,GACrB,mBAAmB,GAAG,IAAI,CAS5B"}
@@ -1,8 +1,10 @@
1
1
  import { OrchestrationEngine } from '../../orchestration/index.js';
2
2
  import { logger } from '../../utils/logger.js';
3
3
  export function initOrchestrationEngine(config, storage) {
4
- if (!config.orchestration.enabled)
4
+ if (!config.orchestration.enabled) {
5
+ logger.info('[编排] 引擎已禁用(orchestration.enabled=false)');
5
6
  return null;
7
+ }
6
8
  const engine = new OrchestrationEngine({ enabled: true });
7
9
  engine.setTrackerDatabase(storage.getDatabase());
8
10
  logger.info('编排引擎已初始化');
@@ -1 +1 @@
1
- {"version":3,"file":"init-orchestration.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-orchestration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAI/C,MAAM,UAAU,uBAAuB,CACrC,MAAc,EACd,OAAsB;IAEtB,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC;IAC/C,MAAM,MAAM,GAAG,IAAI,mBAAmB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IAC1D,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;IACjD,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACxB,OAAO,MAAM,CAAC;AAChB,CAAC"}
1
+ {"version":3,"file":"init-orchestration.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-orchestration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAI/C,MAAM,UAAU,uBAAuB,CACrC,MAAc,EACd,OAAsB;IAEtB,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;QAClC,MAAM,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC;QACvD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,MAAM,MAAM,GAAG,IAAI,mBAAmB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IAC1D,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;IACjD,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACxB,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"init-pipeline.d.ts","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-pipeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAE7D,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,UAAU,GAAG,IAAI,GAC3B,cAAc,GAAG,IAAI,CAOvB"}
1
+ {"version":3,"file":"init-pipeline.d.ts","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-pipeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAE7D,wBAAgB,kBAAkB,CAChC,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,UAAU,GAAG,IAAI,GAC3B,cAAc,GAAG,IAAI,CAUvB"}
@@ -1,8 +1,10 @@
1
1
  import { PipelineEngine } from '../../pipeline/index.js';
2
2
  import { logger } from '../../utils/logger.js';
3
3
  export function initPipelineEngine(storage, sharedApi) {
4
- if (!sharedApi)
4
+ if (!sharedApi) {
5
+ logger.info('[Pipeline] 引擎未初始化(API 不可用)');
5
6
  return null;
7
+ }
6
8
  const engine = new PipelineEngine(storage, sharedApi);
7
9
  // daemon 启动时自动清理超过 2 小时未更新的过期 Pipeline,防止僵尸 Pipeline 持续注入
8
10
  engine.cleanupExpired();
@@ -1 +1 @@
1
- {"version":3,"file":"init-pipeline.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-pipeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAI/C,MAAM,UAAU,kBAAkB,CAChC,OAAsB,EACtB,SAA4B;IAE5B,IAAI,CAAC,SAAS;QAAE,OAAO,IAAI,CAAC;IAC5B,MAAM,MAAM,GAAG,IAAI,cAAc,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IACtD,0DAA0D;IAC1D,MAAM,CAAC,cAAc,EAAE,CAAC;IACxB,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC/B,OAAO,MAAM,CAAC;AAChB,CAAC"}
1
+ {"version":3,"file":"init-pipeline.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-pipeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAI/C,MAAM,UAAU,kBAAkB,CAChC,OAAsB,EACtB,SAA4B;IAE5B,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IACD,MAAM,MAAM,GAAG,IAAI,cAAc,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IACtD,0DAA0D;IAC1D,MAAM,CAAC,cAAc,EAAE,CAAC;IACxB,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC/B,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"init-resume.d.ts","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-resume.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAErD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,UAAU,GAAG,IAAI,GAC3B,YAAY,GAAG,IAAI,CAcrB"}
1
+ {"version":3,"file":"init-resume.d.ts","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-resume.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAErD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,UAAU,GAAG,IAAI,GAC3B,YAAY,GAAG,IAAI,CAiBrB"}
@@ -1,8 +1,10 @@
1
1
  import { ResumeEngine } from '../../resume/index.js';
2
2
  import { logger } from '../../utils/logger.js';
3
3
  export function initResumeEngine(config, storage, sharedApi) {
4
- if (!config.resume.enabled || !sharedApi)
4
+ if (!config.resume.enabled || !sharedApi) {
5
+ logger.info(`[续接] 引擎未初始化(enabled=${config.resume.enabled}, api=${!!sharedApi})`);
5
6
  return null;
7
+ }
6
8
  try {
7
9
  const engine = new ResumeEngine(storage, sharedApi, config.resume.timeout_minutes, config.resume.max_age_days);
8
10
  logger.info('续接引擎已初始化');
@@ -1 +1 @@
1
- {"version":3,"file":"init-resume.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-resume.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAK/C,MAAM,UAAU,gBAAgB,CAC9B,MAAc,EACd,OAAsB,EACtB,SAA4B;IAE5B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,SAAS;QAAE,OAAO,IAAI,CAAC;IACtD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,YAAY,CAC7B,OAAO,EAAE,SAAS,EAClB,MAAM,CAAC,MAAM,CAAC,eAAe,EAC7B,MAAM,CAAC,MAAM,CAAC,YAAY,CAC3B,CAAC;QACF,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACxB,OAAO,MAAM,CAAC;IAChB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"init-resume.js","sourceRoot":"","sources":["../../../src/daemon/engine-registry/init-resume.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAK/C,MAAM,UAAU,gBAAgB,CAC9B,MAAc,EACd,OAAsB,EACtB,SAA4B;IAE5B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC;QACzC,MAAM,CAAC,IAAI,CAAC,uBAAuB,MAAM,CAAC,MAAM,CAAC,OAAO,SAAS,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC;QACjF,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,YAAY,CAC7B,OAAO,EAAE,SAAS,EAClB,MAAM,CAAC,MAAM,CAAC,eAAe,EAC7B,MAAM,CAAC,MAAM,CAAC,YAAY,CAC3B,CAAC;QACF,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACxB,OAAO,MAAM,CAAC;IAChB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
@@ -32,4 +32,12 @@ export interface HandlerContext {
32
32
  /** 已完成首次检查(CLAUDE.md + resume)的项目路径,跨 Handler 共享 */
33
33
  checkedProjects: Set<string>;
34
34
  }
35
+ /** UserPromptHandler 所需的最小上下文 */
36
+ export type UserPromptDeps = Pick<HandlerContext, 'intentEngine' | 'skillRegistry' | 'profileManager' | 'pipelineEngine' | 'qualityGate' | 'conventionManager' | 'patternEngine' | 'storage' | 'config'>;
37
+ /** StopHandler 所需的最小上下文 */
38
+ export type StopHandlerDeps = Pick<HandlerContext, 'resumeEngine' | 'qualityGate' | 'trigger' | 'orchestration' | 'storage' | 'config' | 'sharedApi' | 'skillRegistry' | 'profileManager'>;
39
+ /** PreToolUseHandler 所需的最小上下文 */
40
+ export type PreToolUseDeps = Pick<HandlerContext, 'orchestration' | 'skillRegistry' | 'pipelineEngine' | 'patternEngine' | 'resumeEngine' | 'storage' | 'config' | 'checkedProjects'>;
41
+ /** PostToolUseHandler 所需的最小上下文 */
42
+ export type PostToolUseDeps = Pick<HandlerContext, 'orchestration' | 'patternEngine' | 'pipelineEngine' | 'qualityGate' | 'trigger' | 'storage'>;
35
43
  //# sourceMappingURL=handler-context.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"handler-context.d.ts","sourceRoot":"","sources":["../../src/daemon/handler-context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACtE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE;;;GAGG;AACH,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,aAAa,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,cAAc,GAAG,IAAI,CAAC;IAC/B,YAAY,EAAE,YAAY,GAAG,IAAI,CAAC;IAClC,aAAa,EAAE,mBAAmB,GAAG,IAAI,CAAC;IAC1C,aAAa,EAAE,mBAAmB,CAAC;IACnC,cAAc,EAAE,cAAc,GAAG,IAAI,CAAC;IACtC,YAAY,EAAE,YAAY,GAAG,IAAI,CAAC;IAClC,WAAW,EAAE,iBAAiB,GAAG,IAAI,CAAC;IACtC,cAAc,EAAE,cAAc,CAAC;IAC/B,SAAS,EAAE,UAAU,GAAG,IAAI,CAAC;IAC7B,aAAa,EAAE,aAAa,GAAG,IAAI,CAAC;IACpC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oDAAoD;IACpD,eAAe,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;CAC9B"}
1
+ {"version":3,"file":"handler-context.d.ts","sourceRoot":"","sources":["../../src/daemon/handler-context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACtE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE;;;GAGG;AACH,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,aAAa,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,cAAc,GAAG,IAAI,CAAC;IAC/B,YAAY,EAAE,YAAY,GAAG,IAAI,CAAC;IAClC,aAAa,EAAE,mBAAmB,GAAG,IAAI,CAAC;IAC1C,aAAa,EAAE,mBAAmB,CAAC;IACnC,cAAc,EAAE,cAAc,GAAG,IAAI,CAAC;IACtC,YAAY,EAAE,YAAY,GAAG,IAAI,CAAC;IAClC,WAAW,EAAE,iBAAiB,GAAG,IAAI,CAAC;IACtC,cAAc,EAAE,cAAc,CAAC;IAC/B,SAAS,EAAE,UAAU,GAAG,IAAI,CAAC;IAC7B,aAAa,EAAE,aAAa,GAAG,IAAI,CAAC;IACpC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oDAAoD;IACpD,eAAe,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;CAC9B;AAID,iCAAiC;AACjC,MAAM,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,EAC9C,cAAc,GAAG,eAAe,GAAG,gBAAgB,GAAG,gBAAgB,GACtE,aAAa,GAAG,mBAAmB,GAAG,eAAe,GAAG,SAAS,GAAG,QAAQ,CAC7E,CAAC;AAEF,2BAA2B;AAC3B,MAAM,MAAM,eAAe,GAAG,IAAI,CAAC,cAAc,EAC/C,cAAc,GAAG,aAAa,GAAG,SAAS,GAAG,eAAe,GAC5D,SAAS,GAAG,QAAQ,GAAG,WAAW,GAAG,eAAe,GAAG,gBAAgB,CACxE,CAAC;AAEF,iCAAiC;AACjC,MAAM,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,EAC9C,eAAe,GAAG,eAAe,GAAG,gBAAgB,GAAG,eAAe,GACtE,cAAc,GAAG,SAAS,GAAG,QAAQ,GAAG,iBAAiB,CAC1D,CAAC;AAEF,kCAAkC;AAClC,MAAM,MAAM,eAAe,GAAG,IAAI,CAAC,cAAc,EAC/C,eAAe,GAAG,eAAe,GAAG,gBAAgB,GAAG,aAAa,GACpE,SAAS,GAAG,SAAS,CACtB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import type { ForgeEvent } from '../../types/index.js';
2
+ import type { HandlerContext } from '../handler-context.js';
3
+ /**
4
+ * SessionCleanupService:会话结束后的异步清理任务。
5
+ * 每个任务独立 try/catch,单个任务失败不影响其他任务执行。
6
+ */
7
+ export declare class SessionCleanupService {
8
+ private ctx;
9
+ constructor(ctx: HandlerContext);
10
+ /** 基于蒸馏内容异步更新 CLAUDE.md */
11
+ refineClaudeMd(event: ForgeEvent): Promise<void>;
12
+ /** 文档同步:扫描本次会话改动的文件,更新受影响的项目文档 */
13
+ syncDocs(event: ForgeEvent): Promise<void>;
14
+ /** Skill 自进化检查 */
15
+ evolveSkills(): Promise<void>;
16
+ /** 项目历史学习 */
17
+ learnFromProject(event: ForgeEvent): Promise<void>;
18
+ /** 用户画像更新 */
19
+ updateProfile(): Promise<void>;
20
+ /** AI 驱动的画像进化 */
21
+ evolveProfile(): Promise<void>;
22
+ }
23
+ //# sourceMappingURL=session-cleanup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-cleanup.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/session-cleanup.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAM5D;;;GAGG;AACH,qBAAa,qBAAqB;IAChC,OAAO,CAAC,GAAG,CAAiB;gBAEhB,GAAG,EAAE,cAAc;IAI/B,2BAA2B;IACrB,cAAc,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IA6BtD,kCAAkC;IAC5B,QAAQ,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAyBhD,kBAAkB;IACZ,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAwBnC,aAAa;IACP,gBAAgB,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAqBxD,aAAa;IACP,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IASpC,iBAAiB;IACX,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;CAarC"}
@@ -0,0 +1,149 @@
1
+ import { ClaudeMdEngine } from '../../claudemd/index.js';
2
+ import { DistillWriter } from '../../distill/writer.js';
3
+ import { DocSyncEngine } from '../../doc-sync/index.js';
4
+ import { logger } from '../../utils/logger.js';
5
+ /**
6
+ * SessionCleanupService:会话结束后的异步清理任务。
7
+ * 每个任务独立 try/catch,单个任务失败不影响其他任务执行。
8
+ */
9
+ export class SessionCleanupService {
10
+ ctx;
11
+ constructor(ctx) {
12
+ this.ctx = ctx;
13
+ }
14
+ /** 基于蒸馏内容异步更新 CLAUDE.md */
15
+ async refineClaudeMd(event) {
16
+ if (!event.project_path) {
17
+ logger.info('[Forge:CLAUDE.md] 跳过:无项目路径');
18
+ return;
19
+ }
20
+ if (!this.ctx.sharedApi) {
21
+ logger.info('[Forge:CLAUDE.md] 跳过:API 未配置');
22
+ return;
23
+ }
24
+ try {
25
+ logger.info(`[Forge:CLAUDE.md] 开始自动更新:${event.project_path.split('/').slice(-2).join('/')}`);
26
+ const claudeMdEngine = new ClaudeMdEngine(this.ctx.sharedApi);
27
+ const distillWriter = new DistillWriter();
28
+ const lastDecisions = distillWriter.readDecisionsSince(event.project_path) || distillWriter.readLastDecisions(event.project_path, 30);
29
+ const events = this.ctx.storage.queryEvents({ project_path: event.project_path, limit: 50 });
30
+ const updated = await claudeMdEngine.refine(event.project_path, lastDecisions, events);
31
+ if (updated) {
32
+ logger.info(`[Forge:CLAUDE.md] 自动更新完成`);
33
+ if (this.ctx.orchestration) {
34
+ this.ctx.orchestration.pushNotification('[Forge] CLAUDE.md 已根据最新蒸馏内容自动更新');
35
+ }
36
+ }
37
+ else {
38
+ logger.info('[Forge:CLAUDE.md] 无需更新(内容无变化或不满足条件)');
39
+ }
40
+ }
41
+ catch (err) {
42
+ logger.warn(`[Forge:CLAUDE.md] 自动更新失败:${err}`);
43
+ }
44
+ }
45
+ /** 文档同步:扫描本次会话改动的文件,更新受影响的项目文档 */
46
+ async syncDocs(event) {
47
+ if (!event.project_path) {
48
+ logger.info('[Forge:文档同步] 跳过:无项目路径');
49
+ return;
50
+ }
51
+ if (!this.ctx.sharedApi) {
52
+ logger.info('[Forge:文档同步] 跳过:API 未配置');
53
+ return;
54
+ }
55
+ try {
56
+ const windowStart = new Date(Date.now() - 2 * 60 * 60 * 1000).toISOString();
57
+ const recentEvents = this.ctx.storage.queryEvents({
58
+ project_path: event.project_path,
59
+ start_time: windowStart,
60
+ limit: 1000,
61
+ });
62
+ logger.info(`[Forge:文档同步] 开始同步 | 项目=${event.project_path.split('/').slice(-2).join('/')} | 近 2h 事件=${recentEvents.length} 条`);
63
+ const docSync = new DocSyncEngine(this.ctx.sharedApi);
64
+ await docSync.sync(event.session_id, event.project_path, recentEvents);
65
+ logger.info(`[Forge:文档同步] 完成`);
66
+ }
67
+ catch (err) {
68
+ logger.warn(`[Forge:文档同步] 同步失败:${err}`);
69
+ }
70
+ }
71
+ /** Skill 自进化检查 */
72
+ async evolveSkills() {
73
+ try {
74
+ logger.info('[Forge:技能进化] 开始检查');
75
+ const evolveReport = await this.ctx.skillRegistry.maybeEvolve(10);
76
+ if (evolveReport) {
77
+ const parts = [];
78
+ if (evolveReport.retired.length > 0)
79
+ parts.push(`淘汰 ${evolveReport.retired.length} 个`);
80
+ if (evolveReport.generated.length > 0)
81
+ parts.push(`生成 ${evolveReport.generated.length} 个新 Skill`);
82
+ if (parts.length > 0) {
83
+ logger.info(`[Forge:技能进化] 完成:${parts.join(',')}`);
84
+ if (this.ctx.orchestration) {
85
+ this.ctx.orchestration.pushNotification(`[Forge 进化] ${parts.join(',')}`);
86
+ }
87
+ }
88
+ else {
89
+ logger.info('[Forge:技能进化] 完成:无变更');
90
+ }
91
+ }
92
+ else {
93
+ logger.info('[Forge:技能进化] 跳过(未达到触发条件)');
94
+ }
95
+ }
96
+ catch (err) {
97
+ logger.warn(`[Forge:技能进化] 失败:${err}`);
98
+ }
99
+ }
100
+ /** 项目历史学习 */
101
+ async learnFromProject(event) {
102
+ if (!event.project_path) {
103
+ logger.info('[Forge:项目学习] 跳过:无项目路径');
104
+ return;
105
+ }
106
+ try {
107
+ logger.info(`[Forge:项目学习] 开始:${event.project_path.split('/').slice(-2).join('/')}`);
108
+ const learnReport = await this.ctx.skillRegistry.learnFromProject(event.project_path);
109
+ if (learnReport && learnReport.generated.length > 0) {
110
+ logger.info(`[Forge:项目学习] 完成:生成 ${learnReport.generated.length} 个专属技能`);
111
+ if (this.ctx.orchestration) {
112
+ this.ctx.orchestration.pushNotification(`[Forge 学习] 从项目历史生成 ${learnReport.generated.length} 个专属技能`);
113
+ }
114
+ }
115
+ else {
116
+ logger.info('[Forge:项目学习] 完成:无新技能生成');
117
+ }
118
+ }
119
+ catch (err) {
120
+ logger.warn(`[Forge:项目学习] 失败:${err}`);
121
+ }
122
+ }
123
+ /** 用户画像更新 */
124
+ async updateProfile() {
125
+ try {
126
+ this.ctx.profileManager.updateRatesFromBehavior();
127
+ logger.info('[Forge:画像] 行为统计已更新');
128
+ }
129
+ catch (err) {
130
+ logger.warn(`[Forge:画像] 行为统计更新失败:${err}`);
131
+ }
132
+ }
133
+ /** AI 驱动的画像进化 */
134
+ async evolveProfile() {
135
+ if (!this.ctx.sharedApi) {
136
+ logger.info('[Forge:画像] AI 进化跳过:API 未配置');
137
+ return;
138
+ }
139
+ try {
140
+ logger.info('[Forge:画像] 开始 AI 画像进化');
141
+ await this.ctx.profileManager.evolveWithAI(this.ctx.sharedApi);
142
+ logger.info('[Forge:画像] AI 画像进化完成');
143
+ }
144
+ catch (err) {
145
+ logger.warn(`[Forge:画像] AI 进化失败:${err}`);
146
+ }
147
+ }
148
+ }
149
+ //# sourceMappingURL=session-cleanup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-cleanup.js","sourceRoot":"","sources":["../../../src/daemon/handlers/session-cleanup.ts"],"names":[],"mappings":"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"}
@@ -4,6 +4,7 @@ import type { HandlerContext } from '../handler-context.js';
4
4
  import { BaseHookHandler } from './base-handler.js';
5
5
  export declare class StopHandler extends BaseHookHandler {
6
6
  private readonly promptInjector;
7
+ private readonly cleanup;
7
8
  private stopCount;
8
9
  constructor(ctx: HandlerContext);
9
10
  handle(event: ForgeEvent): Promise<HookResponse | void>;
@@ -1 +1 @@
1
- {"version":3,"file":"stop-handler.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/stop-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAOpD,qBAAa,WAAY,SAAQ,eAAe;IAC9C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAwB;IACvD,OAAO,CAAC,SAAS,CAAK;gBAEV,GAAG,EAAE,cAAc;IAIzB,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;CAmI9D"}
1
+ {"version":3,"file":"stop-handler.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/stop-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAKpD,qBAAa,WAAY,SAAQ,eAAe;IAC9C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAwB;IACvD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAwB;IAChD,OAAO,CAAC,SAAS,CAAK;gBAEV,GAAG,EAAE,cAAc;IAKzB,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;CAmE9D"}
@@ -1,20 +1,20 @@
1
1
  import { BaseHookHandler } from './base-handler.js';
2
2
  import { PromptInjector } from '../../claudemd/prompt-injector.js';
3
- import { ClaudeMdEngine } from '../../claudemd/index.js';
4
- import { DistillWriter } from '../../distill/writer.js';
5
- import { DocSyncEngine } from '../../doc-sync/index.js';
3
+ import { SessionCleanupService } from './session-cleanup.js';
6
4
  import { logger } from '../../utils/logger.js';
7
5
  export class StopHandler extends BaseHookHandler {
8
6
  promptInjector = new PromptInjector();
7
+ cleanup;
9
8
  stopCount = 0;
10
9
  constructor(ctx) {
11
10
  super(ctx);
11
+ this.cleanup = new SessionCleanupService(ctx);
12
12
  }
13
13
  async handle(event) {
14
- const { resumeEngine, qualityGate, trigger, orchestration, skillRegistry, config, profileManager } = this.ctx;
14
+ const { resumeEngine, qualityGate, trigger, config } = this.ctx;
15
15
  this.stopCount++;
16
16
  logger.info(`[Forge:Stop] 会话结束 | session=${event.session_id} | project=${event.project_path.split('/').slice(-2).join('/')}`);
17
- // 1. 保存续接摘要(趁数据新鲜)
17
+ // 1. 保存续接摘要
18
18
  if (resumeEngine) {
19
19
  try {
20
20
  await resumeEngine.saveOnStop(event.session_id, event.project_path);
@@ -28,11 +28,10 @@ export class StopHandler extends BaseHookHandler {
28
28
  if (config.claudemd.auto_generate) {
29
29
  await this.promptInjector.checkAndPrompt(event.project_path);
30
30
  }
31
- // 3. 质量报告:有 fail 项则阻断会话结束,强制修复
31
+ // 3. 质量门禁:有 fail 项则阻断
32
32
  if (qualityGate) {
33
33
  const failures = qualityGate.getUnresolvedFailures();
34
34
  if (failures.length > 0) {
35
- const report = qualityGate.generateReport();
36
35
  logger.warn(`[Forge:质量门禁] 发现 ${failures.length} 个未解决的失败项,阻断会话结束`);
37
36
  const issueLines = [];
38
37
  for (const f of failures) {
@@ -43,9 +42,7 @@ export class StopHandler extends BaseHookHandler {
43
42
  issueLines.push(` 修复建议:${c.suggestion}`);
44
43
  }
45
44
  }
46
- const reason = `[Forge QualityGate] ❌ 以下质量问题必须在结束前修复:\n\n${issueLines.join('\n')}\n\n请修复上述问题后再结束会话。`;
47
- // 不 reset,保留历史供下次 Stop 检查
48
- return { allow: false, reason };
45
+ return { allow: false, reason: `[Forge QualityGate] ❌ 以下质量问题必须在结束前修复:\n\n${issueLines.join('\n')}\n\n请修复上述问题后再结束会话。` };
49
46
  }
50
47
  const report = qualityGate.generateReport();
51
48
  if (report && report !== '暂无审查记录。') {
@@ -53,83 +50,29 @@ export class StopHandler extends BaseHookHandler {
53
50
  }
54
51
  qualityGate.reset();
55
52
  }
56
- // 4. 触发蒸馏
53
+ // 4. 蒸馏
57
54
  if (trigger) {
58
55
  const eventsCount = this.ctx.storage.queryEvents({
59
56
  session_id: event.session_id,
60
- project_path: event.project_path
57
+ project_path: event.project_path,
61
58
  }).length;
62
59
  logger.info(`[Forge:蒸馏] 开始蒸馏 | session=${event.session_id} | events=${eventsCount}`);
63
60
  await trigger.onStopHook(event.session_id, event.project_path);
64
61
  logger.info(`[Forge:蒸馏] 完成 | decisions.md 和 timeline.md 已更新`);
65
- if (orchestration && config.orchestration.notify_on_distill) {
66
- orchestration.pushNotification('[Forge] 会话蒸馏完成,decisions.md 和 timeline.md 已更新');
62
+ if (this.ctx.orchestration && config.orchestration.notify_on_distill) {
63
+ this.ctx.orchestration.pushNotification('[Forge] 会话蒸馏完成');
67
64
  }
68
- // 5b. 蒸馏完成后,异步更新 CLAUDE.md(每 5 次 Stop 触发一次,避免频繁 API 调用)
69
- // 增量优化:ClaudeMdEngine.refine() 内部会检查 refine-state,不足 3 次蒸馏且无新增内容时自动跳过
70
- if (event.project_path && this.stopCount % 5 === 0 && this.ctx.sharedApi) {
71
- const claudeMdEngine = new ClaudeMdEngine(this.ctx.sharedApi);
72
- const distillWriter = new DistillWriter();
73
- const lastDecisions = distillWriter.readDecisionsSince(event.project_path) || distillWriter.readLastDecisions(event.project_path, 30);
74
- const events = this.ctx.storage.queryEvents({ project_path: event.project_path, limit: 50 });
75
- claudeMdEngine.refine(event.project_path, lastDecisions, events).then(updated => {
76
- if (updated) {
77
- logger.info(`[Forge:CLAUDE.md] 基于蒸馏内容自动更新完成:${event.project_path}`);
78
- if (orchestration) {
79
- orchestration.pushNotification('[Forge] CLAUDE.md 已根据最新蒸馏内容自动更新');
80
- }
81
- }
82
- }).catch(err => {
83
- logger.warn(`[Forge:CLAUDE.md] 自动更新失败:${err}`);
84
- });
85
- }
86
- // 5c. 文档同步:扫描本次会话改动的文件,更新受影响的项目文档
87
- // 注意:hooks 未设置 CLAUDE_CODE_SESSION_ID 时 session_id 均为 'cli',
88
- // 因此改用时间窗口(最近 2 小时)查询写操作事件,避免跨会话污染。
89
- if (event.project_path && this.ctx.sharedApi) {
90
- const windowStart = new Date(Date.now() - 2 * 60 * 60 * 1000).toISOString();
91
- const recentEvents = this.ctx.storage.queryEvents({
92
- project_path: event.project_path,
93
- start_time: windowStart,
94
- limit: 1000,
95
- });
96
- logger.info(`[Forge:文档同步] 开始同步 | 近 2h 事件=${recentEvents.length} 条`);
97
- const docSync = new DocSyncEngine(this.ctx.sharedApi);
98
- docSync.sync(event.session_id, event.project_path, recentEvents).then(() => {
99
- logger.info(`[Forge:文档同步] 完成`);
100
- }).catch(err => {
101
- logger.warn(`[Forge:文档同步] 同步失败:${err}`);
102
- });
103
- }
104
- // 6. Skill 自进化检查(每 10 次 Stop 触发一次)
105
- const evolveReport = await skillRegistry.maybeEvolve(10);
106
- if (evolveReport && orchestration) {
107
- const parts = [];
108
- if (evolveReport.retired.length > 0)
109
- parts.push(`淘汰 ${evolveReport.retired.length} 个`);
110
- if (evolveReport.generated.length > 0)
111
- parts.push(`生成 ${evolveReport.generated.length} 个新 Skill`);
112
- if (parts.length > 0) {
113
- orchestration.pushNotification(`[Forge 进化] ${parts.join(',')}`);
114
- }
115
- }
116
- // 7. 项目历史学习(每 5 次 Stop 触发一次)
117
- if (event.project_path && this.stopCount % 5 === 0) {
118
- const learnReport = await skillRegistry.learnFromProject(event.project_path);
119
- if (learnReport && learnReport.generated.length > 0 && orchestration) {
120
- orchestration.pushNotification(`[Forge 学习] 从项目历史生成 ${learnReport.generated.length} 个专属技能`);
121
- }
122
- }
123
- }
124
- // Stop 事件不需要返回 HookResponse
125
- // 8. 用户画像更新(每次 Stop 更新行为统计,每 10 次触发 AI 进化)
126
- profileManager.updateRatesFromBehavior();
127
- if (this.stopCount % 10 === 0 && this.ctx.sharedApi) {
128
- profileManager.evolveWithAI(this.ctx.sharedApi).catch(err => {
129
- logger.warn(`[Forge:画像] AI 进化失败:${err}`);
130
- });
131
- logger.info('[Forge:画像] 已触发 AI 画像进化');
132
65
  }
66
+ // 5-8. 异步清理任务(独立 try/catch,互不影响)
67
+ if (this.stopCount % 5 === 0)
68
+ this.cleanup.refineClaudeMd(event);
69
+ this.cleanup.syncDocs(event);
70
+ this.cleanup.evolveSkills();
71
+ if (this.stopCount % 5 === 0)
72
+ this.cleanup.learnFromProject(event);
73
+ this.cleanup.updateProfile();
74
+ if (this.stopCount % 10 === 0)
75
+ this.cleanup.evolveProfile();
133
76
  }
134
77
  }
135
78
  //# sourceMappingURL=stop-handler.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"stop-handler.js","sourceRoot":"","sources":["../../../src/daemon/handlers/stop-handler.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"stop-handler.js","sourceRoot":"","sources":["../../../src/daemon/handlers/stop-handler.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"user-prompt-handler.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAkBpD,qBAAa,iBAAkB,SAAQ,eAAe;IACpD;;;OAGG;IACH,OAAO,CAAC,iBAAiB,CAA8B;IACvD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAA6B;IACnD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAAqC;IAE3D,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAO;IACnD,iCAAiC;IACjC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAkB;IAE1D,OAAO,CAAC,aAAa,CAA8B;gBAEvC,GAAG,EAAE,cAAc;IAK/B,4DAA4D;IAC5D,OAAO,CAAC,oBAAoB,CAAqB;IACjD,6CAA6C;IAC7C,OAAO,CAAC,cAAc,CAA6B;IAE7C,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IA+E7D;;;OAGG;YACW,mBAAmB;IAsBjC,6BAA6B;IAC7B,OAAO,CAAC,aAAa;IAYrB;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IAqDhC,8CAA8C;IAC9C,OAAO,CAAC,iBAAiB;IAkBzB,OAAO,CAAC,oBAAoB;IAQ5B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAiB3B,OAAO,CAAC,WAAW;IASnB;;;OAGG;YACW,kBAAkB;IAsChC,OAAO,CAAC,kBAAkB;IAW1B,+DAA+D;YACjD,iBAAiB;YA4BjB,iBAAiB;IAwC/B,OAAO,CAAC,oBAAoB;YAkBd,mBAAmB;IAiCjC;;;OAGG;IACH,OAAO,CAAC,oBAAoB;IAoC5B;;;OAGG;IACH,OAAO,CAAC,aAAa;IAerB;;OAEG;YACW,uBAAuB;CA0BtC"}
1
+ {"version":3,"file":"user-prompt-handler.d.ts","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAkBpD,qBAAa,iBAAkB,SAAQ,eAAe;IACpD;;;OAGG;IACH,OAAO,CAAC,iBAAiB,CAA8B;IACvD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAA6B;IACnD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAAqC;IAE3D,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAO;IACnD,iCAAiC;IACjC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAkB;IAE1D,OAAO,CAAC,aAAa,CAA8B;gBAEvC,GAAG,EAAE,cAAc;IAK/B,4DAA4D;IAC5D,OAAO,CAAC,oBAAoB,CAAqB;IACjD,6CAA6C;IAC7C,OAAO,CAAC,cAAc,CAA6B;IAE7C,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAoF7D;;;OAGG;YACW,mBAAmB;IAwBjC,6BAA6B;IAC7B,OAAO,CAAC,aAAa;IAYrB;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IAqDhC,8CAA8C;IAC9C,OAAO,CAAC,iBAAiB;IAkBzB,OAAO,CAAC,oBAAoB;IAQ5B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAiB3B,OAAO,CAAC,WAAW;IASnB;;;OAGG;YACW,kBAAkB;IAyChC,OAAO,CAAC,kBAAkB;IAW1B,+DAA+D;YACjD,iBAAiB;YA4BjB,iBAAiB;IA+C/B,OAAO,CAAC,oBAAoB;YAkBd,mBAAmB;IA2CjC;;;OAGG;IACH,OAAO,CAAC,oBAAoB;IAoC5B;;;OAGG;IACH,OAAO,CAAC,aAAa;IAerB;;OAEG;YACW,uBAAuB;CA0BtC"}
@@ -58,8 +58,10 @@ export class UserPromptHandler extends BaseHookHandler {
58
58
  // 注入确认消息后继续让 Claude 处理原始消息
59
59
  return { allow: true, additionalContext: ForgeFormatter.wrapInQuote(configMsg) };
60
60
  }
61
- if (!intentEngine)
61
+ if (!intentEngine) {
62
+ logger.info('[Forge:处理器] intentEngine 不可用,跳过意图分析');
62
63
  return;
64
+ }
63
65
  // 1. 检查是否是对 Pipeline 选择的回复(优先处理)
64
66
  const pipelineReply = await this.handlePipelineReply(userPrompt, event);
65
67
  if (pipelineReply !== undefined)
@@ -81,8 +83,10 @@ export class UserPromptHandler extends BaseHookHandler {
81
83
  // 4. 干预级别
82
84
  const interventionLevel = this.ctx.profileManager.getInterventionLevel(analysis.complexity);
83
85
  logger.info(`[Forge:画像] intervention=${interventionLevel} | complexity=${analysis.complexity}`);
84
- if (interventionLevel === 'silent' || analysis.complexity === 'simple')
86
+ if (interventionLevel === 'silent' || analysis.complexity === 'simple') {
87
+ logger.info(`[Forge:处理器] 静默跳过:intervention=${interventionLevel} complexity=${analysis.complexity}`);
85
88
  return;
89
+ }
86
90
  // 5. 执行路径卡片
87
91
  const card = this.buildExecutionCard(analysis);
88
92
  // 6. 复杂任务 Pipeline 决策
@@ -93,7 +97,6 @@ export class UserPromptHandler extends BaseHookHandler {
93
97
  }
94
98
  // 7. 简单/中等任务:知识搜索 + 指令注入
95
99
  const response = await this.buildSimpleResponse(analysis, card, event.project_path);
96
- logger.info(`[Forge:处理器] 处理完成:path=直接执行 | complexity=${analysis.complexity} | context=${response.additionalContext ? '已注入' : '无'}`);
97
100
  return response;
98
101
  }
99
102
  catch (err) {
@@ -112,11 +115,13 @@ export class UserPromptHandler extends BaseHookHandler {
112
115
  const choice = parsePipelineChoice(userPrompt);
113
116
  if (choice) {
114
117
  this.setSuggestionPending(event.project_path, false);
118
+ logger.info(`[Forge:处理器] Pipeline 选择已接受:${choice}`);
115
119
  profileManager.recordBehavior({ type: 'accept', context: `pipeline:${choice}`, timestamp: new Date().toISOString() });
116
120
  return this.startPipelineFromChoice(choice, event);
117
121
  }
118
122
  if (this.suggestionPending.get(event.project_path)) {
119
123
  this.setSuggestionPending(event.project_path, false);
124
+ logger.info('[Forge:处理器] Pipeline 建议被忽略');
120
125
  profileManager.recordBehavior({ type: 'skip', context: 'pipeline:ignored', timestamp: new Date().toISOString() });
121
126
  }
122
127
  return undefined;
@@ -243,8 +248,10 @@ export class UserPromptHandler extends BaseHookHandler {
243
248
  return undefined;
244
249
  try {
245
250
  const patternCtx = await patternEngine.routeAndStart(userPrompt, event.session_id, event.project_path, complexity);
246
- if (!patternCtx)
251
+ if (!patternCtx) {
252
+ logger.info('[Forge:Pattern] 未匹配到 Pattern,走常规编排路径');
247
253
  return undefined;
254
+ }
248
255
  const plan = patternEngine.getActivePlan(event.project_path);
249
256
  if (!plan)
250
257
  return undefined;
@@ -310,9 +317,15 @@ export class UserPromptHandler extends BaseHookHandler {
310
317
  }
311
318
  const context = ForgeFormatter.wrapInQuote(this.budgetContext({ content: this.buildProfileContext(event.project_path), priority: -1 }, { content: conventionPrompt, priority: 0 }, { content: autoMsg, priority: 1 }, { content: this.readDecisionsContext(analysis.requirement, event.project_path), priority: 2 }));
312
319
  if (analysis.clarifyQuestions?.length) {
320
+ logger.info(`[Forge:Pipeline] 自动启动 + 注入澄清问题 ${analysis.clarifyQuestions.length} 个`);
313
321
  const clarify = ForgeFormatter.formatClarifyRequest(analysis.clarifyQuestions);
314
322
  return { allow: true, systemMessage: card, additionalContext: ForgeFormatter.mergeContexts(context, clarify) };
315
323
  }
324
+ // 汇总注入内容
325
+ const pipelineInjected = ['Pipeline指令'];
326
+ if (conventionPrompt)
327
+ pipelineInjected.push(`规范(${activeConventions.map(c => c.id).join(',')})`);
328
+ logger.info(`[Forge:Pipeline] 自动启动完成 | tasks=${pipeline.tasks.length} | 注入=[${pipelineInjected.join(', ')}]`);
316
329
  return { allow: true, systemMessage: card, additionalContext: context };
317
330
  }
318
331
  promptPipelineChoice(analysis, card, event) {
@@ -337,6 +350,7 @@ export class UserPromptHandler extends BaseHookHandler {
337
350
  }
338
351
  if (analysis.clarifyQuestions?.length) {
339
352
  const clarify = ForgeFormatter.formatClarifyRequest(analysis.clarifyQuestions);
353
+ logger.info(`[Forge:处理器] 注入澄清问题 ${analysis.clarifyQuestions.length} 个`);
340
354
  return {
341
355
  allow: true,
342
356
  systemMessage: card,
@@ -344,6 +358,17 @@ export class UserPromptHandler extends BaseHookHandler {
344
358
  };
345
359
  }
346
360
  const body = this.budgetContext({ content: this.buildProfileContext(projectPath), priority: -1 }, { content: conventionPrompt, priority: 0 }, { content: directive ?? undefined, priority: 1 }, { content: decisionsContext, priority: 2 });
361
+ // 汇总注入内容
362
+ const injected = [];
363
+ if (this.injectionCache.get(projectPath)?.profileInjected)
364
+ injected.push('画像');
365
+ if (conventionPrompt)
366
+ injected.push(`规范(${activeConventions.map(c => c.id).join(',')})`);
367
+ if (directive)
368
+ injected.push('执行指令');
369
+ if (decisionsContext)
370
+ injected.push('决策历史');
371
+ logger.info(`[Forge:处理器] 处理完成:path=直接执行 | complexity=${analysis.complexity} | 注入=[${injected.join(', ') || '无'}]`);
347
372
  return {
348
373
  allow: true,
349
374
  systemMessage: card,