@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.
- package/dist/autopilot/intent-engine.d.ts +3 -2
- package/dist/autopilot/intent-engine.d.ts.map +1 -1
- package/dist/autopilot/intent-engine.js +27 -19
- package/dist/autopilot/intent-engine.js.map +1 -1
- package/dist/autopilot/quality-gate.d.ts +1 -0
- package/dist/autopilot/quality-gate.d.ts.map +1 -1
- package/dist/autopilot/quality-gate.js +8 -4
- package/dist/autopilot/quality-gate.js.map +1 -1
- package/dist/cli/commands/logs.d.ts.map +1 -1
- package/dist/cli/commands/logs.js +55 -21
- package/dist/cli/commands/logs.js.map +1 -1
- package/dist/convention/convention-manager.d.ts +2 -0
- package/dist/convention/convention-manager.d.ts.map +1 -1
- package/dist/convention/convention-manager.js +51 -28
- package/dist/convention/convention-manager.js.map +1 -1
- package/dist/daemon/engine-registry/init-autopilot.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-autopilot.js +1 -0
- package/dist/daemon/engine-registry/init-autopilot.js.map +1 -1
- package/dist/daemon/engine-registry/init-distill.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-distill.js +8 -1
- package/dist/daemon/engine-registry/init-distill.js.map +1 -1
- package/dist/daemon/engine-registry/init-orchestration.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-orchestration.js +3 -1
- package/dist/daemon/engine-registry/init-orchestration.js.map +1 -1
- package/dist/daemon/engine-registry/init-pipeline.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-pipeline.js +3 -1
- package/dist/daemon/engine-registry/init-pipeline.js.map +1 -1
- package/dist/daemon/engine-registry/init-resume.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-resume.js +3 -1
- package/dist/daemon/engine-registry/init-resume.js.map +1 -1
- package/dist/daemon/handler-context.d.ts +8 -0
- package/dist/daemon/handler-context.d.ts.map +1 -1
- package/dist/daemon/handlers/session-cleanup.d.ts +23 -0
- package/dist/daemon/handlers/session-cleanup.d.ts.map +1 -0
- package/dist/daemon/handlers/session-cleanup.js +149 -0
- package/dist/daemon/handlers/session-cleanup.js.map +1 -0
- package/dist/daemon/handlers/stop-handler.d.ts +1 -0
- package/dist/daemon/handlers/stop-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/stop-handler.js +21 -78
- package/dist/daemon/handlers/stop-handler.js.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.js +29 -4
- package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +7 -2
- package/dist/daemon/index.js.map +1 -1
- package/dist/distill/index.d.ts +8 -3
- package/dist/distill/index.d.ts.map +1 -1
- package/dist/distill/index.js +8 -8
- package/dist/distill/index.js.map +1 -1
- package/dist/distill/prompts.d.ts.map +1 -1
- package/dist/distill/prompts.js +14 -2
- package/dist/distill/prompts.js.map +1 -1
- package/dist/orchestration/index.d.ts.map +1 -1
- package/dist/orchestration/index.js +1 -0
- package/dist/orchestration/index.js.map +1 -1
- package/dist/pattern-engine/pattern-executor.d.ts.map +1 -1
- package/dist/pattern-engine/pattern-executor.js +43 -0
- package/dist/pattern-engine/pattern-executor.js.map +1 -1
- package/dist/pattern-engine/pattern-router.d.ts +2 -0
- package/dist/pattern-engine/pattern-router.d.ts.map +1 -1
- package/dist/pattern-engine/pattern-router.js +26 -4
- package/dist/pattern-engine/pattern-router.js.map +1 -1
- package/dist/storage/sqlite.d.ts +5 -0
- package/dist/storage/sqlite.d.ts.map +1 -1
- package/dist/storage/sqlite.js +40 -0
- package/dist/storage/sqlite.js.map +1 -1
- package/dist/utils/logger.d.ts +2 -0
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +21 -2
- package/dist/utils/logger.js.map +1 -1
- 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,
|
|
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;
|
|
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,
|
|
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;
|
|
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,
|
|
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;
|
|
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,
|
|
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;
|
|
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;
|
|
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 {
|
|
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,
|
|
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.
|
|
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
|
-
|
|
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]
|
|
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":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,
|
|
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;
|
|
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,
|