soloforge 1.1.47 → 1.1.49
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -7
- package/dist/cli/adapter_writers.d.ts +5 -0
- package/dist/cli/adapter_writers.d.ts.map +1 -1
- package/dist/cli/adapter_writers.js +25 -0
- package/dist/cli/adapter_writers.js.map +1 -1
- package/dist/cli/init.d.ts.map +1 -1
- package/dist/cli/init.js +3 -1
- package/dist/cli/init.js.map +1 -1
- package/dist/cli/scope_check.d.ts +4 -0
- package/dist/cli/scope_check.d.ts.map +1 -0
- package/dist/cli/scope_check.js +51 -0
- package/dist/cli/scope_check.js.map +1 -0
- package/dist/context/adapters/claude_code/hooks.d.ts +5 -7
- package/dist/context/adapters/claude_code/hooks.d.ts.map +1 -1
- package/dist/context/adapters/claude_code/hooks.js +11 -9
- package/dist/context/adapters/claude_code/hooks.js.map +1 -1
- package/dist/context/adapters/shared/integration_guide.d.ts +3 -3
- package/dist/context/adapters/shared/integration_guide.js +18 -8
- package/dist/context/adapters/shared/integration_guide.js.map +1 -1
- package/dist/context/adapters/shared/workflow_template.js +1 -1
- package/dist/context/config/intent_schema.d.ts +793 -6
- package/dist/context/config/intent_schema.d.ts.map +1 -1
- package/dist/context/config/intent_schema.js +9 -0
- package/dist/context/config/intent_schema.js.map +1 -1
- package/dist/context/config/resolver.d.ts +9 -0
- package/dist/context/config/resolver.d.ts.map +1 -1
- package/dist/context/config/resolver.js +5 -0
- package/dist/context/config/resolver.js.map +1 -1
- package/dist/core/adversarial_review_store.d.ts +133 -0
- package/dist/core/adversarial_review_store.d.ts.map +1 -0
- package/dist/core/adversarial_review_store.js +161 -0
- package/dist/core/adversarial_review_store.js.map +1 -0
- package/dist/core/domain_transition.d.ts.map +1 -1
- package/dist/core/domain_transition.js +3 -0
- package/dist/core/domain_transition.js.map +1 -1
- package/dist/core/gate_record_store.d.ts +2 -0
- package/dist/core/gate_record_store.d.ts.map +1 -1
- package/dist/core/gate_record_store.js +17 -4
- package/dist/core/gate_record_store.js.map +1 -1
- package/dist/core/git_utils.d.ts +1 -1
- package/dist/core/git_utils.d.ts.map +1 -1
- package/dist/core/git_utils.js +8 -4
- package/dist/core/git_utils.js.map +1 -1
- package/dist/core/observer.d.ts.map +1 -1
- package/dist/core/observer.js +26 -2
- package/dist/core/observer.js.map +1 -1
- package/dist/core/task_context/constants.d.ts.map +1 -1
- package/dist/core/task_context/constants.js +4 -2
- package/dist/core/task_context/constants.js.map +1 -1
- package/dist/core/task_context/manager.d.ts +4 -4
- package/dist/core/task_context/manager.d.ts.map +1 -1
- package/dist/core/task_context/manager.js +69 -62
- package/dist/core/task_context/manager.js.map +1 -1
- package/dist/core/task_context/manager_setters.d.ts +2 -0
- package/dist/core/task_context/manager_setters.d.ts.map +1 -1
- package/dist/core/task_context/manager_setters.js +10 -0
- package/dist/core/task_context/manager_setters.js.map +1 -1
- package/dist/core/task_context/stage_fact_ownership.js +1 -1
- package/dist/core/task_context/stage_fact_ownership.js.map +1 -1
- package/dist/core/task_context/status_transitions.js +5 -5
- package/dist/core/task_context/status_transitions.js.map +1 -1
- package/dist/core/types.d.ts +29 -0
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/waiver_store.d.ts +100 -0
- package/dist/core/waiver_store.d.ts.map +1 -0
- package/dist/core/waiver_store.js +185 -0
- package/dist/core/waiver_store.js.map +1 -0
- package/dist/domain/asset_registry/derived_registry.d.ts +10 -0
- package/dist/domain/asset_registry/derived_registry.d.ts.map +1 -1
- package/dist/domain/asset_registry/derived_registry.js +10 -0
- package/dist/domain/asset_registry/derived_registry.js.map +1 -1
- package/dist/domain/asset_registry/derived_types.d.ts +27 -0
- package/dist/domain/asset_registry/derived_types.d.ts.map +1 -1
- package/dist/domain/asset_registry/derived_types.js +10 -0
- package/dist/domain/asset_registry/derived_types.js.map +1 -1
- package/dist/domain/build/engine.d.ts +1 -0
- package/dist/domain/build/engine.d.ts.map +1 -1
- package/dist/domain/build/engine.js +34 -4
- package/dist/domain/build/engine.js.map +1 -1
- package/dist/domain/contracts/design_lifecycle_contract.d.ts.map +1 -1
- package/dist/domain/contracts/design_lifecycle_contract.js +11 -4
- package/dist/domain/contracts/design_lifecycle_contract.js.map +1 -1
- package/dist/domain/design/contract.d.ts.map +1 -1
- package/dist/domain/design/contract.js +11 -0
- package/dist/domain/design/contract.js.map +1 -1
- package/dist/domain/design/engine.d.ts +1 -0
- package/dist/domain/design/engine.d.ts.map +1 -1
- package/dist/domain/design/engine.js +35 -3
- package/dist/domain/design/engine.js.map +1 -1
- package/dist/domain/engine_helpers.d.ts +37 -0
- package/dist/domain/engine_helpers.d.ts.map +1 -1
- package/dist/domain/engine_helpers.js +86 -0
- package/dist/domain/engine_helpers.js.map +1 -1
- package/dist/domain/operate/engine.d.ts +1 -0
- package/dist/domain/operate/engine.d.ts.map +1 -1
- package/dist/domain/operate/engine.js +19 -2
- package/dist/domain/operate/engine.js.map +1 -1
- package/dist/domain/types.d.ts +6 -0
- package/dist/domain/types.d.ts.map +1 -1
- package/dist/domain/types.js.map +1 -1
- package/dist/domain/verify/engine.d.ts +1 -0
- package/dist/domain/verify/engine.d.ts.map +1 -1
- package/dist/domain/verify/engine.js +18 -1
- package/dist/domain/verify/engine.js.map +1 -1
- package/dist/gate/certainty_gate.d.ts +10 -0
- package/dist/gate/certainty_gate.d.ts.map +1 -1
- package/dist/gate/certainty_gate.js.map +1 -1
- package/dist/gate/contracts/tool_actions.d.ts +11 -2
- package/dist/gate/contracts/tool_actions.d.ts.map +1 -1
- package/dist/gate/contracts/tool_actions.js +12 -2
- package/dist/gate/contracts/tool_actions.js.map +1 -1
- package/dist/gate/contracts/tool_invocation_contract_registry.d.ts.map +1 -1
- package/dist/gate/contracts/tool_invocation_contract_registry.js +11 -1
- package/dist/gate/contracts/tool_invocation_contract_registry.js.map +1 -1
- package/dist/gate/executors/executors_annotation.d.ts +33 -10
- package/dist/gate/executors/executors_annotation.d.ts.map +1 -1
- package/dist/gate/executors/executors_annotation.js +119 -64
- package/dist/gate/executors/executors_annotation.js.map +1 -1
- package/dist/gate/executors/executors_artifact.d.ts +20 -1
- package/dist/gate/executors/executors_artifact.d.ts.map +1 -1
- package/dist/gate/executors/executors_artifact.js +83 -123
- package/dist/gate/executors/executors_artifact.js.map +1 -1
- package/dist/gate/executors/executors_build.d.ts +2 -2
- package/dist/gate/executors/executors_build.d.ts.map +1 -1
- package/dist/gate/executors/executors_build.js +28 -126
- package/dist/gate/executors/executors_build.js.map +1 -1
- package/dist/gate/executors/executors_deploy.d.ts.map +1 -1
- package/dist/gate/executors/executors_deploy.js +35 -7
- package/dist/gate/executors/executors_deploy.js.map +1 -1
- package/dist/gate/executors/executors_external_command.d.ts.map +1 -1
- package/dist/gate/executors/executors_external_command.js +54 -2
- package/dist/gate/executors/executors_external_command.js.map +1 -1
- package/dist/gate/executors/executors_field_mapping.d.ts +7 -0
- package/dist/gate/executors/executors_field_mapping.d.ts.map +1 -0
- package/dist/gate/executors/executors_field_mapping.js +191 -0
- package/dist/gate/executors/executors_field_mapping.js.map +1 -0
- package/dist/gate/executors/executors_jacoco.d.ts +3 -0
- package/dist/gate/executors/executors_jacoco.d.ts.map +1 -0
- package/dist/gate/executors/executors_jacoco.js +70 -0
- package/dist/gate/executors/executors_jacoco.js.map +1 -0
- package/dist/gate/executors/executors_prerequisite.d.ts +1 -1
- package/dist/gate/executors/executors_prerequisite.d.ts.map +1 -1
- package/dist/gate/executors/executors_prerequisite.js +2 -62
- package/dist/gate/executors/executors_prerequisite.js.map +1 -1
- package/dist/gate/executors/executors_probe.d.ts +1 -0
- package/dist/gate/executors/executors_probe.d.ts.map +1 -1
- package/dist/gate/executors/executors_probe.js +1 -0
- package/dist/gate/executors/executors_probe.js.map +1 -1
- package/dist/gate/executors/executors_regex_scan.d.ts.map +1 -1
- package/dist/gate/executors/executors_regex_scan.js +34 -13
- package/dist/gate/executors/executors_regex_scan.js.map +1 -1
- package/dist/gate/executors/executors_scope.d.ts +7 -3
- package/dist/gate/executors/executors_scope.d.ts.map +1 -1
- package/dist/gate/executors/executors_scope.js +20 -173
- package/dist/gate/executors/executors_scope.js.map +1 -1
- package/dist/gate/executors/executors_trace.d.ts +5 -0
- package/dist/gate/executors/executors_trace.d.ts.map +1 -1
- package/dist/gate/executors/executors_trace.js +295 -4
- package/dist/gate/executors/executors_trace.js.map +1 -1
- package/dist/gate/executors/index.d.ts.map +1 -1
- package/dist/gate/executors/index.js +4 -2
- package/dist/gate/executors/index.js.map +1 -1
- package/dist/gate/gate_engine.d.ts +20 -0
- package/dist/gate/gate_engine.d.ts.map +1 -1
- package/dist/gate/gate_engine.js +58 -6
- package/dist/gate/gate_engine.js.map +1 -1
- package/dist/gate/gate_registry_bridge.d.ts +12 -2
- package/dist/gate/gate_registry_bridge.d.ts.map +1 -1
- package/dist/gate/gate_registry_bridge.js +7 -5
- package/dist/gate/gate_registry_bridge.js.map +1 -1
- package/dist/gate/middleware_gates.js +1 -1
- package/dist/gate/middleware_gates.js.map +1 -1
- package/dist/gate/release/gate_checks/checkAssetAntiBloat.d.ts.map +1 -1
- package/dist/gate/release/gate_checks/checkAssetAntiBloat.js +3 -0
- package/dist/gate/release/gate_checks/checkAssetAntiBloat.js.map +1 -1
- package/dist/gate/scope_resolver.d.ts +7 -0
- package/dist/gate/scope_resolver.d.ts.map +1 -1
- package/dist/gate/scope_resolver.js +1 -1
- package/dist/gate/scope_resolver.js.map +1 -1
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/server/tools/index.d.ts.map +1 -1
- package/dist/server/tools/index.js +4 -2
- package/dist/server/tools/index.js.map +1 -1
- package/dist/server/tools/middleware.d.ts.map +1 -1
- package/dist/server/tools/middleware.js +1 -0
- package/dist/server/tools/middleware.js.map +1 -1
- package/dist/server/tools/schemas.d.ts +10 -0
- package/dist/server/tools/schemas.d.ts.map +1 -1
- package/dist/server/tools/schemas.js +10 -0
- package/dist/server/tools/schemas.js.map +1 -1
- package/dist/server/tools/sf_doctor.d.ts +8 -0
- package/dist/server/tools/sf_doctor.d.ts.map +1 -1
- package/dist/server/tools/sf_doctor.js +58 -2
- package/dist/server/tools/sf_doctor.js.map +1 -1
- package/dist/server/tools/sf_task.d.ts +83 -0
- package/dist/server/tools/sf_task.d.ts.map +1 -1
- package/dist/server/tools/sf_task.js +121 -4
- package/dist/server/tools/sf_task.js.map +1 -1
- package/dist/server/tools/sf_waiver.d.ts +31 -0
- package/dist/server/tools/sf_waiver.d.ts.map +1 -0
- package/dist/server/tools/sf_waiver.js +139 -0
- package/dist/server/tools/sf_waiver.js.map +1 -0
- package/dist/server/tools/sf_work.d.ts +194 -0
- package/dist/server/tools/sf_work.d.ts.map +1 -1
- package/dist/server/tools/sf_work.js +603 -40
- package/dist/server/tools/sf_work.js.map +1 -1
- package/dist/shared/paths.d.ts +4 -0
- package/dist/shared/paths.d.ts.map +1 -1
- package/dist/shared/paths.js +6 -0
- package/dist/shared/paths.js.map +1 -1
- package/dist/shared/traceability_id_utils.js +3 -3
- package/dist/shared/traceability_id_utils.js.map +1 -1
- package/dist/types/pipeline_types.d.ts +4 -1
- package/dist/types/pipeline_types.d.ts.map +1 -1
- package/dist/verify/audit/probe_executor.d.ts +4 -1
- package/dist/verify/audit/probe_executor.d.ts.map +1 -1
- package/dist/verify/audit/probe_executor.js +4 -1
- package/dist/verify/audit/probe_executor.js.map +1 -1
- package/dist/verify/audit/probe_rule.d.ts +3 -0
- package/dist/verify/audit/probe_rule.d.ts.map +1 -1
- package/dist/verify/audit/probe_rule.js +3 -0
- package/dist/verify/audit/probe_rule.js.map +1 -1
- package/dist/verify/contracts/decision_workshop.d.ts.map +1 -1
- package/dist/verify/contracts/decision_workshop.js +4 -3
- package/dist/verify/contracts/decision_workshop.js.map +1 -1
- package/dist/verify/contracts/runtime_state_recovery_registry.d.ts.map +1 -1
- package/dist/verify/contracts/runtime_state_recovery_registry.js +0 -1
- package/dist/verify/contracts/runtime_state_recovery_registry.js.map +1 -1
- package/package.json +1 -1
- package/templates/build/enforced.md +263 -68
- package/templates/build//346/263/250/351/207/212/347/272/252/345/276/213.md +48 -0
- package/templates/build//346/265/213/350/257/225/344/274/230/345/205/210/347/274/226/347/240/201.md +1 -0
- package/templates/build//346/265/213/350/257/225/350/256/241/345/210/222.md +9 -4
- package/templates/build//347/274/226/347/240/201/347/272/252/345/276/213.md +28 -1
- package/templates/design/API/346/216/245/345/217/243/350/247/204/346/240/274/346/226/207/346/241/243.md +7 -0
- package/templates/design/enforced.md +204 -14
- package/templates/design//345/205/250/347/224/237/345/221/275/345/221/250/346/234/237/345/267/245/344/275/234/346/265/201/345/257/274/350/210/252.md +9 -7
- package/templates/design//345/210/207/347/211/207/350/247/204/345/210/222.md +4 -0
- package/templates/design//345/274/200/345/217/221/345/210/207/347/211/207/350/256/241/345/210/222.md +76 -0
- package/templates/design//346/225/260/346/215/256/345/272/223/350/256/276/350/256/241/346/226/207/346/241/243.md +2 -0
- package/templates/design//346/236/266/346/236/204/350/256/276/350/256/241.md +24 -0
- package/templates/design//350/256/276/350/256/241/345/206/263/347/255/226/347/272/252/345/276/213.md +58 -0
- package/templates/design//350/256/276/350/256/241/350/264/250/351/207/217/350/246/201/347/202/271.md +58 -0
- package/templates/design//351/234/200/346/261/202/345/210/206/346/236/220.md +24 -0
- package/templates/operate/UI/350/247/206/350/247/211/351/252/214/346/224/266/347/272/252/345/276/213.md +85 -0
- package/templates/operate/enforced.md +42 -6
- package/templates/operate//345/217/221/345/270/203/350/257/264/346/230/216.md +19 -1
- package/templates/operate//351/203/250/347/275/262/351/205/215/347/275/256.md +10 -0
- package/templates/shared/enforced.md +37 -0
- package/templates/shared//345/267/245/344/275/234/346/265/201/345/257/274/350/210/252/345/245/221/347/272/246.md +1 -1
- package/templates/shared//345/267/245/344/275/234/346/265/201/347/241/254/350/247/204/345/210/231/345/245/221/347/272/246.md +2 -2
- package/templates/shared//347/240/224/350/256/250/350/256/260/345/275/225.md +54 -0
- package/templates/verify/enforced.md +92 -262
- package/templates/verify//344/272/244/344/273/230/345/256/214/345/244/207/346/200/247/345/256/241/346/237/245.md +1 -0
- package/templates/verify//344/273/243/347/240/201/345/256/241/346/237/245/346/212/245/345/221/212.md +12 -2
- package/templates/verify//345/256/241/346/237/245/346/270/205/345/215/225.md +3 -1
- package/templates/verify//346/236/266/346/236/204/350/257/255/344/271/211/347/272/242/347/272/277.md +60 -0
- package/dist/core/scope_checker.d.ts +0 -29
- package/dist/core/scope_checker.d.ts.map +0 -1
- package/dist/core/scope_checker.js +0 -53
- package/dist/core/scope_checker.js.map +0 -1
- package/dist/gate/executors/executors_openapi_sync.d.ts +0 -23
- package/dist/gate/executors/executors_openapi_sync.d.ts.map +0 -1
- package/dist/gate/executors/executors_openapi_sync.js +0 -145
- package/dist/gate/executors/executors_openapi_sync.js.map +0 -1
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* sf_waiver 工具 — 门禁豁免管理(waive / list / remove)。
|
|
3
|
+
*
|
|
4
|
+
* 职责边界:
|
|
5
|
+
* - 负责:创建/列出/撤销 gate finding 豁免,强制审计留痕,安全类 check 不可豁免
|
|
6
|
+
* - 不负责:豁免数据存储(WaiverStore)、gate 注入决策(gate_engine evaluateGate)
|
|
7
|
+
*
|
|
8
|
+
* 被谁调用:MCP Server registerTools
|
|
9
|
+
* 调用谁:core/waiver_store(WaiverStore)、gate/gate_registry_bridge(查 block_check)、gate/gate_engine(ruleset hash)
|
|
10
|
+
*
|
|
11
|
+
* 数据流:command → 校验(confirm/reason/NON_WAIVABLE/block_check/scope 计数)→ WaiverStore 写 + 审计
|
|
12
|
+
* 持久化:.soloforge/waivers/{waiver_id}.json + .soloforge/waiver_audit.jsonl(由 WaiverStore 管理)
|
|
13
|
+
*
|
|
14
|
+
* 防后门(契约承诺 docs/SoloForge-设计文档.md「误判时有解除机制,并留下审计记录」):
|
|
15
|
+
* 1. NON_WAIVABLE_CHECK_IDS:artifact_exists/bundle_integrity/gate_engine 合成结构检查不可豁免
|
|
16
|
+
* 2. block_check:反退化硬门禁不可豁免(防"前详后空"退化被绕过)
|
|
17
|
+
* 3. confirm=true + reason≥10字符:强制人工确认 + 说明(防敷衍/社交工程绕过)
|
|
18
|
+
* 4. scope=check_id 每域≤3:防域内全局豁免滥用
|
|
19
|
+
* 5. 全程审计:create/remove 写 waiver_audit.jsonl;sf_doctor 展示 active waivers(不隐性)
|
|
20
|
+
*/
|
|
21
|
+
import { z } from "zod";
|
|
22
|
+
import { createToolRegistrar } from "./middleware.js";
|
|
23
|
+
import { SF_WAIVER_ACTIONS } from "../../gate/contracts/tool_actions.js";
|
|
24
|
+
import { WaiverStore, generateWaiverId, NON_WAIVABLE_CHECK_IDS } from "../../core/waiver_store.js";
|
|
25
|
+
import { buildGateFromRegistry } from "../../gate/gate_registry_bridge.js";
|
|
26
|
+
import { computeRulesetHash } from "../../gate/gate_engine.js";
|
|
27
|
+
/** sf_waiver 参数 schema */
|
|
28
|
+
const sfWaiverSchema = {
|
|
29
|
+
action: z.enum(SF_WAIVER_ACTIONS).describe("动作:waive=创建豁免 / list=列出活跃豁免 / remove=撤销豁免"),
|
|
30
|
+
domain: z.enum(["design", "build", "verify", "operate"]).optional().describe("域(waive/list 必填)"),
|
|
31
|
+
check_id: z.string().optional().describe("被豁免的 check id(waive 必填)"),
|
|
32
|
+
artifact_path: z.string().optional().describe("产物路径(scope=exact 时必填)"),
|
|
33
|
+
scope: z.enum(["exact", "check_id"]).optional().describe("豁免范围:exact=某产物某 check(默认)/ check_id=该 check 在该域所有产物"),
|
|
34
|
+
reason: z.string().optional().describe("豁免理由(waive 必填,≥10 字符;说明为何是误报,审计可追溯)"),
|
|
35
|
+
waiver_id: z.string().optional().describe("要撤销的豁免 id(remove 必填)"),
|
|
36
|
+
// 安全门控
|
|
37
|
+
confirm: z.boolean().optional().describe("waive/remove 必须传 true"),
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* sf_waiver 动作处理(handler 逻辑,提取为独立函数便于单测,仿 sf_task handleReset 模式)。
|
|
41
|
+
* @param args - 工具参数(action/domain/check_id/artifact_path/scope/reason/waiver_id/confirm)
|
|
42
|
+
* @param projectRoot - 项目根目录
|
|
43
|
+
*/
|
|
44
|
+
export async function handleWaiverAction(args, projectRoot) {
|
|
45
|
+
const action = args.action;
|
|
46
|
+
try {
|
|
47
|
+
const store = new WaiverStore(projectRoot);
|
|
48
|
+
// ── list:列出活跃豁免(可选按域过滤)──
|
|
49
|
+
if (action === "list") {
|
|
50
|
+
const domain = args.domain;
|
|
51
|
+
const waivers = await store.listActive(domain);
|
|
52
|
+
return { result: { success: true, count: waivers.length, waivers } };
|
|
53
|
+
}
|
|
54
|
+
// ── waive:创建豁免 ──
|
|
55
|
+
if (action === "waive") {
|
|
56
|
+
if (args.confirm !== true) {
|
|
57
|
+
return { result: { error: "sf_waiver waive 必须传入 confirm=true。" } };
|
|
58
|
+
}
|
|
59
|
+
const domain = args.domain;
|
|
60
|
+
if (!domain || !args.check_id || !args.reason) {
|
|
61
|
+
return { result: { error: "waive 时 domain/check_id/reason 必填" } };
|
|
62
|
+
}
|
|
63
|
+
// 防后门 1:合成结构检查不可豁免(硬规则优先挡,不依赖 reason——不可豁免的 check 无需用户编理由)
|
|
64
|
+
if (NON_WAIVABLE_CHECK_IDS.has(String(args.check_id))) {
|
|
65
|
+
return { result: { error: `check ${args.check_id} 为结构性硬检查(产物存在/完整性/引擎异常),不可豁免——须修复根因` } };
|
|
66
|
+
}
|
|
67
|
+
// 防敷衍:reason 须实质说明为何误报
|
|
68
|
+
if (String(args.reason).trim().length < 10) {
|
|
69
|
+
return { result: { error: "reason 至少 10 个字符——须说明为何是误报(审计可追溯,防敷衍/社交工程绕过)" } };
|
|
70
|
+
}
|
|
71
|
+
const scope = (args.scope ?? "exact");
|
|
72
|
+
if (scope === "exact" && !args.artifact_path) {
|
|
73
|
+
return { result: { error: "scope=exact 时 artifact_path 必填(精确豁免某产物某 check);若要域内全局豁免用 scope=check_id" } };
|
|
74
|
+
}
|
|
75
|
+
// 防后门 4:scope=check_id 每域≤3(防域内全局豁免滥用)
|
|
76
|
+
if (scope === "check_id") {
|
|
77
|
+
const wide = await store.countCheckIdWide(domain);
|
|
78
|
+
if (wide >= 3) {
|
|
79
|
+
return { result: { error: `域 ${domain} 已有 ${wide} 个 check_id-wide 豁免(上限 3)——请改用 scope=exact 精确豁免,或修复规则本身` } };
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
// 防后门 2:block_check 反退化硬门禁不可豁免(查 gate 定义)
|
|
83
|
+
const gates = buildGateFromRegistry(domain, projectRoot);
|
|
84
|
+
const targetCheck = gates.flatMap((g) => g.checks).find((c) => c.id === args.check_id);
|
|
85
|
+
if (targetCheck?.block_check) {
|
|
86
|
+
return { result: { error: `check ${args.check_id} 为 block_check 反退化硬门禁,不可豁免——防止"前详后空"结构退化被绕过` } };
|
|
87
|
+
}
|
|
88
|
+
// 通过全部校验 → 创建(快照 check_name + ruleset_hash 供 doctor 漂移检测)
|
|
89
|
+
const record = await store.create({
|
|
90
|
+
waiver_id: generateWaiverId(),
|
|
91
|
+
domain,
|
|
92
|
+
artifact_path: scope === "exact" ? args.artifact_path : undefined,
|
|
93
|
+
check_id: String(args.check_id),
|
|
94
|
+
check_name: targetCheck?.name,
|
|
95
|
+
scope,
|
|
96
|
+
reason: String(args.reason).trim(),
|
|
97
|
+
created_at: Date.now(),
|
|
98
|
+
created_by: "user",
|
|
99
|
+
ruleset_hash_at_creation: computeRulesetHash(domain, projectRoot),
|
|
100
|
+
});
|
|
101
|
+
return {
|
|
102
|
+
result: {
|
|
103
|
+
success: true,
|
|
104
|
+
waiver_id: record.waiver_id,
|
|
105
|
+
message: `已豁免 ${args.check_id}(scope=${scope})。下次 verify 起 waived 不阻断推进,但 finding 仍记录(标 waived=true)。请定期用 sf_doctor 复核活跃豁免。`,
|
|
106
|
+
},
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
// ── remove:撤销豁免(幂等)──
|
|
110
|
+
if (action === "remove") {
|
|
111
|
+
if (args.confirm !== true) {
|
|
112
|
+
return { result: { error: "sf_waiver remove 必须传入 confirm=true。" } };
|
|
113
|
+
}
|
|
114
|
+
if (!args.waiver_id) {
|
|
115
|
+
return { result: { error: "remove 时 waiver_id 必填" } };
|
|
116
|
+
}
|
|
117
|
+
const ok = await store.remove(String(args.waiver_id), args.reason);
|
|
118
|
+
if (!ok) {
|
|
119
|
+
return { result: { error: `未找到 waiver_id=${args.waiver_id}(可能已撤销或不存在)` } };
|
|
120
|
+
}
|
|
121
|
+
return { result: { success: true, message: `已撤销豁免 ${args.waiver_id},下次 verify 起恢复阻断` } };
|
|
122
|
+
}
|
|
123
|
+
return { result: { error: `未知 action: ${action}` } };
|
|
124
|
+
}
|
|
125
|
+
catch (err) {
|
|
126
|
+
return {
|
|
127
|
+
result: {
|
|
128
|
+
success: false,
|
|
129
|
+
error: `sf_waiver ${action} 失败:${err instanceof Error ? err.message : String(err)}`,
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
export async function registerSfWaiverTools(ctx) {
|
|
135
|
+
const { registerSafeTool } = createToolRegistrar(ctx);
|
|
136
|
+
const projectRoot = ctx.projectPath;
|
|
137
|
+
registerSafeTool("sf_waiver", "门禁豁免管理。waive:创建豁免(需 confirm=true,reason≥10字符,安全类 check/block_check 不可豁免)。list:列出活跃豁免。remove:撤销豁免(需 confirm=true)。", sfWaiverSchema, async (args) => handleWaiverAction(args, projectRoot));
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=sf_waiver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sf_waiver.js","sourceRoot":"","sources":["../../../src/server/tools/sf_waiver.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,5 +12,199 @@
|
|
|
12
12
|
* 持久化:verify 时写 GateRecord
|
|
13
13
|
*/
|
|
14
14
|
import type { ToolRegistrationContext } from "./middleware.js";
|
|
15
|
+
import { DomainRegistry } from "../../domain/registry.js";
|
|
16
|
+
import type { TaskContextManager } from "../../core/task_context.js";
|
|
17
|
+
import type { TaskContext } from "../../types/index.js";
|
|
18
|
+
import { type ReviewFinding } from "../../core/adversarial_review_store.js";
|
|
15
19
|
export declare function registerSfWorkTools(ctx: ToolRegistrationContext): Promise<void>;
|
|
20
|
+
/** act:组装 prompt */
|
|
21
|
+
export declare function handleAct(engine: ReturnType<DomainRegistry["get"]>, task: TaskContext, args: Record<string, unknown>, projectRoot: string): Promise<{
|
|
22
|
+
result: {
|
|
23
|
+
success: boolean;
|
|
24
|
+
error: string;
|
|
25
|
+
gate_blocked?: undefined;
|
|
26
|
+
recovery_guide?: undefined;
|
|
27
|
+
next_domain?: undefined;
|
|
28
|
+
next_step?: undefined;
|
|
29
|
+
prompt?: undefined;
|
|
30
|
+
template?: undefined;
|
|
31
|
+
scope?: undefined;
|
|
32
|
+
self_review_checklist?: undefined;
|
|
33
|
+
};
|
|
34
|
+
} | {
|
|
35
|
+
result: {
|
|
36
|
+
success: boolean;
|
|
37
|
+
error: string;
|
|
38
|
+
gate_blocked: boolean;
|
|
39
|
+
recovery_guide: {
|
|
40
|
+
summary: string;
|
|
41
|
+
steps: string[];
|
|
42
|
+
example_call: unknown;
|
|
43
|
+
bypass_condition: string;
|
|
44
|
+
} | undefined;
|
|
45
|
+
next_domain: string | undefined;
|
|
46
|
+
next_step: string;
|
|
47
|
+
prompt?: undefined;
|
|
48
|
+
template?: undefined;
|
|
49
|
+
scope?: undefined;
|
|
50
|
+
self_review_checklist?: undefined;
|
|
51
|
+
};
|
|
52
|
+
} | {
|
|
53
|
+
result: {
|
|
54
|
+
success: boolean;
|
|
55
|
+
gate_blocked: boolean;
|
|
56
|
+
error: string;
|
|
57
|
+
next_step: string;
|
|
58
|
+
recovery_guide?: undefined;
|
|
59
|
+
next_domain?: undefined;
|
|
60
|
+
prompt?: undefined;
|
|
61
|
+
template?: undefined;
|
|
62
|
+
scope?: undefined;
|
|
63
|
+
self_review_checklist?: undefined;
|
|
64
|
+
};
|
|
65
|
+
} | {
|
|
66
|
+
result: {
|
|
67
|
+
success: boolean;
|
|
68
|
+
prompt: string;
|
|
69
|
+
template: string;
|
|
70
|
+
scope: {
|
|
71
|
+
allowed_paths: string[];
|
|
72
|
+
read_only_paths: string[];
|
|
73
|
+
};
|
|
74
|
+
self_review_checklist: {
|
|
75
|
+
id: string;
|
|
76
|
+
title: string;
|
|
77
|
+
}[];
|
|
78
|
+
next_step: string;
|
|
79
|
+
error?: undefined;
|
|
80
|
+
gate_blocked?: undefined;
|
|
81
|
+
recovery_guide?: undefined;
|
|
82
|
+
next_domain?: undefined;
|
|
83
|
+
};
|
|
84
|
+
}>;
|
|
85
|
+
/** deliberate:组装产出前条件研讨 prompt(有疑问才触发头脑风暴+第一性原理,无疑问举证一行)。
|
|
86
|
+
* 产出研讨记录到 docs/deliberation/{domain}/{kind}-研讨记录.md,供后续 act 承接。
|
|
87
|
+
* SoloForge 不调 LLM——只组装 prompt,AI 自己写研讨记录。 */
|
|
88
|
+
export declare function handleDeliberate(engine: ReturnType<DomainRegistry["get"]>, task: TaskContext, args: Record<string, unknown>, projectRoot: string): Promise<{
|
|
89
|
+
result: {
|
|
90
|
+
success: boolean;
|
|
91
|
+
error: string;
|
|
92
|
+
prompt?: undefined;
|
|
93
|
+
template?: undefined;
|
|
94
|
+
scope?: undefined;
|
|
95
|
+
next_step?: undefined;
|
|
96
|
+
};
|
|
97
|
+
} | {
|
|
98
|
+
result: {
|
|
99
|
+
success: boolean;
|
|
100
|
+
prompt: string;
|
|
101
|
+
template: string;
|
|
102
|
+
scope: {
|
|
103
|
+
allowed_paths: string[];
|
|
104
|
+
read_only_paths: string[];
|
|
105
|
+
};
|
|
106
|
+
next_step: string;
|
|
107
|
+
error?: undefined;
|
|
108
|
+
};
|
|
109
|
+
}>;
|
|
110
|
+
/** adversarial_review:对抗性独立审查(per-artifact 单产物 / cross-artifact 跨产物一致性)。
|
|
111
|
+
* SoloForge 不调 LLM——只组装 prompt 返回,AI 用独立 session/subagent 执行(避免确认偏见)。
|
|
112
|
+
* K 次独立采样取交集:K=REVIEW_SAMPLE_K 轮独立审查,每轮不参考前轮结论,完成后取多数交集。
|
|
113
|
+
* 确定性边界原则:findings 留痕不阻断——放弃"零 error 收敛"(LLM 裁判不可收敛),act 只校验"审过"。
|
|
114
|
+
* 多利益方独立对抗:用户/攻击者/维护者/性能/合规 各自独立目标函数,避免单一视角确认偏见。 */
|
|
115
|
+
export declare function handleAdversarialReview(projectRoot: string, task: TaskContext, args: Record<string, unknown>, _taskContext: TaskContextManager): Promise<{
|
|
116
|
+
result: {
|
|
117
|
+
success: boolean;
|
|
118
|
+
action: string;
|
|
119
|
+
review_id: string;
|
|
120
|
+
round: number;
|
|
121
|
+
mode: "per_artifact" | "cross_artifact";
|
|
122
|
+
review_mode: string;
|
|
123
|
+
artifact_count: number;
|
|
124
|
+
artifacts: string[];
|
|
125
|
+
prompt: string;
|
|
126
|
+
next_step: string;
|
|
127
|
+
error?: undefined;
|
|
128
|
+
review_status?: undefined;
|
|
129
|
+
sample_k?: undefined;
|
|
130
|
+
round_summary?: undefined;
|
|
131
|
+
intersection_count?: undefined;
|
|
132
|
+
intersection_findings?: undefined;
|
|
133
|
+
retained_count?: undefined;
|
|
134
|
+
completed?: undefined;
|
|
135
|
+
rounds_completed?: undefined;
|
|
136
|
+
};
|
|
137
|
+
} | {
|
|
138
|
+
result: {
|
|
139
|
+
success: boolean;
|
|
140
|
+
error: string;
|
|
141
|
+
action?: undefined;
|
|
142
|
+
review_id?: undefined;
|
|
143
|
+
round?: undefined;
|
|
144
|
+
mode?: undefined;
|
|
145
|
+
review_mode?: undefined;
|
|
146
|
+
artifact_count?: undefined;
|
|
147
|
+
artifacts?: undefined;
|
|
148
|
+
prompt?: undefined;
|
|
149
|
+
next_step?: undefined;
|
|
150
|
+
review_status?: undefined;
|
|
151
|
+
sample_k?: undefined;
|
|
152
|
+
round_summary?: undefined;
|
|
153
|
+
intersection_count?: undefined;
|
|
154
|
+
intersection_findings?: undefined;
|
|
155
|
+
retained_count?: undefined;
|
|
156
|
+
completed?: undefined;
|
|
157
|
+
rounds_completed?: undefined;
|
|
158
|
+
};
|
|
159
|
+
} | {
|
|
160
|
+
result: {
|
|
161
|
+
success: boolean;
|
|
162
|
+
action: string;
|
|
163
|
+
review_id: string;
|
|
164
|
+
round: number;
|
|
165
|
+
review_status: string;
|
|
166
|
+
sample_k: number;
|
|
167
|
+
round_summary: {
|
|
168
|
+
errors: number;
|
|
169
|
+
warnings: number;
|
|
170
|
+
};
|
|
171
|
+
intersection_count: number;
|
|
172
|
+
intersection_findings: ReviewFinding[];
|
|
173
|
+
retained_count: number;
|
|
174
|
+
completed: boolean;
|
|
175
|
+
next_step: string;
|
|
176
|
+
mode?: undefined;
|
|
177
|
+
review_mode?: undefined;
|
|
178
|
+
artifact_count?: undefined;
|
|
179
|
+
artifacts?: undefined;
|
|
180
|
+
prompt?: undefined;
|
|
181
|
+
error?: undefined;
|
|
182
|
+
rounds_completed?: undefined;
|
|
183
|
+
};
|
|
184
|
+
} | {
|
|
185
|
+
result: {
|
|
186
|
+
success: boolean;
|
|
187
|
+
action: string;
|
|
188
|
+
review_id: string;
|
|
189
|
+
round: number;
|
|
190
|
+
review_status: string;
|
|
191
|
+
rounds_completed: number;
|
|
192
|
+
sample_k: number;
|
|
193
|
+
round_summary: {
|
|
194
|
+
errors: number;
|
|
195
|
+
warnings: number;
|
|
196
|
+
};
|
|
197
|
+
prompt: string;
|
|
198
|
+
next_step: string;
|
|
199
|
+
mode?: undefined;
|
|
200
|
+
review_mode?: undefined;
|
|
201
|
+
artifact_count?: undefined;
|
|
202
|
+
artifacts?: undefined;
|
|
203
|
+
error?: undefined;
|
|
204
|
+
intersection_count?: undefined;
|
|
205
|
+
intersection_findings?: undefined;
|
|
206
|
+
retained_count?: undefined;
|
|
207
|
+
completed?: undefined;
|
|
208
|
+
};
|
|
209
|
+
}>;
|
|
16
210
|
//# sourceMappingURL=sf_work.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sf_work.d.ts","sourceRoot":"","sources":["../../../src/server/tools/sf_work.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;
|
|
1
|
+
{"version":3,"file":"sf_work.d.ts","sourceRoot":"","sources":["../../../src/server/tools/sf_work.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAKH,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAG/D,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAML,KAAK,aAAa,EAGnB,MAAM,wCAAwC,CAAC;AAkChD,wBAAsB,mBAAmB,CAAC,GAAG,EAAE,uBAAuB,GAAG,OAAO,CAAC,IAAI,CAAC,CA8ErF;AAoCD,oBAAoB;AACpB,wBAAsB,SAAS,CAC7B,MAAM,EAAE,UAAU,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EACzC,IAAI,EAAE,WAAW,EACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,WAAW,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2LpB;AAED;;+CAE+C;AAC/C,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,UAAU,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EACzC,IAAI,EAAE,WAAW,EACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,WAAW,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;GAmBpB;AAsUD;;;;qDAIqD;AACrD,wBAAsB,uBAAuB,CAC3C,WAAW,EAAE,MAAM,EACnB,IAAI,EAAE,WAAW,EACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,YAAY,EAAE,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmHjC"}
|