@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.
Files changed (274) hide show
  1. package/dist/autopilot/quality-gate-utils.d.ts +6 -0
  2. package/dist/autopilot/quality-gate-utils.d.ts.map +1 -0
  3. package/dist/autopilot/quality-gate-utils.js +48 -0
  4. package/dist/autopilot/quality-gate-utils.js.map +1 -0
  5. package/dist/autopilot/quality-gate.d.ts +0 -8
  6. package/dist/autopilot/quality-gate.d.ts.map +1 -1
  7. package/dist/autopilot/quality-gate.js +6 -61
  8. package/dist/autopilot/quality-gate.js.map +1 -1
  9. package/dist/cli/commands/convention.d.ts.map +1 -1
  10. package/dist/cli/commands/convention.js +1 -115
  11. package/dist/cli/commands/convention.js.map +1 -1
  12. package/dist/cli/commands/init/index.d.ts.map +1 -1
  13. package/dist/cli/commands/init/index.js +0 -14
  14. package/dist/cli/commands/init/index.js.map +1 -1
  15. package/dist/cli/commands/init/project-doctor.d.ts.map +1 -1
  16. package/dist/cli/commands/init/project-doctor.js +0 -63
  17. package/dist/cli/commands/init/project-doctor.js.map +1 -1
  18. package/dist/cli/tui.d.ts.map +1 -1
  19. package/dist/cli/tui.js +7 -131
  20. package/dist/cli/tui.js.map +1 -1
  21. package/dist/constants.d.ts +0 -6
  22. package/dist/constants.d.ts.map +1 -1
  23. package/dist/constants.js +0 -6
  24. package/dist/constants.js.map +1 -1
  25. package/dist/convention/convention-loader.js +2 -2
  26. package/dist/convention/convention-loader.js.map +1 -1
  27. package/dist/convention/convention-manager.d.ts +24 -2
  28. package/dist/convention/convention-manager.d.ts.map +1 -1
  29. package/dist/convention/convention-manager.js +62 -4
  30. package/dist/convention/convention-manager.js.map +1 -1
  31. package/dist/convention/index.d.ts +1 -2
  32. package/dist/convention/index.d.ts.map +1 -1
  33. package/dist/convention/index.js +0 -1
  34. package/dist/convention/index.js.map +1 -1
  35. package/dist/convention/types.d.ts +4 -14
  36. package/dist/convention/types.d.ts.map +1 -1
  37. package/dist/daemon/engine-registry/init-governance.d.ts +10 -0
  38. package/dist/daemon/engine-registry/init-governance.d.ts.map +1 -0
  39. package/dist/daemon/engine-registry/init-governance.js +22 -0
  40. package/dist/daemon/engine-registry/init-governance.js.map +1 -0
  41. package/dist/daemon/engine-registry.d.ts.map +1 -1
  42. package/dist/daemon/engine-registry.js +5 -6
  43. package/dist/daemon/engine-registry.js.map +1 -1
  44. package/dist/daemon/handler-context.d.ts +4 -2
  45. package/dist/daemon/handler-context.d.ts.map +1 -1
  46. package/dist/daemon/handlers/post-tool-use-handler.d.ts.map +1 -1
  47. package/dist/daemon/handlers/post-tool-use-handler.js +47 -11
  48. package/dist/daemon/handlers/post-tool-use-handler.js.map +1 -1
  49. package/dist/daemon/handlers/pre-tool-use-handler.d.ts.map +1 -1
  50. package/dist/daemon/handlers/pre-tool-use-handler.js +32 -22
  51. package/dist/daemon/handlers/pre-tool-use-handler.js.map +1 -1
  52. package/dist/daemon/handlers/session-cleanup.d.ts +0 -4
  53. package/dist/daemon/handlers/session-cleanup.d.ts.map +1 -1
  54. package/dist/daemon/handlers/session-cleanup.js +0 -81
  55. package/dist/daemon/handlers/session-cleanup.js.map +1 -1
  56. package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts.map +1 -1
  57. package/dist/daemon/handlers/stages/07-pipeline-reply.js +5 -1
  58. package/dist/daemon/handlers/stages/07-pipeline-reply.js.map +1 -1
  59. package/dist/daemon/handlers/stages/09-pipeline-active.d.ts.map +1 -1
  60. package/dist/daemon/handlers/stages/09-pipeline-active.js +5 -1
  61. package/dist/daemon/handlers/stages/09-pipeline-active.js.map +1 -1
  62. package/dist/daemon/handlers/stages/13-template-route.d.ts.map +1 -1
  63. package/dist/daemon/handlers/stages/13-template-route.js +5 -1
  64. package/dist/daemon/handlers/stages/13-template-route.js.map +1 -1
  65. package/dist/daemon/handlers/stages/18-complex-task.d.ts +5 -2
  66. package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -1
  67. package/dist/daemon/handlers/stages/18-complex-task.js +87 -9
  68. package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
  69. package/dist/daemon/handlers/stop-handler.d.ts.map +1 -1
  70. package/dist/daemon/handlers/stop-handler.js +1 -13
  71. package/dist/daemon/handlers/stop-handler.js.map +1 -1
  72. package/dist/daemon/index.d.ts.map +1 -1
  73. package/dist/daemon/index.js +15 -0
  74. package/dist/daemon/index.js.map +1 -1
  75. package/dist/goal/goal-classifier.d.ts.map +1 -1
  76. package/dist/goal/goal-classifier.js +12 -5
  77. package/dist/goal/goal-classifier.js.map +1 -1
  78. package/dist/goal/goal-types.d.ts +1 -3
  79. package/dist/goal/goal-types.d.ts.map +1 -1
  80. package/dist/goal/index.d.ts +1 -1
  81. package/dist/goal/index.d.ts.map +1 -1
  82. package/dist/governance/contract-builder.d.ts +39 -0
  83. package/dist/governance/contract-builder.d.ts.map +1 -0
  84. package/dist/governance/contract-builder.js +216 -0
  85. package/dist/governance/contract-builder.js.map +1 -0
  86. package/dist/governance/engine.d.ts +33 -0
  87. package/dist/governance/engine.d.ts.map +1 -0
  88. package/dist/governance/engine.js +183 -0
  89. package/dist/governance/engine.js.map +1 -0
  90. package/dist/governance/evidence-collector.d.ts +42 -0
  91. package/dist/governance/evidence-collector.d.ts.map +1 -0
  92. package/dist/governance/evidence-collector.js +136 -0
  93. package/dist/governance/evidence-collector.js.map +1 -0
  94. package/dist/governance/plugins/correction-plugin.d.ts +20 -0
  95. package/dist/governance/plugins/correction-plugin.d.ts.map +1 -0
  96. package/dist/governance/plugins/correction-plugin.js +113 -0
  97. package/dist/governance/plugins/correction-plugin.js.map +1 -0
  98. package/dist/governance/plugins/guidance-plugin.d.ts +21 -0
  99. package/dist/governance/plugins/guidance-plugin.d.ts.map +1 -0
  100. package/dist/governance/plugins/guidance-plugin.js +69 -0
  101. package/dist/governance/plugins/guidance-plugin.js.map +1 -0
  102. package/dist/governance/plugins/memory-plugin.d.ts +22 -0
  103. package/dist/governance/plugins/memory-plugin.d.ts.map +1 -0
  104. package/dist/governance/plugins/memory-plugin.js +106 -0
  105. package/dist/governance/plugins/memory-plugin.js.map +1 -0
  106. package/dist/governance/plugins/policy-plugin.d.ts +16 -0
  107. package/dist/governance/plugins/policy-plugin.d.ts.map +1 -0
  108. package/dist/governance/plugins/policy-plugin.js +69 -0
  109. package/dist/governance/plugins/policy-plugin.js.map +1 -0
  110. package/dist/governance/plugins/verification-plugin.d.ts +15 -0
  111. package/dist/governance/plugins/verification-plugin.d.ts.map +1 -0
  112. package/dist/governance/plugins/verification-plugin.js +65 -0
  113. package/dist/governance/plugins/verification-plugin.js.map +1 -0
  114. package/dist/governance/types.d.ts +202 -0
  115. package/dist/governance/types.d.ts.map +1 -0
  116. package/dist/governance/types.js +10 -0
  117. package/dist/governance/types.js.map +1 -0
  118. package/dist/pipeline/completion-engine.js +7 -7
  119. package/dist/pipeline/completion-engine.js.map +1 -1
  120. package/dist/pipeline/completion-gate.js +3 -3
  121. package/dist/pipeline/completion-gate.js.map +1 -1
  122. package/dist/pipeline/diagnosis-service.d.ts +2 -1
  123. package/dist/pipeline/diagnosis-service.d.ts.map +1 -1
  124. package/dist/pipeline/diagnosis-service.js.map +1 -1
  125. package/dist/pipeline/dynamic-node-executor.js +1 -1
  126. package/dist/pipeline/dynamic-node-executor.js.map +1 -1
  127. package/dist/pipeline/execution-engine.d.ts +1 -6
  128. package/dist/pipeline/execution-engine.d.ts.map +1 -1
  129. package/dist/pipeline/execution-engine.js +1 -1
  130. package/dist/pipeline/execution-engine.js.map +1 -1
  131. package/dist/pipeline/execution-plan.js +1 -1
  132. package/dist/pipeline/execution-plan.js.map +1 -1
  133. package/dist/pipeline/i-node-executor.d.ts +4 -0
  134. package/dist/pipeline/i-node-executor.d.ts.map +1 -1
  135. package/dist/pipeline/node-type-evolver.js +1 -1
  136. package/dist/pipeline/node-type-evolver.js.map +1 -1
  137. package/dist/pipeline/node-type-sync.d.ts.map +1 -1
  138. package/dist/pipeline/node-type-sync.js +10 -43
  139. package/dist/pipeline/node-type-sync.js.map +1 -1
  140. package/dist/pipeline/pattern-types.d.ts +3 -1
  141. package/dist/pipeline/pattern-types.d.ts.map +1 -1
  142. package/dist/retrospective/types.d.ts +2 -4
  143. package/dist/retrospective/types.d.ts.map +1 -1
  144. package/dist/skill-registry/evolver/index.js +6 -2
  145. package/dist/skill-registry/evolver/index.js.map +1 -1
  146. package/dist/skill-registry/index.d.ts +5 -0
  147. package/dist/skill-registry/index.d.ts.map +1 -1
  148. package/dist/skill-registry/index.js +6 -0
  149. package/dist/skill-registry/index.js.map +1 -1
  150. package/dist/storage/repositories/dynamic-pipeline-repository.d.ts.map +1 -1
  151. package/dist/storage/repositories/dynamic-pipeline-repository.js +18 -6
  152. package/dist/storage/repositories/dynamic-pipeline-repository.js.map +1 -1
  153. package/dist/storage/repositories/node-attempt-repository.d.ts +1 -1
  154. package/dist/storage/repositories/node-attempt-repository.d.ts.map +1 -1
  155. package/dist/storage/repositories/node-attempt-repository.js +1 -1
  156. package/dist/storage/repositories/node-attempt-repository.js.map +1 -1
  157. package/dist/storage/repositories/pipeline-plan-repository.d.ts.map +1 -1
  158. package/dist/storage/repositories/pipeline-plan-repository.js +1 -1
  159. package/dist/storage/repositories/pipeline-plan-repository.js.map +1 -1
  160. package/dist/storage/repositories/template-evolution-repository.d.ts.map +1 -1
  161. package/dist/storage/repositories/template-evolution-repository.js.map +1 -1
  162. package/dist/web/routes/pipelines.d.ts.map +1 -1
  163. package/dist/web/routes/pipelines.js +16 -5
  164. package/dist/web/routes/pipelines.js.map +1 -1
  165. package/dist/web/routes/quality.d.ts.map +1 -1
  166. package/dist/web/routes/quality.js +18 -17
  167. package/dist/web/routes/quality.js.map +1 -1
  168. package/dist/web/server.d.ts.map +1 -1
  169. package/dist/web/server.js +0 -7
  170. package/dist/web/server.js.map +1 -1
  171. package/dist/web/sse-broadcaster.d.ts +1 -1
  172. package/dist/web/sse-broadcaster.d.ts.map +1 -1
  173. package/dist/web/sse-broadcaster.js.map +1 -1
  174. package/dist/web-static/assets/Analytics-Bo_OyY9A.js +36 -0
  175. package/dist/web-static/assets/BatchProgress-qW-6664M.js +1 -0
  176. package/dist/web-static/assets/Breadcrumb-C1Mua6se.js +1 -0
  177. package/dist/web-static/assets/Config-Dn-dtdo9.js +1 -0
  178. package/dist/web-static/assets/ConfirmDialog-bdDaAlT1.js +1 -0
  179. package/dist/web-static/assets/Conventions-ByV7r45c.js +1 -0
  180. package/dist/web-static/assets/Dashboard-C-7N8kYZ.js +1 -0
  181. package/dist/web-static/assets/ErrorState-CMLoMrQY.js +1 -0
  182. package/dist/web-static/assets/Events-DHuyQHQe.js +1 -0
  183. package/dist/web-static/assets/Evolution-Dzr5xOLD.js +1 -0
  184. package/dist/web-static/assets/Knowledge-ClwX4cnr.js +2 -0
  185. package/dist/web-static/assets/MiniCharts-DsV2Sqfk.js +1 -0
  186. package/dist/web-static/assets/NodeTypes-DFt8b5gi.js +1 -0
  187. package/dist/web-static/assets/Pagination-CR-eJz36.js +1 -0
  188. package/dist/web-static/assets/PipelineDetail-By1HJlaB.js +4 -0
  189. package/dist/web-static/assets/Pipelines--MGzCPtR.js +2 -0
  190. package/dist/web-static/assets/ProjectDetail-CrpekCeY.js +1 -0
  191. package/dist/web-static/assets/Projects-Dw1qYmjz.js +1 -0
  192. package/dist/web-static/assets/Quality-CYwODfQP.js +3 -0
  193. package/dist/web-static/assets/SessionDetail-c8MYnwnk.js +1 -0
  194. package/dist/web-static/assets/Sessions-BkDd4Mxb.js +2 -0
  195. package/dist/web-static/assets/Skeleton-DbL04wuz.js +1 -0
  196. package/dist/web-static/assets/Skills-2OPSAnaU.js +1 -0
  197. package/dist/web-static/assets/TemplateDetail-DbifRj4h.js +1 -0
  198. package/dist/web-static/assets/Templates-CDw-GGp8.js +1 -0
  199. package/dist/web-static/assets/Toast-CrwuIbKC.js +1 -0
  200. package/dist/web-static/assets/client-C_VWY70M.js +1 -0
  201. package/dist/web-static/assets/index-DD2Z15TY.css +2 -0
  202. package/dist/web-static/assets/index-DR3AaQnu.js +2 -0
  203. package/dist/web-static/assets/ui-DpI1N3yJ.js +1 -0
  204. package/dist/web-static/assets/useDebounce-BLryFdeo.js +1 -0
  205. package/dist/web-static/assets/vendor-2ObLXPrQ.js +9 -0
  206. package/dist/web-static/assets/vendor-motion-BryL_tAt.js +9 -0
  207. package/dist/web-static/assets/vendor-query-CjmRaY7o.js +4 -0
  208. package/dist/web-static/assets/vendor-react-DZi7brq3.js +11 -0
  209. package/dist/web-static/index.html +10 -13
  210. package/package.json +4 -8
  211. package/dist/convention/convention-distiller.d.ts +0 -28
  212. package/dist/convention/convention-distiller.d.ts.map +0 -1
  213. package/dist/convention/convention-distiller.js +0 -172
  214. package/dist/convention/convention-distiller.js.map +0 -1
  215. package/dist/convention/official-sync.d.ts +0 -21
  216. package/dist/convention/official-sync.d.ts.map +0 -1
  217. package/dist/convention/official-sync.js +0 -196
  218. package/dist/convention/official-sync.js.map +0 -1
  219. package/dist/daemon/handlers/stages/19-moderate-task.d.ts +0 -11
  220. package/dist/daemon/handlers/stages/19-moderate-task.d.ts.map +0 -1
  221. package/dist/daemon/handlers/stages/19-moderate-task.js +0 -78
  222. package/dist/daemon/handlers/stages/19-moderate-task.js.map +0 -1
  223. package/dist/web/routes/conventions.d.ts +0 -8
  224. package/dist/web/routes/conventions.d.ts.map +0 -1
  225. package/dist/web/routes/conventions.js +0 -308
  226. package/dist/web/routes/conventions.js.map +0 -1
  227. package/dist/web/routes/logs.d.ts +0 -4
  228. package/dist/web/routes/logs.d.ts.map +0 -1
  229. package/dist/web/routes/logs.js +0 -77
  230. package/dist/web/routes/logs.js.map +0 -1
  231. package/dist/web/routes/project-conventions.d.ts +0 -7
  232. package/dist/web/routes/project-conventions.d.ts.map +0 -1
  233. package/dist/web/routes/project-conventions.js +0 -145
  234. package/dist/web/routes/project-conventions.js.map +0 -1
  235. package/dist/web-static/assets/Analytics-txva5ugO.js +0 -1
  236. package/dist/web-static/assets/BatchProgress-BQ533tSf.js +0 -1
  237. package/dist/web-static/assets/Breadcrumb-DtfwnOx6.js +0 -1
  238. package/dist/web-static/assets/Config-CUb6-ddH.js +0 -1
  239. package/dist/web-static/assets/ConfirmDialog-BKfwMp04.js +0 -1
  240. package/dist/web-static/assets/Conventions-E_2yAYoB.js +0 -1
  241. package/dist/web-static/assets/Dashboard-Dskgf0jG.js +0 -1
  242. package/dist/web-static/assets/ErrorState-BOInXmfg.js +0 -1
  243. package/dist/web-static/assets/Events-CAY9kU9T.js +0 -1
  244. package/dist/web-static/assets/Evolution-Ck_BqRpt.js +0 -1
  245. package/dist/web-static/assets/Knowledge-BHLyFp2U.js +0 -2
  246. package/dist/web-static/assets/NodeTypes-B6wc7VnR.js +0 -1
  247. package/dist/web-static/assets/Pagination-lp8b_3NR.js +0 -1
  248. package/dist/web-static/assets/PipelineDetail-Bc6l2jqX.js +0 -4
  249. package/dist/web-static/assets/PipelineTemplates-sSL-9oRh.js +0 -1
  250. package/dist/web-static/assets/Pipelines-Drat9IqZ.js +0 -2
  251. package/dist/web-static/assets/ProjectDetail-Cx8VZp8O.js +0 -1
  252. package/dist/web-static/assets/Projects-qDolX6Y6.js +0 -1
  253. package/dist/web-static/assets/Quality-Bm7oRSun.js +0 -3
  254. package/dist/web-static/assets/SessionDetail-BMrqH8_W.js +0 -1
  255. package/dist/web-static/assets/Sessions-C0BmdDPK.js +0 -2
  256. package/dist/web-static/assets/Skeleton-B7PVDJJ_.js +0 -1
  257. package/dist/web-static/assets/Skills-B3c1_uFt.js +0 -1
  258. package/dist/web-static/assets/TemplateDetail-ep5h3Cu5.js +0 -1
  259. package/dist/web-static/assets/Templates-Dho__f4l.js +0 -1
  260. package/dist/web-static/assets/Toast-BbB3oD2a.js +0 -1
  261. package/dist/web-static/assets/client-BvVpIixG.js +0 -1
  262. package/dist/web-static/assets/index-CgfiGhyE.js +0 -2
  263. package/dist/web-static/assets/index-CqwJts5v.css +0 -2
  264. package/dist/web-static/assets/ui-CDL3BZ13.js +0 -1
  265. package/dist/web-static/assets/useDebounce-DNfPs3Tv.js +0 -1
  266. package/dist/web-static/assets/vendor-DRGPi8ui.js +0 -9
  267. package/dist/web-static/assets/vendor-charts-9eVsQvUV.js +0 -36
  268. package/dist/web-static/assets/vendor-editor-CYLOGES5.js +0 -11
  269. package/dist/web-static/assets/vendor-flow-CHpVij2M.css +0 -1
  270. package/dist/web-static/assets/vendor-flow-srkes8If.js +0 -7
  271. package/dist/web-static/assets/vendor-motion-CQmdgnI8.js +0 -9
  272. package/dist/web-static/assets/vendor-query-DqPOMnuX.js +0 -4
  273. package/dist/web-static/assets/vendor-react-DJI9oneq.js +0 -11
  274. /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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"}