@winspan/claude-forge 3.7.7 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/autopilot/quality-gate-utils.d.ts +6 -0
- package/dist/autopilot/quality-gate-utils.d.ts.map +1 -0
- package/dist/autopilot/quality-gate-utils.js +48 -0
- package/dist/autopilot/quality-gate-utils.js.map +1 -0
- package/dist/autopilot/quality-gate.d.ts +0 -8
- package/dist/autopilot/quality-gate.d.ts.map +1 -1
- package/dist/autopilot/quality-gate.js +6 -61
- package/dist/autopilot/quality-gate.js.map +1 -1
- package/dist/cli/commands/convention.d.ts.map +1 -1
- package/dist/cli/commands/convention.js +1 -115
- package/dist/cli/commands/convention.js.map +1 -1
- package/dist/cli/commands/init/index.d.ts.map +1 -1
- package/dist/cli/commands/init/index.js +0 -14
- package/dist/cli/commands/init/index.js.map +1 -1
- package/dist/cli/commands/init/project-doctor.d.ts.map +1 -1
- package/dist/cli/commands/init/project-doctor.js +0 -63
- package/dist/cli/commands/init/project-doctor.js.map +1 -1
- package/dist/cli/tui.d.ts.map +1 -1
- package/dist/cli/tui.js +7 -131
- package/dist/cli/tui.js.map +1 -1
- package/dist/constants.d.ts +0 -6
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +0 -6
- package/dist/constants.js.map +1 -1
- package/dist/convention/convention-loader.js +2 -2
- package/dist/convention/convention-loader.js.map +1 -1
- package/dist/convention/convention-manager.d.ts +24 -2
- package/dist/convention/convention-manager.d.ts.map +1 -1
- package/dist/convention/convention-manager.js +62 -4
- package/dist/convention/convention-manager.js.map +1 -1
- package/dist/convention/index.d.ts +1 -2
- package/dist/convention/index.d.ts.map +1 -1
- package/dist/convention/index.js +0 -1
- package/dist/convention/index.js.map +1 -1
- package/dist/convention/types.d.ts +4 -14
- package/dist/convention/types.d.ts.map +1 -1
- package/dist/daemon/engine-registry/init-governance.d.ts +10 -0
- package/dist/daemon/engine-registry/init-governance.d.ts.map +1 -0
- package/dist/daemon/engine-registry/init-governance.js +22 -0
- package/dist/daemon/engine-registry/init-governance.js.map +1 -0
- package/dist/daemon/engine-registry.d.ts.map +1 -1
- package/dist/daemon/engine-registry.js +5 -6
- package/dist/daemon/engine-registry.js.map +1 -1
- package/dist/daemon/handler-context.d.ts +4 -2
- package/dist/daemon/handler-context.d.ts.map +1 -1
- package/dist/daemon/handlers/post-tool-use-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/post-tool-use-handler.js +47 -11
- package/dist/daemon/handlers/post-tool-use-handler.js.map +1 -1
- package/dist/daemon/handlers/pre-tool-use-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/pre-tool-use-handler.js +32 -22
- package/dist/daemon/handlers/pre-tool-use-handler.js.map +1 -1
- package/dist/daemon/handlers/session-cleanup.d.ts +0 -4
- package/dist/daemon/handlers/session-cleanup.d.ts.map +1 -1
- package/dist/daemon/handlers/session-cleanup.js +0 -81
- package/dist/daemon/handlers/session-cleanup.js.map +1 -1
- package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/07-pipeline-reply.js +5 -1
- package/dist/daemon/handlers/stages/07-pipeline-reply.js.map +1 -1
- package/dist/daemon/handlers/stages/09-pipeline-active.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/09-pipeline-active.js +5 -1
- package/dist/daemon/handlers/stages/09-pipeline-active.js.map +1 -1
- package/dist/daemon/handlers/stages/13-template-route.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/13-template-route.js +5 -1
- package/dist/daemon/handlers/stages/13-template-route.js.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.d.ts +5 -2
- package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.js +87 -9
- package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
- package/dist/daemon/handlers/stop-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/stop-handler.js +1 -13
- package/dist/daemon/handlers/stop-handler.js.map +1 -1
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +15 -0
- package/dist/daemon/index.js.map +1 -1
- package/dist/goal/goal-classifier.d.ts.map +1 -1
- package/dist/goal/goal-classifier.js +12 -5
- package/dist/goal/goal-classifier.js.map +1 -1
- package/dist/goal/goal-types.d.ts +1 -3
- package/dist/goal/goal-types.d.ts.map +1 -1
- package/dist/goal/index.d.ts +1 -1
- package/dist/goal/index.d.ts.map +1 -1
- package/dist/governance/contract-builder.d.ts +39 -0
- package/dist/governance/contract-builder.d.ts.map +1 -0
- package/dist/governance/contract-builder.js +216 -0
- package/dist/governance/contract-builder.js.map +1 -0
- package/dist/governance/engine.d.ts +33 -0
- package/dist/governance/engine.d.ts.map +1 -0
- package/dist/governance/engine.js +183 -0
- package/dist/governance/engine.js.map +1 -0
- package/dist/governance/evidence-collector.d.ts +42 -0
- package/dist/governance/evidence-collector.d.ts.map +1 -0
- package/dist/governance/evidence-collector.js +136 -0
- package/dist/governance/evidence-collector.js.map +1 -0
- package/dist/governance/plugins/correction-plugin.d.ts +20 -0
- package/dist/governance/plugins/correction-plugin.d.ts.map +1 -0
- package/dist/governance/plugins/correction-plugin.js +113 -0
- package/dist/governance/plugins/correction-plugin.js.map +1 -0
- package/dist/governance/plugins/guidance-plugin.d.ts +21 -0
- package/dist/governance/plugins/guidance-plugin.d.ts.map +1 -0
- package/dist/governance/plugins/guidance-plugin.js +69 -0
- package/dist/governance/plugins/guidance-plugin.js.map +1 -0
- package/dist/governance/plugins/memory-plugin.d.ts +22 -0
- package/dist/governance/plugins/memory-plugin.d.ts.map +1 -0
- package/dist/governance/plugins/memory-plugin.js +106 -0
- package/dist/governance/plugins/memory-plugin.js.map +1 -0
- package/dist/governance/plugins/policy-plugin.d.ts +16 -0
- package/dist/governance/plugins/policy-plugin.d.ts.map +1 -0
- package/dist/governance/plugins/policy-plugin.js +69 -0
- package/dist/governance/plugins/policy-plugin.js.map +1 -0
- package/dist/governance/plugins/verification-plugin.d.ts +15 -0
- package/dist/governance/plugins/verification-plugin.d.ts.map +1 -0
- package/dist/governance/plugins/verification-plugin.js +65 -0
- package/dist/governance/plugins/verification-plugin.js.map +1 -0
- package/dist/governance/types.d.ts +202 -0
- package/dist/governance/types.d.ts.map +1 -0
- package/dist/governance/types.js +10 -0
- package/dist/governance/types.js.map +1 -0
- package/dist/pipeline/completion-engine.js +7 -7
- package/dist/pipeline/completion-engine.js.map +1 -1
- package/dist/pipeline/completion-gate.js +3 -3
- package/dist/pipeline/completion-gate.js.map +1 -1
- package/dist/pipeline/diagnosis-service.d.ts +2 -1
- package/dist/pipeline/diagnosis-service.d.ts.map +1 -1
- package/dist/pipeline/diagnosis-service.js.map +1 -1
- package/dist/pipeline/dynamic-node-executor.js +1 -1
- package/dist/pipeline/dynamic-node-executor.js.map +1 -1
- package/dist/pipeline/execution-engine.d.ts +1 -6
- package/dist/pipeline/execution-engine.d.ts.map +1 -1
- package/dist/pipeline/execution-engine.js +1 -1
- package/dist/pipeline/execution-engine.js.map +1 -1
- package/dist/pipeline/execution-plan.js +1 -1
- package/dist/pipeline/execution-plan.js.map +1 -1
- package/dist/pipeline/i-node-executor.d.ts +4 -0
- package/dist/pipeline/i-node-executor.d.ts.map +1 -1
- package/dist/pipeline/node-type-evolver.js +1 -1
- package/dist/pipeline/node-type-evolver.js.map +1 -1
- package/dist/pipeline/node-type-sync.d.ts.map +1 -1
- package/dist/pipeline/node-type-sync.js +10 -43
- package/dist/pipeline/node-type-sync.js.map +1 -1
- package/dist/pipeline/pattern-types.d.ts +3 -1
- package/dist/pipeline/pattern-types.d.ts.map +1 -1
- package/dist/retrospective/types.d.ts +2 -4
- package/dist/retrospective/types.d.ts.map +1 -1
- package/dist/skill-registry/evolver/index.js +6 -2
- package/dist/skill-registry/evolver/index.js.map +1 -1
- package/dist/skill-registry/index.d.ts +5 -0
- package/dist/skill-registry/index.d.ts.map +1 -1
- package/dist/skill-registry/index.js +6 -0
- package/dist/skill-registry/index.js.map +1 -1
- package/dist/storage/repositories/dynamic-pipeline-repository.d.ts.map +1 -1
- package/dist/storage/repositories/dynamic-pipeline-repository.js +18 -6
- package/dist/storage/repositories/dynamic-pipeline-repository.js.map +1 -1
- package/dist/storage/repositories/node-attempt-repository.d.ts +1 -1
- package/dist/storage/repositories/node-attempt-repository.d.ts.map +1 -1
- package/dist/storage/repositories/node-attempt-repository.js +1 -1
- package/dist/storage/repositories/node-attempt-repository.js.map +1 -1
- package/dist/storage/repositories/pipeline-plan-repository.d.ts.map +1 -1
- package/dist/storage/repositories/pipeline-plan-repository.js +1 -1
- package/dist/storage/repositories/pipeline-plan-repository.js.map +1 -1
- package/dist/storage/repositories/template-evolution-repository.d.ts.map +1 -1
- package/dist/storage/repositories/template-evolution-repository.js.map +1 -1
- package/dist/web/routes/pipelines.d.ts.map +1 -1
- package/dist/web/routes/pipelines.js +16 -5
- package/dist/web/routes/pipelines.js.map +1 -1
- package/dist/web/routes/quality.d.ts.map +1 -1
- package/dist/web/routes/quality.js +18 -17
- package/dist/web/routes/quality.js.map +1 -1
- package/dist/web/server.d.ts.map +1 -1
- package/dist/web/server.js +0 -7
- package/dist/web/server.js.map +1 -1
- package/dist/web/sse-broadcaster.d.ts +1 -1
- package/dist/web/sse-broadcaster.d.ts.map +1 -1
- package/dist/web/sse-broadcaster.js.map +1 -1
- package/dist/web-static/assets/Analytics-Bo_OyY9A.js +36 -0
- package/dist/web-static/assets/BatchProgress-qW-6664M.js +1 -0
- package/dist/web-static/assets/Breadcrumb-C1Mua6se.js +1 -0
- package/dist/web-static/assets/Config-Dn-dtdo9.js +1 -0
- package/dist/web-static/assets/ConfirmDialog-bdDaAlT1.js +1 -0
- package/dist/web-static/assets/Conventions-ByV7r45c.js +1 -0
- package/dist/web-static/assets/Dashboard-C-7N8kYZ.js +1 -0
- package/dist/web-static/assets/ErrorState-CMLoMrQY.js +1 -0
- package/dist/web-static/assets/Events-DHuyQHQe.js +1 -0
- package/dist/web-static/assets/Evolution-Dzr5xOLD.js +1 -0
- package/dist/web-static/assets/Knowledge-ClwX4cnr.js +2 -0
- package/dist/web-static/assets/MiniCharts-DsV2Sqfk.js +1 -0
- package/dist/web-static/assets/NodeTypes-DFt8b5gi.js +1 -0
- package/dist/web-static/assets/Pagination-CR-eJz36.js +1 -0
- package/dist/web-static/assets/PipelineDetail-By1HJlaB.js +4 -0
- package/dist/web-static/assets/Pipelines--MGzCPtR.js +2 -0
- package/dist/web-static/assets/ProjectDetail-CrpekCeY.js +1 -0
- package/dist/web-static/assets/Projects-Dw1qYmjz.js +1 -0
- package/dist/web-static/assets/Quality-CYwODfQP.js +3 -0
- package/dist/web-static/assets/SessionDetail-c8MYnwnk.js +1 -0
- package/dist/web-static/assets/Sessions-BkDd4Mxb.js +2 -0
- package/dist/web-static/assets/Skeleton-DbL04wuz.js +1 -0
- package/dist/web-static/assets/Skills-2OPSAnaU.js +1 -0
- package/dist/web-static/assets/TemplateDetail-DbifRj4h.js +1 -0
- package/dist/web-static/assets/Templates-CDw-GGp8.js +1 -0
- package/dist/web-static/assets/Toast-CrwuIbKC.js +1 -0
- package/dist/web-static/assets/client-C_VWY70M.js +1 -0
- package/dist/web-static/assets/index-DD2Z15TY.css +2 -0
- package/dist/web-static/assets/index-DR3AaQnu.js +2 -0
- package/dist/web-static/assets/ui-DpI1N3yJ.js +1 -0
- package/dist/web-static/assets/useDebounce-BLryFdeo.js +1 -0
- package/dist/web-static/assets/vendor-2ObLXPrQ.js +9 -0
- package/dist/web-static/assets/vendor-motion-BryL_tAt.js +9 -0
- package/dist/web-static/assets/vendor-query-CjmRaY7o.js +4 -0
- package/dist/web-static/assets/vendor-react-DZi7brq3.js +11 -0
- package/dist/web-static/index.html +10 -13
- package/package.json +4 -8
- package/dist/convention/convention-distiller.d.ts +0 -28
- package/dist/convention/convention-distiller.d.ts.map +0 -1
- package/dist/convention/convention-distiller.js +0 -172
- package/dist/convention/convention-distiller.js.map +0 -1
- package/dist/convention/official-sync.d.ts +0 -21
- package/dist/convention/official-sync.d.ts.map +0 -1
- package/dist/convention/official-sync.js +0 -196
- package/dist/convention/official-sync.js.map +0 -1
- package/dist/daemon/handlers/stages/19-moderate-task.d.ts +0 -11
- package/dist/daemon/handlers/stages/19-moderate-task.d.ts.map +0 -1
- package/dist/daemon/handlers/stages/19-moderate-task.js +0 -78
- package/dist/daemon/handlers/stages/19-moderate-task.js.map +0 -1
- package/dist/web/routes/conventions.d.ts +0 -8
- package/dist/web/routes/conventions.d.ts.map +0 -1
- package/dist/web/routes/conventions.js +0 -308
- package/dist/web/routes/conventions.js.map +0 -1
- package/dist/web/routes/logs.d.ts +0 -4
- package/dist/web/routes/logs.d.ts.map +0 -1
- package/dist/web/routes/logs.js +0 -77
- package/dist/web/routes/logs.js.map +0 -1
- package/dist/web/routes/project-conventions.d.ts +0 -7
- package/dist/web/routes/project-conventions.d.ts.map +0 -1
- package/dist/web/routes/project-conventions.js +0 -145
- package/dist/web/routes/project-conventions.js.map +0 -1
- package/dist/web-static/assets/Analytics-txva5ugO.js +0 -1
- package/dist/web-static/assets/BatchProgress-BQ533tSf.js +0 -1
- package/dist/web-static/assets/Breadcrumb-DtfwnOx6.js +0 -1
- package/dist/web-static/assets/Config-CUb6-ddH.js +0 -1
- package/dist/web-static/assets/ConfirmDialog-BKfwMp04.js +0 -1
- package/dist/web-static/assets/Conventions-E_2yAYoB.js +0 -1
- package/dist/web-static/assets/Dashboard-Dskgf0jG.js +0 -1
- package/dist/web-static/assets/ErrorState-BOInXmfg.js +0 -1
- package/dist/web-static/assets/Events-CAY9kU9T.js +0 -1
- package/dist/web-static/assets/Evolution-Ck_BqRpt.js +0 -1
- package/dist/web-static/assets/Knowledge-BHLyFp2U.js +0 -2
- package/dist/web-static/assets/NodeTypes-B6wc7VnR.js +0 -1
- package/dist/web-static/assets/Pagination-lp8b_3NR.js +0 -1
- package/dist/web-static/assets/PipelineDetail-Bc6l2jqX.js +0 -4
- package/dist/web-static/assets/PipelineTemplates-sSL-9oRh.js +0 -1
- package/dist/web-static/assets/Pipelines-Drat9IqZ.js +0 -2
- package/dist/web-static/assets/ProjectDetail-Cx8VZp8O.js +0 -1
- package/dist/web-static/assets/Projects-qDolX6Y6.js +0 -1
- package/dist/web-static/assets/Quality-Bm7oRSun.js +0 -3
- package/dist/web-static/assets/SessionDetail-BMrqH8_W.js +0 -1
- package/dist/web-static/assets/Sessions-C0BmdDPK.js +0 -2
- package/dist/web-static/assets/Skeleton-B7PVDJJ_.js +0 -1
- package/dist/web-static/assets/Skills-B3c1_uFt.js +0 -1
- package/dist/web-static/assets/TemplateDetail-ep5h3Cu5.js +0 -1
- package/dist/web-static/assets/Templates-Dho__f4l.js +0 -1
- package/dist/web-static/assets/Toast-BbB3oD2a.js +0 -1
- package/dist/web-static/assets/client-BvVpIixG.js +0 -1
- package/dist/web-static/assets/index-CgfiGhyE.js +0 -2
- package/dist/web-static/assets/index-CqwJts5v.css +0 -2
- package/dist/web-static/assets/ui-CDL3BZ13.js +0 -1
- package/dist/web-static/assets/useDebounce-DNfPs3Tv.js +0 -1
- package/dist/web-static/assets/vendor-DRGPi8ui.js +0 -9
- package/dist/web-static/assets/vendor-charts-9eVsQvUV.js +0 -36
- package/dist/web-static/assets/vendor-editor-CYLOGES5.js +0 -11
- package/dist/web-static/assets/vendor-flow-CHpVij2M.css +0 -1
- package/dist/web-static/assets/vendor-flow-srkes8If.js +0 -7
- package/dist/web-static/assets/vendor-motion-CQmdgnI8.js +0 -9
- package/dist/web-static/assets/vendor-query-DqPOMnuX.js +0 -4
- package/dist/web-static/assets/vendor-react-DJI9oneq.js +0 -11
- /package/dist/web-static/assets/{exportCsv-Dm5Y5M_E.js → exportCsv-CO51kx6P.js} +0 -0
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ContractBuilder — 契约构建器
|
|
3
|
+
*
|
|
4
|
+
* 从多个来源编译治理契约:
|
|
5
|
+
* - Convention 规范
|
|
6
|
+
* - 用户需求
|
|
7
|
+
* - 默认模板
|
|
8
|
+
*/
|
|
9
|
+
import { randomUUID } from 'crypto';
|
|
10
|
+
import { PolicyEngine } from '../orchestration/policy-engine.js';
|
|
11
|
+
export class ContractBuilder {
|
|
12
|
+
contract = {};
|
|
13
|
+
/** 从需求开始构建 */
|
|
14
|
+
static fromRequirement(requirement, projectPath, sessionId, executionMode = 'governance') {
|
|
15
|
+
const builder = new ContractBuilder();
|
|
16
|
+
builder.contract = {
|
|
17
|
+
id: `gc_${Date.now()}_${randomUUID().slice(0, 8)}`,
|
|
18
|
+
requirement,
|
|
19
|
+
project_path: projectPath,
|
|
20
|
+
session_id: sessionId,
|
|
21
|
+
execution_mode: executionMode,
|
|
22
|
+
forbidden_rules: [],
|
|
23
|
+
required_deliverables: [],
|
|
24
|
+
verification_rules: [],
|
|
25
|
+
quality_standards: [],
|
|
26
|
+
suggested_skills: [],
|
|
27
|
+
memory_scope: {
|
|
28
|
+
enable_resume: true,
|
|
29
|
+
enable_knowledge: true,
|
|
30
|
+
enable_failure_patterns: true,
|
|
31
|
+
},
|
|
32
|
+
created_at: new Date().toISOString(),
|
|
33
|
+
updated_at: new Date().toISOString(),
|
|
34
|
+
};
|
|
35
|
+
return builder;
|
|
36
|
+
}
|
|
37
|
+
/** 从 Convention 编译契约 */
|
|
38
|
+
withConvention(convention) {
|
|
39
|
+
// 1. 编译质量标准
|
|
40
|
+
if (convention.quality_standards) {
|
|
41
|
+
this.contract.quality_standards = [
|
|
42
|
+
...(this.contract.quality_standards ?? []),
|
|
43
|
+
...convention.quality_standards,
|
|
44
|
+
];
|
|
45
|
+
}
|
|
46
|
+
// 2. 编译禁止规则(从 quality_standards 中提取 must 级别)
|
|
47
|
+
const mustStandards = convention.quality_standards?.filter(s => s.severity === 'must') ?? [];
|
|
48
|
+
for (const std of mustStandards) {
|
|
49
|
+
this.addForbiddenRule({
|
|
50
|
+
id: `conv_${convention.id}_${std.category}`,
|
|
51
|
+
name: std.rule,
|
|
52
|
+
tool: '.*', // 匹配所有工具
|
|
53
|
+
pattern: '', // 由 AI 审查判断
|
|
54
|
+
action: 'warn', // must 规范违反先 warn,由 QualityGate 判断是否 block
|
|
55
|
+
reason: `违反 ${convention.name} 规范:${std.rule}`,
|
|
56
|
+
source: convention.id,
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
// 3. 编译交付物(从 node_types 的 expected_artifacts 提取)
|
|
60
|
+
if (convention.node_types) {
|
|
61
|
+
for (const nodeType of convention.node_types) {
|
|
62
|
+
if (nodeType.expected_artifacts) {
|
|
63
|
+
for (const artifact of nodeType.expected_artifacts) {
|
|
64
|
+
this.addDeliverable({
|
|
65
|
+
name: artifact.description,
|
|
66
|
+
description: artifact.description,
|
|
67
|
+
path_pattern: artifact.path_pattern,
|
|
68
|
+
required: artifact.required ?? true,
|
|
69
|
+
verification: artifact.path_pattern
|
|
70
|
+
? {
|
|
71
|
+
type: 'artifact',
|
|
72
|
+
description: artifact.description,
|
|
73
|
+
path_glob: artifact.path_pattern,
|
|
74
|
+
min_count: artifact.min_count ?? 1,
|
|
75
|
+
min_size_bytes: artifact.min_size_bytes,
|
|
76
|
+
contains: artifact.content_constraints?.required_keywords,
|
|
77
|
+
required: artifact.required ?? true,
|
|
78
|
+
}
|
|
79
|
+
: undefined,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return this;
|
|
86
|
+
}
|
|
87
|
+
/** 添加内置安全规则 */
|
|
88
|
+
withBuiltinRules() {
|
|
89
|
+
const policyEngine = new PolicyEngine();
|
|
90
|
+
// 从 PolicyEngine 获取内置规则并转换为 ForbiddenRule
|
|
91
|
+
const builtinRules = [
|
|
92
|
+
{
|
|
93
|
+
id: 'no-rm-rf-root',
|
|
94
|
+
name: '禁止删除根目录',
|
|
95
|
+
tool: 'Bash',
|
|
96
|
+
pattern: 'rm\\s+-[^\\s]*r[^\\s]*f[^\\s]*\\s+/',
|
|
97
|
+
action: 'deny',
|
|
98
|
+
reason: '危险操作:禁止对根目录执行 rm -rf',
|
|
99
|
+
source: 'builtin',
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
id: 'no-sudo-rm',
|
|
103
|
+
name: '禁止 sudo 删除',
|
|
104
|
+
tool: 'Bash',
|
|
105
|
+
pattern: 'sudo\\s+rm\\s+-[^\\s]*r',
|
|
106
|
+
action: 'deny',
|
|
107
|
+
reason: '危险操作:禁止 sudo rm -r',
|
|
108
|
+
source: 'builtin',
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
id: 'warn-force-push',
|
|
112
|
+
name: 'force push 警告',
|
|
113
|
+
tool: 'Bash',
|
|
114
|
+
pattern: 'git\\s+push\\s+.*--force',
|
|
115
|
+
action: 'warn',
|
|
116
|
+
reason: '警告:force push 可能覆盖远程历史',
|
|
117
|
+
source: 'builtin',
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
id: 'no-chmod-777',
|
|
121
|
+
name: '禁止 chmod 777',
|
|
122
|
+
tool: 'Bash',
|
|
123
|
+
pattern: 'chmod\\s+777',
|
|
124
|
+
action: 'deny',
|
|
125
|
+
reason: '安全风险:禁止设置 777 权限',
|
|
126
|
+
source: 'builtin',
|
|
127
|
+
},
|
|
128
|
+
];
|
|
129
|
+
this.contract.forbidden_rules = [
|
|
130
|
+
...(this.contract.forbidden_rules ?? []),
|
|
131
|
+
...builtinRules,
|
|
132
|
+
];
|
|
133
|
+
return this;
|
|
134
|
+
}
|
|
135
|
+
/** 添加禁止规则 */
|
|
136
|
+
addForbiddenRule(rule) {
|
|
137
|
+
this.contract.forbidden_rules = this.contract.forbidden_rules ?? [];
|
|
138
|
+
this.contract.forbidden_rules.push(rule);
|
|
139
|
+
return this;
|
|
140
|
+
}
|
|
141
|
+
/** 添加交付物 */
|
|
142
|
+
addDeliverable(deliverable) {
|
|
143
|
+
this.contract.required_deliverables = this.contract.required_deliverables ?? [];
|
|
144
|
+
this.contract.required_deliverables.push(deliverable);
|
|
145
|
+
return this;
|
|
146
|
+
}
|
|
147
|
+
/** 添加验证规则 */
|
|
148
|
+
addVerificationRule(rule) {
|
|
149
|
+
this.contract.verification_rules = this.contract.verification_rules ?? [];
|
|
150
|
+
this.contract.verification_rules.push(rule);
|
|
151
|
+
return this;
|
|
152
|
+
}
|
|
153
|
+
/** 添加质量标准 */
|
|
154
|
+
addQualityStandard(standard) {
|
|
155
|
+
this.contract.quality_standards = this.contract.quality_standards ?? [];
|
|
156
|
+
this.contract.quality_standards.push(standard);
|
|
157
|
+
return this;
|
|
158
|
+
}
|
|
159
|
+
/** 添加建议技能 */
|
|
160
|
+
addSuggestedSkill(skillName) {
|
|
161
|
+
this.contract.suggested_skills = this.contract.suggested_skills ?? [];
|
|
162
|
+
if (!this.contract.suggested_skills.includes(skillName)) {
|
|
163
|
+
this.contract.suggested_skills.push(skillName);
|
|
164
|
+
}
|
|
165
|
+
return this;
|
|
166
|
+
}
|
|
167
|
+
/** 配置记忆范围 */
|
|
168
|
+
withMemoryScope(scope) {
|
|
169
|
+
this.contract.memory_scope = {
|
|
170
|
+
...(this.contract.memory_scope ?? {
|
|
171
|
+
enable_resume: true,
|
|
172
|
+
enable_knowledge: true,
|
|
173
|
+
enable_failure_patterns: true,
|
|
174
|
+
}),
|
|
175
|
+
...scope,
|
|
176
|
+
};
|
|
177
|
+
return this;
|
|
178
|
+
}
|
|
179
|
+
/** 配置升级策略 */
|
|
180
|
+
withEscalationPolicy(policy) {
|
|
181
|
+
this.contract.escalation_policy = policy;
|
|
182
|
+
return this;
|
|
183
|
+
}
|
|
184
|
+
/** 合并另一个契约 */
|
|
185
|
+
merge(other) {
|
|
186
|
+
this.contract.forbidden_rules = [
|
|
187
|
+
...(this.contract.forbidden_rules ?? []),
|
|
188
|
+
...other.forbidden_rules,
|
|
189
|
+
];
|
|
190
|
+
this.contract.required_deliverables = [
|
|
191
|
+
...(this.contract.required_deliverables ?? []),
|
|
192
|
+
...other.required_deliverables,
|
|
193
|
+
];
|
|
194
|
+
this.contract.verification_rules = [
|
|
195
|
+
...(this.contract.verification_rules ?? []),
|
|
196
|
+
...other.verification_rules,
|
|
197
|
+
];
|
|
198
|
+
this.contract.quality_standards = [
|
|
199
|
+
...(this.contract.quality_standards ?? []),
|
|
200
|
+
...other.quality_standards,
|
|
201
|
+
];
|
|
202
|
+
this.contract.suggested_skills = [
|
|
203
|
+
...(this.contract.suggested_skills ?? []),
|
|
204
|
+
...other.suggested_skills.filter(s => !this.contract.suggested_skills?.includes(s)),
|
|
205
|
+
];
|
|
206
|
+
return this;
|
|
207
|
+
}
|
|
208
|
+
/** 构建最终契约 */
|
|
209
|
+
build() {
|
|
210
|
+
if (!this.contract.id || !this.contract.requirement || !this.contract.project_path || !this.contract.session_id) {
|
|
211
|
+
throw new Error('Contract 缺少必需字段:id, requirement, project_path, session_id');
|
|
212
|
+
}
|
|
213
|
+
return this.contract;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
//# sourceMappingURL=contract-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contract-builder.js","sourceRoot":"","sources":["../../src/governance/contract-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GovernanceEngine — 统一治理引擎
|
|
3
|
+
*
|
|
4
|
+
* 核心职责:
|
|
5
|
+
* - 管理契约生命周期
|
|
6
|
+
* - 注册和调度插件
|
|
7
|
+
* - 协调 Pre/Post 处理
|
|
8
|
+
* - 维护证据收集
|
|
9
|
+
*/
|
|
10
|
+
import type { GovernanceContract, GovernancePlugin, GovernanceDecision } from './types.js';
|
|
11
|
+
import type { ForgeEvent } from '../types/index.js';
|
|
12
|
+
export declare class GovernanceEngine {
|
|
13
|
+
private contracts;
|
|
14
|
+
private evidenceCollector;
|
|
15
|
+
private plugins;
|
|
16
|
+
/** 注册插件 */
|
|
17
|
+
registerPlugin(plugin: GovernancePlugin): void;
|
|
18
|
+
/** 加载契约 */
|
|
19
|
+
loadContract(contract: GovernanceContract): void;
|
|
20
|
+
/** 获取契约 */
|
|
21
|
+
getContract(sessionId: string): GovernanceContract | null;
|
|
22
|
+
/** 获取证据 */
|
|
23
|
+
getEvidence(contractId: string): import("./types.js").GovernanceEvidence | null;
|
|
24
|
+
/** PreToolUse 处理 */
|
|
25
|
+
handlePreToolUse(event: ForgeEvent): Promise<GovernanceDecision | null>;
|
|
26
|
+
/** PostToolUse 处理 */
|
|
27
|
+
handlePostToolUse(event: ForgeEvent): Promise<GovernanceDecision | null>;
|
|
28
|
+
/** 清理契约 */
|
|
29
|
+
clearContract(sessionId: string): void;
|
|
30
|
+
/** 合并多个决策 */
|
|
31
|
+
private mergeDecisions;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=engine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../src/governance/engine.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EACV,kBAAkB,EAClB,gBAAgB,EAChB,kBAAkB,EAEnB,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAIpD,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,SAAS,CAAyC;IAC1D,OAAO,CAAC,iBAAiB,CAA2B;IACpD,OAAO,CAAC,OAAO,CAA0B;IAEzC,WAAW;IACX,cAAc,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI;IAO9C,WAAW;IACX,YAAY,CAAC,QAAQ,EAAE,kBAAkB,GAAG,IAAI;IAQhD,WAAW;IACX,WAAW,CAAC,SAAS,EAAE,MAAM,GAAG,kBAAkB,GAAG,IAAI;IAIzD,WAAW;IACX,WAAW,CAAC,UAAU,EAAE,MAAM;IAI9B,oBAAoB;IACd,gBAAgB,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAwD7E,qBAAqB;IACf,iBAAiB,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAqE9E,WAAW;IACX,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAWtC,aAAa;IACb,OAAO,CAAC,cAAc;CAyBvB"}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GovernanceEngine — 统一治理引擎
|
|
3
|
+
*
|
|
4
|
+
* 核心职责:
|
|
5
|
+
* - 管理契约生命周期
|
|
6
|
+
* - 注册和调度插件
|
|
7
|
+
* - 协调 Pre/Post 处理
|
|
8
|
+
* - 维护证据收集
|
|
9
|
+
*/
|
|
10
|
+
import { EvidenceCollector } from './evidence-collector.js';
|
|
11
|
+
import { logger } from '../utils/logger.js';
|
|
12
|
+
export class GovernanceEngine {
|
|
13
|
+
contracts = new Map(); // sessionId → contract
|
|
14
|
+
evidenceCollector = new EvidenceCollector();
|
|
15
|
+
plugins = [];
|
|
16
|
+
/** 注册插件 */
|
|
17
|
+
registerPlugin(plugin) {
|
|
18
|
+
this.plugins.push(plugin);
|
|
19
|
+
// 按优先级排序
|
|
20
|
+
this.plugins.sort((a, b) => a.priority - b.priority);
|
|
21
|
+
logger.info(`[GovernanceEngine] 插件已注册:${plugin.name} (priority=${plugin.priority})`);
|
|
22
|
+
}
|
|
23
|
+
/** 加载契约 */
|
|
24
|
+
loadContract(contract) {
|
|
25
|
+
this.contracts.set(contract.session_id, contract);
|
|
26
|
+
this.evidenceCollector.init(contract.id);
|
|
27
|
+
logger.info(`[GovernanceEngine] 契约已加载:${contract.id} (mode=${contract.execution_mode}, session=${contract.session_id})`);
|
|
28
|
+
}
|
|
29
|
+
/** 获取契约 */
|
|
30
|
+
getContract(sessionId) {
|
|
31
|
+
return this.contracts.get(sessionId) ?? null;
|
|
32
|
+
}
|
|
33
|
+
/** 获取证据 */
|
|
34
|
+
getEvidence(contractId) {
|
|
35
|
+
return this.evidenceCollector.get(contractId);
|
|
36
|
+
}
|
|
37
|
+
/** PreToolUse 处理 */
|
|
38
|
+
async handlePreToolUse(event) {
|
|
39
|
+
const contract = this.contracts.get(event.session_id);
|
|
40
|
+
if (!contract) {
|
|
41
|
+
logger.debug(`[GovernanceEngine] 无契约,跳过 PreToolUse 处理`);
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
// 只处理 governance 模式
|
|
45
|
+
if (contract.execution_mode !== 'governance') {
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
const evidence = this.evidenceCollector.get(contract.id);
|
|
49
|
+
if (!evidence) {
|
|
50
|
+
logger.warn(`[GovernanceEngine] 证据容器未初始化:${contract.id}`);
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
const ctx = { contract, evidence, event };
|
|
54
|
+
const decisions = [];
|
|
55
|
+
// 执行 PreToolUse 插件链
|
|
56
|
+
for (const plugin of this.plugins) {
|
|
57
|
+
if (!plugin.runOnPreTool)
|
|
58
|
+
continue;
|
|
59
|
+
try {
|
|
60
|
+
const result = await plugin.execute(ctx);
|
|
61
|
+
// 更新证据
|
|
62
|
+
if (result.evidence_update) {
|
|
63
|
+
if (result.evidence_update.knowledge_hits) {
|
|
64
|
+
for (const hit of result.evidence_update.knowledge_hits) {
|
|
65
|
+
this.evidenceCollector.recordKnowledgeHit(contract.id, hit);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
// 收集决策
|
|
70
|
+
if (result.decision) {
|
|
71
|
+
decisions.push(result.decision);
|
|
72
|
+
}
|
|
73
|
+
// 如果插件要求停止,立即返回
|
|
74
|
+
if (!result.continue) {
|
|
75
|
+
logger.info(`[GovernanceEngine] 插件 ${plugin.name} 要求停止,返回决策`);
|
|
76
|
+
return result.decision ?? null;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
catch (err) {
|
|
80
|
+
logger.error(`[GovernanceEngine] 插件 ${plugin.name} 执行失败:${err}`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// 合并所有决策
|
|
84
|
+
return this.mergeDecisions(decisions);
|
|
85
|
+
}
|
|
86
|
+
/** PostToolUse 处理 */
|
|
87
|
+
async handlePostToolUse(event) {
|
|
88
|
+
const contract = this.contracts.get(event.session_id);
|
|
89
|
+
if (!contract) {
|
|
90
|
+
logger.debug(`[GovernanceEngine] 无契约,跳过 PostToolUse 处理`);
|
|
91
|
+
return null;
|
|
92
|
+
}
|
|
93
|
+
// 只处理 governance 模式
|
|
94
|
+
if (contract.execution_mode !== 'governance') {
|
|
95
|
+
return null;
|
|
96
|
+
}
|
|
97
|
+
const evidence = this.evidenceCollector.get(contract.id);
|
|
98
|
+
if (!evidence) {
|
|
99
|
+
logger.warn(`[GovernanceEngine] 证据容器未初始化:${contract.id}`);
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
// 记录工具事件
|
|
103
|
+
this.evidenceCollector.recordToolEvent(contract.id, {
|
|
104
|
+
tool_name: event.tool_name || 'unknown',
|
|
105
|
+
tool_input: event.tool_input,
|
|
106
|
+
timestamp: new Date().toISOString(),
|
|
107
|
+
success: true, // TODO: 从 event 中获取实际状态
|
|
108
|
+
});
|
|
109
|
+
const ctx = { contract, evidence, event };
|
|
110
|
+
const decisions = [];
|
|
111
|
+
// 执行 PostToolUse 插件链
|
|
112
|
+
for (const plugin of this.plugins) {
|
|
113
|
+
if (!plugin.runOnPostTool)
|
|
114
|
+
continue;
|
|
115
|
+
try {
|
|
116
|
+
const result = await plugin.execute(ctx);
|
|
117
|
+
// 更新证据
|
|
118
|
+
if (result.evidence_update) {
|
|
119
|
+
if (result.evidence_update.verification_results) {
|
|
120
|
+
for (const vr of result.evidence_update.verification_results) {
|
|
121
|
+
this.evidenceCollector.recordVerification(contract.id, vr);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
if (result.evidence_update.quality_issues) {
|
|
125
|
+
for (const qi of result.evidence_update.quality_issues) {
|
|
126
|
+
this.evidenceCollector.recordQualityIssue(contract.id, qi);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
// 收集决策
|
|
131
|
+
if (result.decision) {
|
|
132
|
+
decisions.push(result.decision);
|
|
133
|
+
}
|
|
134
|
+
// 如果插件要求停止,立即返回
|
|
135
|
+
if (!result.continue) {
|
|
136
|
+
logger.info(`[GovernanceEngine] 插件 ${plugin.name} 要求停止,返回决策`);
|
|
137
|
+
return result.decision ?? null;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
catch (err) {
|
|
141
|
+
logger.error(`[GovernanceEngine] 插件 ${plugin.name} 执行失败:${err}`);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
// 合并所有决策
|
|
145
|
+
return this.mergeDecisions(decisions);
|
|
146
|
+
}
|
|
147
|
+
/** 清理契约 */
|
|
148
|
+
clearContract(sessionId) {
|
|
149
|
+
const contract = this.contracts.get(sessionId);
|
|
150
|
+
if (contract) {
|
|
151
|
+
this.evidenceCollector.clear(contract.id);
|
|
152
|
+
this.contracts.delete(sessionId);
|
|
153
|
+
logger.info(`[GovernanceEngine] 契约已清理:${contract.id}`);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
// ─── 私有辅助方法 ────────────────────────────────────────────────────
|
|
157
|
+
/** 合并多个决策 */
|
|
158
|
+
mergeDecisions(decisions) {
|
|
159
|
+
if (decisions.length === 0)
|
|
160
|
+
return null;
|
|
161
|
+
if (decisions.length === 1)
|
|
162
|
+
return decisions[0];
|
|
163
|
+
// 优先级:deny > warn > allow
|
|
164
|
+
const hasDeny = decisions.some(d => d.action === 'deny');
|
|
165
|
+
const hasWarn = decisions.some(d => d.action === 'warn');
|
|
166
|
+
const action = hasDeny ? 'deny' : hasWarn ? 'warn' : 'allow';
|
|
167
|
+
const reasons = decisions.map(d => d.reason).filter(Boolean);
|
|
168
|
+
const contexts = decisions.map(d => d.inject_context).filter(Boolean);
|
|
169
|
+
const missingDeliverables = decisions.flatMap(d => d.missing_deliverables ?? []);
|
|
170
|
+
const qualityFailures = decisions.flatMap(d => d.quality_failures ?? []);
|
|
171
|
+
const correctiveActions = decisions.flatMap(d => d.corrective_actions ?? []);
|
|
172
|
+
return {
|
|
173
|
+
action,
|
|
174
|
+
reason: reasons.length > 0 ? reasons.join('; ') : undefined,
|
|
175
|
+
inject_context: contexts.length > 0 ? contexts.join('\n\n') : undefined,
|
|
176
|
+
missing_deliverables: missingDeliverables.length > 0 ? missingDeliverables : undefined,
|
|
177
|
+
quality_failures: qualityFailures.length > 0 ? qualityFailures : undefined,
|
|
178
|
+
corrective_actions: correctiveActions.length > 0 ? correctiveActions : undefined,
|
|
179
|
+
decided_at: new Date().toISOString(),
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/governance/engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* EvidenceCollector — 统一证据收集器
|
|
3
|
+
*
|
|
4
|
+
* 收集执行过程中的所有证据:工具事件、产物、验证结果、质量问题、知识命中。
|
|
5
|
+
* 按 contract_id 隔离,支持查询和统计。
|
|
6
|
+
*/
|
|
7
|
+
import type { GovernanceEvidence, ToolEvent, GovernanceArtifact, GovernanceVerificationResult, QualityIssue, KnowledgeHit } from './types.js';
|
|
8
|
+
export declare class EvidenceCollector {
|
|
9
|
+
private evidenceMap;
|
|
10
|
+
/** 初始化一个契约的证据容器 */
|
|
11
|
+
init(contractId: string): void;
|
|
12
|
+
/** 获取证据(只读快照) */
|
|
13
|
+
get(contractId: string): GovernanceEvidence | null;
|
|
14
|
+
/** 记录工具事件 */
|
|
15
|
+
recordToolEvent(contractId: string, event: ToolEvent): void;
|
|
16
|
+
/** 记录产物 */
|
|
17
|
+
recordArtifact(contractId: string, artifact: GovernanceArtifact): void;
|
|
18
|
+
/** 记录验证结果 */
|
|
19
|
+
recordVerification(contractId: string, result: GovernanceVerificationResult): void;
|
|
20
|
+
/** 记录质量问题 */
|
|
21
|
+
recordQualityIssue(contractId: string, issue: QualityIssue): void;
|
|
22
|
+
/** 记录知识命中 */
|
|
23
|
+
recordKnowledgeHit(contractId: string, hit: KnowledgeHit): void;
|
|
24
|
+
/** 设置会话摘要 */
|
|
25
|
+
setSessionSummary(contractId: string, summary: string): void;
|
|
26
|
+
/** 最近 N 次工具事件 */
|
|
27
|
+
recentToolEvents(contractId: string, n: number): ToolEvent[];
|
|
28
|
+
/** 连续失败次数 */
|
|
29
|
+
consecutiveFailures(contractId: string): number;
|
|
30
|
+
/** 检测重复失败模式(最近 N 次是否都是同一工具失败) */
|
|
31
|
+
detectRepetitiveFailure(contractId: string, windowSize?: number): {
|
|
32
|
+
detected: boolean;
|
|
33
|
+
tool?: string;
|
|
34
|
+
};
|
|
35
|
+
/** 未通过的必需验证项 */
|
|
36
|
+
failedVerifications(contractId: string): GovernanceVerificationResult[];
|
|
37
|
+
/** 未解决的质量问题(fail 级别) */
|
|
38
|
+
openQualityIssues(contractId: string): QualityIssue[];
|
|
39
|
+
/** 清理契约证据 */
|
|
40
|
+
clear(contractId: string): void;
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=evidence-collector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evidence-collector.d.ts","sourceRoot":"","sources":["../../src/governance/evidence-collector.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EACV,kBAAkB,EAClB,SAAS,EACT,kBAAkB,EAClB,4BAA4B,EAC5B,YAAY,EACZ,YAAY,EACb,MAAM,YAAY,CAAC;AAEpB,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,WAAW,CAAyC;IAE5D,mBAAmB;IACnB,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAa9B,iBAAiB;IACjB,GAAG,CAAC,UAAU,EAAE,MAAM,GAAG,kBAAkB,GAAG,IAAI;IAIlD,aAAa;IACb,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,IAAI;IAO3D,WAAW;IACX,cAAc,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,kBAAkB,GAAG,IAAI;IAYtE,aAAa;IACb,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,4BAA4B,GAAG,IAAI;IAOlF,aAAa;IACb,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,GAAG,IAAI;IAOjE,aAAa;IACb,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,EAAE,YAAY,GAAG,IAAI;IAO/D,aAAa;IACb,iBAAiB,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAS5D,iBAAiB;IACjB,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,SAAS,EAAE;IAM5D,aAAa;IACb,mBAAmB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;IAW/C,iCAAiC;IACjC,uBAAuB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,SAAI,GAAG;QAAE,QAAQ,EAAE,OAAO,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE;IAYjG,gBAAgB;IAChB,mBAAmB,CAAC,UAAU,EAAE,MAAM,GAAG,4BAA4B,EAAE;IAMvE,wBAAwB;IACxB,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,YAAY,EAAE;IAMrD,aAAa;IACb,KAAK,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;CAGhC"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* EvidenceCollector — 统一证据收集器
|
|
3
|
+
*
|
|
4
|
+
* 收集执行过程中的所有证据:工具事件、产物、验证结果、质量问题、知识命中。
|
|
5
|
+
* 按 contract_id 隔离,支持查询和统计。
|
|
6
|
+
*/
|
|
7
|
+
export class EvidenceCollector {
|
|
8
|
+
evidenceMap = new Map();
|
|
9
|
+
/** 初始化一个契约的证据容器 */
|
|
10
|
+
init(contractId) {
|
|
11
|
+
if (this.evidenceMap.has(contractId))
|
|
12
|
+
return;
|
|
13
|
+
this.evidenceMap.set(contractId, {
|
|
14
|
+
contract_id: contractId,
|
|
15
|
+
tool_events: [],
|
|
16
|
+
artifacts: [],
|
|
17
|
+
verification_results: [],
|
|
18
|
+
quality_issues: [],
|
|
19
|
+
knowledge_hits: [],
|
|
20
|
+
updated_at: new Date().toISOString(),
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
/** 获取证据(只读快照) */
|
|
24
|
+
get(contractId) {
|
|
25
|
+
return this.evidenceMap.get(contractId) ?? null;
|
|
26
|
+
}
|
|
27
|
+
/** 记录工具事件 */
|
|
28
|
+
recordToolEvent(contractId, event) {
|
|
29
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
30
|
+
if (!evidence)
|
|
31
|
+
return;
|
|
32
|
+
evidence.tool_events.push(event);
|
|
33
|
+
evidence.updated_at = event.timestamp;
|
|
34
|
+
}
|
|
35
|
+
/** 记录产物 */
|
|
36
|
+
recordArtifact(contractId, artifact) {
|
|
37
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
38
|
+
if (!evidence)
|
|
39
|
+
return;
|
|
40
|
+
const existing = evidence.artifacts.findIndex(a => a.path === artifact.path);
|
|
41
|
+
if (existing >= 0) {
|
|
42
|
+
evidence.artifacts[existing] = artifact;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
evidence.artifacts.push(artifact);
|
|
46
|
+
}
|
|
47
|
+
evidence.updated_at = artifact.created_at;
|
|
48
|
+
}
|
|
49
|
+
/** 记录验证结果 */
|
|
50
|
+
recordVerification(contractId, result) {
|
|
51
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
52
|
+
if (!evidence)
|
|
53
|
+
return;
|
|
54
|
+
evidence.verification_results.push(result);
|
|
55
|
+
evidence.updated_at = result.verified_at;
|
|
56
|
+
}
|
|
57
|
+
/** 记录质量问题 */
|
|
58
|
+
recordQualityIssue(contractId, issue) {
|
|
59
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
60
|
+
if (!evidence)
|
|
61
|
+
return;
|
|
62
|
+
evidence.quality_issues.push(issue);
|
|
63
|
+
evidence.updated_at = issue.detected_at;
|
|
64
|
+
}
|
|
65
|
+
/** 记录知识命中 */
|
|
66
|
+
recordKnowledgeHit(contractId, hit) {
|
|
67
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
68
|
+
if (!evidence)
|
|
69
|
+
return;
|
|
70
|
+
evidence.knowledge_hits.push(hit);
|
|
71
|
+
evidence.updated_at = hit.retrieved_at;
|
|
72
|
+
}
|
|
73
|
+
/** 设置会话摘要 */
|
|
74
|
+
setSessionSummary(contractId, summary) {
|
|
75
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
76
|
+
if (!evidence)
|
|
77
|
+
return;
|
|
78
|
+
evidence.session_summary = summary;
|
|
79
|
+
evidence.updated_at = new Date().toISOString();
|
|
80
|
+
}
|
|
81
|
+
// ─── 查询与统计 ──────────────────────────────────────────────────────
|
|
82
|
+
/** 最近 N 次工具事件 */
|
|
83
|
+
recentToolEvents(contractId, n) {
|
|
84
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
85
|
+
if (!evidence)
|
|
86
|
+
return [];
|
|
87
|
+
return evidence.tool_events.slice(-n);
|
|
88
|
+
}
|
|
89
|
+
/** 连续失败次数 */
|
|
90
|
+
consecutiveFailures(contractId) {
|
|
91
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
92
|
+
if (!evidence)
|
|
93
|
+
return 0;
|
|
94
|
+
let count = 0;
|
|
95
|
+
for (let i = evidence.tool_events.length - 1; i >= 0; i--) {
|
|
96
|
+
if (!evidence.tool_events[i].success)
|
|
97
|
+
count++;
|
|
98
|
+
else
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
return count;
|
|
102
|
+
}
|
|
103
|
+
/** 检测重复失败模式(最近 N 次是否都是同一工具失败) */
|
|
104
|
+
detectRepetitiveFailure(contractId, windowSize = 5) {
|
|
105
|
+
const recent = this.recentToolEvents(contractId, windowSize);
|
|
106
|
+
if (recent.length < windowSize)
|
|
107
|
+
return { detected: false };
|
|
108
|
+
const allFailed = recent.every(e => !e.success);
|
|
109
|
+
if (!allFailed)
|
|
110
|
+
return { detected: false };
|
|
111
|
+
const tools = new Set(recent.map(e => e.tool_name));
|
|
112
|
+
if (tools.size === 1) {
|
|
113
|
+
return { detected: true, tool: recent[0].tool_name };
|
|
114
|
+
}
|
|
115
|
+
return { detected: true };
|
|
116
|
+
}
|
|
117
|
+
/** 未通过的必需验证项 */
|
|
118
|
+
failedVerifications(contractId) {
|
|
119
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
120
|
+
if (!evidence)
|
|
121
|
+
return [];
|
|
122
|
+
return evidence.verification_results.filter(r => !r.passed);
|
|
123
|
+
}
|
|
124
|
+
/** 未解决的质量问题(fail 级别) */
|
|
125
|
+
openQualityIssues(contractId) {
|
|
126
|
+
const evidence = this.evidenceMap.get(contractId);
|
|
127
|
+
if (!evidence)
|
|
128
|
+
return [];
|
|
129
|
+
return evidence.quality_issues.filter(i => i.level === 'fail');
|
|
130
|
+
}
|
|
131
|
+
/** 清理契约证据 */
|
|
132
|
+
clear(contractId) {
|
|
133
|
+
this.evidenceMap.delete(contractId);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=evidence-collector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evidence-collector.js","sourceRoot":"","sources":["../../src/governance/evidence-collector.ts"],"names":[],"mappings":"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"}
|