@winspan/claude-forge 0.6.8 → 0.7.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.
Files changed (77) hide show
  1. package/dist/ai-gateway/index.d.ts.map +1 -1
  2. package/dist/ai-gateway/index.js +8 -1
  3. package/dist/ai-gateway/index.js.map +1 -1
  4. package/dist/daemon/handlers/context-builder.d.ts +7 -5
  5. package/dist/daemon/handlers/context-builder.d.ts.map +1 -1
  6. package/dist/daemon/handlers/context-builder.js +29 -26
  7. package/dist/daemon/handlers/context-builder.js.map +1 -1
  8. package/dist/daemon/handlers/orchestration-context.d.ts +5 -0
  9. package/dist/daemon/handlers/orchestration-context.d.ts.map +1 -1
  10. package/dist/daemon/handlers/stages/01-failure-signal.d.ts.map +1 -1
  11. package/dist/daemon/handlers/stages/01-failure-signal.js +1 -0
  12. package/dist/daemon/handlers/stages/01-failure-signal.js.map +1 -1
  13. package/dist/daemon/handlers/stages/04-skill-suggestions.js +1 -1
  14. package/dist/daemon/handlers/stages/04-skill-suggestions.js.map +1 -1
  15. package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts.map +1 -1
  16. package/dist/daemon/handlers/stages/07-pipeline-reply.js +2 -0
  17. package/dist/daemon/handlers/stages/07-pipeline-reply.js.map +1 -1
  18. package/dist/daemon/handlers/stages/10-cooldown.d.ts.map +1 -1
  19. package/dist/daemon/handlers/stages/10-cooldown.js +21 -0
  20. package/dist/daemon/handlers/stages/10-cooldown.js.map +1 -1
  21. package/dist/daemon/handlers/stages/11-intent-analysis.d.ts +2 -0
  22. package/dist/daemon/handlers/stages/11-intent-analysis.d.ts.map +1 -1
  23. package/dist/daemon/handlers/stages/11-intent-analysis.js +44 -5
  24. package/dist/daemon/handlers/stages/11-intent-analysis.js.map +1 -1
  25. package/dist/daemon/handlers/stages/17-simple-task.js +1 -1
  26. package/dist/daemon/handlers/stages/17-simple-task.js.map +1 -1
  27. package/dist/daemon/handlers/stages/18-complex-task.d.ts +2 -0
  28. package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -1
  29. package/dist/daemon/handlers/stages/18-complex-task.js +52 -4
  30. package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
  31. package/dist/daemon/handlers/stages/19-moderate-task.d.ts +2 -0
  32. package/dist/daemon/handlers/stages/19-moderate-task.d.ts.map +1 -1
  33. package/dist/daemon/handlers/stages/19-moderate-task.js +22 -2
  34. package/dist/daemon/handlers/stages/19-moderate-task.js.map +1 -1
  35. package/dist/daemon/handlers/stages/stage-interface.d.ts +4 -1
  36. package/dist/daemon/handlers/stages/stage-interface.d.ts.map +1 -1
  37. package/dist/daemon/handlers/user-prompt-handler.d.ts +9 -0
  38. package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
  39. package/dist/daemon/handlers/user-prompt-handler.js +107 -7
  40. package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
  41. package/dist/storage/repositories/base-repository.d.ts +6 -0
  42. package/dist/storage/repositories/base-repository.d.ts.map +1 -1
  43. package/dist/storage/repositories/base-repository.js +23 -0
  44. package/dist/storage/repositories/base-repository.js.map +1 -1
  45. package/dist/storage/repositories/event-repository.d.ts.map +1 -1
  46. package/dist/storage/repositories/event-repository.js +96 -87
  47. package/dist/storage/repositories/event-repository.js.map +1 -1
  48. package/dist/storage/repositories/graph-traversal.d.ts +37 -0
  49. package/dist/storage/repositories/graph-traversal.d.ts.map +1 -0
  50. package/dist/storage/repositories/graph-traversal.js +157 -0
  51. package/dist/storage/repositories/graph-traversal.js.map +1 -0
  52. package/dist/storage/repositories/knowledge-repository.d.ts +14 -0
  53. package/dist/storage/repositories/knowledge-repository.d.ts.map +1 -1
  54. package/dist/storage/repositories/knowledge-repository.js +22 -0
  55. package/dist/storage/repositories/knowledge-repository.js.map +1 -1
  56. package/dist/storage/repositories/latency-repository.d.ts.map +1 -1
  57. package/dist/storage/repositories/latency-repository.js +2 -5
  58. package/dist/storage/repositories/latency-repository.js.map +1 -1
  59. package/dist/storage/repositories/maintenance-repository.d.ts +3 -0
  60. package/dist/storage/repositories/maintenance-repository.d.ts.map +1 -1
  61. package/dist/storage/repositories/maintenance-repository.js +12 -3
  62. package/dist/storage/repositories/maintenance-repository.js.map +1 -1
  63. package/dist/storage/repositories/task-repository.d.ts.map +1 -1
  64. package/dist/storage/repositories/task-repository.js +16 -11
  65. package/dist/storage/repositories/task-repository.js.map +1 -1
  66. package/dist/storage/sqlite.d.ts.map +1 -1
  67. package/dist/storage/sqlite.js +16 -1
  68. package/dist/storage/sqlite.js.map +1 -1
  69. package/dist/utils/error-handler.d.ts +39 -0
  70. package/dist/utils/error-handler.d.ts.map +1 -0
  71. package/dist/utils/error-handler.js +155 -0
  72. package/dist/utils/error-handler.js.map +1 -0
  73. package/dist/utils/stage-trace.d.ts +74 -0
  74. package/dist/utils/stage-trace.d.ts.map +1 -0
  75. package/dist/utils/stage-trace.js +125 -0
  76. package/dist/utils/stage-trace.js.map +1 -0
  77. package/package.json +1 -1
@@ -30,7 +30,7 @@ export class SimpleTaskStage {
30
30
  const similarSessionCtx = analysis.searchKeywords?.length
31
31
  ? builder.buildSimilarSessionContext(analysis.searchKeywords, ctx.event.project_path, ctx.injectionCache)
32
32
  : undefined;
33
- const body = ContextInjector.build({ content: builder.buildPlanStartContext(ctx.event.project_path, ctx.injectionCache), priority: INJECT_PRIORITY.PLAN, topic: 'plan' }, { content: builder.buildProfileContext(ctx.event.project_path, ctx.injectionCache), priority: INJECT_PRIORITY.PROFILE, topic: 'profile' }, { content: similarSessionCtx, priority: INJECT_PRIORITY.HISTORY, minBudget: 500, topic: 'history' }, { content: conventionPrompt, priority: INJECT_PRIORITY.CONVENTION, topic: 'convention' });
33
+ const body = ContextInjector.build({ content: builder.buildPlanStartContext(ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt), priority: INJECT_PRIORITY.PLAN, topic: 'plan' }, { content: builder.buildProfileContext(ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt), priority: INJECT_PRIORITY.PROFILE, topic: 'profile' }, { content: similarSessionCtx, priority: INJECT_PRIORITY.HISTORY, minBudget: 500, topic: 'history' }, { content: conventionPrompt, priority: INJECT_PRIORITY.CONVENTION, topic: 'convention' });
34
34
  const injected = [];
35
35
  if (ctx.injectionCache.get(ctx.event.project_path)?.profileInjected)
36
36
  injected.push('画像');
@@ -1 +1 @@
1
- {"version":3,"file":"17-simple-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/17-simple-task.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"17-simple-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/17-simple-task.ts"],"names":[],"mappings":"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"}
@@ -3,9 +3,11 @@ import type { OrchestrationContext } from '../orchestration-context.js';
3
3
  /** Stage 18: 复杂任务处理 — Pipeline 决策 */
4
4
  export declare class ComplexTaskStage implements Stage {
5
5
  readonly name = "\u590D\u6742\u4EFB\u52A1\u5904\u7406";
6
+ readonly critical = true;
6
7
  execute(ctx: OrchestrationContext): Promise<StageResult>;
7
8
  private buildCard;
8
9
  private autoStartPipeline;
9
10
  private promptPipelineChoice;
11
+ fallback(ctx: OrchestrationContext, error: unknown): Promise<StageResult>;
10
12
  }
11
13
  //# sourceMappingURL=18-complex-task.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"18-complex-task.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAOxE,qCAAqC;AACrC,qBAAa,gBAAiB,YAAW,KAAK;IAC5C,QAAQ,CAAC,IAAI,0CAAY;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IA8B9D,OAAO,CAAC,SAAS;YAWH,iBAAiB;IA8C/B,OAAO,CAAC,oBAAoB;CAoB7B"}
1
+ {"version":3,"file":"18-complex-task.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAOxE,qCAAqC;AACrC,qBAAa,gBAAiB,YAAW,KAAK;IAC5C,QAAQ,CAAC,IAAI,0CAAY;IACzB,QAAQ,CAAC,QAAQ,QAAQ;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IAsD9D,OAAO,CAAC,SAAS;YAWH,iBAAiB;IA8C/B,OAAO,CAAC,oBAAoB;IAsBtB,QAAQ,CAAC,GAAG,EAAE,oBAAoB,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CAgDhF"}
@@ -5,6 +5,7 @@ import { logger } from '../../../utils/logger.js';
5
5
  /** Stage 18: 复杂任务处理 — Pipeline 决策 */
6
6
  export class ComplexTaskStage {
7
7
  name = '复杂任务处理';
8
+ critical = true;
8
9
  async execute(ctx) {
9
10
  const { analysis, interventionLevel } = ctx;
10
11
  if (!analysis || !analysis.requiresPipeline)
@@ -13,21 +14,40 @@ export class ComplexTaskStage {
13
14
  if (!pipelineEngine || !config.autopilot.auto_start_pipeline)
14
15
  return { shouldTerminate: false };
15
16
  if (pipelineEngine.hasActivePipeline(ctx.event.project_path)) {
16
- logger.info('已有活跃的编排流程');
17
+ logger.info('[复杂任务] 已有活跃的编排流程');
17
18
  return { shouldTerminate: false };
18
19
  }
19
20
  const card = this.buildCard(analysis);
20
21
  ctx.card = card;
21
22
  const confirmMode = config.autopilot.pipeline_confirm_mode;
23
+ ctx.stageTracer.recordDecision(this.name, {
24
+ context: [
25
+ `analysis.requiresPipeline=${analysis.requiresPipeline}`,
26
+ `interventionLevel=${interventionLevel ?? 'undefined'}`,
27
+ `confirmMode=${confirmMode}`,
28
+ ],
29
+ }, `需要编排流程,确认模式=${confirmMode},干预级别=${interventionLevel ?? 'undefined'}`);
22
30
  if (interventionLevel === 'auto' || confirmMode === 'auto') {
31
+ ctx.stageTracer.recordAction(this.name, '自动启动编排流程');
23
32
  const response = await this.autoStartPipeline(analysis, card, ctx);
33
+ ctx.stageTracer.recordResult(this.name, {
34
+ type: 'terminate',
35
+ artifact: `pipeline_id=${response?.pipeline_id ?? 'unknown'}`,
36
+ summary: '已启动编排流程',
37
+ });
24
38
  return { shouldTerminate: true, response };
25
39
  }
26
40
  if (confirmMode === 'prompt') {
41
+ ctx.stageTracer.recordAction(this.name, '提示用户选择是否启动编排');
27
42
  const response = this.promptPipelineChoice(analysis, card, ctx);
43
+ ctx.stageTracer.recordResult(this.name, {
44
+ type: 'terminate',
45
+ summary: '已提示用户选择',
46
+ });
28
47
  return { shouldTerminate: true, response };
29
48
  }
30
- logger.info('预览模式,不启动编排流程');
49
+ ctx.stageTracer.recordAction(this.name, '预览模式,不启动编排');
50
+ logger.info('[复杂任务] 预览模式,不启动编排流程');
31
51
  return { shouldTerminate: false };
32
52
  }
33
53
  buildCard(analysis) {
@@ -53,8 +73,8 @@ export class ComplexTaskStage {
53
73
  logger.info(`已加载项目规范:${ForgeFormatter.formatConventionSummary(activeConventions)}`);
54
74
  }
55
75
  const autoMsg = ForgeFormatter.formatModuleNotification('pipeline', `已自动启动完整编排,共 ${pipeline.tasks.length} 个任务\n阶段:${analysis.suggestedPhases.join(' → ')}`);
56
- const decisionsCtx = await builder.readDecisionsContext(analysis.requirement, ctx.event.project_path, ctx.injectionCache);
57
- const context = ForgeFormatter.wrapInQuote(ContextInjector.build({ content: builder.buildPlanStartContext(ctx.event.project_path, ctx.injectionCache), priority: INJECT_PRIORITY.PLAN, topic: 'plan' }, { content: builder.buildProfileContext(ctx.event.project_path, ctx.injectionCache), priority: INJECT_PRIORITY.PROFILE, topic: 'profile' }, { content: conventionPrompt, priority: INJECT_PRIORITY.CONVENTION, topic: 'convention' }, { content: autoMsg, priority: INJECT_PRIORITY.PIPELINE, topic: 'pipeline' }, { content: decisionsCtx, priority: INJECT_PRIORITY.DECISIONS, topic: 'decisions' }));
76
+ const decisionsCtx = await builder.readDecisionsContext(analysis.requirement, ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt);
77
+ const context = ForgeFormatter.wrapInQuote(ContextInjector.build({ content: builder.buildPlanStartContext(ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt), priority: INJECT_PRIORITY.PLAN, topic: 'plan' }, { content: builder.buildProfileContext(ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt), priority: INJECT_PRIORITY.PROFILE, topic: 'profile' }, { content: conventionPrompt, priority: INJECT_PRIORITY.CONVENTION, topic: 'convention' }, { content: autoMsg, priority: INJECT_PRIORITY.PIPELINE, topic: 'pipeline' }, { content: decisionsCtx, priority: INJECT_PRIORITY.DECISIONS, topic: 'decisions' }));
58
78
  if (analysis.clarifyQuestions?.length) {
59
79
  logger.info(`[Forge:Pipeline] 自动启动 + 注入澄清问题 ${analysis.clarifyQuestions.length} 个`);
60
80
  const clarify = ForgeFormatter.formatClarifyRequest(analysis.clarifyQuestions);
@@ -69,6 +89,7 @@ export class ComplexTaskStage {
69
89
  promptPipelineChoice(analysis, card, ctx) {
70
90
  const options = ForgeFormatter.formatPipelineOptions(analysis.suggestedPhases, analysis.requirement);
71
91
  ctx.suggestionPending.set(ctx.event.project_path, true);
92
+ ctx.suggestionPendingAt.set(ctx.event.project_path, Date.now());
72
93
  if (!ctx.lastAnalysisAt.has(ctx.event.project_path)) {
73
94
  ctx.lastAnalysisAt.set(ctx.event.project_path, Date.now());
74
95
  }
@@ -80,5 +101,32 @@ export class ComplexTaskStage {
80
101
  logger.info('向用户展示编排方案选项');
81
102
  return { allow: true, systemMessage: card, additionalContext: ForgeFormatter.wrapInQuote(options) };
82
103
  }
104
+ async fallback(ctx, error) {
105
+ logger.warn(`[复杂任务处理] Pipeline 启动失败,降级为直接执行:${error}`);
106
+ const { analysis } = ctx;
107
+ if (!analysis)
108
+ return { shouldTerminate: false };
109
+ ctx.stageTracer.recordDecision(this.name, { rules: ['Pipeline 不可用时降级为直接执行'] }, `Pipeline 启动失败(${error}),切换为直接执行模式`);
110
+ ctx.stageTracer.recordAction(this.name, '构建降级上下文(directive + decisions)');
111
+ const builder = new ContextBuilder(ctx.handlerCtx);
112
+ const directive = ctx.handlerCtx.intentEngine?.generateDirective(analysis);
113
+ const decisionsContext = await builder.readDecisionsContext(analysis.requirement, ctx.event.project_path, ctx.injectionCache, ctx.injectionCacheAt).catch(() => undefined);
114
+ const fallbackMsg = ForgeFormatter.formatModuleNotification('pipeline', '编排流程暂时不可用,已切换为直接执行模式');
115
+ const context = ContextInjector.build({ content: fallbackMsg, priority: INJECT_PRIORITY.PIPELINE, topic: 'pipeline' }, { content: directive ?? undefined, priority: INJECT_PRIORITY.DIRECTIVE, topic: 'directive' }, { content: decisionsContext, priority: INJECT_PRIORITY.DECISIONS, topic: 'decisions' });
116
+ ctx.stageTracer.recordResult(this.name, {
117
+ type: 'terminate',
118
+ artifact: 'fallback_context',
119
+ summary: `降级完成:注入 directive + decisions 上下文`,
120
+ });
121
+ logger.info('[复杂任务处理] 降级完成:使用直接执行模式');
122
+ return {
123
+ shouldTerminate: true,
124
+ response: {
125
+ allow: true,
126
+ systemMessage: ctx.card,
127
+ additionalContext: context ? ForgeFormatter.wrapInQuote(context) : undefined,
128
+ },
129
+ };
130
+ }
83
131
  }
84
132
  //# sourceMappingURL=18-complex-task.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"18-complex-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"18-complex-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/18-complex-task.ts"],"names":[],"mappings":"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"}
@@ -3,6 +3,8 @@ import type { OrchestrationContext } from '../orchestration-context.js';
3
3
  /** Stage 19: 中等任务处理 — 知识搜索 + 指令注入 */
4
4
  export declare class ModerateTaskStage implements Stage {
5
5
  readonly name = "\u4E2D\u7B49\u4EFB\u52A1\u5904\u7406";
6
+ readonly critical = true;
6
7
  execute(ctx: OrchestrationContext): Promise<StageResult>;
8
+ fallback(ctx: OrchestrationContext, error: unknown): Promise<StageResult>;
7
9
  }
8
10
  //# sourceMappingURL=19-moderate-task.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"19-moderate-task.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/19-moderate-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAMxE,qCAAqC;AACrC,qBAAa,iBAAkB,YAAW,KAAK;IAC7C,QAAQ,CAAC,IAAI,0CAAY;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;CA6D/D"}
1
+ {"version":3,"file":"19-moderate-task.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/19-moderate-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAMxE,qCAAqC;AACrC,qBAAa,iBAAkB,YAAW,KAAK;IAC7C,QAAQ,CAAC,IAAI,0CAAY;IACzB,QAAQ,CAAC,QAAQ,QAAQ;IAEnB,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC;IA8DxD,QAAQ,CAAC,GAAG,EAAE,oBAAoB,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CA4BhF"}
@@ -5,6 +5,7 @@ import { logger } from '../../../utils/logger.js';
5
5
  /** Stage 19: 中等任务处理 — 知识搜索 + 指令注入 */
6
6
  export class ModerateTaskStage {
7
7
  name = '中等任务处理';
8
+ critical = true;
8
9
  async execute(ctx) {
9
10
  const { analysis, event, handlerCtx } = ctx;
10
11
  if (!analysis)
@@ -12,7 +13,7 @@ export class ModerateTaskStage {
12
13
  const projectPath = event.project_path;
13
14
  const builder = new ContextBuilder(handlerCtx);
14
15
  const directive = handlerCtx.intentEngine.generateDirective(analysis);
15
- const decisionsContext = await builder.readDecisionsContext(analysis.requirement, projectPath, ctx.injectionCache);
16
+ const decisionsContext = await builder.readDecisionsContext(analysis.requirement, projectPath, ctx.injectionCache, ctx.injectionCacheAt);
16
17
  const similarSessionCtx = analysis.searchKeywords?.length
17
18
  ? builder.buildSimilarSessionContext(analysis.searchKeywords, projectPath, ctx.injectionCache)
18
19
  : undefined;
@@ -32,7 +33,7 @@ export class ModerateTaskStage {
32
33
  response: { allow: true, systemMessage: ctx.card, additionalContext: clarify },
33
34
  };
34
35
  }
35
- const body = ContextInjector.build({ content: builder.buildPlanStartContext(projectPath, ctx.injectionCache), priority: INJECT_PRIORITY.PLAN, topic: 'plan' }, { content: builder.buildProfileContext(projectPath, ctx.injectionCache), priority: INJECT_PRIORITY.PROFILE, topic: 'profile' }, { content: conventionPrompt, priority: INJECT_PRIORITY.CONVENTION, topic: 'convention' }, { content: directive ?? undefined, priority: INJECT_PRIORITY.DIRECTIVE, topic: 'directive' }, { content: similarSessionCtx, priority: INJECT_PRIORITY.HISTORY, minBudget: 500, topic: 'history' }, { content: graphContext, priority: INJECT_PRIORITY.HISTORY - 1, minBudget: 300, topic: 'graph' }, { content: decisionsContext, priority: INJECT_PRIORITY.DECISIONS, topic: 'decisions' });
36
+ const body = ContextInjector.build({ content: builder.buildPlanStartContext(projectPath, ctx.injectionCache, ctx.injectionCacheAt), priority: INJECT_PRIORITY.PLAN, topic: 'plan' }, { content: builder.buildProfileContext(projectPath, ctx.injectionCache, ctx.injectionCacheAt), priority: INJECT_PRIORITY.PROFILE, topic: 'profile' }, { content: conventionPrompt, priority: INJECT_PRIORITY.CONVENTION, topic: 'convention' }, { content: directive ?? undefined, priority: INJECT_PRIORITY.DIRECTIVE, topic: 'directive' }, { content: similarSessionCtx, priority: INJECT_PRIORITY.HISTORY, minBudget: 500, topic: 'history' }, { content: graphContext, priority: INJECT_PRIORITY.HISTORY - 1, minBudget: 300, topic: 'graph' }, { content: decisionsContext, priority: INJECT_PRIORITY.DECISIONS, topic: 'decisions' });
36
37
  const injected = [];
37
38
  if (ctx.injectionCache.get(projectPath)?.profileInjected)
38
39
  injected.push('画像');
@@ -58,5 +59,24 @@ export class ModerateTaskStage {
58
59
  },
59
60
  };
60
61
  }
62
+ async fallback(ctx, error) {
63
+ logger.warn(`[中等任务处理] 知识搜索失败,使用基础指令:${error}`);
64
+ const { analysis } = ctx;
65
+ if (!analysis)
66
+ return { shouldTerminate: false };
67
+ const builder = new ContextBuilder(ctx.handlerCtx);
68
+ const directive = ctx.handlerCtx.intentEngine?.generateDirective(analysis);
69
+ const fallbackMsg = ForgeFormatter.formatModuleNotification('knowledge', '知识搜索暂时不可用,使用基础执行模式');
70
+ const context = ContextInjector.build({ content: fallbackMsg, priority: INJECT_PRIORITY.DIRECTIVE, topic: 'fallback' }, { content: directive ?? undefined, priority: INJECT_PRIORITY.DIRECTIVE, topic: 'directive' });
71
+ logger.info('降级完成:使用基础执行模式');
72
+ return {
73
+ shouldTerminate: true,
74
+ response: {
75
+ allow: true,
76
+ systemMessage: ctx.card,
77
+ additionalContext: context ? ForgeFormatter.wrapInQuote(context) : undefined,
78
+ },
79
+ };
80
+ }
61
81
  }
62
82
  //# sourceMappingURL=19-moderate-task.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"19-moderate-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/19-moderate-task.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"19-moderate-task.js","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/19-moderate-task.ts"],"names":[],"mappings":"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"}
@@ -16,11 +16,14 @@ export type StageResult = {
16
16
  /**
17
17
  * Stage 接口
18
18
  * 每个 Stage 负责流水线中的一个独立步骤
19
- * critical=true 时,该 Stage 抛出异常将终止整个流水线(不继续后续 Stage)
19
+ * - critical=true 时,该 Stage 抛出异常将终止整个流水线(不继续后续 Stage)
20
+ * - fallback() 提供降级处理,当 execute() 失败时调用
20
21
  */
21
22
  export interface Stage {
22
23
  readonly name: string;
23
24
  readonly critical?: boolean;
24
25
  execute(ctx: OrchestrationContext): Promise<StageResult>;
26
+ /** 降级处理(可选),当 execute() 失败时调用 */
27
+ fallback?(ctx: OrchestrationContext, error: unknown): Promise<StageResult>;
25
28
  }
26
29
  //# sourceMappingURL=stage-interface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"stage-interface.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/stage-interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAEpD;;;;;GAKG;AACH,MAAM,MAAM,WAAW,GACnB;IAAE,eAAe,EAAE,IAAI,CAAC;IAAC,QAAQ,EAAE,YAAY,GAAG,IAAI,CAAA;CAAE,GACxD;IAAE,eAAe,EAAE,KAAK,CAAC;IAAC,aAAa,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAExD;;;;GAIG;AACH,MAAM,WAAW,KAAK;IACpB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAC5B,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;CAC1D"}
1
+ {"version":3,"file":"stage-interface.d.ts","sourceRoot":"","sources":["../../../../src/daemon/handlers/stages/stage-interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAEpD;;;;;GAKG;AACH,MAAM,MAAM,WAAW,GACnB;IAAE,eAAe,EAAE,IAAI,CAAC;IAAC,QAAQ,EAAE,YAAY,GAAG,IAAI,CAAA;CAAE,GACxD;IAAE,eAAe,EAAE,KAAK,CAAC;IAAC,aAAa,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAExD;;;;;GAKG;AACH,MAAM,WAAW,KAAK;IACpB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAC5B,OAAO,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IACzD,iCAAiC;IACjC,QAAQ,CAAC,CAAC,GAAG,EAAE,oBAAoB,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;CAC5E"}
@@ -3,11 +3,14 @@ import type { HookResponse } from '../server.js';
3
3
  import type { HandlerContext } from '../handler-context.js';
4
4
  import { BaseHookHandler } from './base-handler.js';
5
5
  export declare class UserPromptHandler extends BaseHookHandler {
6
+ /** 状态缓存 TTL:1 小时后自动清理,防止长期运行内存增长 */
7
+ private static readonly MAX_STATE_AGE_MS;
6
8
  /**
7
9
  * 上一轮是否向用户展示了 pipeline 建议(按 project_path 隔离)
8
10
  * 条目在 MAX_STATE_AGE_MS 后自动清理,防止长期运行内存增长。
9
11
  */
10
12
  private suggestionPending;
13
+ private suggestionPendingAt;
11
14
  /**
12
15
  * 意图分析冷却:记录每个项目上次分析的时间戳。
13
16
  * 同一项目 800ms 内的连续 UserPromptSubmit 跳过 AI 分析。
@@ -18,16 +21,22 @@ export declare class UserPromptHandler extends BaseHookHandler {
18
21
  * 相同 keywords / decisions 内容在同一 session 内只注入一次。
19
22
  */
20
23
  private injectionCache;
24
+ private injectionCacheAt;
21
25
  /** 已处理过负向重启检测的 session(key=sessionId),避免同 session 重复触发 */
22
26
  private negativeRestartChecked;
27
+ private negativeRestartCheckedAt;
23
28
  /** Batch 4:统一编排模板注册表 + 路由器 */
24
29
  private templateRegistry;
25
30
  private templateRouter;
31
+ /** 定时清理任务 */
32
+ private cleanupTimer;
26
33
  constructor(ctx: HandlerContext);
27
34
  /** 已提示过初始化的 session,避免每条消息都提示(key=sessionId:projectPath) */
28
35
  private initPromptedSessions;
29
36
  /** initPromptedSessions 条目的写入时间,用于 TTL 清理 */
30
37
  private initPromptedAt;
38
+ /** 清理超过 TTL 的状态缓存 */
39
+ private cleanupStaleState;
31
40
  handle(event: ForgeEvent): Promise<HookResponse | void>;
32
41
  private createStages;
33
42
  }
@@ -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;AA0BpD,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;IAC3D,0DAA0D;IAC1D,OAAO,CAAC,sBAAsB,CAAqB;IAEnD,8BAA8B;IAC9B,OAAO,CAAC,gBAAgB,CAAiC;IACzD,OAAO,CAAC,cAAc,CAA+B;gBAEzC,GAAG,EAAE,cAAc;IAU/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;IAwD7D,OAAO,CAAC,YAAY;CAyBrB"}
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;AA2BpD,qBAAa,iBAAkB,SAAQ,eAAe;IACpD,oCAAoC;IACpC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAkB;IAE1D;;;OAGG;IACH,OAAO,CAAC,iBAAiB,CAA8B;IACvD,OAAO,CAAC,mBAAmB,CAA6B;IACxD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAA6B;IACnD;;;OAGG;IACH,OAAO,CAAC,cAAc,CAAqC;IAC3D,OAAO,CAAC,gBAAgB,CAA6B;IACrD,0DAA0D;IAC1D,OAAO,CAAC,sBAAsB,CAAqB;IACnD,OAAO,CAAC,wBAAwB,CAA6B;IAE7D,8BAA8B;IAC9B,OAAO,CAAC,gBAAgB,CAAiC;IACzD,OAAO,CAAC,cAAc,CAA+B;IAErD,aAAa;IACb,OAAO,CAAC,YAAY,CAAiB;gBAEzB,GAAG,EAAE,cAAc;IAc/B,4DAA4D;IAC5D,OAAO,CAAC,oBAAoB,CAAqB;IACjD,6CAA6C;IAC7C,OAAO,CAAC,cAAc,CAA6B;IAEnD,qBAAqB;IACrB,OAAO,CAAC,iBAAiB;IAqDnB,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAuG7D,OAAO,CAAC,YAAY;CAyBrB"}
@@ -2,6 +2,7 @@ import { BaseHookHandler } from './base-handler.js';
2
2
  import { logger, relPath } from '../../utils/logger.js';
3
3
  import { TemplateRegistry } from '../../pipeline/template-registry.js';
4
4
  import { TemplateRouter } from '../../pipeline/template-router.js';
5
+ import { StageTraceLogger } from '../../utils/stage-trace.js';
5
6
  import { FailureSignalStage } from './stages/01-failure-signal.js';
6
7
  import { ActiveInterventionStage } from './stages/02-active-intervention.js';
7
8
  import { InitPromptStage } from './stages/03-init-prompt.js';
@@ -22,11 +23,14 @@ import { SimpleTaskStage } from './stages/17-simple-task.js';
22
23
  import { ComplexTaskStage } from './stages/18-complex-task.js';
23
24
  import { ModerateTaskStage } from './stages/19-moderate-task.js';
24
25
  export class UserPromptHandler extends BaseHookHandler {
26
+ /** 状态缓存 TTL:1 小时后自动清理,防止长期运行内存增长 */
27
+ static MAX_STATE_AGE_MS = 60 * 60 * 1000;
25
28
  /**
26
29
  * 上一轮是否向用户展示了 pipeline 建议(按 project_path 隔离)
27
30
  * 条目在 MAX_STATE_AGE_MS 后自动清理,防止长期运行内存增长。
28
31
  */
29
32
  suggestionPending = new Map();
33
+ suggestionPendingAt = new Map();
30
34
  /**
31
35
  * 意图分析冷却:记录每个项目上次分析的时间戳。
32
36
  * 同一项目 800ms 内的连续 UserPromptSubmit 跳过 AI 分析。
@@ -37,11 +41,15 @@ export class UserPromptHandler extends BaseHookHandler {
37
41
  * 相同 keywords / decisions 内容在同一 session 内只注入一次。
38
42
  */
39
43
  injectionCache = new Map();
44
+ injectionCacheAt = new Map();
40
45
  /** 已处理过负向重启检测的 session(key=sessionId),避免同 session 重复触发 */
41
46
  negativeRestartChecked = new Set();
47
+ negativeRestartCheckedAt = new Map();
42
48
  /** Batch 4:统一编排模板注册表 + 路由器 */
43
49
  templateRegistry = null;
44
50
  templateRouter = null;
51
+ /** 定时清理任务 */
52
+ cleanupTimer;
45
53
  constructor(ctx) {
46
54
  super(ctx);
47
55
  // 初始化模板路由器(仅在 sharedApi 可用时)
@@ -50,36 +58,93 @@ export class UserPromptHandler extends BaseHookHandler {
50
58
  this.templateRegistry.loadUserTemplates();
51
59
  this.templateRouter = new TemplateRouter(ctx.sharedApi);
52
60
  }
61
+ // 每 10 分钟清理一次过期状态
62
+ this.cleanupTimer = setInterval(() => this.cleanupStaleState(), 10 * 60 * 1000);
63
+ this.cleanupTimer.unref();
53
64
  }
54
65
  /** 已提示过初始化的 session,避免每条消息都提示(key=sessionId:projectPath) */
55
66
  initPromptedSessions = new Set();
56
67
  /** initPromptedSessions 条目的写入时间,用于 TTL 清理 */
57
68
  initPromptedAt = new Map();
69
+ /** 清理超过 TTL 的状态缓存 */
70
+ cleanupStaleState() {
71
+ const now = Date.now();
72
+ const cutoff = now - UserPromptHandler.MAX_STATE_AGE_MS;
73
+ // 清理 suggestionPending
74
+ for (const [key, timestamp] of this.suggestionPendingAt.entries()) {
75
+ if (timestamp < cutoff) {
76
+ this.suggestionPending.delete(key);
77
+ this.suggestionPendingAt.delete(key);
78
+ }
79
+ }
80
+ // 清理 lastAnalysisAt(保留最近 800ms 的即可,但为了统一用 1h TTL)
81
+ for (const [key, timestamp] of this.lastAnalysisAt.entries()) {
82
+ if (timestamp < cutoff) {
83
+ this.lastAnalysisAt.delete(key);
84
+ }
85
+ }
86
+ // 清理 injectionCache
87
+ for (const [key, timestamp] of this.injectionCacheAt.entries()) {
88
+ if (timestamp < cutoff) {
89
+ this.injectionCache.delete(key);
90
+ this.injectionCacheAt.delete(key);
91
+ }
92
+ }
93
+ // 清理 negativeRestartChecked
94
+ for (const [key, timestamp] of this.negativeRestartCheckedAt.entries()) {
95
+ if (timestamp < cutoff) {
96
+ this.negativeRestartChecked.delete(key);
97
+ this.negativeRestartCheckedAt.delete(key);
98
+ }
99
+ }
100
+ // 清理 initPromptedSessions
101
+ for (const [key, timestamp] of this.initPromptedAt.entries()) {
102
+ if (timestamp < cutoff) {
103
+ this.initPromptedSessions.delete(key);
104
+ this.initPromptedAt.delete(key);
105
+ }
106
+ }
107
+ const cleaned = {
108
+ suggestionPending: this.suggestionPending.size,
109
+ lastAnalysisAt: this.lastAnalysisAt.size,
110
+ injectionCache: this.injectionCache.size,
111
+ negativeRestartChecked: this.negativeRestartChecked.size,
112
+ initPromptedSessions: this.initPromptedSessions.size,
113
+ };
114
+ logger.debug(`[Forge:内存] 状态清理完成,剩余条目:${JSON.stringify(cleaned)}`);
115
+ }
58
116
  async handle(event) {
59
117
  const userPrompt = event.tool_input?.user_prompt || '';
60
118
  if (!userPrompt)
61
119
  return;
120
+ const proj = relPath(event.project_path);
121
+ const promptPreview = userPrompt.length > 120 ? userPrompt.slice(0, 120) + `…(共${userPrompt.length}字)` : userPrompt;
122
+ logger.info(`[Forge:编排] 开始 | 项目=${proj} | 提示="${promptPreview}"`);
123
+ const stageTracer = new StageTraceLogger();
62
124
  const ctx = {
63
125
  event,
64
126
  userPrompt,
65
127
  handlerCtx: this.ctx,
66
128
  suggestionPending: this.suggestionPending,
129
+ suggestionPendingAt: this.suggestionPendingAt,
67
130
  lastAnalysisAt: this.lastAnalysisAt,
68
131
  injectionCache: this.injectionCache,
132
+ injectionCacheAt: this.injectionCacheAt,
69
133
  negativeRestartChecked: this.negativeRestartChecked,
134
+ negativeRestartCheckedAt: this.negativeRestartCheckedAt,
70
135
  initPromptedSessions: this.initPromptedSessions,
71
136
  initPromptedAt: this.initPromptedAt,
72
137
  templateRegistry: this.templateRegistry,
73
138
  templateRouter: this.templateRouter,
139
+ stageTracer,
74
140
  };
75
141
  const stages = this.createStages();
76
- const proj = relPath(event.project_path);
77
- const tracer = this.ctx.latencyTracer;
78
- logger.info(`[Forge:编排] 开始 | 项目=${proj} | prompt="${userPrompt.slice(0, 60)}${userPrompt.length > 60 ? '…' : ''}"`);
142
+ const latencyTracer = this.ctx.latencyTracer;
79
143
  let stageIdx = 0;
80
144
  for (const stage of stages) {
81
145
  stageIdx++;
82
- const spanId = tracer.startSpan({
146
+ stageTracer.start(stage.name, stageIdx);
147
+ const spanId = latencyTracer.startSpan({
83
148
  session_id: event.session_id,
84
149
  project_path: event.project_path,
85
150
  trace_type: 'stage',
@@ -87,27 +152,62 @@ export class UserPromptHandler extends BaseHookHandler {
87
152
  });
88
153
  try {
89
154
  const result = await stage.execute(ctx);
90
- tracer.endSpan(spanId);
155
+ latencyTracer.endSpan(spanId);
91
156
  if (result.shouldTerminate) {
157
+ stageTracer.recordResult(stage.name, {
158
+ type: 'terminate',
159
+ summary: result.response ? '返回响应给用户' : '终止流水线(无响应)',
160
+ });
161
+ stageTracer.success(stage.name);
92
162
  logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} → 终止${result.response ? '(有响应)' : '(无响应)'}`);
163
+ logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
93
164
  return result.response ?? undefined;
94
165
  }
95
166
  if (result.skipRemaining) {
167
+ stageTracer.recordResult(stage.name, { type: 'skip', summary: '跳过剩余 Stage' });
168
+ stageTracer.success(stage.name);
96
169
  logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} → 跳过剩余`);
170
+ logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
97
171
  break;
98
172
  }
173
+ stageTracer.recordResult(stage.name, { type: 'continue', summary: '继续' });
174
+ stageTracer.success(stage.name);
99
175
  logger.debug(`[Forge:编排] · [${stageIdx}/${stages.length}] ${stage.name} → 继续`);
100
176
  }
101
177
  catch (err) {
102
- tracer.endSpan(spanId);
103
- logger.error(`[Forge:编排] [${stageIdx}/${stages.length}] ${stage.name} 执行失败:${err}`);
178
+ latencyTracer.endSpan(spanId);
179
+ const errMsg = err instanceof Error ? err.message : String(err);
180
+ stageTracer.error(stage.name, errMsg);
181
+ logger.error(`[Forge:编排] ✗ [${stageIdx}/${stages.length}] ${stage.name} 执行失败:${errMsg}`);
182
+ // 尝试降级处理
183
+ if (stage.fallback) {
184
+ try {
185
+ logger.info(`[Forge:编排] ↓ [${stageIdx}/${stages.length}] ${stage.name} 尝试降级处理`);
186
+ const fallbackResult = await stage.fallback(ctx, err);
187
+ if (fallbackResult.shouldTerminate) {
188
+ stageTracer.recordResult(stage.name, { type: 'terminate', summary: '降级后终止' });
189
+ logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} 降级成功 → 终止`);
190
+ logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
191
+ return fallbackResult.response ?? undefined;
192
+ }
193
+ stageTracer.recordResult(stage.name, { type: 'continue', summary: '降级后继续' });
194
+ logger.info(`[Forge:编排] ✓ [${stageIdx}/${stages.length}] ${stage.name} 降级成功 → 继续`);
195
+ continue;
196
+ }
197
+ catch (fallbackErr) {
198
+ logger.error(`[Forge:编排] ✗ [${stageIdx}/${stages.length}] ${stage.name} 降级失败:${fallbackErr}`);
199
+ }
200
+ }
201
+ // 关键 Stage 失败则终止流水线
104
202
  if (stage.critical) {
105
203
  logger.warn(`[Forge:编排] 关键 Stage 失败,终止流水线`);
204
+ logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
106
205
  break;
107
206
  }
108
207
  }
109
208
  }
110
209
  logger.info(`[Forge:编排] 完成 | 项目=${proj} | 所有 Stage 通过,无响应`);
210
+ logger.info(`[Forge:编排] 执行摘要:\n${stageTracer.getSummary()}`);
111
211
  }
112
212
  createStages() {
113
213
  return [
@@ -1 +1 @@
1
- {"version":3,"file":"user-prompt-handler.js","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AAGnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAEjE,MAAM,OAAO,iBAAkB,SAAQ,eAAe;IACpD;;;OAGG;IACK,iBAAiB,GAAG,IAAI,GAAG,EAAmB,CAAC;IACvD;;;OAGG;IACK,cAAc,GAAG,IAAI,GAAG,EAAkB,CAAC;IACnD;;;OAGG;IACK,cAAc,GAAG,IAAI,GAAG,EAA0B,CAAC;IAC3D,0DAA0D;IAClD,sBAAsB,GAAG,IAAI,GAAG,EAAU,CAAC;IAEnD,8BAA8B;IACtB,gBAAgB,GAA4B,IAAI,CAAC;IACjD,cAAc,GAA0B,IAAI,CAAC;IAErD,YAAY,GAAmB;QAC7B,KAAK,CAAC,GAAG,CAAC,CAAC;QACX,6BAA6B;QAC7B,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;YAClB,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,EAAE,CAAC;YAC/C,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;YAC1C,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,4DAA4D;IACpD,oBAAoB,GAAG,IAAI,GAAG,EAAU,CAAC;IACjD,6CAA6C;IACrC,cAAc,GAAG,IAAI,GAAG,EAAkB,CAAC;IAEnD,KAAK,CAAC,MAAM,CAAC,KAAiB;QAC5B,MAAM,UAAU,GAAI,KAAK,CAAC,UAAqC,EAAE,WAAW,IAAI,EAAE,CAAC;QACnF,IAAI,CAAC,UAAU;YAAE,OAAO;QAExB,MAAM,GAAG,GAA8D;YACrE,KAAK;YACL,UAAU;YACV,UAAU,EAAE,IAAI,CAAC,GAAG;YACpB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,sBAAsB,EAAE,IAAI,CAAC,sBAAsB;YACnD,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC;QAEF,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACnC,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC;QACtC,MAAM,CAAC,IAAI,CAAC,sBAAsB,IAAI,cAAc,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAEpH,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,QAAQ,EAAE,CAAC;YACX,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC;gBAC9B,UAAU,EAAE,KAAK,CAAC,UAAU;gBAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,UAAU,EAAE,OAAO;gBACnB,WAAW,EAAE,KAAK,CAAC,IAAI;aACxB,CAAC,CAAC;YACH,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;gBACxC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBACvB,IAAI,MAAM,CAAC,eAAe,EAAE,CAAC;oBAC3B,MAAM,CAAC,IAAI,CAAC,iBAAiB,QAAQ,IAAI,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,QAAQ,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;oBACpH,OAAO,MAAM,CAAC,QAAQ,IAAI,SAAS,CAAC;gBACtC,CAAC;gBACD,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;oBACzB,MAAM,CAAC,IAAI,CAAC,iBAAiB,QAAQ,IAAI,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,SAAS,CAAC,CAAC;oBAChF,MAAM;gBACR,CAAC;gBACD,MAAM,CAAC,KAAK,CAAC,iBAAiB,QAAQ,IAAI,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,OAAO,CAAC,CAAC;YACjF,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBACvB,MAAM,CAAC,KAAK,CAAC,iBAAiB,QAAQ,IAAI,MAAM,CAAC,MAAM,KAAK,KAAK,CAAC,IAAI,SAAS,GAAG,EAAE,CAAC,CAAC;gBACtF,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;oBACnB,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;oBAC5C,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;QACD,MAAM,CAAC,IAAI,CAAC,sBAAsB,IAAI,oBAAoB,CAAC,CAAC;IAC9D,CAAC;IAEO,YAAY;QAClB,OAAO;YACL,IAAI,kBAAkB,EAAE;YACxB,IAAI,uBAAuB,EAAE;YAC7B,IAAI,eAAe,EAAE;YACrB,IAAI,qBAAqB,EAAE;YAC3B,IAAI,yBAAyB,CAAC,IAAI,CAAC,GAAG,CAAC;YACvC,IAAI,gBAAgB,EAAE;YACtB,IAAI,kBAAkB,EAAE;YACxB,IAAI,iBAAiB,EAAE;YACvB,IAAI,mBAAmB,EAAE;YACzB,IAAI,aAAa,EAAE;YACnB,IAAI,mBAAmB,EAAE;YACzB,IAAI,mBAAmB,EAAE;YACzB,IAAI,kBAAkB,EAAE;YACxB,IAAI,eAAe,EAAE;YACrB,IAAI,oBAAoB,EAAE;YAC1B,IAAI,sBAAsB,EAAE;YAC5B,IAAI,eAAe,EAAE;YACrB,IAAI,gBAAgB,EAAE;YACtB,IAAI,iBAAiB,EAAE;SACxB,CAAC;IACJ,CAAC;CAGF"}
1
+ {"version":3,"file":"user-prompt-handler.js","sourceRoot":"","sources":["../../../src/daemon/handlers/user-prompt-handler.ts"],"names":[],"mappings":"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"}
@@ -2,5 +2,11 @@ import type Database from 'better-sqlite3';
2
2
  export declare abstract class BaseRepository {
3
3
  protected db: Database.Database;
4
4
  constructor(db: Database.Database);
5
+ /** 带重试的数据库写操作 */
6
+ protected writeWithRetry<T>(fn: () => T, context: string): Promise<T>;
7
+ /** 带重试的数据库读操作 */
8
+ protected readWithRetry<T>(fn: () => T, context: string): Promise<T>;
9
+ /** 静默错误的数据库操作(用于非关键操作) */
10
+ protected withSilent<T>(fn: () => T, context: string, defaultValue: T): Promise<T>;
5
11
  }
6
12
  //# sourceMappingURL=base-repository.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"base-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/base-repository.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAE3C,8BAAsB,cAAc;IACtB,SAAS,CAAC,EAAE,EAAE,QAAQ,CAAC,QAAQ;gBAArB,EAAE,EAAE,QAAQ,CAAC,QAAQ;CAC5C"}
1
+ {"version":3,"file":"base-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/base-repository.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAG3C,8BAAsB,cAAc;IACtB,SAAS,CAAC,EAAE,EAAE,QAAQ,CAAC,QAAQ;gBAArB,EAAE,EAAE,QAAQ,CAAC,QAAQ;IAE3C,iBAAiB;cACD,cAAc,CAAC,CAAC,EAC9B,EAAE,EAAE,MAAM,CAAC,EACX,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,CAAC,CAAC;IAab,iBAAiB;cACD,aAAa,CAAC,CAAC,EAC7B,EAAE,EAAE,MAAM,CAAC,EACX,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,CAAC,CAAC;IAab,0BAA0B;cACV,UAAU,CAAC,CAAC,EAC1B,EAAE,EAAE,MAAM,CAAC,EACX,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,CAAC,GACd,OAAO,CAAC,CAAC,CAAC;CAOd"}