@namzu/sdk 0.1.3 → 0.1.4-rc.2
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/CHANGELOG.md +45 -29
- package/README.md +14 -2
- package/dist/advisory/context.d.ts +23 -0
- package/dist/advisory/context.d.ts.map +1 -0
- package/dist/advisory/context.js +33 -0
- package/dist/advisory/context.js.map +1 -0
- package/dist/advisory/evaluator.d.ts +14 -0
- package/dist/advisory/evaluator.d.ts.map +1 -0
- package/dist/advisory/evaluator.js +87 -0
- package/dist/advisory/evaluator.js.map +1 -0
- package/dist/advisory/executor.d.ts +40 -0
- package/dist/advisory/executor.d.ts.map +1 -0
- package/dist/advisory/executor.js +132 -0
- package/dist/advisory/executor.js.map +1 -0
- package/dist/advisory/index.d.ts +6 -0
- package/dist/advisory/index.d.ts.map +1 -0
- package/dist/advisory/index.js +5 -0
- package/dist/advisory/index.js.map +1 -0
- package/dist/advisory/registry.d.ts +14 -0
- package/dist/advisory/registry.d.ts.map +1 -0
- package/dist/advisory/registry.js +36 -0
- package/dist/advisory/registry.js.map +1 -0
- package/dist/agents/ReactiveAgent.d.ts.map +1 -1
- package/dist/agents/ReactiveAgent.js +1 -0
- package/dist/agents/ReactiveAgent.js.map +1 -1
- package/dist/agents/SupervisorAgent.d.ts.map +1 -1
- package/dist/agents/SupervisorAgent.js +12 -1
- package/dist/agents/SupervisorAgent.js.map +1 -1
- package/dist/bridge/a2a/mapper.d.ts.map +1 -1
- package/dist/bridge/a2a/mapper.js +2 -0
- package/dist/bridge/a2a/mapper.js.map +1 -1
- package/dist/bridge/sse/mapper.d.ts.map +1 -1
- package/dist/bridge/sse/mapper.js +17 -0
- package/dist/bridge/sse/mapper.js.map +1 -1
- package/dist/bus/breaker.d.ts +18 -0
- package/dist/bus/breaker.d.ts.map +1 -0
- package/dist/bus/breaker.js +158 -0
- package/dist/bus/breaker.js.map +1 -0
- package/dist/bus/index.d.ts +33 -0
- package/dist/bus/index.d.ts.map +1 -0
- package/dist/bus/index.js +72 -0
- package/dist/bus/index.js.map +1 -0
- package/dist/bus/lock.d.ts +27 -0
- package/dist/bus/lock.d.ts.map +1 -0
- package/dist/bus/lock.js +194 -0
- package/dist/bus/lock.js.map +1 -0
- package/dist/bus/ownership.d.ts +18 -0
- package/dist/bus/ownership.d.ts.map +1 -0
- package/dist/bus/ownership.js +111 -0
- package/dist/bus/ownership.js.map +1 -0
- package/dist/compaction/extractor.d.ts +7 -0
- package/dist/compaction/extractor.d.ts.map +1 -0
- package/dist/compaction/extractor.js +131 -0
- package/dist/compaction/extractor.js.map +1 -0
- package/dist/compaction/index.d.ts +6 -0
- package/dist/compaction/index.d.ts.map +1 -0
- package/dist/compaction/index.js +5 -0
- package/dist/compaction/index.js.map +1 -0
- package/dist/compaction/manager.d.ts +22 -0
- package/dist/compaction/manager.d.ts.map +1 -0
- package/dist/compaction/manager.js +91 -0
- package/dist/compaction/manager.js.map +1 -0
- package/dist/compaction/serializer.d.ts +3 -0
- package/dist/compaction/serializer.d.ts.map +1 -0
- package/dist/compaction/serializer.js +67 -0
- package/dist/compaction/serializer.js.map +1 -0
- package/dist/compaction/types.d.ts +40 -0
- package/dist/compaction/types.d.ts.map +1 -0
- package/dist/compaction/types.js +2 -0
- package/dist/compaction/types.js.map +1 -0
- package/dist/compaction/verifier.d.ts +6 -0
- package/dist/compaction/verifier.d.ts.map +1 -0
- package/dist/compaction/verifier.js +68 -0
- package/dist/compaction/verifier.js.map +1 -0
- package/dist/config/runtime.d.ts +328 -0
- package/dist/config/runtime.d.ts.map +1 -1
- package/dist/config/runtime.js +51 -0
- package/dist/config/runtime.js.map +1 -1
- package/dist/constants/advisory/index.d.ts +8 -0
- package/dist/constants/advisory/index.d.ts.map +1 -0
- package/dist/constants/advisory/index.js +8 -0
- package/dist/constants/advisory/index.js.map +1 -0
- package/dist/constants/bus/index.d.ts +7 -0
- package/dist/constants/bus/index.d.ts.map +1 -0
- package/dist/constants/bus/index.js +7 -0
- package/dist/constants/bus/index.js.map +1 -0
- package/dist/constants/compaction/index.d.ts +17 -0
- package/dist/constants/compaction/index.d.ts.map +1 -0
- package/dist/constants/compaction/index.js +17 -0
- package/dist/constants/compaction/index.js.map +1 -0
- package/dist/constants/emergency.d.ts +4 -0
- package/dist/constants/emergency.d.ts.map +1 -0
- package/dist/constants/emergency.js +4 -0
- package/dist/constants/emergency.js.map +1 -0
- package/dist/constants/index.d.ts +6 -0
- package/dist/constants/index.d.ts.map +1 -1
- package/dist/constants/index.js +6 -0
- package/dist/constants/index.js.map +1 -1
- package/dist/constants/limits.d.ts +1 -0
- package/dist/constants/limits.d.ts.map +1 -1
- package/dist/constants/limits.js +1 -0
- package/dist/constants/limits.js.map +1 -1
- package/dist/constants/plugin/index.d.ts +21 -0
- package/dist/constants/plugin/index.d.ts.map +1 -0
- package/dist/constants/plugin/index.js +21 -0
- package/dist/constants/plugin/index.js.map +1 -0
- package/dist/constants/verification/index.d.ts +2 -0
- package/dist/constants/verification/index.d.ts.map +1 -0
- package/dist/constants/verification/index.js +2 -0
- package/dist/constants/verification/index.js.map +1 -0
- package/dist/contracts/api.d.ts +1 -1
- package/dist/contracts/api.d.ts.map +1 -1
- package/dist/contracts/schemas.d.ts +20 -20
- package/dist/index.d.ts +24 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -1
- package/dist/index.js.map +1 -1
- package/dist/manager/run/emergency.d.ts +19 -0
- package/dist/manager/run/emergency.d.ts.map +1 -0
- package/dist/manager/run/emergency.js +88 -0
- package/dist/manager/run/emergency.js.map +1 -0
- package/dist/manager/run/persistence.d.ts +2 -0
- package/dist/manager/run/persistence.d.ts.map +1 -1
- package/dist/manager/run/persistence.js +14 -0
- package/dist/manager/run/persistence.js.map +1 -1
- package/dist/persona/assembler.d.ts +2 -1
- package/dist/persona/assembler.d.ts.map +1 -1
- package/dist/persona/assembler.js +23 -0
- package/dist/persona/assembler.js.map +1 -1
- package/dist/plugin/index.d.ts +4 -0
- package/dist/plugin/index.d.ts.map +1 -0
- package/dist/plugin/index.js +4 -0
- package/dist/plugin/index.js.map +1 -0
- package/dist/plugin/lifecycle.d.ts +30 -0
- package/dist/plugin/lifecycle.d.ts.map +1 -0
- package/dist/plugin/lifecycle.js +227 -0
- package/dist/plugin/lifecycle.js.map +1 -0
- package/dist/plugin/loader.d.ts +25 -0
- package/dist/plugin/loader.d.ts.map +1 -0
- package/dist/plugin/loader.js +76 -0
- package/dist/plugin/loader.js.map +1 -0
- package/dist/plugin/resolver.d.ts +36 -0
- package/dist/plugin/resolver.d.ts.map +1 -0
- package/dist/plugin/resolver.js +80 -0
- package/dist/plugin/resolver.js.map +1 -0
- package/dist/registry/plugin/index.d.ts +9 -0
- package/dist/registry/plugin/index.d.ts.map +1 -0
- package/dist/registry/plugin/index.js +16 -0
- package/dist/registry/plugin/index.js.map +1 -0
- package/dist/registry/tool/execute.d.ts +3 -0
- package/dist/registry/tool/execute.d.ts.map +1 -1
- package/dist/registry/tool/execute.js +45 -11
- package/dist/registry/tool/execute.js.map +1 -1
- package/dist/router/index.d.ts +2 -0
- package/dist/router/index.d.ts.map +1 -0
- package/dist/router/index.js +2 -0
- package/dist/router/index.js.map +1 -0
- package/dist/router/task-router.d.ts +8 -0
- package/dist/router/task-router.d.ts.map +1 -0
- package/dist/router/task-router.js +19 -0
- package/dist/router/task-router.js.map +1 -0
- package/dist/run/reporter.d.ts.map +1 -1
- package/dist/run/reporter.js +15 -0
- package/dist/run/reporter.js.map +1 -1
- package/dist/runtime/query/context-cache.d.ts +6 -0
- package/dist/runtime/query/context-cache.d.ts.map +1 -1
- package/dist/runtime/query/context-cache.js +36 -0
- package/dist/runtime/query/context-cache.js.map +1 -1
- package/dist/runtime/query/executor.d.ts +4 -0
- package/dist/runtime/query/executor.d.ts.map +1 -1
- package/dist/runtime/query/executor.js +30 -1
- package/dist/runtime/query/executor.js.map +1 -1
- package/dist/runtime/query/index.d.ts +10 -0
- package/dist/runtime/query/index.d.ts.map +1 -1
- package/dist/runtime/query/index.js +77 -12
- package/dist/runtime/query/index.js.map +1 -1
- package/dist/runtime/query/iteration/index.d.ts +9 -0
- package/dist/runtime/query/iteration/index.d.ts.map +1 -1
- package/dist/runtime/query/iteration/index.js +40 -0
- package/dist/runtime/query/iteration/index.js.map +1 -1
- package/dist/runtime/query/iteration/phases/advisory.d.ts +4 -0
- package/dist/runtime/query/iteration/phases/advisory.d.ts.map +1 -0
- package/dist/runtime/query/iteration/phases/advisory.js +150 -0
- package/dist/runtime/query/iteration/phases/advisory.js.map +1 -0
- package/dist/runtime/query/iteration/phases/compaction.d.ts +3 -0
- package/dist/runtime/query/iteration/phases/compaction.d.ts.map +1 -0
- package/dist/runtime/query/iteration/phases/compaction.js +87 -0
- package/dist/runtime/query/iteration/phases/compaction.js.map +1 -0
- package/dist/runtime/query/iteration/phases/context.d.ts +10 -0
- package/dist/runtime/query/iteration/phases/context.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/context.js.map +1 -1
- package/dist/runtime/query/iteration/phases/index.d.ts +2 -0
- package/dist/runtime/query/iteration/phases/index.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/index.js +2 -0
- package/dist/runtime/query/iteration/phases/index.js.map +1 -1
- package/dist/runtime/query/iteration/phases/tool-review.d.ts +6 -1
- package/dist/runtime/query/iteration/phases/tool-review.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/tool-review.js +39 -0
- package/dist/runtime/query/iteration/phases/tool-review.js.map +1 -1
- package/dist/runtime/query/prompt.d.ts +7 -0
- package/dist/runtime/query/prompt.d.ts.map +1 -1
- package/dist/runtime/query/prompt.js +44 -0
- package/dist/runtime/query/prompt.js.map +1 -1
- package/dist/store/memory/disk.d.ts +30 -0
- package/dist/store/memory/disk.d.ts.map +1 -0
- package/dist/store/memory/disk.js +154 -0
- package/dist/store/memory/disk.js.map +1 -0
- package/dist/store/memory/index.d.ts +13 -0
- package/dist/store/memory/index.d.ts.map +1 -0
- package/dist/store/memory/index.js +46 -0
- package/dist/store/memory/index.js.map +1 -0
- package/dist/store/memory/memory.d.ts +17 -0
- package/dist/store/memory/memory.d.ts.map +1 -0
- package/dist/store/memory/memory.js +72 -0
- package/dist/store/memory/memory.js.map +1 -0
- package/dist/tools/advisory/index.d.ts +7 -0
- package/dist/tools/advisory/index.d.ts.map +1 -0
- package/dist/tools/advisory/index.js +125 -0
- package/dist/tools/advisory/index.js.map +1 -0
- package/dist/tools/defineTool.d.ts +1 -0
- package/dist/tools/defineTool.d.ts.map +1 -1
- package/dist/tools/defineTool.js +1 -0
- package/dist/tools/defineTool.js.map +1 -1
- package/dist/tools/memory/index.d.ts +7 -0
- package/dist/tools/memory/index.d.ts.map +1 -0
- package/dist/tools/memory/index.js +10 -0
- package/dist/tools/memory/index.js.map +1 -0
- package/dist/tools/memory/read.d.ts +4 -0
- package/dist/tools/memory/read.d.ts.map +1 -0
- package/dist/tools/memory/read.js +37 -0
- package/dist/tools/memory/read.js.map +1 -0
- package/dist/tools/memory/save.d.ts +4 -0
- package/dist/tools/memory/save.d.ts.map +1 -0
- package/dist/tools/memory/save.js +37 -0
- package/dist/tools/memory/save.js.map +1 -0
- package/dist/tools/memory/search.d.ts +4 -0
- package/dist/tools/memory/search.d.ts.map +1 -0
- package/dist/tools/memory/search.js +41 -0
- package/dist/tools/memory/search.js.map +1 -0
- package/dist/types/advisory/config.d.ts +33 -0
- package/dist/types/advisory/config.d.ts.map +1 -0
- package/dist/types/advisory/config.js +2 -0
- package/dist/types/advisory/config.js.map +1 -0
- package/dist/types/advisory/index.d.ts +4 -0
- package/dist/types/advisory/index.d.ts.map +1 -0
- package/dist/types/advisory/index.js +2 -0
- package/dist/types/advisory/index.js.map +1 -0
- package/dist/types/advisory/result.d.ts +35 -0
- package/dist/types/advisory/result.d.ts.map +1 -0
- package/dist/types/advisory/result.js +2 -0
- package/dist/types/advisory/result.js.map +1 -0
- package/dist/types/advisory/trigger.d.ts +44 -0
- package/dist/types/advisory/trigger.d.ts.map +1 -0
- package/dist/types/advisory/trigger.js +2 -0
- package/dist/types/advisory/trigger.js.map +1 -0
- package/dist/types/agent/factory.d.ts +2 -0
- package/dist/types/agent/factory.d.ts.map +1 -1
- package/dist/types/agent/reactive.d.ts +2 -0
- package/dist/types/agent/reactive.d.ts.map +1 -1
- package/dist/types/agent/supervisor.d.ts +4 -0
- package/dist/types/agent/supervisor.d.ts.map +1 -1
- package/dist/types/bus/index.d.ts +96 -0
- package/dist/types/bus/index.d.ts.map +1 -0
- package/dist/types/bus/index.js +2 -0
- package/dist/types/bus/index.js.map +1 -0
- package/dist/types/ids/index.d.ts +6 -0
- package/dist/types/ids/index.d.ts.map +1 -1
- package/dist/types/memory/index.d.ts +54 -0
- package/dist/types/memory/index.d.ts.map +1 -0
- package/dist/types/memory/index.js +12 -0
- package/dist/types/memory/index.js.map +1 -0
- package/dist/types/message/index.d.ts +3 -1
- package/dist/types/message/index.d.ts.map +1 -1
- package/dist/types/message/index.js +7 -2
- package/dist/types/message/index.js.map +1 -1
- package/dist/types/persona/index.d.ts +9 -0
- package/dist/types/persona/index.d.ts.map +1 -1
- package/dist/types/plugin/index.d.ts +186 -0
- package/dist/types/plugin/index.d.ts.map +1 -0
- package/dist/types/plugin/index.js +90 -0
- package/dist/types/plugin/index.js.map +1 -0
- package/dist/types/router/index.d.ts +2 -0
- package/dist/types/router/index.d.ts.map +1 -0
- package/dist/types/router/index.js +2 -0
- package/dist/types/router/index.js.map +1 -0
- package/dist/types/router/task-router.d.ts +12 -0
- package/dist/types/router/task-router.d.ts.map +1 -0
- package/dist/types/router/task-router.js +2 -0
- package/dist/types/router/task-router.js.map +1 -0
- package/dist/types/run/emergency.d.ts +27 -0
- package/dist/types/run/emergency.d.ts.map +1 -0
- package/dist/types/run/emergency.js +6 -0
- package/dist/types/run/emergency.js.map +1 -0
- package/dist/types/run/events.d.ts +13 -1
- package/dist/types/run/events.d.ts.map +1 -1
- package/dist/types/run/index.d.ts +1 -0
- package/dist/types/run/index.d.ts.map +1 -1
- package/dist/types/run/index.js +1 -0
- package/dist/types/run/index.js.map +1 -1
- package/dist/types/tool/index.d.ts +13 -0
- package/dist/types/tool/index.d.ts.map +1 -1
- package/dist/types/verification/index.d.ts +219 -0
- package/dist/types/verification/index.d.ts.map +1 -0
- package/dist/types/verification/index.js +43 -0
- package/dist/types/verification/index.js.map +1 -0
- package/dist/utils/id.d.ts +7 -1
- package/dist/utils/id.d.ts.map +1 -1
- package/dist/utils/id.js +18 -0
- package/dist/utils/id.js.map +1 -1
- package/dist/utils/shell-compress.d.ts +13 -0
- package/dist/utils/shell-compress.d.ts.map +1 -0
- package/dist/utils/shell-compress.js +97 -0
- package/dist/utils/shell-compress.js.map +1 -0
- package/dist/verification/gate.d.ts +19 -0
- package/dist/verification/gate.d.ts.map +1 -0
- package/dist/verification/gate.js +103 -0
- package/dist/verification/gate.js.map +1 -0
- package/dist/verification/index.d.ts +3 -0
- package/dist/verification/index.d.ts.map +1 -0
- package/dist/verification/index.js +3 -0
- package/dist/verification/index.js.map +1 -0
- package/dist/verification/rules.d.ts +4 -0
- package/dist/verification/rules.d.ts.map +1 -0
- package/dist/verification/rules.js +61 -0
- package/dist/verification/rules.js.map +1 -0
- package/package.json +5 -1
- package/src/advisory/context.ts +47 -0
- package/src/advisory/evaluator.ts +98 -0
- package/src/advisory/executor.ts +187 -0
- package/src/advisory/index.ts +5 -0
- package/src/advisory/registry.ts +42 -0
- package/src/agents/ReactiveAgent.ts +1 -0
- package/src/agents/SupervisorAgent.ts +13 -1
- package/src/bridge/a2a/mapper.ts +3 -0
- package/src/bridge/sse/mapper.ts +19 -0
- package/src/bus/breaker.ts +192 -0
- package/src/bus/index.ts +120 -0
- package/src/bus/lock.ts +233 -0
- package/src/bus/ownership.ts +133 -0
- package/src/compaction/extractor.ts +149 -0
- package/src/compaction/index.ts +21 -0
- package/src/compaction/manager.ts +107 -0
- package/src/compaction/serializer.ts +88 -0
- package/src/compaction/types.ts +37 -0
- package/src/compaction/verifier.ts +91 -0
- package/src/config/runtime.ts +64 -0
- package/src/constants/advisory/index.ts +7 -0
- package/src/constants/bus/index.ts +6 -0
- package/src/constants/compaction/index.ts +20 -0
- package/src/constants/emergency.ts +3 -0
- package/src/constants/index.ts +6 -0
- package/src/constants/limits.ts +2 -0
- package/src/constants/plugin/index.ts +25 -0
- package/src/constants/verification/index.ts +1 -0
- package/src/contracts/api.ts +2 -0
- package/src/index.ts +69 -2
- package/src/manager/run/emergency.ts +117 -0
- package/src/manager/run/persistence.ts +16 -0
- package/src/persona/assembler.ts +36 -1
- package/src/plugin/index.ts +3 -0
- package/src/plugin/lifecycle.ts +308 -0
- package/src/plugin/loader.ts +91 -0
- package/src/plugin/resolver.ts +95 -0
- package/src/registry/plugin/index.ts +20 -0
- package/src/registry/tool/execute.ts +51 -11
- package/src/router/index.ts +1 -0
- package/src/router/task-router.ts +24 -0
- package/src/run/reporter.ts +17 -0
- package/src/runtime/query/context-cache.ts +50 -0
- package/src/runtime/query/executor.ts +37 -1
- package/src/runtime/query/index.ts +125 -12
- package/src/runtime/query/iteration/index.ts +60 -0
- package/src/runtime/query/iteration/phases/advisory.ts +185 -0
- package/src/runtime/query/iteration/phases/compaction.ts +98 -0
- package/src/runtime/query/iteration/phases/context.ts +16 -0
- package/src/runtime/query/iteration/phases/index.ts +2 -0
- package/src/runtime/query/iteration/phases/tool-review.ts +52 -1
- package/src/runtime/query/prompt.ts +64 -0
- package/src/store/memory/disk.ts +205 -0
- package/src/store/memory/index.ts +68 -0
- package/src/store/memory/memory.ts +103 -0
- package/src/tools/advisory/index.ts +157 -0
- package/src/tools/defineTool.ts +2 -0
- package/src/tools/memory/index.ts +13 -0
- package/src/tools/memory/read.ts +42 -0
- package/src/tools/memory/save.ts +40 -0
- package/src/tools/memory/search.ts +52 -0
- package/src/types/advisory/config.ts +35 -0
- package/src/types/advisory/index.ts +18 -0
- package/src/types/advisory/result.ts +34 -0
- package/src/types/advisory/trigger.ts +39 -0
- package/src/types/agent/factory.ts +3 -0
- package/src/types/agent/reactive.ts +3 -0
- package/src/types/agent/supervisor.ts +6 -0
- package/src/types/bus/index.ts +53 -0
- package/src/types/ids/index.ts +6 -0
- package/src/types/memory/index.ts +69 -0
- package/src/types/message/index.ts +10 -2
- package/src/types/persona/index.ts +11 -0
- package/src/types/plugin/index.ts +231 -0
- package/src/types/router/index.ts +1 -0
- package/src/types/router/task-router.ts +20 -0
- package/src/types/run/emergency.ts +23 -0
- package/src/types/run/events.ts +15 -1
- package/src/types/run/index.ts +1 -0
- package/src/types/tool/index.ts +15 -0
- package/src/types/verification/index.ts +69 -0
- package/src/utils/id.ts +28 -0
- package/src/utils/shell-compress.ts +137 -0
- package/src/verification/gate.ts +136 -0
- package/src/verification/index.ts +2 -0
- package/src/verification/rules.ts +78 -0
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export type GateDecision = 'allow' | 'deny' | 'review';
|
|
3
|
+
export interface GateEvaluationResult {
|
|
4
|
+
readonly decision: GateDecision;
|
|
5
|
+
readonly matchedRule: VerificationRule | null;
|
|
6
|
+
readonly reason: string;
|
|
7
|
+
}
|
|
8
|
+
export type VerificationRule = {
|
|
9
|
+
type: 'allow_read_only';
|
|
10
|
+
} | {
|
|
11
|
+
type: 'deny_dangerous_patterns';
|
|
12
|
+
} | {
|
|
13
|
+
type: 'allow_by_category';
|
|
14
|
+
categories: string[];
|
|
15
|
+
} | {
|
|
16
|
+
type: 'allow_by_name';
|
|
17
|
+
toolNames: string[];
|
|
18
|
+
} | {
|
|
19
|
+
type: 'deny_by_name';
|
|
20
|
+
toolNames: string[];
|
|
21
|
+
} | {
|
|
22
|
+
type: 'custom_pattern';
|
|
23
|
+
pattern: string;
|
|
24
|
+
target: 'name' | 'args' | 'both';
|
|
25
|
+
decision: 'allow' | 'deny';
|
|
26
|
+
} | {
|
|
27
|
+
type: 'allow_by_tier';
|
|
28
|
+
tiers: string[];
|
|
29
|
+
};
|
|
30
|
+
export declare const VerificationRuleSchema: z.ZodDiscriminatedUnion<"type", [z.ZodObject<{
|
|
31
|
+
type: z.ZodLiteral<"allow_read_only">;
|
|
32
|
+
}, "strip", z.ZodTypeAny, {
|
|
33
|
+
type: "allow_read_only";
|
|
34
|
+
}, {
|
|
35
|
+
type: "allow_read_only";
|
|
36
|
+
}>, z.ZodObject<{
|
|
37
|
+
type: z.ZodLiteral<"deny_dangerous_patterns">;
|
|
38
|
+
}, "strip", z.ZodTypeAny, {
|
|
39
|
+
type: "deny_dangerous_patterns";
|
|
40
|
+
}, {
|
|
41
|
+
type: "deny_dangerous_patterns";
|
|
42
|
+
}>, z.ZodObject<{
|
|
43
|
+
type: z.ZodLiteral<"allow_by_category">;
|
|
44
|
+
categories: z.ZodArray<z.ZodString, "many">;
|
|
45
|
+
}, "strip", z.ZodTypeAny, {
|
|
46
|
+
categories: string[];
|
|
47
|
+
type: "allow_by_category";
|
|
48
|
+
}, {
|
|
49
|
+
categories: string[];
|
|
50
|
+
type: "allow_by_category";
|
|
51
|
+
}>, z.ZodObject<{
|
|
52
|
+
type: z.ZodLiteral<"allow_by_name">;
|
|
53
|
+
toolNames: z.ZodArray<z.ZodString, "many">;
|
|
54
|
+
}, "strip", z.ZodTypeAny, {
|
|
55
|
+
type: "allow_by_name";
|
|
56
|
+
toolNames: string[];
|
|
57
|
+
}, {
|
|
58
|
+
type: "allow_by_name";
|
|
59
|
+
toolNames: string[];
|
|
60
|
+
}>, z.ZodObject<{
|
|
61
|
+
type: z.ZodLiteral<"deny_by_name">;
|
|
62
|
+
toolNames: z.ZodArray<z.ZodString, "many">;
|
|
63
|
+
}, "strip", z.ZodTypeAny, {
|
|
64
|
+
type: "deny_by_name";
|
|
65
|
+
toolNames: string[];
|
|
66
|
+
}, {
|
|
67
|
+
type: "deny_by_name";
|
|
68
|
+
toolNames: string[];
|
|
69
|
+
}>, z.ZodObject<{
|
|
70
|
+
type: z.ZodLiteral<"custom_pattern">;
|
|
71
|
+
pattern: z.ZodString;
|
|
72
|
+
target: z.ZodEnum<["name", "args", "both"]>;
|
|
73
|
+
decision: z.ZodEnum<["allow", "deny"]>;
|
|
74
|
+
}, "strip", z.ZodTypeAny, {
|
|
75
|
+
type: "custom_pattern";
|
|
76
|
+
decision: "allow" | "deny";
|
|
77
|
+
target: "name" | "args" | "both";
|
|
78
|
+
pattern: string;
|
|
79
|
+
}, {
|
|
80
|
+
type: "custom_pattern";
|
|
81
|
+
decision: "allow" | "deny";
|
|
82
|
+
target: "name" | "args" | "both";
|
|
83
|
+
pattern: string;
|
|
84
|
+
}>, z.ZodObject<{
|
|
85
|
+
type: z.ZodLiteral<"allow_by_tier">;
|
|
86
|
+
tiers: z.ZodArray<z.ZodString, "many">;
|
|
87
|
+
}, "strip", z.ZodTypeAny, {
|
|
88
|
+
type: "allow_by_tier";
|
|
89
|
+
tiers: string[];
|
|
90
|
+
}, {
|
|
91
|
+
type: "allow_by_tier";
|
|
92
|
+
tiers: string[];
|
|
93
|
+
}>]>;
|
|
94
|
+
export declare const VerificationGateConfigSchema: z.ZodObject<{
|
|
95
|
+
enabled: z.ZodDefault<z.ZodBoolean>;
|
|
96
|
+
rules: z.ZodDefault<z.ZodArray<z.ZodDiscriminatedUnion<"type", [z.ZodObject<{
|
|
97
|
+
type: z.ZodLiteral<"allow_read_only">;
|
|
98
|
+
}, "strip", z.ZodTypeAny, {
|
|
99
|
+
type: "allow_read_only";
|
|
100
|
+
}, {
|
|
101
|
+
type: "allow_read_only";
|
|
102
|
+
}>, z.ZodObject<{
|
|
103
|
+
type: z.ZodLiteral<"deny_dangerous_patterns">;
|
|
104
|
+
}, "strip", z.ZodTypeAny, {
|
|
105
|
+
type: "deny_dangerous_patterns";
|
|
106
|
+
}, {
|
|
107
|
+
type: "deny_dangerous_patterns";
|
|
108
|
+
}>, z.ZodObject<{
|
|
109
|
+
type: z.ZodLiteral<"allow_by_category">;
|
|
110
|
+
categories: z.ZodArray<z.ZodString, "many">;
|
|
111
|
+
}, "strip", z.ZodTypeAny, {
|
|
112
|
+
categories: string[];
|
|
113
|
+
type: "allow_by_category";
|
|
114
|
+
}, {
|
|
115
|
+
categories: string[];
|
|
116
|
+
type: "allow_by_category";
|
|
117
|
+
}>, z.ZodObject<{
|
|
118
|
+
type: z.ZodLiteral<"allow_by_name">;
|
|
119
|
+
toolNames: z.ZodArray<z.ZodString, "many">;
|
|
120
|
+
}, "strip", z.ZodTypeAny, {
|
|
121
|
+
type: "allow_by_name";
|
|
122
|
+
toolNames: string[];
|
|
123
|
+
}, {
|
|
124
|
+
type: "allow_by_name";
|
|
125
|
+
toolNames: string[];
|
|
126
|
+
}>, z.ZodObject<{
|
|
127
|
+
type: z.ZodLiteral<"deny_by_name">;
|
|
128
|
+
toolNames: z.ZodArray<z.ZodString, "many">;
|
|
129
|
+
}, "strip", z.ZodTypeAny, {
|
|
130
|
+
type: "deny_by_name";
|
|
131
|
+
toolNames: string[];
|
|
132
|
+
}, {
|
|
133
|
+
type: "deny_by_name";
|
|
134
|
+
toolNames: string[];
|
|
135
|
+
}>, z.ZodObject<{
|
|
136
|
+
type: z.ZodLiteral<"custom_pattern">;
|
|
137
|
+
pattern: z.ZodString;
|
|
138
|
+
target: z.ZodEnum<["name", "args", "both"]>;
|
|
139
|
+
decision: z.ZodEnum<["allow", "deny"]>;
|
|
140
|
+
}, "strip", z.ZodTypeAny, {
|
|
141
|
+
type: "custom_pattern";
|
|
142
|
+
decision: "allow" | "deny";
|
|
143
|
+
target: "name" | "args" | "both";
|
|
144
|
+
pattern: string;
|
|
145
|
+
}, {
|
|
146
|
+
type: "custom_pattern";
|
|
147
|
+
decision: "allow" | "deny";
|
|
148
|
+
target: "name" | "args" | "both";
|
|
149
|
+
pattern: string;
|
|
150
|
+
}>, z.ZodObject<{
|
|
151
|
+
type: z.ZodLiteral<"allow_by_tier">;
|
|
152
|
+
tiers: z.ZodArray<z.ZodString, "many">;
|
|
153
|
+
}, "strip", z.ZodTypeAny, {
|
|
154
|
+
type: "allow_by_tier";
|
|
155
|
+
tiers: string[];
|
|
156
|
+
}, {
|
|
157
|
+
type: "allow_by_tier";
|
|
158
|
+
tiers: string[];
|
|
159
|
+
}>]>, "many">>;
|
|
160
|
+
allowReadOnlyTools: z.ZodDefault<z.ZodBoolean>;
|
|
161
|
+
denyDangerousPatterns: z.ZodDefault<z.ZodBoolean>;
|
|
162
|
+
logDecisions: z.ZodDefault<z.ZodBoolean>;
|
|
163
|
+
}, "strip", z.ZodTypeAny, {
|
|
164
|
+
enabled: boolean;
|
|
165
|
+
rules: ({
|
|
166
|
+
type: "allow_read_only";
|
|
167
|
+
} | {
|
|
168
|
+
type: "deny_dangerous_patterns";
|
|
169
|
+
} | {
|
|
170
|
+
categories: string[];
|
|
171
|
+
type: "allow_by_category";
|
|
172
|
+
} | {
|
|
173
|
+
type: "allow_by_name";
|
|
174
|
+
toolNames: string[];
|
|
175
|
+
} | {
|
|
176
|
+
type: "deny_by_name";
|
|
177
|
+
toolNames: string[];
|
|
178
|
+
} | {
|
|
179
|
+
type: "custom_pattern";
|
|
180
|
+
decision: "allow" | "deny";
|
|
181
|
+
target: "name" | "args" | "both";
|
|
182
|
+
pattern: string;
|
|
183
|
+
} | {
|
|
184
|
+
type: "allow_by_tier";
|
|
185
|
+
tiers: string[];
|
|
186
|
+
})[];
|
|
187
|
+
allowReadOnlyTools: boolean;
|
|
188
|
+
denyDangerousPatterns: boolean;
|
|
189
|
+
logDecisions: boolean;
|
|
190
|
+
}, {
|
|
191
|
+
enabled?: boolean | undefined;
|
|
192
|
+
rules?: ({
|
|
193
|
+
type: "allow_read_only";
|
|
194
|
+
} | {
|
|
195
|
+
type: "deny_dangerous_patterns";
|
|
196
|
+
} | {
|
|
197
|
+
categories: string[];
|
|
198
|
+
type: "allow_by_category";
|
|
199
|
+
} | {
|
|
200
|
+
type: "allow_by_name";
|
|
201
|
+
toolNames: string[];
|
|
202
|
+
} | {
|
|
203
|
+
type: "deny_by_name";
|
|
204
|
+
toolNames: string[];
|
|
205
|
+
} | {
|
|
206
|
+
type: "custom_pattern";
|
|
207
|
+
decision: "allow" | "deny";
|
|
208
|
+
target: "name" | "args" | "both";
|
|
209
|
+
pattern: string;
|
|
210
|
+
} | {
|
|
211
|
+
type: "allow_by_tier";
|
|
212
|
+
tiers: string[];
|
|
213
|
+
})[] | undefined;
|
|
214
|
+
allowReadOnlyTools?: boolean | undefined;
|
|
215
|
+
denyDangerousPatterns?: boolean | undefined;
|
|
216
|
+
logDecisions?: boolean | undefined;
|
|
217
|
+
}>;
|
|
218
|
+
export type VerificationGateConfig = z.infer<typeof VerificationGateConfigSchema>;
|
|
219
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAGvB,MAAM,MAAM,YAAY,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAA;AAEtD,MAAM,WAAW,oBAAoB;IACpC,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAA;IAC/B,QAAQ,CAAC,WAAW,EAAE,gBAAgB,GAAG,IAAI,CAAA;IAC7C,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;CACvB;AAED,MAAM,MAAM,gBAAgB,GACzB;IAAE,IAAI,EAAE,iBAAiB,CAAA;CAAE,GAC3B;IAAE,IAAI,EAAE,yBAAyB,CAAA;CAAE,GACnC;IAAE,IAAI,EAAE,mBAAmB,CAAC;IAAC,UAAU,EAAE,MAAM,EAAE,CAAA;CAAE,GACnD;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,SAAS,EAAE,MAAM,EAAE,CAAA;CAAE,GAC9C;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,SAAS,EAAE,MAAM,EAAE,CAAA;CAAE,GAC7C;IACA,IAAI,EAAE,gBAAgB,CAAA;IACtB,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;IAChC,QAAQ,EAAE,OAAO,GAAG,MAAM,CAAA;CACzB,GACD;IAAE,IAAI,EAAE,eAAe,CAAC;IAAC,KAAK,EAAE,MAAM,EAAE,CAAA;CAAE,CAAA;AA2B7C,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAQjC,CAAA;AAEF,eAAO,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAMvC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,4BAA4B,CAAC,CAAA"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { MAX_CUSTOM_PATTERN_LENGTH } from '../../constants/verification/index.js';
|
|
3
|
+
const AllowReadOnlySchema = z.object({ type: z.literal('allow_read_only') });
|
|
4
|
+
const DenyDangerousPatternsSchema = z.object({ type: z.literal('deny_dangerous_patterns') });
|
|
5
|
+
const AllowByCategorySchema = z.object({
|
|
6
|
+
type: z.literal('allow_by_category'),
|
|
7
|
+
categories: z.array(z.string()),
|
|
8
|
+
});
|
|
9
|
+
const AllowByNameSchema = z.object({
|
|
10
|
+
type: z.literal('allow_by_name'),
|
|
11
|
+
toolNames: z.array(z.string()),
|
|
12
|
+
});
|
|
13
|
+
const DenyByNameSchema = z.object({
|
|
14
|
+
type: z.literal('deny_by_name'),
|
|
15
|
+
toolNames: z.array(z.string()),
|
|
16
|
+
});
|
|
17
|
+
const CustomPatternSchema = z.object({
|
|
18
|
+
type: z.literal('custom_pattern'),
|
|
19
|
+
pattern: z.string().max(MAX_CUSTOM_PATTERN_LENGTH),
|
|
20
|
+
target: z.enum(['name', 'args', 'both']),
|
|
21
|
+
decision: z.enum(['allow', 'deny']),
|
|
22
|
+
});
|
|
23
|
+
const AllowByTierSchema = z.object({
|
|
24
|
+
type: z.literal('allow_by_tier'),
|
|
25
|
+
tiers: z.array(z.string()),
|
|
26
|
+
});
|
|
27
|
+
export const VerificationRuleSchema = z.discriminatedUnion('type', [
|
|
28
|
+
AllowReadOnlySchema,
|
|
29
|
+
DenyDangerousPatternsSchema,
|
|
30
|
+
AllowByCategorySchema,
|
|
31
|
+
AllowByNameSchema,
|
|
32
|
+
DenyByNameSchema,
|
|
33
|
+
CustomPatternSchema,
|
|
34
|
+
AllowByTierSchema,
|
|
35
|
+
]);
|
|
36
|
+
export const VerificationGateConfigSchema = z.object({
|
|
37
|
+
enabled: z.boolean().default(false),
|
|
38
|
+
rules: z.array(VerificationRuleSchema).default([]),
|
|
39
|
+
allowReadOnlyTools: z.boolean().default(false),
|
|
40
|
+
denyDangerousPatterns: z.boolean().default(false),
|
|
41
|
+
logDecisions: z.boolean().default(true),
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AACvB,OAAO,EAAE,yBAAyB,EAAE,MAAM,uCAAuC,CAAA;AAwBjF,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAA;AAC5E,MAAM,2BAA2B,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,yBAAyB,CAAC,EAAE,CAAC,CAAA;AAC5F,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC;IACpC,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC/B,CAAC,CAAA;AACF,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IAClC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;IAChC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC9B,CAAC,CAAA;AACF,MAAM,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC;IACjC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC;IAC/B,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC9B,CAAC,CAAA;AACF,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IACpC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC;IACjC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,yBAAyB,CAAC;IAClD,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;CACnC,CAAC,CAAA;AACF,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IAClC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;IAChC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;CAC1B,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,kBAAkB,CAAC,MAAM,EAAE;IAClE,mBAAmB;IACnB,2BAA2B;IAC3B,qBAAqB;IACrB,iBAAiB;IACjB,gBAAgB;IAChB,mBAAmB;IACnB,iBAAiB;CACjB,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,4BAA4B,GAAG,CAAC,CAAC,MAAM,CAAC;IACpD,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACnC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IAClD,kBAAkB,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IAC9C,qBAAqB,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;IACjD,YAAY,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;CACvC,CAAC,CAAA"}
|
package/dist/utils/id.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { ActivityId, CheckpointId, ChunkId, ConnectorId, ConnectorInstanceId, CredentialId, DocumentId, EnvironmentId, ExecutionContextId, KnowledgeBaseId, MCPClientId, MCPServerId, MCPSessionId, MessageId, PlanId, RunId, SessionId, TaskId, TenantId, ThreadId, ToolCallId } from '../types/ids/index.js';
|
|
1
|
+
import type { ActivityId, AdvisoryCallId, AdvisoryId, CheckpointId, ChunkId, ConnectorId, ConnectorInstanceId, CredentialId, DocumentId, EmergencySaveId, EnvironmentId, ExecutionContextId, KnowledgeBaseId, MCPClientId, MCPServerId, MCPSessionId, MemoryId, MessageId, PlanId, PluginId, RunId, SessionId, TaskId, TenantId, ThreadId, ToolCallId } from '../types/ids/index.js';
|
|
2
2
|
export declare function generateThreadId(): ThreadId;
|
|
3
3
|
export declare function generateRunId(): RunId;
|
|
4
4
|
export declare function generateMessageId(): MessageId;
|
|
@@ -20,7 +20,13 @@ export declare function generateMCPClientId(): MCPClientId;
|
|
|
20
20
|
export declare function generateMCPSessionId(): MCPSessionId;
|
|
21
21
|
export declare function generateEnvironmentId(): EnvironmentId;
|
|
22
22
|
export declare function generateCheckpointId(): CheckpointId;
|
|
23
|
+
export declare function generateAdvisoryId(): AdvisoryId;
|
|
24
|
+
export declare function generateAdvisoryCallId(): AdvisoryCallId;
|
|
25
|
+
export declare function generateEmergencySaveId(): EmergencySaveId;
|
|
26
|
+
export declare function generateMemoryId(): MemoryId;
|
|
27
|
+
export declare function generatePluginId(): PluginId;
|
|
23
28
|
export declare function parseThreadId(raw: string): ThreadId;
|
|
24
29
|
export declare function parseRunId(raw: string): RunId;
|
|
25
30
|
export declare function parseConnectorInstanceId(raw: string): ConnectorInstanceId;
|
|
31
|
+
export declare function parsePluginId(raw: string): PluginId;
|
|
26
32
|
//# sourceMappingURL=id.d.ts.map
|
package/dist/utils/id.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"id.d.ts","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACX,UAAU,EACV,YAAY,EACZ,OAAO,EACP,WAAW,EACX,mBAAmB,EACnB,YAAY,EACZ,UAAU,EACV,aAAa,EACb,kBAAkB,EAClB,eAAe,EACf,WAAW,EACX,WAAW,EACX,YAAY,EACZ,SAAS,EACT,MAAM,EACN,KAAK,EACL,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,MAAM,uBAAuB,CAAA;AAsB9B,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,aAAa,IAAI,KAAK,CAErC;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,uBAAuB,IAAI,eAAe,CAEzD;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,eAAe,IAAI,OAAO,CAEzC;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,2BAA2B,IAAI,mBAAmB,CAEjE;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,0BAA0B,IAAI,kBAAkB,CAE/D;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,qBAAqB,IAAI,aAAa,CAErD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AASD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAEnD;AACD,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAE7C;AACD,wBAAgB,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,mBAAmB,CAEzE"}
|
|
1
|
+
{"version":3,"file":"id.d.ts","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACX,UAAU,EACV,cAAc,EACd,UAAU,EACV,YAAY,EACZ,OAAO,EACP,WAAW,EACX,mBAAmB,EACnB,YAAY,EACZ,UAAU,EACV,eAAe,EACf,aAAa,EACb,kBAAkB,EAClB,eAAe,EACf,WAAW,EACX,WAAW,EACX,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,MAAM,EACN,QAAQ,EACR,KAAK,EACL,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,MAAM,uBAAuB,CAAA;AAsB9B,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,aAAa,IAAI,KAAK,CAErC;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,iBAAiB,IAAI,SAAS,CAE7C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,uBAAuB,IAAI,eAAe,CAEzD;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,eAAe,IAAI,OAAO,CAEzC;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,2BAA2B,IAAI,mBAAmB,CAEjE;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,0BAA0B,IAAI,kBAAkB,CAE/D;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,mBAAmB,IAAI,WAAW,CAEjD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,qBAAqB,IAAI,aAAa,CAErD;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,kBAAkB,IAAI,UAAU,CAE/C;AAED,wBAAgB,sBAAsB,IAAI,cAAc,CAEvD;AAED,wBAAgB,uBAAuB,IAAI,eAAe,CAEzD;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AAED,wBAAgB,gBAAgB,IAAI,QAAQ,CAE3C;AASD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAEnD;AACD,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,CAE7C;AACD,wBAAgB,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,mBAAmB,CAEzE;AACD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAEnD"}
|
package/dist/utils/id.js
CHANGED
|
@@ -81,6 +81,21 @@ export function generateEnvironmentId() {
|
|
|
81
81
|
export function generateCheckpointId() {
|
|
82
82
|
return generateId('cp_');
|
|
83
83
|
}
|
|
84
|
+
export function generateAdvisoryId() {
|
|
85
|
+
return generateId('adv_');
|
|
86
|
+
}
|
|
87
|
+
export function generateAdvisoryCallId() {
|
|
88
|
+
return generateId('advc_');
|
|
89
|
+
}
|
|
90
|
+
export function generateEmergencySaveId() {
|
|
91
|
+
return generateId('esave_');
|
|
92
|
+
}
|
|
93
|
+
export function generateMemoryId() {
|
|
94
|
+
return generateId('mem_');
|
|
95
|
+
}
|
|
96
|
+
export function generatePluginId() {
|
|
97
|
+
return generateId('plg_');
|
|
98
|
+
}
|
|
84
99
|
function parseId(raw, prefix, typeName) {
|
|
85
100
|
if (!raw.startsWith(prefix)) {
|
|
86
101
|
throw new Error(`Invalid ${typeName}: expected "${prefix}" prefix, got "${raw}"`);
|
|
@@ -96,4 +111,7 @@ export function parseRunId(raw) {
|
|
|
96
111
|
export function parseConnectorInstanceId(raw) {
|
|
97
112
|
return parseId(raw, 'ci_', 'ConnectorInstanceId');
|
|
98
113
|
}
|
|
114
|
+
export function parsePluginId(raw) {
|
|
115
|
+
return parseId(raw, 'plg_', 'PluginId');
|
|
116
|
+
}
|
|
99
117
|
//# sourceMappingURL=id.js.map
|
package/dist/utils/id.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"id.js","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"id.js","sourceRoot":"","sources":["../../src/utils/id.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface ShellCompressResult {
|
|
2
|
+
text: string;
|
|
3
|
+
original: string | null;
|
|
4
|
+
}
|
|
5
|
+
export interface ShellCompressOptions {
|
|
6
|
+
minLines?: number;
|
|
7
|
+
minReductionPercent?: number;
|
|
8
|
+
maxStackFrames?: number;
|
|
9
|
+
maxPassLines?: number;
|
|
10
|
+
}
|
|
11
|
+
export declare function compressShellOutputFull(raw: string, options?: ShellCompressOptions): ShellCompressResult;
|
|
12
|
+
export declare function compressShellOutput(raw: string, options?: ShellCompressOptions): string;
|
|
13
|
+
//# sourceMappingURL=shell-compress.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shell-compress.d.ts","sourceRoot":"","sources":["../../src/utils/shell-compress.ts"],"names":[],"mappings":"AAcA,MAAM,WAAW,mBAAmB;IACnC,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;CACvB;AAED,MAAM,WAAW,oBAAoB;IACpC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,mBAAmB,CAAC,EAAE,MAAM,CAAA;IAC5B,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,YAAY,CAAC,EAAE,MAAM,CAAA;CACrB;AAgCD,wBAAgB,uBAAuB,CACtC,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,oBAAoB,GAC5B,mBAAmB,CAyErB;AAED,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,oBAAoB,GAAG,MAAM,CAEvF"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
const STACK_FRAME_RE = /^\s+at\s+|^\s+File\s+"[^"]+",\s+line\s+\d+|^\s+at\s+[\w.$]+\(|^\s+\d+:\s+\w|^\s+from\s+\//;
|
|
2
|
+
const PASS_LINE_RE = /[\s✓✔√●∙·►▸▹]+\s*(PASS|pass|ok|OK|✓|✔|√)\s|^\s*(PASS|ok)\s+[\w/.-]+|^ok\s+\d+\s|PASSED\s*$|^---\s*PASS:|^test\s+\S+\s+\.\.\.\s+ok\s*$/;
|
|
3
|
+
const NOISE_RE = /^\s*[\\\/|─━░▓█▒■□◻◼⠋⠙⠹⠸⠼⠴⠦⠧⠇⠏⣾⣽⣻⢿⡿⣟⣯⣷]+\s*$|^\s*\d+%\s*[|█▓░]+|^(Downloading|Fetching|Installing|Resolving|Compiling)\b.*\.\.\./;
|
|
4
|
+
const DEFAULT_MIN_LINES = 20;
|
|
5
|
+
const DEFAULT_MIN_REDUCTION = 0.1;
|
|
6
|
+
const DEFAULT_MAX_STACK_FRAMES = 5;
|
|
7
|
+
const DEFAULT_MAX_PASS_LINES = 3;
|
|
8
|
+
function normalizeLine(line) {
|
|
9
|
+
return line.replace(/^\s*\d+[\s:.|)]+/, '').replace(/\d+/g, 'N');
|
|
10
|
+
}
|
|
11
|
+
function collapseRepeated(lines) {
|
|
12
|
+
const result = [];
|
|
13
|
+
let prevNorm = '';
|
|
14
|
+
let repeatCount = 0;
|
|
15
|
+
for (const line of lines) {
|
|
16
|
+
const norm = normalizeLine(line);
|
|
17
|
+
if (norm === prevNorm && norm.trim().length > 0) {
|
|
18
|
+
repeatCount++;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
if (repeatCount > 0) {
|
|
22
|
+
result.push(`... ${repeatCount} similar line${repeatCount === 1 ? '' : 's'} omitted`);
|
|
23
|
+
}
|
|
24
|
+
result.push(line);
|
|
25
|
+
prevNorm = norm;
|
|
26
|
+
repeatCount = 0;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
if (repeatCount > 0) {
|
|
30
|
+
result.push(`... ${repeatCount} similar line${repeatCount === 1 ? '' : 's'} omitted`);
|
|
31
|
+
}
|
|
32
|
+
return result;
|
|
33
|
+
}
|
|
34
|
+
export function compressShellOutputFull(raw, options) {
|
|
35
|
+
const minLines = options?.minLines ?? DEFAULT_MIN_LINES;
|
|
36
|
+
const minReduction = options?.minReductionPercent ?? DEFAULT_MIN_REDUCTION;
|
|
37
|
+
const maxStackFrames = options?.maxStackFrames ?? DEFAULT_MAX_STACK_FRAMES;
|
|
38
|
+
const maxPassLines = options?.maxPassLines ?? DEFAULT_MAX_PASS_LINES;
|
|
39
|
+
const lines = raw.split('\n');
|
|
40
|
+
if (lines.length < minLines) {
|
|
41
|
+
return { text: raw, original: null };
|
|
42
|
+
}
|
|
43
|
+
// Pass 1: stack frame compression, pass test suppression, noise removal
|
|
44
|
+
const pass1 = [];
|
|
45
|
+
let stackCount = 0;
|
|
46
|
+
let passCount = 0;
|
|
47
|
+
for (const line of lines) {
|
|
48
|
+
// Noise removal
|
|
49
|
+
if (NOISE_RE.test(line)) {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
// Stack frame compression
|
|
53
|
+
if (STACK_FRAME_RE.test(line)) {
|
|
54
|
+
stackCount++;
|
|
55
|
+
if (stackCount <= maxStackFrames) {
|
|
56
|
+
pass1.push(line);
|
|
57
|
+
}
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
if (stackCount > maxStackFrames) {
|
|
61
|
+
pass1.push(`... ${stackCount - maxStackFrames} more frames`);
|
|
62
|
+
}
|
|
63
|
+
stackCount = 0;
|
|
64
|
+
// Pass test suppression
|
|
65
|
+
if (PASS_LINE_RE.test(line)) {
|
|
66
|
+
passCount++;
|
|
67
|
+
if (passCount <= maxPassLines) {
|
|
68
|
+
pass1.push(line);
|
|
69
|
+
}
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
if (passCount > maxPassLines) {
|
|
73
|
+
pass1.push(`... ${passCount - maxPassLines} passing tests omitted`);
|
|
74
|
+
}
|
|
75
|
+
passCount = 0;
|
|
76
|
+
pass1.push(line);
|
|
77
|
+
}
|
|
78
|
+
// Flush trailing counters
|
|
79
|
+
if (stackCount > maxStackFrames) {
|
|
80
|
+
pass1.push(`... ${stackCount - maxStackFrames} more frames`);
|
|
81
|
+
}
|
|
82
|
+
if (passCount > maxPassLines) {
|
|
83
|
+
pass1.push(`... ${passCount - maxPassLines} passing tests omitted`);
|
|
84
|
+
}
|
|
85
|
+
// Pass 2: collapse repeated lines
|
|
86
|
+
const pass2 = collapseRepeated(pass1);
|
|
87
|
+
const compressed = pass2.join('\n');
|
|
88
|
+
const reduction = 1 - compressed.length / raw.length;
|
|
89
|
+
if (reduction < minReduction) {
|
|
90
|
+
return { text: raw, original: null };
|
|
91
|
+
}
|
|
92
|
+
return { text: compressed, original: raw };
|
|
93
|
+
}
|
|
94
|
+
export function compressShellOutput(raw, options) {
|
|
95
|
+
return compressShellOutputFull(raw, options).text;
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=shell-compress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shell-compress.js","sourceRoot":"","sources":["../../src/utils/shell-compress.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { ToolDefinition } from '../types/tool/index.js';
|
|
2
|
+
import type { GateEvaluationResult, VerificationGateConfig } from '../types/verification/index.js';
|
|
3
|
+
import type { Logger } from '../utils/logger.js';
|
|
4
|
+
export interface ToolCallContext {
|
|
5
|
+
readonly toolName: string;
|
|
6
|
+
readonly toolInput: unknown;
|
|
7
|
+
readonly toolDef: ToolDefinition | undefined;
|
|
8
|
+
}
|
|
9
|
+
export declare class VerificationGate {
|
|
10
|
+
private readonly rules;
|
|
11
|
+
private readonly compiledPatterns;
|
|
12
|
+
private readonly nameSets;
|
|
13
|
+
private readonly log;
|
|
14
|
+
private readonly logDecisions;
|
|
15
|
+
private readonly enabled;
|
|
16
|
+
constructor(config: VerificationGateConfig, log: Logger);
|
|
17
|
+
evaluate(ctx: ToolCallContext): GateEvaluationResult;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=gate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gate.d.ts","sourceRoot":"","sources":["../../src/verification/gate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,KAAK,EACX,oBAAoB,EACpB,sBAAsB,EAEtB,MAAM,gCAAgC,CAAA;AAEvC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAGhD,MAAM,WAAW,eAAe;IAC/B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAA;IAC3B,QAAQ,CAAC,OAAO,EAAE,cAAc,GAAG,SAAS,CAAA;CAC5C;AAED,qBAAa,gBAAgB;IAC5B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAoB;IAC1C,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAqB;IACtD,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;IACnD,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAQ;IAC5B,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;gBAErB,MAAM,EAAE,sBAAsB,EAAE,GAAG,EAAE,MAAM;IAsDvD,QAAQ,CAAC,GAAG,EAAE,eAAe,GAAG,oBAAoB;CAwDpD"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { MAX_CUSTOM_PATTERN_LENGTH } from '../constants/verification/index.js';
|
|
2
|
+
import { VerificationGateConfigSchema } from '../types/verification/index.js';
|
|
3
|
+
import { evaluateRule } from './rules.js';
|
|
4
|
+
export class VerificationGate {
|
|
5
|
+
rules;
|
|
6
|
+
compiledPatterns;
|
|
7
|
+
nameSets;
|
|
8
|
+
log;
|
|
9
|
+
logDecisions;
|
|
10
|
+
enabled;
|
|
11
|
+
constructor(config, log) {
|
|
12
|
+
const parsed = VerificationGateConfigSchema.parse(config);
|
|
13
|
+
this.log = log.child({ component: 'VerificationGate' });
|
|
14
|
+
this.logDecisions = parsed.logDecisions;
|
|
15
|
+
this.enabled = parsed.enabled;
|
|
16
|
+
const expandedRules = [];
|
|
17
|
+
if (parsed.denyDangerousPatterns) {
|
|
18
|
+
expandedRules.push({ type: 'deny_dangerous_patterns' });
|
|
19
|
+
}
|
|
20
|
+
if (parsed.allowReadOnlyTools) {
|
|
21
|
+
expandedRules.push({ type: 'allow_read_only' });
|
|
22
|
+
}
|
|
23
|
+
expandedRules.push(...parsed.rules);
|
|
24
|
+
this.rules = expandedRules;
|
|
25
|
+
this.compiledPatterns = new Map();
|
|
26
|
+
this.nameSets = new Map();
|
|
27
|
+
for (let i = 0; i < this.rules.length; i++) {
|
|
28
|
+
const rule = this.rules[i];
|
|
29
|
+
if (!rule)
|
|
30
|
+
continue;
|
|
31
|
+
if (rule.type === 'custom_pattern') {
|
|
32
|
+
if (rule.pattern.length > MAX_CUSTOM_PATTERN_LENGTH) {
|
|
33
|
+
this.log.warn('Custom pattern exceeds max length, skipping', {
|
|
34
|
+
index: i,
|
|
35
|
+
length: rule.pattern.length,
|
|
36
|
+
maxLength: MAX_CUSTOM_PATTERN_LENGTH,
|
|
37
|
+
});
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
try {
|
|
41
|
+
this.compiledPatterns.set(i, new RegExp(rule.pattern));
|
|
42
|
+
}
|
|
43
|
+
catch (err) {
|
|
44
|
+
this.log.warn('Invalid custom pattern regex, skipping', {
|
|
45
|
+
index: i,
|
|
46
|
+
pattern: rule.pattern,
|
|
47
|
+
error: err instanceof Error ? err.message : String(err),
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
if (rule.type === 'allow_by_name') {
|
|
52
|
+
this.nameSets.set(i, new Set(rule.toolNames));
|
|
53
|
+
}
|
|
54
|
+
if (rule.type === 'deny_by_name') {
|
|
55
|
+
this.nameSets.set(i, new Set(rule.toolNames));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
evaluate(ctx) {
|
|
60
|
+
if (!this.enabled) {
|
|
61
|
+
return {
|
|
62
|
+
decision: 'review',
|
|
63
|
+
matchedRule: null,
|
|
64
|
+
reason: 'Gate disabled',
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
for (let i = 0; i < this.rules.length; i++) {
|
|
68
|
+
const rule = this.rules[i];
|
|
69
|
+
if (!rule)
|
|
70
|
+
continue;
|
|
71
|
+
const decision = evaluateRule(rule, ctx.toolName, ctx.toolInput, ctx.toolDef, this.compiledPatterns.get(i), this.nameSets.get(i));
|
|
72
|
+
if (decision !== null) {
|
|
73
|
+
const result = {
|
|
74
|
+
decision,
|
|
75
|
+
matchedRule: rule,
|
|
76
|
+
reason: `Matched rule: ${rule.type}`,
|
|
77
|
+
};
|
|
78
|
+
if (this.logDecisions) {
|
|
79
|
+
this.log.debug('Gate decision', {
|
|
80
|
+
toolName: ctx.toolName,
|
|
81
|
+
decision,
|
|
82
|
+
ruleType: rule.type,
|
|
83
|
+
ruleIndex: i,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
const result = {
|
|
90
|
+
decision: 'review',
|
|
91
|
+
matchedRule: null,
|
|
92
|
+
reason: 'No matching rule found',
|
|
93
|
+
};
|
|
94
|
+
if (this.logDecisions) {
|
|
95
|
+
this.log.debug('Gate decision (default)', {
|
|
96
|
+
toolName: ctx.toolName,
|
|
97
|
+
decision: 'review',
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
return result;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gate.js","sourceRoot":"","sources":["../../src/verification/gate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,KAAK,eAAe,EAAE,MAAM,WAAW,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/verification/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAwB,MAAM,WAAW,CAAA;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ToolDefinition } from '../types/tool/index.js';
|
|
2
|
+
import type { GateDecision, VerificationRule } from '../types/verification/index.js';
|
|
3
|
+
export declare function evaluateRule(rule: VerificationRule, toolName: string, toolInput: unknown, toolDef: ToolDefinition | undefined, compiledPattern?: RegExp, nameSet?: Set<string>): GateDecision | null;
|
|
4
|
+
//# sourceMappingURL=rules.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rules.d.ts","sourceRoot":"","sources":["../../src/verification/rules.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAEpF,wBAAgB,YAAY,CAC3B,IAAI,EAAE,gBAAgB,EACtB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,OAAO,EAClB,OAAO,EAAE,cAAc,GAAG,SAAS,EACnC,eAAe,CAAC,EAAE,MAAM,EACxB,OAAO,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,GACnB,YAAY,GAAG,IAAI,CAkErB"}
|