soloforge 1.1.30 → 1.1.31

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 (804) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/README.md +33 -18
  3. package/dist/adapters/claude_code/claude_md.d.ts +2 -1
  4. package/dist/adapters/claude_code/claude_md.d.ts.map +1 -1
  5. package/dist/adapters/claude_code/claude_md.js.map +1 -1
  6. package/dist/adapters/codex/codex_rules.d.ts +2 -1
  7. package/dist/adapters/codex/codex_rules.d.ts.map +1 -1
  8. package/dist/adapters/codex/codex_rules.js.map +1 -1
  9. package/dist/adapters/shared/workflow_template.d.ts.map +1 -1
  10. package/dist/adapters/shared/workflow_template.js +0 -1
  11. package/dist/adapters/shared/workflow_template.js.map +1 -1
  12. package/dist/adapters/trae/trae_config.d.ts +17 -1
  13. package/dist/adapters/trae/trae_config.d.ts.map +1 -1
  14. package/dist/adapters/trae/trae_config.js +2 -2
  15. package/dist/adapters/trae/trae_config.js.map +1 -1
  16. package/dist/adapters/trae/trae_rules.d.ts +2 -1
  17. package/dist/adapters/trae/trae_rules.d.ts.map +1 -1
  18. package/dist/adapters/trae/trae_rules.js.map +1 -1
  19. package/dist/bin/args.d.ts +9 -0
  20. package/dist/bin/args.d.ts.map +1 -1
  21. package/dist/bin/args.js +44 -1
  22. package/dist/bin/args.js.map +1 -1
  23. package/dist/bin/commands/audit.d.ts.map +1 -1
  24. package/dist/bin/commands/audit.js +5 -40
  25. package/dist/bin/commands/audit.js.map +1 -1
  26. package/dist/bin/commands/check_bash.d.ts.map +1 -1
  27. package/dist/bin/commands/check_bash.js +28 -6
  28. package/dist/bin/commands/check_bash.js.map +1 -1
  29. package/dist/bin/commands/check_write.d.ts +2 -1
  30. package/dist/bin/commands/check_write.d.ts.map +1 -1
  31. package/dist/bin/commands/check_write.js +14 -45
  32. package/dist/bin/commands/check_write.js.map +1 -1
  33. package/dist/bin/commands/hooks.d.ts.map +1 -1
  34. package/dist/bin/commands/hooks.js +7 -3
  35. package/dist/bin/commands/hooks.js.map +1 -1
  36. package/dist/bin/commands/init.d.ts +19 -2
  37. package/dist/bin/commands/init.d.ts.map +1 -1
  38. package/dist/bin/commands/init.js +97 -72
  39. package/dist/bin/commands/init.js.map +1 -1
  40. package/dist/bin/commands/status.d.ts.map +1 -1
  41. package/dist/bin/commands/status.js +49 -65
  42. package/dist/bin/commands/status.js.map +1 -1
  43. package/dist/bin/commands/sync.d.ts.map +1 -1
  44. package/dist/bin/commands/sync.js +18 -26
  45. package/dist/bin/commands/sync.js.map +1 -1
  46. package/dist/bin/commands/validate.d.ts +1 -1
  47. package/dist/bin/commands/validate.d.ts.map +1 -1
  48. package/dist/bin/commands/validate.js +47 -58
  49. package/dist/bin/commands/validate.js.map +1 -1
  50. package/dist/bin/config_commands.d.ts +1 -1
  51. package/dist/bin/config_commands.d.ts.map +1 -1
  52. package/dist/bin/config_commands.js +40 -26
  53. package/dist/bin/config_commands.js.map +1 -1
  54. package/dist/bin/soloforge.js +30 -3
  55. package/dist/bin/soloforge.js.map +1 -1
  56. package/dist/engine/audit/audit_pool.d.ts.map +1 -1
  57. package/dist/engine/audit/audit_pool.js +2 -1
  58. package/dist/engine/audit/audit_pool.js.map +1 -1
  59. package/dist/engine/audit/audit_sampler.d.ts +2 -0
  60. package/dist/engine/audit/audit_sampler.d.ts.map +1 -1
  61. package/dist/engine/audit/audit_sampler.js.map +1 -1
  62. package/dist/engine/audit/code_reviewer.d.ts +1 -1
  63. package/dist/engine/audit/code_reviewer.d.ts.map +1 -1
  64. package/dist/engine/audit/code_reviewer.js +9 -21
  65. package/dist/engine/audit/code_reviewer.js.map +1 -1
  66. package/dist/engine/audit/core_experience_principle.js +1 -1
  67. package/dist/engine/audit/core_experience_principle.js.map +1 -1
  68. package/dist/engine/audit/debt_reporter.d.ts +3 -0
  69. package/dist/engine/audit/debt_reporter.d.ts.map +1 -1
  70. package/dist/engine/audit/debt_reporter.js.map +1 -1
  71. package/dist/engine/audit/debt_tracker.d.ts.map +1 -1
  72. package/dist/engine/audit/debt_tracker.js +12 -5
  73. package/dist/engine/audit/debt_tracker.js.map +1 -1
  74. package/dist/engine/audit/debugger.d.ts +3 -0
  75. package/dist/engine/audit/debugger.d.ts.map +1 -1
  76. package/dist/engine/audit/debugger.js.map +1 -1
  77. package/dist/engine/audit/delivery.d.ts +1 -1
  78. package/dist/engine/audit/delivery.d.ts.map +1 -1
  79. package/dist/engine/audit/delivery.js +7 -4
  80. package/dist/engine/audit/delivery.js.map +1 -1
  81. package/dist/engine/audit/delivery_readiness.d.ts +2 -0
  82. package/dist/engine/audit/delivery_readiness.d.ts.map +1 -1
  83. package/dist/engine/audit/delivery_readiness.js +2 -0
  84. package/dist/engine/audit/delivery_readiness.js.map +1 -1
  85. package/dist/engine/audit/developer_sovereignty.d.ts +5 -43
  86. package/dist/engine/audit/developer_sovereignty.d.ts.map +1 -1
  87. package/dist/engine/audit/developer_sovereignty.js +2 -6
  88. package/dist/engine/audit/developer_sovereignty.js.map +1 -1
  89. package/dist/engine/audit/evolver.js +5 -5
  90. package/dist/engine/audit/evolver.js.map +1 -1
  91. package/dist/engine/audit/failure_classifier.d.ts.map +1 -1
  92. package/dist/engine/audit/governance_report.d.ts +1 -1
  93. package/dist/engine/audit/governance_report.d.ts.map +1 -1
  94. package/dist/engine/audit/governance_report.js +1 -1
  95. package/dist/engine/audit/governance_report.js.map +1 -1
  96. package/dist/engine/audit/main_path_integration_contract/gates.d.ts +2 -1
  97. package/dist/engine/audit/main_path_integration_contract/gates.d.ts.map +1 -1
  98. package/dist/engine/audit/main_path_integration_contract/gates.js.map +1 -1
  99. package/dist/engine/audit/main_path_integration_contract/queries.d.ts +2 -2
  100. package/dist/engine/audit/main_path_integration_contract/queries.d.ts.map +1 -1
  101. package/dist/engine/audit/main_path_integration_contract/queries.js +2 -2
  102. package/dist/engine/audit/main_path_integration_contract/queries.js.map +1 -1
  103. package/dist/engine/audit/main_path_integration_contract/scanning.d.ts.map +1 -1
  104. package/dist/engine/audit/main_path_integration_contract/scanning.js +2 -2
  105. package/dist/engine/audit/main_path_integration_contract/scanning.js.map +1 -1
  106. package/dist/engine/audit/main_path_integration_contract/scanning_infra.d.ts.map +1 -1
  107. package/dist/engine/audit/main_path_integration_contract/scanning_infra.js +3 -2
  108. package/dist/engine/audit/main_path_integration_contract/scanning_infra.js.map +1 -1
  109. package/dist/engine/audit/mutation_audit.d.ts +4 -22
  110. package/dist/engine/audit/mutation_audit.d.ts.map +1 -1
  111. package/dist/engine/audit/mutation_audit.js.map +1 -1
  112. package/dist/engine/audit/observability.d.ts.map +1 -1
  113. package/dist/engine/audit/observability.js +4 -2
  114. package/dist/engine/audit/observability.js.map +1 -1
  115. package/dist/engine/audit/privacy_grants.d.ts +108 -0
  116. package/dist/engine/audit/privacy_grants.d.ts.map +1 -0
  117. package/dist/engine/audit/privacy_grants.js +171 -0
  118. package/dist/engine/audit/privacy_grants.js.map +1 -0
  119. package/dist/engine/audit/privacy_patterns.d.ts +24 -0
  120. package/dist/engine/audit/privacy_patterns.d.ts.map +1 -0
  121. package/dist/engine/audit/privacy_patterns.js +143 -0
  122. package/dist/engine/audit/privacy_patterns.js.map +1 -0
  123. package/dist/engine/audit/privacy_scanning.d.ts +153 -0
  124. package/dist/engine/audit/privacy_scanning.d.ts.map +1 -0
  125. package/dist/engine/audit/privacy_scanning.js +567 -0
  126. package/dist/engine/audit/privacy_scanning.js.map +1 -0
  127. package/dist/engine/audit/privacy_secret_contract.d.ts +9 -317
  128. package/dist/engine/audit/privacy_secret_contract.d.ts.map +1 -1
  129. package/dist/engine/audit/privacy_secret_contract.js +12 -873
  130. package/dist/engine/audit/privacy_secret_contract.js.map +1 -1
  131. package/dist/engine/audit/privacy_types.d.ts +48 -0
  132. package/dist/engine/audit/privacy_types.d.ts.map +1 -0
  133. package/dist/engine/audit/privacy_types.js +14 -0
  134. package/dist/engine/audit/privacy_types.js.map +1 -0
  135. package/dist/engine/audit/risk_sampler.d.ts +2 -0
  136. package/dist/engine/audit/risk_sampler.d.ts.map +1 -1
  137. package/dist/engine/audit/risk_sampler.js +2 -0
  138. package/dist/engine/audit/risk_sampler.js.map +1 -1
  139. package/dist/engine/audit/semantic_evidence.d.ts +5 -1
  140. package/dist/engine/audit/semantic_evidence.d.ts.map +1 -1
  141. package/dist/engine/audit/semantic_evidence.js +2 -0
  142. package/dist/engine/audit/semantic_evidence.js.map +1 -1
  143. package/dist/engine/audit/test_generator.d.ts.map +1 -1
  144. package/dist/engine/audit/test_generator.js +4 -1
  145. package/dist/engine/audit/test_generator.js.map +1 -1
  146. package/dist/engine/audit/test_quality.d.ts +3 -0
  147. package/dist/engine/audit/test_quality.d.ts.map +1 -1
  148. package/dist/engine/audit/test_quality.js +1 -71
  149. package/dist/engine/audit/test_quality.js.map +1 -1
  150. package/dist/engine/change_coordinator.d.ts +1 -1
  151. package/dist/engine/change_coordinator.d.ts.map +1 -1
  152. package/dist/engine/change_coordinator.js +30 -27
  153. package/dist/engine/change_coordinator.js.map +1 -1
  154. package/dist/engine/cognitive_anchor.d.ts.map +1 -1
  155. package/dist/engine/cognitive_anchor.js +6 -7
  156. package/dist/engine/cognitive_anchor.js.map +1 -1
  157. package/dist/engine/config/config_auto_repair.d.ts +2 -1
  158. package/dist/engine/config/config_auto_repair.d.ts.map +1 -1
  159. package/dist/engine/config/config_auto_repair.js +18 -13
  160. package/dist/engine/config/config_auto_repair.js.map +1 -1
  161. package/dist/engine/config/config_precedence_contract/field_class.d.ts +11 -0
  162. package/dist/engine/config/config_precedence_contract/field_class.d.ts.map +1 -0
  163. package/dist/engine/config/config_precedence_contract/field_class.js +10 -0
  164. package/dist/engine/config/config_precedence_contract/field_class.js.map +1 -0
  165. package/dist/engine/config/config_precedence_contract/index.d.ts +1 -0
  166. package/dist/engine/config/config_precedence_contract/index.d.ts.map +1 -1
  167. package/dist/engine/config/config_precedence_contract/index.js.map +1 -1
  168. package/dist/engine/config/config_precedence_contract/project_config.d.ts.map +1 -1
  169. package/dist/engine/config/config_precedence_contract/project_config.js +17 -9
  170. package/dist/engine/config/config_precedence_contract/project_config.js.map +1 -1
  171. package/dist/engine/config/config_precedence_contract/resolution.d.ts +1 -1
  172. package/dist/engine/config/config_precedence_contract/resolution.d.ts.map +1 -1
  173. package/dist/engine/config/config_precedence_contract/resolution.js +9 -0
  174. package/dist/engine/config/config_precedence_contract/resolution.js.map +1 -1
  175. package/dist/engine/config/config_precedence_contract/types.d.ts +4 -26
  176. package/dist/engine/config/config_precedence_contract/types.d.ts.map +1 -1
  177. package/dist/engine/config/config_precedence_contract/types.js +2 -0
  178. package/dist/engine/config/config_precedence_contract/types.js.map +1 -1
  179. package/dist/engine/config/config_precedence_contract.d.ts +3 -1
  180. package/dist/engine/config/config_precedence_contract.d.ts.map +1 -1
  181. package/dist/engine/config/config_precedence_contract.js +7 -1
  182. package/dist/engine/config/config_precedence_contract.js.map +1 -1
  183. package/dist/engine/config/config_write_boundary.d.ts.map +1 -1
  184. package/dist/engine/config/config_write_boundary.js +16 -0
  185. package/dist/engine/config/config_write_boundary.js.map +1 -1
  186. package/dist/engine/config/regression_matrix.d.ts.map +1 -1
  187. package/dist/engine/config/regression_matrix.js +3 -3
  188. package/dist/engine/config/regression_matrix.js.map +1 -1
  189. package/dist/engine/config/zero_config_init.d.ts +30 -5
  190. package/dist/engine/config/zero_config_init.d.ts.map +1 -1
  191. package/dist/engine/config/zero_config_init.js +26 -15
  192. package/dist/engine/config/zero_config_init.js.map +1 -1
  193. package/dist/engine/contracts/architecture_design_contract.d.ts.map +1 -1
  194. package/dist/engine/contracts/architecture_design_contract.js.map +1 -1
  195. package/dist/engine/contracts/artifact_contract_registry.d.ts +1 -1
  196. package/dist/engine/contracts/artifact_contract_registry.d.ts.map +1 -1
  197. package/dist/engine/contracts/artifact_contract_registry.js +1 -1
  198. package/dist/engine/contracts/artifact_contract_registry.js.map +1 -1
  199. package/dist/engine/contracts/backend_implementation_contract.js +4 -4
  200. package/dist/engine/contracts/backend_implementation_contract.js.map +1 -1
  201. package/dist/engine/contracts/brainstorm_contract.d.ts +1 -1
  202. package/dist/engine/contracts/brainstorm_contract.d.ts.map +1 -1
  203. package/dist/engine/contracts/brainstorm_contract.js +1 -1
  204. package/dist/engine/contracts/brainstorm_contract.js.map +1 -1
  205. package/dist/engine/contracts/capability_state_store.d.ts +2 -0
  206. package/dist/engine/contracts/capability_state_store.d.ts.map +1 -1
  207. package/dist/engine/contracts/capability_state_store.js +11 -1
  208. package/dist/engine/contracts/capability_state_store.js.map +1 -1
  209. package/dist/engine/contracts/code_maintainability_observability_contract.js +5 -5
  210. package/dist/engine/contracts/code_maintainability_observability_contract.js.map +1 -1
  211. package/dist/engine/contracts/coding_readiness_gate.d.ts +1 -1
  212. package/dist/engine/contracts/coding_readiness_gate.d.ts.map +1 -1
  213. package/dist/engine/contracts/coding_readiness_gate.js +1 -1
  214. package/dist/engine/contracts/coding_readiness_gate.js.map +1 -1
  215. package/dist/engine/contracts/command_execution_contract.d.ts +1 -11
  216. package/dist/engine/contracts/command_execution_contract.d.ts.map +1 -1
  217. package/dist/engine/contracts/command_execution_contract.js +1 -11
  218. package/dist/engine/contracts/command_execution_contract.js.map +1 -1
  219. package/dist/engine/contracts/contract_guard.d.ts +1 -1
  220. package/dist/engine/contracts/contract_guard.d.ts.map +1 -1
  221. package/dist/engine/contracts/contract_registry/registry.d.ts.map +1 -1
  222. package/dist/engine/contracts/contract_registry/registry.js +2 -2
  223. package/dist/engine/contracts/contract_registry/registry.js.map +1 -1
  224. package/dist/engine/contracts/contract_registry/validation.js.map +1 -1
  225. package/dist/engine/contracts/contract_state_store.d.ts +2 -0
  226. package/dist/engine/contracts/contract_state_store.d.ts.map +1 -1
  227. package/dist/engine/contracts/contract_state_store.js +4 -1
  228. package/dist/engine/contracts/contract_state_store.js.map +1 -1
  229. package/dist/engine/contracts/control_plane_contract.d.ts.map +1 -1
  230. package/dist/engine/contracts/control_plane_contract.js +5 -4
  231. package/dist/engine/contracts/control_plane_contract.js.map +1 -1
  232. package/dist/engine/contracts/decision_contract.js +1 -1
  233. package/dist/engine/contracts/decision_contract.js.map +1 -1
  234. package/dist/engine/contracts/decision_workshop.d.ts.map +1 -1
  235. package/dist/engine/contracts/decision_workshop.js.map +1 -1
  236. package/dist/engine/contracts/design_artifact_pack.d.ts +3 -40
  237. package/dist/engine/contracts/design_artifact_pack.d.ts.map +1 -1
  238. package/dist/engine/contracts/design_artifact_pack.js.map +1 -1
  239. package/dist/engine/contracts/detail_discipline.d.ts.map +1 -1
  240. package/dist/engine/contracts/detail_discipline.js.map +1 -1
  241. package/dist/engine/contracts/dual_layer_mechanism_registry/validation.js +1 -1
  242. package/dist/engine/contracts/dual_layer_mechanism_registry/validation.js.map +1 -1
  243. package/dist/engine/contracts/enforcement_guard.d.ts +2 -1
  244. package/dist/engine/contracts/enforcement_guard.d.ts.map +1 -1
  245. package/dist/engine/contracts/enforcement_guard.js +1 -1
  246. package/dist/engine/contracts/enforcement_guard.js.map +1 -1
  247. package/dist/engine/contracts/escape_report.d.ts.map +1 -1
  248. package/dist/engine/contracts/escape_report.js +2 -1
  249. package/dist/engine/contracts/escape_report.js.map +1 -1
  250. package/dist/engine/contracts/evidence_grounding_contract.d.ts +2 -4
  251. package/dist/engine/contracts/evidence_grounding_contract.d.ts.map +1 -1
  252. package/dist/engine/contracts/evidence_grounding_contract.js +3 -9
  253. package/dist/engine/contracts/evidence_grounding_contract.js.map +1 -1
  254. package/dist/engine/contracts/evolution_regression_gate.d.ts +2 -0
  255. package/dist/engine/contracts/evolution_regression_gate.d.ts.map +1 -1
  256. package/dist/engine/contracts/evolution_regression_gate.js +2 -0
  257. package/dist/engine/contracts/evolution_regression_gate.js.map +1 -1
  258. package/dist/engine/contracts/existing_system_analysis.d.ts.map +1 -1
  259. package/dist/engine/contracts/existing_system_analysis.js.map +1 -1
  260. package/dist/engine/contracts/existing_system_analyzer.d.ts +9 -9
  261. package/dist/engine/contracts/existing_system_analyzer.d.ts.map +1 -1
  262. package/dist/engine/contracts/existing_system_analyzer.js +83 -80
  263. package/dist/engine/contracts/existing_system_analyzer.js.map +1 -1
  264. package/dist/engine/contracts/extension_contract.d.ts +2 -2
  265. package/dist/engine/contracts/extension_contract.d.ts.map +1 -1
  266. package/dist/engine/contracts/extension_contract.js +2 -2
  267. package/dist/engine/contracts/extension_contract.js.map +1 -1
  268. package/dist/engine/contracts/extension_scenario_definitions.d.ts +10 -0
  269. package/dist/engine/contracts/extension_scenario_definitions.d.ts.map +1 -0
  270. package/dist/engine/contracts/extension_scenario_definitions.js +112 -0
  271. package/dist/engine/contracts/extension_scenario_definitions.js.map +1 -0
  272. package/dist/engine/contracts/extension_scenario_registry.d.ts +1 -7
  273. package/dist/engine/contracts/extension_scenario_registry.d.ts.map +1 -1
  274. package/dist/engine/contracts/extension_scenario_registry.js +5 -257
  275. package/dist/engine/contracts/extension_scenario_registry.js.map +1 -1
  276. package/dist/engine/contracts/first_principles.d.ts.map +1 -1
  277. package/dist/engine/contracts/first_principles.js.map +1 -1
  278. package/dist/engine/contracts/instruction_contract.d.ts.map +1 -1
  279. package/dist/engine/contracts/instruction_contract.js +0 -6
  280. package/dist/engine/contracts/instruction_contract.js.map +1 -1
  281. package/dist/engine/contracts/local_docker_acceptance.d.ts +1 -1
  282. package/dist/engine/contracts/local_docker_acceptance.d.ts.map +1 -1
  283. package/dist/engine/contracts/local_docker_acceptance.js +4 -4
  284. package/dist/engine/contracts/local_docker_acceptance.js.map +1 -1
  285. package/dist/engine/contracts/mechanism_health_check.d.ts +2 -0
  286. package/dist/engine/contracts/mechanism_health_check.d.ts.map +1 -1
  287. package/dist/engine/contracts/mechanism_health_check.js +2 -0
  288. package/dist/engine/contracts/mechanism_health_check.js.map +1 -1
  289. package/dist/engine/contracts/metric_governance.d.ts.map +1 -1
  290. package/dist/engine/contracts/metric_governance.js.map +1 -1
  291. package/dist/engine/contracts/ood_solid_contract.js +2 -2
  292. package/dist/engine/contracts/ood_solid_contract.js.map +1 -1
  293. package/dist/engine/contracts/platform_context.d.ts +2 -0
  294. package/dist/engine/contracts/platform_context.d.ts.map +1 -1
  295. package/dist/engine/contracts/platform_context.js +2 -0
  296. package/dist/engine/contracts/platform_context.js.map +1 -1
  297. package/dist/engine/contracts/project_knowledge_contract.d.ts.map +1 -1
  298. package/dist/engine/contracts/project_knowledge_contract.js +3 -0
  299. package/dist/engine/contracts/project_knowledge_contract.js.map +1 -1
  300. package/dist/engine/contracts/route_decision_contract_verifier.js +1 -1
  301. package/dist/engine/contracts/route_decision_contract_verifier.js.map +1 -1
  302. package/dist/engine/contracts/technology_decision.d.ts.map +1 -1
  303. package/dist/engine/contracts/technology_decision.js.map +1 -1
  304. package/dist/engine/contracts/tool_invocation_contract_registry.d.ts +3 -62
  305. package/dist/engine/contracts/tool_invocation_contract_registry.d.ts.map +1 -1
  306. package/dist/engine/contracts/tool_invocation_contract_registry.js +2 -0
  307. package/dist/engine/contracts/tool_invocation_contract_registry.js.map +1 -1
  308. package/dist/engine/contracts/traceability.d.ts +2 -1
  309. package/dist/engine/contracts/traceability.d.ts.map +1 -1
  310. package/dist/engine/contracts/traceability.js +5 -5
  311. package/dist/engine/contracts/traceability.js.map +1 -1
  312. package/dist/engine/contracts/user_feedback_contract.js +2 -2
  313. package/dist/engine/contracts/user_feedback_contract.js.map +1 -1
  314. package/dist/engine/contracts/workflow_template_pack.js +1 -1
  315. package/dist/engine/contracts/workflow_template_pack.js.map +1 -1
  316. package/dist/engine/core/config_defaults.d.ts +11 -0
  317. package/dist/engine/core/config_defaults.d.ts.map +1 -0
  318. package/dist/engine/core/config_defaults.js +11 -0
  319. package/dist/engine/core/config_defaults.js.map +1 -0
  320. package/dist/engine/core/env.d.ts +12 -0
  321. package/dist/engine/core/env.d.ts.map +1 -0
  322. package/dist/engine/core/env.js +12 -0
  323. package/dist/engine/core/env.js.map +1 -0
  324. package/dist/engine/core/errors.d.ts +21 -0
  325. package/dist/engine/core/errors.d.ts.map +1 -0
  326. package/dist/engine/core/errors.js +35 -0
  327. package/dist/engine/core/errors.js.map +1 -0
  328. package/dist/engine/core/exit_codes.d.ts +14 -0
  329. package/dist/engine/core/exit_codes.d.ts.map +1 -0
  330. package/dist/engine/core/exit_codes.js +14 -0
  331. package/dist/engine/core/exit_codes.js.map +1 -0
  332. package/dist/engine/core/helpers.d.ts +15 -0
  333. package/dist/engine/core/helpers.d.ts.map +1 -1
  334. package/dist/engine/core/helpers.js +31 -0
  335. package/dist/engine/core/helpers.js.map +1 -1
  336. package/dist/engine/core/index.d.ts +15 -0
  337. package/dist/engine/core/index.d.ts.map +1 -0
  338. package/dist/engine/core/index.js +22 -0
  339. package/dist/engine/core/index.js.map +1 -0
  340. package/dist/engine/core/io_controller.d.ts +1 -0
  341. package/dist/engine/core/io_controller.d.ts.map +1 -1
  342. package/dist/engine/core/io_controller.js +18 -2
  343. package/dist/engine/core/io_controller.js.map +1 -1
  344. package/dist/engine/core/llm_gateway.d.ts +20 -3
  345. package/dist/engine/core/llm_gateway.d.ts.map +1 -1
  346. package/dist/engine/core/llm_gateway.js +95 -13
  347. package/dist/engine/core/llm_gateway.js.map +1 -1
  348. package/dist/engine/core/log_governance.d.ts.map +1 -1
  349. package/dist/engine/core/log_governance.js +4 -9
  350. package/dist/engine/core/log_governance.js.map +1 -1
  351. package/dist/engine/core/logger.d.ts.map +1 -1
  352. package/dist/engine/core/logger.js +5 -2
  353. package/dist/engine/core/logger.js.map +1 -1
  354. package/dist/engine/core/path_scope_utils.d.ts +1 -1
  355. package/dist/engine/core/path_scope_utils.d.ts.map +1 -1
  356. package/dist/engine/core/path_scope_utils.js +1 -1
  357. package/dist/engine/core/path_scope_utils.js.map +1 -1
  358. package/dist/engine/core/paths.d.ts +86 -0
  359. package/dist/engine/core/paths.d.ts.map +1 -0
  360. package/dist/engine/core/paths.js +103 -0
  361. package/dist/engine/core/paths.js.map +1 -0
  362. package/dist/engine/core/write_file_atomic.d.ts +25 -0
  363. package/dist/engine/core/write_file_atomic.d.ts.map +1 -0
  364. package/dist/engine/core/write_file_atomic.js +63 -0
  365. package/dist/engine/core/write_file_atomic.js.map +1 -0
  366. package/dist/engine/dependency_scanner.d.ts.map +1 -1
  367. package/dist/engine/dependency_scanner.js +14 -16
  368. package/dist/engine/dependency_scanner.js.map +1 -1
  369. package/dist/engine/exploration.d.ts.map +1 -1
  370. package/dist/engine/exploration.js +9 -8
  371. package/dist/engine/exploration.js.map +1 -1
  372. package/dist/engine/knowledge/chinese_semantic_priority.d.ts.map +1 -1
  373. package/dist/engine/knowledge/chinese_semantic_priority.js.map +1 -1
  374. package/dist/engine/knowledge/drift_classifier.d.ts +26 -0
  375. package/dist/engine/knowledge/drift_classifier.d.ts.map +1 -0
  376. package/dist/engine/knowledge/drift_classifier.js +82 -0
  377. package/dist/engine/knowledge/drift_classifier.js.map +1 -0
  378. package/dist/engine/knowledge/knowledge_asset_audit.d.ts.map +1 -1
  379. package/dist/engine/knowledge/knowledge_asset_audit.js.map +1 -1
  380. package/dist/engine/knowledge/knowledge_asset_consumer.d.ts.map +1 -1
  381. package/dist/engine/knowledge/knowledge_asset_consumer.js +0 -4
  382. package/dist/engine/knowledge/knowledge_asset_consumer.js.map +1 -1
  383. package/dist/engine/knowledge/knowledge_asset_generation_gate.d.ts.map +1 -1
  384. package/dist/engine/knowledge/knowledge_asset_generation_gate.js.map +1 -1
  385. package/dist/engine/knowledge/knowledge_asset_schema.d.ts.map +1 -1
  386. package/dist/engine/knowledge/knowledge_asset_schema.js +0 -3
  387. package/dist/engine/knowledge/knowledge_asset_schema.js.map +1 -1
  388. package/dist/engine/knowledge/knowledge_evolution.d.ts +1 -17
  389. package/dist/engine/knowledge/knowledge_evolution.d.ts.map +1 -1
  390. package/dist/engine/knowledge/knowledge_evolution.js +2 -74
  391. package/dist/engine/knowledge/knowledge_evolution.js.map +1 -1
  392. package/dist/engine/knowledge/knowledge_health.d.ts +44 -0
  393. package/dist/engine/knowledge/knowledge_health.d.ts.map +1 -0
  394. package/dist/engine/knowledge/knowledge_health.js +303 -0
  395. package/dist/engine/knowledge/knowledge_health.js.map +1 -0
  396. package/dist/engine/knowledge/knowledge_injection_boundary.d.ts +1 -1
  397. package/dist/engine/knowledge/knowledge_injection_boundary.d.ts.map +1 -1
  398. package/dist/engine/knowledge/knowledge_injection_boundary.js +21 -5
  399. package/dist/engine/knowledge/knowledge_injection_boundary.js.map +1 -1
  400. package/dist/engine/knowledge/knowledge_lifecycle.d.ts +4 -2
  401. package/dist/engine/knowledge/knowledge_lifecycle.d.ts.map +1 -1
  402. package/dist/engine/knowledge/knowledge_lifecycle.js +37 -27
  403. package/dist/engine/knowledge/knowledge_lifecycle.js.map +1 -1
  404. package/dist/engine/knowledge/knowledge_manager.d.ts +2 -148
  405. package/dist/engine/knowledge/knowledge_manager.d.ts.map +1 -1
  406. package/dist/engine/knowledge/knowledge_manager.js +4 -933
  407. package/dist/engine/knowledge/knowledge_manager.js.map +1 -1
  408. package/dist/engine/knowledge/knowledge_scenario_registry.d.ts +1 -1
  409. package/dist/engine/knowledge/knowledge_scenario_registry.d.ts.map +1 -1
  410. package/dist/engine/knowledge/knowledge_scenario_registry.js +6 -6
  411. package/dist/engine/knowledge/knowledge_scenario_registry.js.map +1 -1
  412. package/dist/engine/knowledge/knowledge_sovereignty.js +2 -2
  413. package/dist/engine/knowledge/knowledge_sovereignty.js.map +1 -1
  414. package/dist/engine/knowledge/knowledge_writer.d.ts +108 -0
  415. package/dist/engine/knowledge/knowledge_writer.d.ts.map +1 -0
  416. package/dist/engine/knowledge/knowledge_writer.js +637 -0
  417. package/dist/engine/knowledge/knowledge_writer.js.map +1 -0
  418. package/dist/engine/knowledge/language_policy.d.ts +1 -1
  419. package/dist/engine/knowledge/language_policy.js +1 -1
  420. package/dist/engine/knowledge/release_compatibility.d.ts.map +1 -1
  421. package/dist/engine/knowledge/release_compatibility.js.map +1 -1
  422. package/dist/engine/migration_guard.js +4 -4
  423. package/dist/engine/migration_guard.js.map +1 -1
  424. package/dist/engine/onboarding.d.ts +1 -1
  425. package/dist/engine/onboarding.d.ts.map +1 -1
  426. package/dist/engine/onboarding.js +4 -1
  427. package/dist/engine/onboarding.js.map +1 -1
  428. package/dist/engine/pipeline/conflict_gate.js +1 -1
  429. package/dist/engine/pipeline/conflict_gate.js.map +1 -1
  430. package/dist/engine/pipeline/diff_ownership.d.ts.map +1 -1
  431. package/dist/engine/pipeline/diff_ownership.js +7 -0
  432. package/dist/engine/pipeline/diff_ownership.js.map +1 -1
  433. package/dist/engine/pipeline/diff_ownership_store.d.ts.map +1 -1
  434. package/dist/engine/pipeline/diff_ownership_store.js +8 -6
  435. package/dist/engine/pipeline/diff_ownership_store.js.map +1 -1
  436. package/dist/engine/pipeline/expand_pipeline.d.ts +2 -1
  437. package/dist/engine/pipeline/expand_pipeline.d.ts.map +1 -1
  438. package/dist/engine/pipeline/expand_pipeline.js.map +1 -1
  439. package/dist/engine/pipeline/input_material_contract_registry.d.ts +1 -1
  440. package/dist/engine/pipeline/input_material_contract_registry.d.ts.map +1 -1
  441. package/dist/engine/pipeline/input_material_contract_registry.js +44 -43
  442. package/dist/engine/pipeline/input_material_contract_registry.js.map +1 -1
  443. package/dist/engine/pipeline/input_material_extractor.js +3 -3
  444. package/dist/engine/pipeline/input_material_extractor.js.map +1 -1
  445. package/dist/engine/pipeline/intent_expander/expand.d.ts +6 -6
  446. package/dist/engine/pipeline/intent_expander/expand.d.ts.map +1 -1
  447. package/dist/engine/pipeline/intent_expander/expand.js +57 -50
  448. package/dist/engine/pipeline/intent_expander/expand.js.map +1 -1
  449. package/dist/engine/pipeline/intent_expander/helpers.d.ts +6 -4
  450. package/dist/engine/pipeline/intent_expander/helpers.d.ts.map +1 -1
  451. package/dist/engine/pipeline/intent_expander/helpers.js +4 -4
  452. package/dist/engine/pipeline/intent_expander/helpers.js.map +1 -1
  453. package/dist/engine/pipeline/intent_expander/index.d.ts +4 -4
  454. package/dist/engine/pipeline/intent_expander/index.js +8 -8
  455. package/dist/engine/pipeline/intent_expander/index.js.map +1 -1
  456. package/dist/engine/pipeline/intent_expander/knowledge.d.ts.map +1 -1
  457. package/dist/engine/pipeline/intent_expander/knowledge.js.map +1 -1
  458. package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts +12 -9
  459. package/dist/engine/pipeline/intent_expander/knowledge_resolution.d.ts.map +1 -1
  460. package/dist/engine/pipeline/intent_expander/knowledge_resolution.js +11 -11
  461. package/dist/engine/pipeline/intent_expander/knowledge_resolution.js.map +1 -1
  462. package/dist/engine/pipeline/intent_expander/privacy_gates.d.ts +68 -6
  463. package/dist/engine/pipeline/intent_expander/privacy_gates.d.ts.map +1 -1
  464. package/dist/engine/pipeline/intent_expander/privacy_gates.js +94 -21
  465. package/dist/engine/pipeline/intent_expander/privacy_gates.js.map +1 -1
  466. package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts +37 -3
  467. package/dist/engine/pipeline/intent_expander/scope_acceptance.d.ts.map +1 -1
  468. package/dist/engine/pipeline/intent_expander/scope_acceptance.js +1 -1
  469. package/dist/engine/pipeline/intent_expander/scope_acceptance.js.map +1 -1
  470. package/dist/engine/pipeline/intent_expander/templates.d.ts +2 -1
  471. package/dist/engine/pipeline/intent_expander/templates.d.ts.map +1 -1
  472. package/dist/engine/pipeline/intent_expander/templates.js.map +1 -1
  473. package/dist/engine/pipeline/intent_expander/types.d.ts +35 -5
  474. package/dist/engine/pipeline/intent_expander/types.d.ts.map +1 -1
  475. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.d.ts +4 -3
  476. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.d.ts.map +1 -1
  477. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.js +1 -1
  478. package/dist/engine/pipeline/intent_expander/uncertainty_circuit.js.map +1 -1
  479. package/dist/engine/pipeline/intent_expander.d.ts +2 -2
  480. package/dist/engine/pipeline/intent_expander.js +6 -6
  481. package/dist/engine/pipeline/intent_expander.js.map +1 -1
  482. package/dist/engine/pipeline/intent_route_scorer.d.ts +2 -2
  483. package/dist/engine/pipeline/intent_route_scorer.d.ts.map +1 -1
  484. package/dist/engine/pipeline/intent_route_scorer.js +3 -3
  485. package/dist/engine/pipeline/intent_route_scorer.js.map +1 -1
  486. package/dist/engine/pipeline/intent_router.d.ts +4 -5
  487. package/dist/engine/pipeline/intent_router.d.ts.map +1 -1
  488. package/dist/engine/pipeline/intent_router.js +64 -112
  489. package/dist/engine/pipeline/intent_router.js.map +1 -1
  490. package/dist/engine/pipeline/intent_signal_extractor.d.ts +18 -0
  491. package/dist/engine/pipeline/intent_signal_extractor.d.ts.map +1 -1
  492. package/dist/engine/pipeline/intent_signal_extractor.js +8 -8
  493. package/dist/engine/pipeline/intent_signal_extractor.js.map +1 -1
  494. package/dist/engine/pipeline/job_manager.d.ts.map +1 -1
  495. package/dist/engine/pipeline/job_manager.js +18 -4
  496. package/dist/engine/pipeline/job_manager.js.map +1 -1
  497. package/dist/engine/pipeline/plan_proposal_gate.d.ts.map +1 -1
  498. package/dist/engine/pipeline/plan_proposal_gate.js +0 -1
  499. package/dist/engine/pipeline/plan_proposal_gate.js.map +1 -1
  500. package/dist/engine/pipeline/route_types.d.ts +10 -0
  501. package/dist/engine/pipeline/route_types.d.ts.map +1 -0
  502. package/dist/engine/pipeline/route_types.js +9 -0
  503. package/dist/engine/pipeline/route_types.js.map +1 -0
  504. package/dist/engine/pipeline/scope_controller.d.ts +1 -1
  505. package/dist/engine/pipeline/scope_controller.d.ts.map +1 -1
  506. package/dist/engine/pipeline/scope_controller.js +18 -17
  507. package/dist/engine/pipeline/scope_controller.js.map +1 -1
  508. package/dist/engine/pipeline/scope_lease.d.ts.map +1 -1
  509. package/dist/engine/pipeline/scope_lease.js +3 -1
  510. package/dist/engine/pipeline/scope_lease.js.map +1 -1
  511. package/dist/engine/pipeline/slice_executor.d.ts +1 -1
  512. package/dist/engine/pipeline/slice_executor.d.ts.map +1 -1
  513. package/dist/engine/pipeline/slice_executor.js +1 -1
  514. package/dist/engine/pipeline/slice_executor.js.map +1 -1
  515. package/dist/engine/pipeline/stage_gate_engine.d.ts +2 -0
  516. package/dist/engine/pipeline/stage_gate_engine.d.ts.map +1 -1
  517. package/dist/engine/pipeline/stage_gate_engine.js +9 -3
  518. package/dist/engine/pipeline/stage_gate_engine.js.map +1 -1
  519. package/dist/engine/pipeline/stale_current_task_detector.d.ts.map +1 -1
  520. package/dist/engine/pipeline/stale_current_task_detector.js +8 -5
  521. package/dist/engine/pipeline/stale_current_task_detector.js.map +1 -1
  522. package/dist/engine/pipeline/task_context/cleanup.d.ts.map +1 -1
  523. package/dist/engine/pipeline/task_context/cleanup.js +4 -1
  524. package/dist/engine/pipeline/task_context/cleanup.js.map +1 -1
  525. package/dist/engine/pipeline/task_context/expansion_privacy.d.ts +1 -3
  526. package/dist/engine/pipeline/task_context/expansion_privacy.d.ts.map +1 -1
  527. package/dist/engine/pipeline/task_context/expansion_privacy.js +1 -1
  528. package/dist/engine/pipeline/task_context/expansion_privacy.js.map +1 -1
  529. package/dist/engine/pipeline/task_context/manager.d.ts +4 -4
  530. package/dist/engine/pipeline/task_context/manager.d.ts.map +1 -1
  531. package/dist/engine/pipeline/task_context/manager.js +25 -13
  532. package/dist/engine/pipeline/task_context/manager.js.map +1 -1
  533. package/dist/engine/pipeline/task_context/manager_setters.d.ts +3 -3
  534. package/dist/engine/pipeline/task_context/manager_setters.d.ts.map +1 -1
  535. package/dist/engine/pipeline/task_context/manager_setters.js.map +1 -1
  536. package/dist/engine/pipeline/task_context/status_transitions.d.ts.map +1 -1
  537. package/dist/engine/pipeline/task_context/status_transitions.js +4 -3
  538. package/dist/engine/pipeline/task_context/status_transitions.js.map +1 -1
  539. package/dist/engine/pipeline/task_planner.js +3 -4
  540. package/dist/engine/pipeline/task_planner.js.map +1 -1
  541. package/dist/engine/pipeline/workspace_lease.d.ts +10 -1
  542. package/dist/engine/pipeline/workspace_lease.d.ts.map +1 -1
  543. package/dist/engine/pipeline/workspace_lease.js +29 -3
  544. package/dist/engine/pipeline/workspace_lease.js.map +1 -1
  545. package/dist/engine/pipeline/workspace_resumer.d.ts.map +1 -1
  546. package/dist/engine/pipeline/workspace_resumer.js +3 -0
  547. package/dist/engine/pipeline/workspace_resumer.js.map +1 -1
  548. package/dist/engine/release/foundation_scenario_registry.d.ts +1 -1
  549. package/dist/engine/release/foundation_scenario_registry.d.ts.map +1 -1
  550. package/dist/engine/release/foundation_scenario_registry.js +3 -2
  551. package/dist/engine/release/foundation_scenario_registry.js.map +1 -1
  552. package/dist/engine/release/foundation_scenario_runners.d.ts.map +1 -1
  553. package/dist/engine/release/foundation_scenario_runners.js +40 -33
  554. package/dist/engine/release/foundation_scenario_runners.js.map +1 -1
  555. package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts +2 -2
  556. package/dist/engine/release/gate_checks/checkControlPlaneTrust.d.ts.map +1 -1
  557. package/dist/engine/release/gate_checks/checkControlPlaneTrust.js +3 -2
  558. package/dist/engine/release/gate_checks/checkControlPlaneTrust.js.map +1 -1
  559. package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.d.ts.map +1 -1
  560. package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.js +3 -3
  561. package/dist/engine/release/gate_checks/checkCriticalProblemConsumption.js.map +1 -1
  562. package/dist/engine/release/gate_checks/checkDependencyAudit.d.ts.map +1 -1
  563. package/dist/engine/release/gate_checks/checkDependencyAudit.js +8 -3
  564. package/dist/engine/release/gate_checks/checkDependencyAudit.js.map +1 -1
  565. package/dist/engine/release/gate_checks/checkDistFreshness.d.ts.map +1 -1
  566. package/dist/engine/release/gate_checks/checkDistFreshness.js +4 -2
  567. package/dist/engine/release/gate_checks/checkDistFreshness.js.map +1 -1
  568. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.d.ts +1 -1
  569. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.d.ts.map +1 -1
  570. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js +1 -1
  571. package/dist/engine/release/gate_checks/checkKnowledgeAssetSchemaP0.js.map +1 -1
  572. package/dist/engine/release/gate_checks/checkMainlineConsumption.js +2 -2
  573. package/dist/engine/release/gate_checks/checkMainlineConsumption.js.map +1 -1
  574. package/dist/engine/release/gate_checks/{check_npm_pack.d.ts → checkNpmPack.d.ts} +1 -1
  575. package/dist/engine/release/gate_checks/checkNpmPack.d.ts.map +1 -0
  576. package/dist/engine/release/gate_checks/{check_npm_pack.js → checkNpmPack.js} +5 -7
  577. package/dist/engine/release/gate_checks/checkNpmPack.js.map +1 -0
  578. package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.d.ts.map +1 -1
  579. package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.js +4 -3
  580. package/dist/engine/release/gate_checks/checkTemplateKnowledgeHygiene.js.map +1 -1
  581. package/dist/engine/release/gate_checks/checkWorkflowNavigation.d.ts.map +1 -1
  582. package/dist/engine/release/gate_checks/checkWorkflowNavigation.js +58 -4
  583. package/dist/engine/release/gate_checks/checkWorkflowNavigation.js.map +1 -1
  584. package/dist/engine/release/gate_checks/helpers.d.ts.map +1 -1
  585. package/dist/engine/release/gate_checks/helpers.js +2 -1
  586. package/dist/engine/release/gate_checks/helpers.js.map +1 -1
  587. package/dist/engine/release/index.d.ts +6 -0
  588. package/dist/engine/release/index.d.ts.map +1 -0
  589. package/dist/engine/release/index.js +6 -0
  590. package/dist/engine/release/index.js.map +1 -0
  591. package/dist/engine/release/release_gate_scenario_registry.d.ts.map +1 -1
  592. package/dist/engine/release/release_gate_scenario_registry.js.map +1 -1
  593. package/dist/engine/release/release_issue_scenario_registry/registry.d.ts.map +1 -1
  594. package/dist/engine/release/release_issue_scenario_registry/registry.js +4 -1
  595. package/dist/engine/release/release_issue_scenario_registry/registry.js.map +1 -1
  596. package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js +38 -19
  597. package/dist/engine/release/release_issue_scenario_registry/scenarios_architecture_workshop.js.map +1 -1
  598. package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.d.ts.map +1 -1
  599. package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js +3 -2
  600. package/dist/engine/release/release_issue_scenario_registry/scenarios_code_observability.js.map +1 -1
  601. package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.d.ts.map +1 -1
  602. package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js +50 -26
  603. package/dist/engine/release/release_issue_scenario_registry/scenarios_decision_workshop.js.map +1 -1
  604. package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.d.ts.map +1 -1
  605. package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js +12 -6
  606. package/dist/engine/release/release_issue_scenario_registry/scenarios_design_pack.js.map +1 -1
  607. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.d.ts.map +1 -1
  608. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js +26 -13
  609. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_contract.js.map +1 -1
  610. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.d.ts.map +1 -1
  611. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js +14 -8
  612. package/dist/engine/release/release_issue_scenario_registry/scenarios_template_visibility.js.map +1 -1
  613. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.d.ts +12 -0
  614. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.d.ts.map +1 -0
  615. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.js +147 -0
  616. package/dist/engine/release/release_issue_scenario_registry/scenarios_workflow_navigation.js.map +1 -0
  617. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts +24 -40
  618. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.d.ts.map +1 -1
  619. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js +12 -6
  620. package/dist/engine/release/release_issue_scenario_registry/workshop_helpers.js.map +1 -1
  621. package/dist/engine/release/release_readiness_gate.d.ts +3 -1
  622. package/dist/engine/release/release_readiness_gate.d.ts.map +1 -1
  623. package/dist/engine/release/release_readiness_gate.js +47 -4
  624. package/dist/engine/release/release_readiness_gate.js.map +1 -1
  625. package/dist/engine/release/release_tool_harness.d.ts +18 -5
  626. package/dist/engine/release/release_tool_harness.d.ts.map +1 -1
  627. package/dist/engine/release/release_tool_harness.js +15 -7
  628. package/dist/engine/release/release_tool_harness.js.map +1 -1
  629. package/dist/engine/release/types.d.ts +81 -0
  630. package/dist/engine/release/types.d.ts.map +1 -0
  631. package/dist/engine/release/types.js +7 -0
  632. package/dist/engine/release/types.js.map +1 -0
  633. package/dist/engine/release/verifier.d.ts.map +1 -1
  634. package/dist/engine/release/verifier.js +1 -1
  635. package/dist/engine/release/verifier.js.map +1 -1
  636. package/dist/engine/team_awareness.d.ts +1 -1
  637. package/dist/engine/team_awareness.d.ts.map +1 -1
  638. package/dist/engine/team_awareness.js.map +1 -1
  639. package/dist/engine/templates/asset_manifest.d.ts +1 -1
  640. package/dist/engine/templates/asset_manifest.d.ts.map +1 -1
  641. package/dist/engine/templates/asset_manifest.js +1 -2
  642. package/dist/engine/templates/asset_manifest.js.map +1 -1
  643. package/dist/engine/templates/consumption_trace_store.d.ts +2 -1
  644. package/dist/engine/templates/consumption_trace_store.d.ts.map +1 -1
  645. package/dist/engine/templates/consumption_trace_store.js +0 -6
  646. package/dist/engine/templates/consumption_trace_store.js.map +1 -1
  647. package/dist/engine/templates/explicit_asset_registry/index.js +14 -14
  648. package/dist/engine/templates/explicit_asset_registry/index.js.map +1 -1
  649. package/dist/engine/templates/observed_consumption.d.ts.map +1 -1
  650. package/dist/engine/templates/observed_consumption.js +1 -1
  651. package/dist/engine/templates/observed_consumption.js.map +1 -1
  652. package/dist/engine/templates/scaffolder.js +2 -2
  653. package/dist/engine/templates/scaffolder.js.map +1 -1
  654. package/dist/engine/templates/standard_asset_coverage.js +1 -1
  655. package/dist/engine/templates/standard_asset_coverage.js.map +1 -1
  656. package/dist/engine/templates/template_asset_contract_registry.d.ts +1 -1
  657. package/dist/engine/templates/template_asset_contract_registry.d.ts.map +1 -1
  658. package/dist/engine/templates/template_asset_contract_registry.js +1 -2
  659. package/dist/engine/templates/template_asset_contract_registry.js.map +1 -1
  660. package/dist/engine/templates/template_asset_visibility.js +0 -17
  661. package/dist/engine/templates/template_asset_visibility.js.map +1 -1
  662. package/dist/engine/templates/template_init_sync.d.ts.map +1 -1
  663. package/dist/engine/templates/template_init_sync.js +9 -11
  664. package/dist/engine/templates/template_init_sync.js.map +1 -1
  665. package/dist/engine/templates/template_manifest_io.d.ts.map +1 -1
  666. package/dist/engine/templates/template_manifest_io.js +3 -2
  667. package/dist/engine/templates/template_manifest_io.js.map +1 -1
  668. package/dist/engine/templates/template_sync.d.ts.map +1 -1
  669. package/dist/engine/templates/template_sync.js.map +1 -1
  670. package/dist/engine/templates/workflow_rule_generator.d.ts +1 -1
  671. package/dist/engine/templates/workflow_rule_generator.d.ts.map +1 -1
  672. package/dist/engine/templates/workflow_rule_generator.js +1 -1
  673. package/dist/engine/templates/workflow_rule_generator.js.map +1 -1
  674. package/dist/engine/workflow/index.d.ts +10 -0
  675. package/dist/engine/workflow/index.d.ts.map +1 -0
  676. package/dist/engine/workflow/index.js +12 -0
  677. package/dist/engine/workflow/index.js.map +1 -0
  678. package/dist/engine/workflow/legacy_type_migration.d.ts +4 -3
  679. package/dist/engine/workflow/legacy_type_migration.d.ts.map +1 -1
  680. package/dist/engine/workflow/legacy_type_migration.js +6 -5
  681. package/dist/engine/workflow/legacy_type_migration.js.map +1 -1
  682. package/dist/engine/workflow/next_action_planner.d.ts +2 -2
  683. package/dist/engine/workflow/next_action_planner.d.ts.map +1 -1
  684. package/dist/engine/workflow/next_action_planner.js +70 -21
  685. package/dist/engine/workflow/next_action_planner.js.map +1 -1
  686. package/dist/engine/workflow/project_stage_detector.d.ts.map +1 -1
  687. package/dist/engine/workflow/project_stage_detector.js +28 -13
  688. package/dist/engine/workflow/project_stage_detector.js.map +1 -1
  689. package/dist/engine/workflow/workflow_navigation_contract.d.ts +8 -1
  690. package/dist/engine/workflow/workflow_navigation_contract.d.ts.map +1 -1
  691. package/dist/engine/workflow/workflow_navigation_contract.js +0 -1
  692. package/dist/engine/workflow/workflow_navigation_contract.js.map +1 -1
  693. package/dist/{engine/core → git}/git_deps.d.ts +3 -1
  694. package/dist/git/git_deps.d.ts.map +1 -0
  695. package/dist/{engine/core → git}/git_deps.js +2 -2
  696. package/dist/git/git_deps.js.map +1 -0
  697. package/dist/index.js +6 -2
  698. package/dist/index.js.map +1 -1
  699. package/dist/knowledge/conflict_detector.d.ts +14 -0
  700. package/dist/knowledge/conflict_detector.d.ts.map +1 -1
  701. package/dist/knowledge/conflict_detector.js +67 -0
  702. package/dist/knowledge/conflict_detector.js.map +1 -1
  703. package/dist/knowledge/health_checker.d.ts.map +1 -1
  704. package/dist/knowledge/health_checker.js +17 -8
  705. package/dist/knowledge/health_checker.js.map +1 -1
  706. package/dist/knowledge/index_manager.d.ts +3 -0
  707. package/dist/knowledge/index_manager.d.ts.map +1 -1
  708. package/dist/knowledge/index_manager.js +82 -40
  709. package/dist/knowledge/index_manager.js.map +1 -1
  710. package/dist/knowledge/loader.d.ts.map +1 -1
  711. package/dist/knowledge/loader.js +14 -5
  712. package/dist/knowledge/loader.js.map +1 -1
  713. package/dist/knowledge/writer.d.ts.map +1 -1
  714. package/dist/knowledge/writer.js +2 -1
  715. package/dist/knowledge/writer.js.map +1 -1
  716. package/dist/server/index.d.ts +2 -2
  717. package/dist/server/index.d.ts.map +1 -1
  718. package/dist/server/index.js +14 -18
  719. package/dist/server/index.js.map +1 -1
  720. package/dist/server/lifecycle.d.ts +4 -2
  721. package/dist/server/lifecycle.d.ts.map +1 -1
  722. package/dist/server/lifecycle.js +6 -11
  723. package/dist/server/lifecycle.js.map +1 -1
  724. package/dist/server/tools/cep_assessment.d.ts.map +1 -1
  725. package/dist/server/tools/cep_assessment.js +6 -6
  726. package/dist/server/tools/cep_assessment.js.map +1 -1
  727. package/dist/server/tools/gate_checks.d.ts +4 -2
  728. package/dist/server/tools/gate_checks.d.ts.map +1 -1
  729. package/dist/server/tools/gate_checks.js.map +1 -1
  730. package/dist/server/tools/index.d.ts.map +1 -1
  731. package/dist/server/tools/index.js +37 -1
  732. package/dist/server/tools/index.js.map +1 -1
  733. package/dist/server/tools/lazy_loaders.d.ts +1 -1
  734. package/dist/server/tools/lazy_loaders.d.ts.map +1 -1
  735. package/dist/server/tools/lazy_loaders.js +2 -2
  736. package/dist/server/tools/lazy_loaders.js.map +1 -1
  737. package/dist/server/tools/middleware.d.ts +22 -2
  738. package/dist/server/tools/middleware.d.ts.map +1 -1
  739. package/dist/server/tools/middleware.js +55 -22
  740. package/dist/server/tools/middleware.js.map +1 -1
  741. package/dist/server/tools/schemas.d.ts +2 -2
  742. package/dist/server/tools/tool_groups/admin.d.ts.map +1 -1
  743. package/dist/server/tools/tool_groups/admin.js +5 -4
  744. package/dist/server/tools/tool_groups/admin.js.map +1 -1
  745. package/dist/server/tools/tool_groups/auxiliary.js +4 -4
  746. package/dist/server/tools/tool_groups/auxiliary.js.map +1 -1
  747. package/dist/server/tools/tool_groups/classify_expand.d.ts.map +1 -1
  748. package/dist/server/tools/tool_groups/classify_expand.js +4 -869
  749. package/dist/server/tools/tool_groups/classify_expand.js.map +1 -1
  750. package/dist/server/tools/tool_groups/classify_handler.d.ts +3 -0
  751. package/dist/server/tools/tool_groups/classify_handler.d.ts.map +1 -0
  752. package/dist/server/tools/tool_groups/classify_handler.js +65 -0
  753. package/dist/server/tools/tool_groups/classify_handler.js.map +1 -0
  754. package/dist/server/tools/tool_groups/expand_handler.d.ts +3 -0
  755. package/dist/server/tools/tool_groups/expand_handler.d.ts.map +1 -0
  756. package/dist/server/tools/tool_groups/expand_handler.js +819 -0
  757. package/dist/server/tools/tool_groups/expand_handler.js.map +1 -0
  758. package/dist/server/tools/tool_groups/knowledge.js +2 -2
  759. package/dist/server/tools/tool_groups/knowledge.js.map +1 -1
  760. package/dist/server/tools/tool_groups/scaffold_accept_deliver.js +1 -1
  761. package/dist/server/tools/tool_groups/scaffold_accept_deliver.js.map +1 -1
  762. package/dist/server/tools/tool_groups/status_plan_analyze_review.js +5 -5
  763. package/dist/server/tools/tool_groups/status_plan_analyze_review.js.map +1 -1
  764. package/dist/server/tools/tool_groups/verify_learn.d.ts.map +1 -1
  765. package/dist/server/tools/tool_groups/verify_learn.js +6 -11
  766. package/dist/server/tools/tool_groups/verify_learn.js.map +1 -1
  767. package/dist/server/tools/tool_names.d.ts +55 -0
  768. package/dist/server/tools/tool_names.d.ts.map +1 -0
  769. package/dist/server/tools/tool_names.js +62 -0
  770. package/dist/server/tools/tool_names.js.map +1 -0
  771. package/dist/server/tools/utils.d.ts.map +1 -1
  772. package/dist/server/tools/utils.js +5 -11
  773. package/dist/server/tools/utils.js.map +1 -1
  774. package/dist/types/base.d.ts +2 -0
  775. package/dist/types/base.d.ts.map +1 -1
  776. package/dist/types/config.d.ts +2 -0
  777. package/dist/types/config.d.ts.map +1 -1
  778. package/dist/types/delivery.d.ts +44 -1
  779. package/dist/types/delivery.d.ts.map +1 -1
  780. package/dist/types/knowledge.d.ts +3 -1
  781. package/dist/types/knowledge.d.ts.map +1 -1
  782. package/dist/types/knowledge.js.map +1 -1
  783. package/dist/types/pipeline.d.ts +151 -14
  784. package/dist/types/pipeline.d.ts.map +1 -1
  785. package/dist/types/task.d.ts +103 -38
  786. package/dist/types/task.d.ts.map +1 -1
  787. package/package.json +7 -3
  788. package/templates/internal/rules//351/205/215/347/275/256/344/274/230/345/205/210/347/272/247/350/247/204/345/210/231.md +11 -1
  789. package/dist/engine/audit/audit_verifier.d.ts +0 -52
  790. package/dist/engine/audit/audit_verifier.d.ts.map +0 -1
  791. package/dist/engine/audit/audit_verifier.js +0 -101
  792. package/dist/engine/audit/audit_verifier.js.map +0 -1
  793. package/dist/engine/contracts/policy_drift_detector.d.ts +0 -72
  794. package/dist/engine/contracts/policy_drift_detector.d.ts.map +0 -1
  795. package/dist/engine/contracts/policy_drift_detector.js +0 -277
  796. package/dist/engine/contracts/policy_drift_detector.js.map +0 -1
  797. package/dist/engine/core/git_deps.d.ts.map +0 -1
  798. package/dist/engine/core/git_deps.js.map +0 -1
  799. package/dist/engine/release/gate_checks/check_npm_pack.d.ts.map +0 -1
  800. package/dist/engine/release/gate_checks/check_npm_pack.js.map +0 -1
  801. package/dist/engine/state_update_bypass.d.ts +0 -19
  802. package/dist/engine/state_update_bypass.d.ts.map +0 -1
  803. package/dist/engine/state_update_bypass.js +0 -17
  804. package/dist/engine/state_update_bypass.js.map +0 -1
@@ -1,875 +1,14 @@
1
- import crypto from "node:crypto";
2
- import { debugLog } from "../core/logger.js";
3
- // ── 敏感标签的默认处理方式 ──
4
- const DEFAULT_HANDLING = {
5
- public: "allow",
6
- internal: "allow",
7
- confidential: "require_human",
8
- secret: "forbidden",
9
- credential: "forbidden",
10
- pii: "require_human",
11
- customer_data: "require_human",
12
- production_data: "require_human",
13
- unknown: "require_human",
14
- };
15
- // ── 上下文相关处理方式 ──
16
- const CONTEXT_HANDLING = {
17
- public: {
18
- prompt_injection: "allow",
19
- task_context_store: "allow",
20
- artifact_store: "allow",
21
- evidence_store: "allow",
22
- external_send: "allow",
23
- read_operation: "allow",
24
- },
25
- internal: {
26
- prompt_injection: "allow",
27
- task_context_store: "allow",
28
- artifact_store: "allow",
29
- evidence_store: "allow",
30
- external_send: "forbidden",
31
- read_operation: "allow",
32
- },
33
- confidential: {
34
- prompt_injection: "summarize_only",
35
- task_context_store: "redact",
36
- artifact_store: "redact",
37
- evidence_store: "redact",
38
- external_send: "require_human",
39
- read_operation: "require_human",
40
- },
41
- secret: {
42
- prompt_injection: "forbidden",
43
- task_context_store: "forbidden",
44
- artifact_store: "forbidden",
45
- evidence_store: "forbidden",
46
- external_send: "forbidden",
47
- read_operation: "forbidden",
48
- },
49
- credential: {
50
- prompt_injection: "forbidden",
51
- task_context_store: "forbidden",
52
- artifact_store: "forbidden",
53
- evidence_store: "forbidden",
54
- external_send: "forbidden",
55
- read_operation: "forbidden",
56
- },
57
- pii: {
58
- prompt_injection: "redact",
59
- task_context_store: "redact",
60
- artifact_store: "redact",
61
- evidence_store: "redact",
62
- external_send: "require_human",
63
- read_operation: "require_human",
64
- },
65
- customer_data: {
66
- prompt_injection: "summarize_only",
67
- task_context_store: "summarize_only",
68
- artifact_store: "summarize_only",
69
- evidence_store: "summarize_only",
70
- external_send: "require_human",
71
- read_operation: "require_human",
72
- },
73
- production_data: {
74
- prompt_injection: "summarize_only",
75
- task_context_store: "summarize_only",
76
- artifact_store: "summarize_only",
77
- evidence_store: "summarize_only",
78
- external_send: "require_human",
79
- read_operation: "require_human",
80
- },
81
- unknown: {
82
- prompt_injection: "summarize_only",
83
- task_context_store: "summarize_only",
84
- artifact_store: "summarize_only",
85
- evidence_store: "summarize_only",
86
- external_send: "require_human",
87
- read_operation: "require_human",
88
- },
89
- };
90
- // ── 禁止读取模式(内容读取禁止,仅允许存在性检查) ──
91
- export const FORBIDDEN_READ_PATTERNS = [
92
- { pattern: /\.env($|\.)/, label: "credential", reason: ".env 文件默认禁止读取内容" },
93
- { pattern: /id_rsa/, label: "secret", reason: "SSH 私钥默认禁止读取" },
94
- { pattern: /\.pem$/, label: "secret", reason: "PEM 私钥默认禁止读取" },
95
- { pattern: /\.key$/, label: "secret", reason: "密钥文件默认禁止读取" },
96
- { pattern: /\.aws[\\/]credentials/, label: "credential", reason: "AWS 凭证默认禁止读取" },
97
- { pattern: /\.npmrc$/, label: "credential", reason: "npmrc 可能包含 token" },
98
- { pattern: /\.pypirc$/, label: "credential", reason: "PyPI 配置可能包含凭证" },
99
- { pattern: /kubeconfig/, label: "credential", reason: "kubeconfig 可能包含集群凭证" },
100
- { pattern: /\.docker[\\/]config\.json/, label: "credential", reason: "Docker 配置可能包含 registry 凭证" },
101
- { pattern: /tokens\.json|token_store|\.token/, label: "credential", reason: "token store 文件默认禁止读取" },
102
- { pattern: /cookies\.sqlite|cookies\.db|\.cookie[\\/]/, label: "secret", reason: "浏览器 cookie/session 默认禁止读取" },
103
- { pattern: /login\.keychain|\.keychain|\.keystore/, label: "secret", reason: "系统钥匙串默认禁止读取" },
104
- { pattern: /ssh[\\/]config$/i, label: "secret", reason: "SSH config 可能包含敏感主机/代理配置" },
105
- ];
106
- // ── 需确认读取模式 ──
107
- export const CONFIRMATION_READ_PATTERNS = [
108
- { pattern: /\.log$/, label: "production_data", reason: "日志文件可能包含敏感信息" },
109
- { pattern: /\.sql$/, label: "production_data", reason: "SQL 文件可能是数据库 dump" },
110
- { pattern: /\.csv$/, label: "customer_data", reason: "CSV 可能包含客户数据" },
111
- { pattern: /dump/, label: "production_data", reason: "dump 文件可能包含生产数据" },
112
- { pattern: /[\\/]export[\\/]/, label: "customer_data", reason: "export 目录可能包含客户导出数据" },
113
- { pattern: /figma[\\/]|notion[\\/]|drive[\\/]|slack[\\/]|github[\\/]private/, label: "confidential", reason: "私有云文档/协作平台数据需确认" },
114
- { pattern: /api[_-]?response|_response\.json|_result\.json/, label: "confidential", reason: "外部系统返回数据需确认" },
115
- { pattern: new RegExp('\\b(Users|home)\\/[\\w.-]+\\/(Desktop|Documents|Downloads|Pictures)', 's'), label: "confidential", reason: "用户 home 大范围目录需确认" },
116
- { pattern: /sample.*\.json|fixture.*\.json/, label: "confidential", reason: "真实 API 响应样本需确认" },
117
- { pattern: /\.vcf$|\. contacts$/, label: "pii", reason: "包含联系方式/PII 的文件需确认" },
118
- ];
119
- // ── 检测辅助函数 ──
120
1
  /**
121
- * 检测来源的敏感等级。
122
- * @param sourceRef - 来源引用路径
123
- * @param contentHints - 内容提示关键词(可选)
124
- * @returns 数据敏感标签
125
- */
126
- export function detectSensitivity(sourceRef, contentHints) {
127
- debugLog(`隐私契约: 检测敏感等级 ${sourceRef}`);
128
- // 优先检查禁止模式
129
- for (const { pattern, label, reason } of FORBIDDEN_READ_PATTERNS) {
130
- if (pattern.test(sourceRef)) {
131
- return {
132
- label,
133
- source_ref: sourceRef,
134
- detected_by: [`pattern: ${pattern.source}`],
135
- confidence: 0.9,
136
- handling: "forbidden",
137
- };
138
- }
139
- }
140
- // 检查确认模式
141
- for (const { pattern, label, reason } of CONFIRMATION_READ_PATTERNS) {
142
- if (pattern.test(sourceRef)) {
143
- return {
144
- label,
145
- source_ref: sourceRef,
146
- detected_by: [`pattern: ${pattern.source}`],
147
- confidence: 0.7,
148
- handling: "require_human",
149
- };
150
- }
151
- }
152
- // 基于内容的检测
153
- if (contentHints && contentHints.length > 0) {
154
- const joined = contentHints.join(" ");
155
- if (/token|api[_-]?key|secret[_-]?key|private[_-]?key/i.test(joined)) {
156
- return {
157
- label: "secret",
158
- source_ref: sourceRef,
159
- detected_by: ["content_keyword"],
160
- confidence: 0.6,
161
- handling: "forbidden",
162
- };
163
- }
164
- if (/\bpassword\b|\bpasswd\b/i.test(joined)) {
165
- return {
166
- label: "credential",
167
- source_ref: sourceRef,
168
- detected_by: ["content_keyword"],
169
- confidence: 0.6,
170
- handling: "forbidden",
171
- };
172
- }
173
- if (/\b\d{11}\b/.test(joined) || /\b[\w.+-]+@[\w-]+\.[\w.]+\b/.test(joined)) {
174
- return {
175
- label: "pii",
176
- source_ref: sourceRef,
177
- detected_by: ["content_pattern"],
178
- confidence: 0.5,
179
- handling: "require_human",
180
- };
181
- }
182
- }
183
- // 常规代码文件 (.ts, .js, .py, .go, .rs, .java, .tsx, .jsx) 默认为 internal
184
- const codeExtensions = /\.(ts|tsx|js|jsx|py|go|rs|java|c|cpp|h|rb|php|swift|kt)$/i;
185
- if (codeExtensions.test(sourceRef)) {
186
- return {
187
- label: "internal",
188
- source_ref: sourceRef,
189
- detected_by: ["file_extension"],
190
- confidence: 0.7,
191
- handling: "allow",
192
- };
193
- }
194
- return {
195
- label: "unknown",
196
- source_ref: sourceRef,
197
- detected_by: ["no_match"],
198
- confidence: 0.3,
199
- handling: DEFAULT_HANDLING["unknown"],
200
- };
201
- }
202
- // ── 检查函数 ──
203
- /**
204
- * 获取指定敏感标签的默认处理方式。
205
- * @param label - 敏感标签
206
- * @returns 处理方式
207
- */
208
- export function getDefaultHandling(label) {
209
- debugLog(`隐私契约: 获取默认处理方式 — ${label}`);
210
- return DEFAULT_HANDLING[label];
211
- }
212
- /**
213
- * 获取指定敏感标签在特定上下文中的处理方式。
214
- * @param label - 敏感标签
215
- * @param context - 检查上下文
216
- * @returns 处理方式
217
- */
218
- export function getContextHandling(label, context) {
219
- debugLog(`隐私契约: 获取上下文处理方式 — ${label}/${context}`);
220
- return CONTEXT_HANDLING[label][context];
221
- }
222
- /**
223
- * 判断数据是否可以注入 prompt。
224
- * @param label - 敏感标签
225
- * @returns 是否允许
226
- */
227
- export function canInjectInPrompt(label) {
228
- debugLog(`隐私契约: 检查 prompt 注入许可 — ${label}`);
229
- const handling = CONTEXT_HANDLING[label].prompt_injection;
230
- return handling === "allow";
231
- }
232
- /**
233
- * 判断数据是否可以存入任务上下文。
234
- * @param label - 敏感标签
235
- * @returns 是否允许
236
- */
237
- export function canStoreInTaskContext(label) {
238
- debugLog(`隐私契约: 检查 TaskContext 存储许可 — ${label}`);
239
- const handling = CONTEXT_HANDLING[label].task_context_store;
240
- return handling === "allow" || handling === "redact" || handling === "summarize_only";
241
- }
242
- /**
243
- * 判断数据是否可以存入产物。
244
- * @param label - 敏感标签
245
- * @returns 是否允许
246
- */
247
- export function canStoreInArtifact(label) {
248
- debugLog(`隐私契约: 检查 artifact 存储许可 — ${label}`);
249
- const handling = CONTEXT_HANDLING[label].artifact_store;
250
- return handling === "allow" || handling === "redact" || handling === "summarize_only";
251
- }
252
- /**
253
- * 判断数据是否可以外部发送。
254
- * @param label - 敏感标签
255
- * @returns 是否允许
256
- */
257
- export function canSendExternally(label) {
258
- debugLog(`隐私契约: 检查外发许可 — ${label}`);
259
- return CONTEXT_HANDLING[label].external_send === "allow";
260
- }
261
- /**
262
- * 判断来源的内容是否可以读取。
263
- * @param sourceRef - 来源引用路径
264
- * @returns 读取许可结果
265
- */
266
- export function canReadContent(sourceRef) {
267
- debugLog(`隐私契约: 检查内容读取许可 — ${sourceRef}`);
268
- for (const { pattern, label, reason } of FORBIDDEN_READ_PATTERNS) {
269
- if (pattern.test(sourceRef)) {
270
- return { allowed: false, reason, label, requires_confirmation: false };
271
- }
272
- }
273
- for (const { pattern, label, reason } of CONFIRMATION_READ_PATTERNS) {
274
- if (pattern.test(sourceRef)) {
275
- return { allowed: false, reason, label, requires_confirmation: true };
276
- }
277
- }
278
- return { allowed: true, reason: "", label: "public" };
279
- }
280
- /**
281
- * 判断来源是否禁止读取。
282
- * @param sourceRef - 来源引用路径
283
- * @returns 是否禁止
284
- */
285
- export function isReadForbidden(sourceRef) {
286
- debugLog(`隐私契约: 检查是否禁止读取 — ${sourceRef}`);
287
- return FORBIDDEN_READ_PATTERNS.some(({ pattern }) => pattern.test(sourceRef));
288
- }
289
- /**
290
- * 判断来源是否需要确认后才能读取。
291
- * @param sourceRef - 来源引用路径
292
- * @returns 是否需要确认
293
- */
294
- export function isReadRequiresConfirmation(sourceRef) {
295
- debugLog(`隐私契约: 检查是否需要确认读取 — ${sourceRef}`);
296
- return CONFIRMATION_READ_PATTERNS.some(({ pattern }) => pattern.test(sourceRef));
297
- }
298
- // ── 授权管理 ──
299
- /**
300
- * 创建数据访问授权。
301
- * @param options.granted_by - 授权人
302
- * @param options.scope_refs - 授权范围引用
303
- * @param options.sensitivity_allowed - 允许的敏感标签
304
- * @param options.allowed_operations - 允许的操作
305
- * @param options.purpose - 用途
306
- * @param options.duration_hours - 有效时长(小时)
307
- * @returns 数据访问授权
308
- */
309
- export function createDataAccessGrant(options) {
310
- debugLog(`隐私契约: 创建数据访问授权 — 授权人: ${options.granted_by}, 范围: ${options.scope_refs.length} 个引用`);
311
- const expiresAt = new Date(Date.now() + options.duration_hours * 3600_000);
312
- return {
313
- grant_id: `grant-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
314
- granted_by: options.granted_by,
315
- scope_refs: options.scope_refs,
316
- sensitivity_allowed: options.sensitivity_allowed,
317
- allowed_operations: options.allowed_operations,
318
- purpose: options.purpose,
319
- expires_at: expiresAt.toISOString(),
320
- revocable: true,
321
- };
322
- }
323
- /**
324
- * 判断授权是否有效。
325
- * @param grant - 数据访问授权
326
- * @returns 是否有效
327
- */
328
- export function isGrantValid(grant) {
329
- debugLog(`隐私契约: 检查授权有效性 — ${grant.grant_id}`);
330
- return new Date(grant.expires_at) > new Date();
331
- }
332
- /**
333
- * 判断授权是否已过期。
334
- * @param grant - 数据访问授权
335
- * @returns 是否已过期
336
- */
337
- export function isGrantExpired(grant) {
338
- debugLog(`隐私契约: 检查授权是否过期 — ${grant.grant_id}`);
339
- return new Date(grant.expires_at) <= new Date();
340
- }
341
- /**
342
- * 检查授权是否允许指定操作。
343
- * @param grant - 数据访问授权
344
- * @param operation - 请求的操作
345
- * @param sensitivity - 敏感标签
346
- * @returns 权限检查结果
347
- */
348
- export function checkGrantPermission(grant, operation, sensitivity) {
349
- debugLog(`隐私契约: 检查授权权限 — ${grant.grant_id}, 操作: ${operation}, 等级: ${sensitivity}`);
350
- if (isGrantExpired(grant)) {
351
- debugLog(`隐私契约: 授权权限拒绝 — 授权已过期`);
352
- return { allowed: false, reason: `授权 ${grant.grant_id} 已过期` };
353
- }
354
- if (!grant.allowed_operations.includes(operation)) {
355
- debugLog(`隐私契约: 授权权限拒绝 — 不允许操作 ${operation}`);
356
- return { allowed: false, reason: `授权 ${grant.grant_id} 不允许操作 ${operation}` };
357
- }
358
- if (!grant.sensitivity_allowed.includes(sensitivity)) {
359
- debugLog(`隐私契约: 授权权限拒绝 — 不允许敏感等级 ${sensitivity}`);
360
- return { allowed: false, reason: `授权 ${grant.grant_id} 不允许敏感等级 ${sensitivity}` };
361
- }
362
- debugLog(`隐私契约: 授权权限通过`);
363
- return { allowed: true, reason: "" };
364
- }
365
- // ── 脱敏处理 ──
366
- /**
367
- * 对内容进行脱敏处理。
368
- * @param content - 原始内容
369
- * @param label - 敏感标签
370
- * @param sourceRef - 来源引用(可选)
371
- * @returns 脱敏结果和脱敏记录
372
- */
373
- export function redactContent(content, label, sourceRef) {
374
- debugLog(`隐私契约: 开始内容脱敏 — 等级: ${label}, 来源: ${sourceRef ?? "未知"}`);
375
- let redacted = content;
376
- const fieldsRedacted = [];
377
- if (label === "secret" || label === "credential") {
378
- redacted = "***REDACTED***";
379
- fieldsRedacted.push("all");
380
- }
381
- else if (label === "pii") {
382
- redacted = redactPII(content);
383
- fieldsRedacted.push("phone", "email", "id_number", "address");
384
- }
385
- else if (label === "customer_data" || label === "production_data") {
386
- redacted = summarizeOnly(content);
387
- fieldsRedacted.push("raw_data");
388
- }
389
- else if (label === "confidential") {
390
- redacted = summarizeOnly(content);
391
- fieldsRedacted.push("details");
392
- }
393
- return {
394
- redacted,
395
- record: {
396
- source_ref: sourceRef ?? "",
397
- redaction_type: labelToRedactionType(label),
398
- after_hash: simpleHash(redacted),
399
- fields_redacted: fieldsRedacted,
400
- },
401
- };
402
- }
403
- function redactPII(text) {
404
- let result = text;
405
- // 手机号: 138****1234
406
- result = result.replace(/1[3-9]\d(\d{4})\d{4}/g, (m, last) => m.slice(0, 3) + "****" + last);
407
- // 邮箱: a***@domain.com
408
- result = result.replace(/([\w.+-])[\w.+-]*@([\w-]+\.[\w.]+)/g, (_, first, domain) => first + "***@" + domain);
409
- // 身份证号: 保留后 4 位
410
- result = result.replace(/\b\d{14}(\d{4})\b/g, "**************$1");
411
- // Address: keep city-level (省/市 + following district, redact detail)
412
- result = result.replace(/([\u4e00-\u9fa5]{2,6}(?:省|市|自治区|特别行政区))([\u4e00-\u9fa5]{2,6}(?:市|区|县|镇))([\u4e00-\u9fa5\d]+路?[\u4e00-\u9fa5\d]+)/g, "$1$2***");
413
- return result;
414
- }
415
- function summarizeOnly(text) {
416
- if (text.length <= 100)
417
- return `[摘要] ${text.slice(0, 50)}...`;
418
- return `[摘要] ${text.slice(0, 80)}... (共 ${text.length} 字符)`;
419
- }
420
- function labelToRedactionType(label) {
421
- const map = {
422
- secret: "secret_mask",
423
- credential: "credential_removed",
424
- pii: "pii_mask",
425
- customer_data: "customer_data_summary",
426
- production_data: "production_data_summary",
427
- confidential: "path_only",
428
- };
429
- return map[label] ?? "hash_only";
430
- }
431
- function simpleHash(text) {
432
- return crypto.createHash("sha256").update(text).digest("hex").slice(0, 16);
433
- }
434
- // ── 外发检查 ──
435
- /**
436
- * 检查内容是否可以外部发送。
437
- * @param content - 待发送内容
438
- * @param sensitivity - 敏感标签
439
- * @param grants - 授权列表
440
- * @returns 外发检查结果
441
- */
442
- export function checkExternalSend(content, sensitivity, grants) {
443
- debugLog(`隐私契约: 检查外发许可 — 等级: ${sensitivity.label}`);
444
- const handling = CONTEXT_HANDLING[sensitivity.label].external_send;
445
- if (handling === "forbidden") {
446
- debugLog(`隐私契约: 外发拒绝 — 等级 ${sensitivity.label} 禁止外发`);
447
- return { allowed: false, reason: `敏感等级 ${sensitivity.label} 禁止外发`, requiresRedaction: false };
448
- }
449
- if (handling === "allow") {
450
- return { allowed: true, reason: "", requiresRedaction: false };
451
- }
452
- // require_human — 检查授权
453
- for (const grant of grants) {
454
- const perm = checkGrantPermission(grant, "external_send", sensitivity.label);
455
- if (perm.allowed) {
456
- debugLog(`隐私契约: 外发通过 — 授权 ${grant.grant_id} 允许(已脱敏)`);
457
- const { redacted, record } = redactContent(content, sensitivity.label);
458
- return { allowed: true, reason: `授权 ${grant.grant_id} 允许外发(已脱敏)`, requiresRedaction: true, redactedContent: redacted };
459
- }
460
- }
461
- debugLog(`隐私契约: 外发拒绝 — 等级 ${sensitivity.label} 需要人工授权`);
462
- return {
463
- allowed: false,
464
- reason: `敏感等级 ${sensitivity.label} 需要人工授权才能外发`,
465
- requiresRedaction: true,
466
- };
467
- }
468
- // ── Prompt 注入检查 ──
469
- /**
470
- * 检查数据是否可以注入 prompt。
471
- * @param sensitivity - 敏感标签
472
- * @param grants - 授权列表
473
- * @returns 注入检查结果
474
- */
475
- export function checkPromptInjection(sensitivity, grants) {
476
- debugLog(`隐私契约: 检查 prompt 注入许可 — 等级: ${sensitivity.label}`);
477
- const handling = CONTEXT_HANDLING[sensitivity.label].prompt_injection;
478
- if (handling === "forbidden") {
479
- debugLog(`隐私契约: 注入拒绝 — 等级 ${sensitivity.label} 禁止注入 prompt`);
480
- return { allowed: false, reason: `敏感等级 ${sensitivity.label} 禁止注入 prompt`, handling };
481
- }
482
- if (handling === "allow") {
483
- return { allowed: true, reason: "", handling };
484
- }
485
- // 检查 prompt_inject 授权
486
- for (const grant of grants) {
487
- const perm = checkGrantPermission(grant, "prompt_inject", sensitivity.label);
488
- if (perm.allowed) {
489
- return { allowed: true, reason: `授权 ${grant.grant_id} 允许注入(${handling})`, handling };
490
- }
491
- }
492
- debugLog(`隐私契约: 注入拒绝 — 等级 ${sensitivity.label} 需要 ${handling} 处理`);
493
- return { allowed: false, reason: `敏感等级 ${sensitivity.label} 需要 ${handling} 处理`, handling };
494
- }
495
- // ── 中文反馈 ──
496
- /**
497
- * 构建隐私处理反馈信息。
498
- * @param options - 反馈选项
499
- * @returns 格式化的反馈文本
500
- */
501
- export function buildPrivacyFeedback(options) {
502
- debugLog(`隐私契约: 构建隐私反馈 — 未读: ${options.notRead.length}, 脱敏: ${options.redacted.length}, 需授权: ${options.requiresAuth.length}`);
503
- const lines = [];
504
- if (options.notRead.length > 0) {
505
- lines.push(`未读取的内容: ${options.notRead.join(", ")}`);
506
- }
507
- if (options.redacted.length > 0) {
508
- lines.push(`已脱敏的内容: ${options.redacted.join(", ")}`);
509
- }
510
- if (options.requiresAuth.length > 0) {
511
- lines.push(`需要授权的内容: ${options.requiresAuth.join(", ")}`);
512
- }
513
- if (options.notInPrompt.length > 0) {
514
- lines.push(`未进入 prompt 的内容: ${options.notInPrompt.join(", ")}`);
515
- }
516
- if (options.blocked) {
517
- lines.push(`⚠️ 存在敏感信息阻断`);
518
- }
519
- if (options.externalRedaction) {
520
- lines.push(`外发前已完成 redaction check`);
521
- }
522
- return lines.join("\n");
523
- }
524
- // ── 治理验证 ──
525
- /**
526
- * 验证隐私契约合规性。
527
- * @param options.sensitivities - 敏感标签列表
528
- * @param options.grants - 授权列表
529
- * @param options.redactionRecords - 脱敏记录列表
530
- * @param options.promptInjections - prompt 注入列表
531
- * @param options.taskContextStores - 任务上下文存储列表
532
- * @param options.artifactStores - 产物存储列表
533
- * @param options.externalSends - 外部发送列表
534
- * @returns 治理发现列表
535
- */
536
- /**
537
- * 验证隐私契约合规性。
538
- * @param options - 验证选项
539
- * @returns 验证结果,包含合规检查项和发现的问题
540
- */
541
- export function validatePrivacyContract(options) {
542
- const findings = [];
543
- debugLog(`隐私契约: 开始治理验证 — 检查 ${options.sensitivities.length} 个敏感来源`);
544
- // 规则 1: secret 不得进入 prompt
545
- for (const inj of options.promptInjections) {
546
- if (inj.label === "secret" || inj.label === "credential") {
547
- findings.push({
548
- severity: "hard_fail",
549
- rule: "gc-secret-no-prompt",
550
- source_ref: inj.source_ref,
551
- message: `secret/credential (${inj.label}) 不得注入 prompt — ${inj.source_ref}`,
552
- });
553
- }
554
- }
555
- // 规则 2: secret 不得写入 TaskContext
556
- for (const store of options.taskContextStores) {
557
- if (store.label === "secret" || store.label === "credential") {
558
- findings.push({
559
- severity: "hard_fail",
560
- rule: "gc-secret-no-taskcontext",
561
- source_ref: store.source_ref,
562
- message: `secret/credential (${store.label}) 不得写入 TaskContext — ${store.source_ref}`,
563
- });
564
- }
565
- }
566
- // 规则 3: secret 不得写入 artifact/report
567
- for (const art of options.artifactStores) {
568
- if (art.label === "secret" || art.label === "credential") {
569
- findings.push({
570
- severity: "hard_fail",
571
- rule: "gc-secret-no-artifact",
572
- source_ref: art.source_ref,
573
- message: `secret/credential (${art.label}) 不得写入 artifact — ${art.source_ref}`,
574
- });
575
- }
576
- }
577
- // 规则 4: PII 未脱敏外发
578
- for (const ext of options.externalSends) {
579
- if (ext.label === "pii" || ext.label === "customer_data" || ext.label === "production_data") {
580
- const hasRedaction = options.redactionRecords.some((r) => r.source_ref === ext.source_ref);
581
- if (!hasRedaction) {
582
- findings.push({
583
- severity: "hard_fail",
584
- rule: "gc-pii-no-unredacted-external",
585
- source_ref: ext.source_ref,
586
- message: `${ext.label} 未脱敏不得外发 — ${ext.source_ref}`,
587
- });
588
- }
589
- }
590
- }
591
- // 规则 5: secret 外发 hard fail
592
- for (const ext of options.externalSends) {
593
- if (ext.label === "secret" || ext.label === "credential") {
594
- findings.push({
595
- severity: "hard_fail",
596
- rule: "gc-secret-no-external",
597
- source_ref: ext.source_ref,
598
- message: `secret/credential (${ext.label}) 外发 hard fail — ${ext.source_ref}`,
599
- });
600
- }
601
- }
602
- // 规则 6: DataAccessGrant 过期后不得使用
603
- for (const grant of options.grants) {
604
- if (isGrantExpired(grant)) {
605
- findings.push({
606
- severity: "hard_fail",
607
- rule: "gc-grant-expired",
608
- source_ref: grant.grant_id,
609
- message: `授权 ${grant.grant_id} 已过期,不得继续使用`,
610
- });
611
- }
612
- }
613
- // 规则 7: unknown sensitivity 不能当 public
614
- for (const s of options.sensitivities) {
615
- if (s.label === "unknown" && s.handling === "allow") {
616
- findings.push({
617
- severity: "hard_fail",
618
- rule: "gc-unknown-not-public",
619
- source_ref: s.source_ref,
620
- message: `unknown sensitivity 不能当做 public 处理 — ${s.source_ref}`,
621
- });
622
- }
623
- }
624
- // 规则 8: private evidence 不得注入 prompt
625
- for (const s of options.sensitivities) {
626
- if (s.label === "secret" || s.label === "credential") {
627
- const injected = options.promptInjections.some((i) => i.source_ref === s.source_ref);
628
- if (injected) {
629
- findings.push({
630
- severity: "hard_fail",
631
- rule: "gc-private-no-prompt",
632
- source_ref: s.source_ref,
633
- message: `private evidence (${s.label}) 不得注入 prompt — ${s.source_ref}`,
634
- });
635
- }
636
- }
637
- }
638
- // 规则 9: 每次脱敏必须有 RedactionRecord
639
- const redactedSources = new Set(options.redactionRecords.map((r) => r.source_ref));
640
- for (const s of options.sensitivities) {
641
- if (s.handling === "redact" && !redactedSources.has(s.source_ref)) {
642
- findings.push({
643
- severity: "advisory",
644
- rule: "gc-redaction-record-missing",
645
- source_ref: s.source_ref,
646
- message: `敏感来源 ${s.source_ref} 标记为脱敏但缺少 RedactionRecord`,
647
- });
648
- }
649
- }
650
- return findings;
651
- }
652
- // ── Unified Privacy Gate (硬门) ──
653
- const TEXT_SECRET_PATTERNS = [
654
- { pattern: /sk-[a-zA-Z0-9]{32,}/, label: "secret", fields: ["api_key"] },
655
- { pattern: /AKIA[0-9A-Z]{16}/, label: "credential", fields: ["aws_access_key"] },
656
- { pattern: /aws_secret_access_key\s*=\s*['"][^'"]+['"]/, label: "credential", fields: ["aws_secret"] },
657
- { pattern: /password\s*=\s*['"][^'"]{4,}['"]/, label: "credential", fields: ["password"] },
658
- { pattern: /secret_key\s*=\s*['"][^'"]+['"]/, label: "secret", fields: ["secret_key"] },
659
- { pattern: /jwt_secret\s*=\s*['"][^'"]+['"]/, label: "secret", fields: ["jwt_secret"] },
660
- { pattern: /1[3-9]\d{9}/, label: "pii", fields: ["phone"] },
661
- { pattern: /[\w.+-]+@[\w-]+\.[\w.]+/, label: "pii", fields: ["email"] },
662
- { pattern: /\b\d{17}[\dXx]\b/, label: "pii", fields: ["id_number"] },
663
- // 生产数据模式
664
- { pattern: /production\.log|prod-\w+\.\w+|\bproduction\s+data\b/i, label: "production_data", fields: ["production_log"] },
665
- { pattern: /SELECT\s+.{1,}?\s+FROM\s+/is, label: "production_data", fields: ["sql_query"] },
666
- { pattern: /database\s+dump|db\s+dump|\bdb_dump\b/i, label: "production_data", fields: ["database_dump"] },
667
- { pattern: /API\s+Response:\s*\{/i, label: "production_data", fields: ["api_response"] },
668
- // 客户数据模式
669
- { pattern: /email,\s*phone,\s*name|name,\s*email,\s*phone/i, label: "customer_data", fields: ["customer_csv"] },
670
- { pattern: /user_id["']?\s*:\s*\d+.*["']?email["']?\s*:/i, label: "customer_data", fields: ["user_export"] },
671
- { pattern: /customer.*export|export.*customer/i, label: "customer_data", fields: ["customer_export"] },
672
- ];
673
- /**
674
- * 扫描文本中的敏感信息。
675
- * @param text - 待扫描文本
676
- * @param sourceRef - 来源引用
677
- * @returns 检测到的敏感标签列表
678
- */
679
- export function scanTextSensitivity(text, sourceRef) {
680
- debugLog(`隐私契约: 扫描文本敏感信息 — 来源: ${sourceRef}`);
681
- const labels = [];
682
- for (const { pattern, label, fields } of TEXT_SECRET_PATTERNS) {
683
- if (pattern.test(text)) {
684
- labels.push({
685
- label,
686
- source_ref: sourceRef,
687
- detected_by: [`text_pattern:${fields.join(",")}`],
688
- confidence: 0.85,
689
- handling: (label === "pii" || label === "production_data" || label === "customer_data") ? "require_human" : "forbidden",
690
- });
691
- }
692
- }
693
- return labels;
694
- }
695
- /**
696
- * 扫描来源引用的敏感等级。
697
- * @param sourceRef - 来源引用路径
698
- * @returns 数据敏感标签
699
- */
700
- export function scanSourceRefSensitivity(sourceRef) {
701
- debugLog(`隐私契约: 扫描来源敏感等级 — ${sourceRef}`);
702
- return detectSensitivity(sourceRef);
703
- }
704
- /**
705
- * 对文本中的敏感信息进行脱敏处理。
706
- * @param text - 原始文本
707
- * @param sourceRef - 来源引用(可选)
708
- * @returns 脱敏结果和脱敏记录
709
- */
710
- export function redactSensitiveText(text, sourceRef) {
711
- let result = text;
712
- const records = [];
713
- const fieldsRedacted = [];
714
- debugLog(`隐私契约: 开始文本脱敏 — 来源: ${sourceRef ?? '未知'}`);
715
- // API 密钥 / 令牌
716
- if (/sk-[a-zA-Z0-9]{32,}/.test(result)) {
717
- result = result.replace(/sk-[a-zA-Z0-9]{32,}/g, "sk-****REDACTED****");
718
- fieldsRedacted.push("api_key");
719
- }
720
- // AWS 访问密钥
721
- if (/AKIA[0-9A-Z]{16}/.test(result)) {
722
- result = result.replace(/AKIA[0-9A-Z]{16}/g, "AKIA****REDACTED****");
723
- fieldsRedacted.push("aws_access_key");
724
- }
725
- // AWS 秘密访问密钥值
726
- result = result.replace(/(aws_secret_access_key\s*=\s*['"])[^'"]+(['"])/g, "$1****REDACTED****$2");
727
- // 密码值
728
- result = result.replace(/(password\s*=\s*['"])[^'"]{4,}(['"])/gi, "$1****REDACTED****$2");
729
- // 密钥值
730
- result = result.replace(/(secret_key\s*=\s*['"])[^'"]+(['"])/gi, "$1****REDACTED****$2");
731
- // JWT 密钥值
732
- result = result.replace(/(jwt_secret\s*=\s*['"])[^'"]+(['"])/gi, "$1****REDACTED****$2");
733
- // 个人身份信息
734
- const piiResult = redactPII(result);
735
- if (piiResult !== result) {
736
- result = piiResult;
737
- fieldsRedacted.push("phone", "email", "id_number", "address");
738
- }
739
- if (fieldsRedacted.length > 0) {
740
- debugLog(`隐私契约: 文本脱敏完成 — 脱敏字段: ${fieldsRedacted.join(", ")}`);
741
- records.push({
742
- source_ref: sourceRef ?? "",
743
- redaction_type: "secret_mask",
744
- after_hash: simpleHash(result),
745
- fields_redacted: [...new Set(fieldsRedacted)],
746
- });
747
- }
748
- return { redacted: result, records };
749
- }
750
- /**
751
- * 评估统一隐私门禁。
752
- * @param params.intent - 用户意图文本(可选)
753
- * @param params.input_materials - 输入材料(可选)
754
- * @param params.prompt_sources - prompt 来源(可选)
755
- * @param params.task_context_stores - 任务上下文存储(可选)
756
- * @param params.artifact_stores - 产物存储(可选)
757
- * @param params.external_sends - 外部发送列表(可选)
758
- * @param params.grants - 授权列表(可选)
759
- * @returns 隐私门禁结果
760
- */
761
- /**
762
- * 评估隐私门禁,决定是否阻断操作。
763
- * @param options - 门禁评估选项
764
- * @returns 门禁结果,包含是否通过、阻断源和警告
765
- */
766
- export function evaluatePrivacyGate(params) {
767
- const findings = [];
768
- const blockedSources = [];
769
- debugLog(`隐私契约: 开始隐私门禁评估`);
770
- const allLabels = [];
771
- const redactionRecords = [];
772
- let hardFail = false;
773
- // 扫描意图文本
774
- if (params.intent) {
775
- const intentLabels = scanTextSensitivity(params.intent, "intent");
776
- for (const l of intentLabels) {
777
- allLabels.push(l);
778
- if (l.label === "secret" || l.label === "credential") {
779
- hardFail = true;
780
- blockedSources.push("intent");
781
- findings.push({ severity: "hard_fail", rule: "gc-intent-secret", source_ref: "intent", message: `用户意图包含 ${l.label}(${l.detected_by.join(", ")}),禁止执行` });
782
- }
783
- }
784
- }
785
- // 按来源引用扫描输入材料
786
- if (params.input_materials) {
787
- for (const m of params.input_materials) {
788
- const refLabel = scanSourceRefSensitivity(m.path_or_ref);
789
- allLabels.push(refLabel);
790
- if (refLabel.handling === "forbidden") {
791
- hardFail = true;
792
- blockedSources.push(m.path_or_ref);
793
- findings.push({ severity: "hard_fail", rule: "gc-material-forbidden", source_ref: m.path_or_ref, message: `输入材料 ${m.path_or_ref} 匹配禁止模式(${refLabel.label}),禁止读取` });
794
- }
795
- else if (refLabel.handling === "require_human") {
796
- const hasGrant = (params.grants ?? []).some(g => isGrantValid(g) && g.sensitivity_allowed.includes(refLabel.label) && g.allowed_operations.includes("read"));
797
- if (!hasGrant) {
798
- blockedSources.push(m.path_or_ref);
799
- findings.push({ severity: "advisory", rule: "gc-material-requires-confirmation", source_ref: m.path_or_ref, message: `输入材料 ${m.path_or_ref} 标记为 ${refLabel.label},需人工确认后读取` });
800
- }
801
- }
802
- // 如果提供了内容也进行扫描
803
- if (m.content) {
804
- const contentLabels = scanTextSensitivity(m.content, m.path_or_ref);
805
- for (const cl of contentLabels) {
806
- if (cl.label === "secret" || cl.label === "credential") {
807
- hardFail = true;
808
- blockedSources.push(m.path_or_ref);
809
- findings.push({ severity: "hard_fail", rule: "gc-content-secret", source_ref: m.path_or_ref, message: `输入材料内容包含 ${cl.label}(${cl.detected_by.join(", ")}),禁止执行` });
810
- }
811
- allLabels.push(cl);
812
- }
813
- }
814
- }
815
- }
816
- // 检查 task_context_stores 是否包含敏感内容
817
- if (params.task_context_stores) {
818
- for (const s of params.task_context_stores) {
819
- if (s.content) {
820
- const labels = scanTextSensitivity(s.content, s.source_ref);
821
- for (const l of labels) {
822
- if (l.label === "secret" || l.label === "credential") {
823
- hardFail = true;
824
- findings.push({ severity: "hard_fail", rule: "gc-taskcontext-secret", source_ref: s.source_ref, message: `TaskContext 写入内容包含 ${l.label},禁止保存` });
825
- }
826
- }
827
- }
828
- }
829
- }
830
- // 检查外发内容
831
- if (params.external_sends) {
832
- for (const e of params.external_sends) {
833
- const labels = e.content ? scanTextSensitivity(e.content, e.source_ref) : [];
834
- const refLabel = scanSourceRefSensitivity(e.source_ref);
835
- if (refLabel.label === "secret" || refLabel.label === "credential") {
836
- hardFail = true;
837
- findings.push({ severity: "hard_fail", rule: "gc-external-secret", source_ref: e.source_ref, message: `外发来源 ${e.source_ref} 标记为 ${refLabel.label},禁止外发` });
838
- }
839
- for (const l of labels) {
840
- if (l.label === "secret" || l.label === "credential") {
841
- hardFail = true;
842
- findings.push({ severity: "hard_fail", rule: "gc-external-content-secret", source_ref: e.source_ref, message: `外发内容包含 ${l.label},禁止外发` });
843
- }
844
- }
845
- }
846
- }
847
- // 如有需要,脱敏意图文本
848
- let redactedText;
849
- if (params.intent) {
850
- const { redacted, records } = redactSensitiveText(params.intent, "intent");
851
- if (records.length > 0) {
852
- redactedText = redacted;
853
- redactionRecords.push(...records);
854
- }
855
- }
856
- if (hardFail) {
857
- debugLog(`隐私契约: 隐私门禁阻断 — 发现 ${blockedSources.length} 个阻断源`);
858
- }
859
- else if (findings.length > 0) {
860
- debugLog(`隐私契约: 隐私门禁通过 — 但有 ${findings.length} 个警告`);
861
- }
862
- else {
863
- debugLog(`隐私契约: 隐私门禁通过`);
864
- }
865
- return {
866
- allowed: !hardFail,
867
- hard_fail: hardFail,
868
- blocked_sources: [...new Set(blockedSources)],
869
- findings,
870
- redacted_text: redactedText,
871
- redaction_records: redactionRecords,
872
- labels: allLabels,
873
- };
874
- }
2
+ * Privacy / Secret / Data Sovereignty Contract — barrel 重导出
3
+ *
4
+ * 将隐私合约拆分为 4 个模块,此文件保持原有导出 API 不变。
5
+ * 消费者无需任何改动。
6
+ */
7
+ export * from "./privacy_types.js";
8
+ export * from "./privacy_patterns.js";
9
+ export * from "./privacy_grants.js";
10
+ export * from "./privacy_scanning.js";
11
+ // 显式重导出入口点名称,确保代码审计扫描器可检测
12
+ export { scanTextSensitivity, evaluatePrivacyGate, redactSensitiveText, detectSensitivity, scanSourceRefSensitivity, redactContent, checkExternalSend, checkPromptInjection, buildPrivacyFeedback, validatePrivacyContract, } from "./privacy_scanning.js";
13
+ // [隐私合约已拆分到 privacy_types/patterns/grants/scanning 四个模块]
875
14
  //# sourceMappingURL=privacy_secret_contract.js.map