@vigil-guard/vge-cc-guard 0.9.0-beta.1
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/LICENSE.md +37 -0
- package/README.md +441 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +61 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/_lib/install-paths.d.ts +16 -0
- package/dist/commands/_lib/install-paths.d.ts.map +1 -0
- package/dist/commands/_lib/install-paths.js +46 -0
- package/dist/commands/_lib/install-paths.js.map +1 -0
- package/dist/commands/_lib/parse-install-flags.d.ts +8 -0
- package/dist/commands/_lib/parse-install-flags.d.ts.map +1 -0
- package/dist/commands/_lib/parse-install-flags.js +15 -0
- package/dist/commands/_lib/parse-install-flags.js.map +1 -0
- package/dist/commands/config.d.ts +2 -0
- package/dist/commands/config.d.ts.map +1 -0
- package/dist/commands/config.js +41 -0
- package/dist/commands/config.js.map +1 -0
- package/dist/commands/daemon.d.ts +2 -0
- package/dist/commands/daemon.d.ts.map +1 -0
- package/dist/commands/daemon.js +116 -0
- package/dist/commands/daemon.js.map +1 -0
- package/dist/commands/doctor.d.ts +2 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +53 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/install-wizard.d.ts +2 -0
- package/dist/commands/install-wizard.d.ts.map +1 -0
- package/dist/commands/install-wizard.js +85 -0
- package/dist/commands/install-wizard.js.map +1 -0
- package/dist/commands/install.d.ts +15 -0
- package/dist/commands/install.d.ts.map +1 -0
- package/dist/commands/install.js +136 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/reset-session.d.ts +2 -0
- package/dist/commands/reset-session.d.ts.map +1 -0
- package/dist/commands/reset-session.js +113 -0
- package/dist/commands/reset-session.js.map +1 -0
- package/dist/commands/uninstall.d.ts +2 -0
- package/dist/commands/uninstall.d.ts.map +1 -0
- package/dist/commands/uninstall.js +277 -0
- package/dist/commands/uninstall.js.map +1 -0
- package/dist/daemon/active-conversation-decisions.d.ts +9 -0
- package/dist/daemon/active-conversation-decisions.d.ts.map +1 -0
- package/dist/daemon/active-conversation-decisions.js +58 -0
- package/dist/daemon/active-conversation-decisions.js.map +1 -0
- package/dist/daemon/allowlist.d.ts +2 -0
- package/dist/daemon/allowlist.d.ts.map +1 -0
- package/dist/daemon/allowlist.js +118 -0
- package/dist/daemon/allowlist.js.map +1 -0
- package/dist/daemon/analysis-source.d.ts +17 -0
- package/dist/daemon/analysis-source.d.ts.map +1 -0
- package/dist/daemon/analysis-source.js +114 -0
- package/dist/daemon/analysis-source.js.map +1 -0
- package/dist/daemon/ask-dialog.d.ts +23 -0
- package/dist/daemon/ask-dialog.d.ts.map +1 -0
- package/dist/daemon/ask-dialog.js +114 -0
- package/dist/daemon/ask-dialog.js.map +1 -0
- package/dist/daemon/attachment-decision-escrow.d.ts +27 -0
- package/dist/daemon/attachment-decision-escrow.d.ts.map +1 -0
- package/dist/daemon/attachment-decision-escrow.js +34 -0
- package/dist/daemon/attachment-decision-escrow.js.map +1 -0
- package/dist/daemon/attachment-input-enforcement.d.ts +11 -0
- package/dist/daemon/attachment-input-enforcement.d.ts.map +1 -0
- package/dist/daemon/attachment-input-enforcement.js +434 -0
- package/dist/daemon/attachment-input-enforcement.js.map +1 -0
- package/dist/daemon/audit-decisions.d.ts +51 -0
- package/dist/daemon/audit-decisions.d.ts.map +1 -0
- package/dist/daemon/audit-decisions.js +178 -0
- package/dist/daemon/audit-decisions.js.map +1 -0
- package/dist/daemon/audit-logger.d.ts +6 -0
- package/dist/daemon/audit-logger.d.ts.map +1 -0
- package/dist/daemon/audit-logger.js +6 -0
- package/dist/daemon/audit-logger.js.map +1 -0
- package/dist/daemon/audit-posttool.d.ts +123 -0
- package/dist/daemon/audit-posttool.d.ts.map +1 -0
- package/dist/daemon/audit-posttool.js +173 -0
- package/dist/daemon/audit-posttool.js.map +1 -0
- package/dist/daemon/audit-pretool.d.ts +56 -0
- package/dist/daemon/audit-pretool.d.ts.map +1 -0
- package/dist/daemon/audit-pretool.js +77 -0
- package/dist/daemon/audit-pretool.js.map +1 -0
- package/dist/daemon/audit-userprompt.d.ts +113 -0
- package/dist/daemon/audit-userprompt.d.ts.map +1 -0
- package/dist/daemon/audit-userprompt.js +162 -0
- package/dist/daemon/audit-userprompt.js.map +1 -0
- package/dist/daemon/blocking-decision-triggers.d.ts +5 -0
- package/dist/daemon/blocking-decision-triggers.d.ts.map +1 -0
- package/dist/daemon/blocking-decision-triggers.js +40 -0
- package/dist/daemon/blocking-decision-triggers.js.map +1 -0
- package/dist/daemon/cc-contract-auto-probe.d.ts +40 -0
- package/dist/daemon/cc-contract-auto-probe.d.ts.map +1 -0
- package/dist/daemon/cc-contract-auto-probe.js +101 -0
- package/dist/daemon/cc-contract-auto-probe.js.map +1 -0
- package/dist/daemon/cc-contract-probe.d.ts +46 -0
- package/dist/daemon/cc-contract-probe.d.ts.map +1 -0
- package/dist/daemon/cc-contract-probe.js +138 -0
- package/dist/daemon/cc-contract-probe.js.map +1 -0
- package/dist/daemon/cc-contract-runtime.d.ts +8 -0
- package/dist/daemon/cc-contract-runtime.d.ts.map +1 -0
- package/dist/daemon/cc-contract-runtime.js +42 -0
- package/dist/daemon/cc-contract-runtime.js.map +1 -0
- package/dist/daemon/cc-contract-status.d.ts +40 -0
- package/dist/daemon/cc-contract-status.d.ts.map +1 -0
- package/dist/daemon/cc-contract-status.js +242 -0
- package/dist/daemon/cc-contract-status.js.map +1 -0
- package/dist/daemon/confidence-router.d.ts +3 -0
- package/dist/daemon/confidence-router.d.ts.map +1 -0
- package/dist/daemon/confidence-router.js +34 -0
- package/dist/daemon/confidence-router.js.map +1 -0
- package/dist/daemon/conversation-context.d.ts +28 -0
- package/dist/daemon/conversation-context.d.ts.map +1 -0
- package/dist/daemon/conversation-context.js +271 -0
- package/dist/daemon/conversation-context.js.map +1 -0
- package/dist/daemon/conversation-decision-cleanup.d.ts +2 -0
- package/dist/daemon/conversation-decision-cleanup.d.ts.map +1 -0
- package/dist/daemon/conversation-decision-cleanup.js +22 -0
- package/dist/daemon/conversation-decision-cleanup.js.map +1 -0
- package/dist/daemon/conversation-decision-escrow.d.ts +20 -0
- package/dist/daemon/conversation-decision-escrow.d.ts.map +1 -0
- package/dist/daemon/conversation-decision-escrow.js +78 -0
- package/dist/daemon/conversation-decision-escrow.js.map +1 -0
- package/dist/daemon/conversation-decision-prompt.d.ts +30 -0
- package/dist/daemon/conversation-decision-prompt.d.ts.map +1 -0
- package/dist/daemon/conversation-decision-prompt.js +250 -0
- package/dist/daemon/conversation-decision-prompt.js.map +1 -0
- package/dist/daemon/daemon-instance.d.ts +27 -0
- package/dist/daemon/daemon-instance.d.ts.map +1 -0
- package/dist/daemon/daemon-instance.js +41 -0
- package/dist/daemon/daemon-instance.js.map +1 -0
- package/dist/daemon/daemon-ipc.d.ts +29 -0
- package/dist/daemon/daemon-ipc.d.ts.map +1 -0
- package/dist/daemon/daemon-ipc.js +82 -0
- package/dist/daemon/daemon-ipc.js.map +1 -0
- package/dist/daemon/daemon-supersede.d.ts +3 -0
- package/dist/daemon/daemon-supersede.d.ts.map +1 -0
- package/dist/daemon/daemon-supersede.js +126 -0
- package/dist/daemon/daemon-supersede.js.map +1 -0
- package/dist/daemon/debug-logger.d.ts +5 -0
- package/dist/daemon/debug-logger.d.ts.map +1 -0
- package/dist/daemon/debug-logger.js +247 -0
- package/dist/daemon/debug-logger.js.map +1 -0
- package/dist/daemon/decision-broker.d.ts +58 -0
- package/dist/daemon/decision-broker.d.ts.map +1 -0
- package/dist/daemon/decision-broker.js +340 -0
- package/dist/daemon/decision-broker.js.map +1 -0
- package/dist/daemon/decision-metrics.d.ts +40 -0
- package/dist/daemon/decision-metrics.d.ts.map +1 -0
- package/dist/daemon/decision-metrics.js +116 -0
- package/dist/daemon/decision-metrics.js.map +1 -0
- package/dist/daemon/decision-owner.d.ts +10 -0
- package/dist/daemon/decision-owner.d.ts.map +1 -0
- package/dist/daemon/decision-owner.js +30 -0
- package/dist/daemon/decision-owner.js.map +1 -0
- package/dist/daemon/decision-routes.d.ts +7 -0
- package/dist/daemon/decision-routes.d.ts.map +1 -0
- package/dist/daemon/decision-routes.js +104 -0
- package/dist/daemon/decision-routes.js.map +1 -0
- package/dist/daemon/decision-timeout.d.ts +3 -0
- package/dist/daemon/decision-timeout.d.ts.map +1 -0
- package/dist/daemon/decision-timeout.js +5 -0
- package/dist/daemon/decision-timeout.js.map +1 -0
- package/dist/daemon/decision-transition.d.ts +12 -0
- package/dist/daemon/decision-transition.d.ts.map +1 -0
- package/dist/daemon/decision-transition.js +8 -0
- package/dist/daemon/decision-transition.js.map +1 -0
- package/dist/daemon/http-server.d.ts +4 -0
- package/dist/daemon/http-server.d.ts.map +1 -0
- package/dist/daemon/http-server.js +535 -0
- package/dist/daemon/http-server.js.map +1 -0
- package/dist/daemon/id-validation.d.ts +2 -0
- package/dist/daemon/id-validation.d.ts.map +1 -0
- package/dist/daemon/id-validation.js +5 -0
- package/dist/daemon/id-validation.js.map +1 -0
- package/dist/daemon/path-deny.d.ts +14 -0
- package/dist/daemon/path-deny.d.ts.map +1 -0
- package/dist/daemon/path-deny.js +88 -0
- package/dist/daemon/path-deny.js.map +1 -0
- package/dist/daemon/posttool-decision-escrow.d.ts +42 -0
- package/dist/daemon/posttool-decision-escrow.d.ts.map +1 -0
- package/dist/daemon/posttool-decision-escrow.js +349 -0
- package/dist/daemon/posttool-decision-escrow.js.map +1 -0
- package/dist/daemon/posttool-decision-state.d.ts +65 -0
- package/dist/daemon/posttool-decision-state.d.ts.map +1 -0
- package/dist/daemon/posttool-decision-state.js +223 -0
- package/dist/daemon/posttool-decision-state.js.map +1 -0
- package/dist/daemon/posttool-enforcement.d.ts +7 -0
- package/dist/daemon/posttool-enforcement.d.ts.map +1 -0
- package/dist/daemon/posttool-enforcement.js +511 -0
- package/dist/daemon/posttool-enforcement.js.map +1 -0
- package/dist/daemon/posttool-render.d.ts +48 -0
- package/dist/daemon/posttool-render.d.ts.map +1 -0
- package/dist/daemon/posttool-render.js +335 -0
- package/dist/daemon/posttool-render.js.map +1 -0
- package/dist/daemon/pretool-decision-escrow.d.ts +51 -0
- package/dist/daemon/pretool-decision-escrow.d.ts.map +1 -0
- package/dist/daemon/pretool-decision-escrow.js +295 -0
- package/dist/daemon/pretool-decision-escrow.js.map +1 -0
- package/dist/daemon/pretool-url-gate.d.ts +17 -0
- package/dist/daemon/pretool-url-gate.d.ts.map +1 -0
- package/dist/daemon/pretool-url-gate.js +60 -0
- package/dist/daemon/pretool-url-gate.js.map +1 -0
- package/dist/daemon/prompt-input-enforcement.d.ts +18 -0
- package/dist/daemon/prompt-input-enforcement.d.ts.map +1 -0
- package/dist/daemon/prompt-input-enforcement.js +248 -0
- package/dist/daemon/prompt-input-enforcement.js.map +1 -0
- package/dist/daemon/reply-parser.d.ts +10 -0
- package/dist/daemon/reply-parser.d.ts.map +1 -0
- package/dist/daemon/reply-parser.js +81 -0
- package/dist/daemon/reply-parser.js.map +1 -0
- package/dist/daemon/resolve-escalation-route.d.ts +5 -0
- package/dist/daemon/resolve-escalation-route.d.ts.map +1 -0
- package/dist/daemon/resolve-escalation-route.js +85 -0
- package/dist/daemon/resolve-escalation-route.js.map +1 -0
- package/dist/daemon/response-cache.d.ts +14 -0
- package/dist/daemon/response-cache.d.ts.map +1 -0
- package/dist/daemon/response-cache.js +38 -0
- package/dist/daemon/response-cache.js.map +1 -0
- package/dist/daemon/security-frame.d.ts +14 -0
- package/dist/daemon/security-frame.d.ts.map +1 -0
- package/dist/daemon/security-frame.js +96 -0
- package/dist/daemon/security-frame.js.map +1 -0
- package/dist/daemon/session-hook-routes.d.ts +3 -0
- package/dist/daemon/session-hook-routes.d.ts.map +1 -0
- package/dist/daemon/session-hook-routes.js +66 -0
- package/dist/daemon/session-hook-routes.js.map +1 -0
- package/dist/daemon/session-state.d.ts +52 -0
- package/dist/daemon/session-state.d.ts.map +1 -0
- package/dist/daemon/session-state.js +495 -0
- package/dist/daemon/session-state.js.map +1 -0
- package/dist/daemon/subagent-lifecycle.d.ts +8 -0
- package/dist/daemon/subagent-lifecycle.d.ts.map +1 -0
- package/dist/daemon/subagent-lifecycle.js +56 -0
- package/dist/daemon/subagent-lifecycle.js.map +1 -0
- package/dist/daemon/tool-output-redactor.d.ts +13 -0
- package/dist/daemon/tool-output-redactor.d.ts.map +1 -0
- package/dist/daemon/tool-output-redactor.js +82 -0
- package/dist/daemon/tool-output-redactor.js.map +1 -0
- package/dist/daemon/tool-policy.d.ts +16 -0
- package/dist/daemon/tool-policy.d.ts.map +1 -0
- package/dist/daemon/tool-policy.js +60 -0
- package/dist/daemon/tool-policy.js.map +1 -0
- package/dist/daemon/tool-response-normalizer.d.ts +11 -0
- package/dist/daemon/tool-response-normalizer.d.ts.map +1 -0
- package/dist/daemon/tool-response-normalizer.js +67 -0
- package/dist/daemon/tool-response-normalizer.js.map +1 -0
- package/dist/daemon/truncate.d.ts +3 -0
- package/dist/daemon/truncate.d.ts.map +1 -0
- package/dist/daemon/truncate.js +22 -0
- package/dist/daemon/truncate.js.map +1 -0
- package/dist/daemon/url-access-baseline.d.ts +46 -0
- package/dist/daemon/url-access-baseline.d.ts.map +1 -0
- package/dist/daemon/url-access-baseline.js +154 -0
- package/dist/daemon/url-access-baseline.js.map +1 -0
- package/dist/daemon/url-block-decisions.d.ts +27 -0
- package/dist/daemon/url-block-decisions.d.ts.map +1 -0
- package/dist/daemon/url-block-decisions.js +100 -0
- package/dist/daemon/url-block-decisions.js.map +1 -0
- package/dist/daemon/url-extractor.d.ts +7 -0
- package/dist/daemon/url-extractor.d.ts.map +1 -0
- package/dist/daemon/url-extractor.js +101 -0
- package/dist/daemon/url-extractor.js.map +1 -0
- package/dist/daemon/userprompt-decision-escrow.d.ts +45 -0
- package/dist/daemon/userprompt-decision-escrow.d.ts.map +1 -0
- package/dist/daemon/userprompt-decision-escrow.js +248 -0
- package/dist/daemon/userprompt-decision-escrow.js.map +1 -0
- package/dist/daemon/vge-client.d.ts +64 -0
- package/dist/daemon/vge-client.d.ts.map +1 -0
- package/dist/daemon/vge-client.js +453 -0
- package/dist/daemon/vge-client.js.map +1 -0
- package/dist/daemon/vge-connectivity.d.ts +27 -0
- package/dist/daemon/vge-connectivity.d.ts.map +1 -0
- package/dist/daemon/vge-connectivity.js +214 -0
- package/dist/daemon/vge-connectivity.js.map +1 -0
- package/dist/daemon/vge-health-route.d.ts +4 -0
- package/dist/daemon/vge-health-route.d.ts.map +1 -0
- package/dist/daemon/vge-health-route.js +107 -0
- package/dist/daemon/vge-health-route.js.map +1 -0
- package/dist/daemon/vge-overload-backpressure.d.ts +51 -0
- package/dist/daemon/vge-overload-backpressure.d.ts.map +1 -0
- package/dist/daemon/vge-overload-backpressure.js +79 -0
- package/dist/daemon/vge-overload-backpressure.js.map +1 -0
- package/dist/daemon/vge-scan-failure-policy.d.ts +8 -0
- package/dist/daemon/vge-scan-failure-policy.d.ts.map +1 -0
- package/dist/daemon/vge-scan-failure-policy.js +12 -0
- package/dist/daemon/vge-scan-failure-policy.js.map +1 -0
- package/dist/shared/audit-writer.d.ts +9 -0
- package/dist/shared/audit-writer.d.ts.map +1 -0
- package/dist/shared/audit-writer.js +72 -0
- package/dist/shared/audit-writer.js.map +1 -0
- package/dist/shared/blocking-decision-choices.d.ts +13 -0
- package/dist/shared/blocking-decision-choices.d.ts.map +1 -0
- package/dist/shared/blocking-decision-choices.js +40 -0
- package/dist/shared/blocking-decision-choices.js.map +1 -0
- package/dist/shared/blocking-decision-reply.d.ts +13 -0
- package/dist/shared/blocking-decision-reply.d.ts.map +1 -0
- package/dist/shared/blocking-decision-reply.js +78 -0
- package/dist/shared/blocking-decision-reply.js.map +1 -0
- package/dist/shared/build-stamp.d.ts +7 -0
- package/dist/shared/build-stamp.d.ts.map +1 -0
- package/dist/shared/build-stamp.js +23 -0
- package/dist/shared/build-stamp.js.map +1 -0
- package/dist/shared/config-io.d.ts +41 -0
- package/dist/shared/config-io.d.ts.map +1 -0
- package/dist/shared/config-io.js +105 -0
- package/dist/shared/config-io.js.map +1 -0
- package/dist/shared/config-schema.d.ts +467 -0
- package/dist/shared/config-schema.d.ts.map +1 -0
- package/dist/shared/config-schema.js +281 -0
- package/dist/shared/config-schema.js.map +1 -0
- package/dist/shared/daemon-token.d.ts +7 -0
- package/dist/shared/daemon-token.d.ts.map +1 -0
- package/dist/shared/daemon-token.js +45 -0
- package/dist/shared/daemon-token.js.map +1 -0
- package/dist/shared/detect-os-user.d.ts +8 -0
- package/dist/shared/detect-os-user.d.ts.map +1 -0
- package/dist/shared/detect-os-user.js +34 -0
- package/dist/shared/detect-os-user.js.map +1 -0
- package/dist/shared/effective-client-id.d.ts +6 -0
- package/dist/shared/effective-client-id.d.ts.map +1 -0
- package/dist/shared/effective-client-id.js +22 -0
- package/dist/shared/effective-client-id.js.map +1 -0
- package/dist/shared/ipc-address.d.ts +10 -0
- package/dist/shared/ipc-address.d.ts.map +1 -0
- package/dist/shared/ipc-address.js +33 -0
- package/dist/shared/ipc-address.js.map +1 -0
- package/dist/shared/ipc-protocol.d.ts +60 -0
- package/dist/shared/ipc-protocol.d.ts.map +1 -0
- package/dist/shared/ipc-protocol.js +2 -0
- package/dist/shared/ipc-protocol.js.map +1 -0
- package/dist/shared/path-match.d.ts +4 -0
- package/dist/shared/path-match.d.ts.map +1 -0
- package/dist/shared/path-match.js +15 -0
- package/dist/shared/path-match.js.map +1 -0
- package/dist/shared/private-file.d.ts +17 -0
- package/dist/shared/private-file.d.ts.map +1 -0
- package/dist/shared/private-file.js +144 -0
- package/dist/shared/private-file.js.map +1 -0
- package/dist/shared/runtime-lock.d.ts +30 -0
- package/dist/shared/runtime-lock.d.ts.map +1 -0
- package/dist/shared/runtime-lock.js +142 -0
- package/dist/shared/runtime-lock.js.map +1 -0
- package/dist/shared/system-ca.d.ts +2 -0
- package/dist/shared/system-ca.d.ts.map +1 -0
- package/dist/shared/system-ca.js +31 -0
- package/dist/shared/system-ca.js.map +1 -0
- package/dist/shared/types.d.ts +172 -0
- package/dist/shared/types.d.ts.map +1 -0
- package/dist/shared/types.js +2 -0
- package/dist/shared/types.js.map +1 -0
- package/dist/shared/url-allowlist.d.ts +4 -0
- package/dist/shared/url-allowlist.d.ts.map +1 -0
- package/dist/shared/url-allowlist.js +33 -0
- package/dist/shared/url-allowlist.js.map +1 -0
- package/dist/shared/url-patterns.d.ts +12 -0
- package/dist/shared/url-patterns.d.ts.map +1 -0
- package/dist/shared/url-patterns.js +165 -0
- package/dist/shared/url-patterns.js.map +1 -0
- package/dist/shared/vge-url.d.ts +16 -0
- package/dist/shared/vge-url.d.ts.map +1 -0
- package/dist/shared/vge-url.js +75 -0
- package/dist/shared/vge-url.js.map +1 -0
- package/dist/shared/vge-verification.d.ts +18 -0
- package/dist/shared/vge-verification.d.ts.map +1 -0
- package/dist/shared/vge-verification.js +24 -0
- package/dist/shared/vge-verification.js.map +1 -0
- package/dist/shim/daemon-start-lock.d.ts +13 -0
- package/dist/shim/daemon-start-lock.d.ts.map +1 -0
- package/dist/shim/daemon-start-lock.js +26 -0
- package/dist/shim/daemon-start-lock.js.map +1 -0
- package/dist/shim/index.d.ts +17 -0
- package/dist/shim/index.d.ts.map +1 -0
- package/dist/shim/index.js +180 -0
- package/dist/shim/index.js.map +1 -0
- package/dist/shim/inline-resolver-terminal.d.ts +12 -0
- package/dist/shim/inline-resolver-terminal.d.ts.map +1 -0
- package/dist/shim/inline-resolver-terminal.js +201 -0
- package/dist/shim/inline-resolver-terminal.js.map +1 -0
- package/dist/shim/inline-resolver-transport.d.ts +15 -0
- package/dist/shim/inline-resolver-transport.d.ts.map +1 -0
- package/dist/shim/inline-resolver-transport.js +68 -0
- package/dist/shim/inline-resolver-transport.js.map +1 -0
- package/dist/shim/inline-resolver.d.ts +18 -0
- package/dist/shim/inline-resolver.d.ts.map +1 -0
- package/dist/shim/inline-resolver.js +152 -0
- package/dist/shim/inline-resolver.js.map +1 -0
- package/dist/shim/lazy-start.d.ts +2 -0
- package/dist/shim/lazy-start.d.ts.map +1 -0
- package/dist/shim/lazy-start.js +68 -0
- package/dist/shim/lazy-start.js.map +1 -0
- package/dist/tui/App.d.ts +7 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +62 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/components/Banner.d.ts +9 -0
- package/dist/tui/components/Banner.d.ts.map +1 -0
- package/dist/tui/components/Banner.js +29 -0
- package/dist/tui/components/Banner.js.map +1 -0
- package/dist/tui/components/BlockingDecisionModal.d.ts +11 -0
- package/dist/tui/components/BlockingDecisionModal.d.ts.map +1 -0
- package/dist/tui/components/BlockingDecisionModal.js +34 -0
- package/dist/tui/components/BlockingDecisionModal.js.map +1 -0
- package/dist/tui/components/ScreenChrome.d.ts +20 -0
- package/dist/tui/components/ScreenChrome.d.ts.map +1 -0
- package/dist/tui/components/ScreenChrome.js +30 -0
- package/dist/tui/components/ScreenChrome.js.map +1 -0
- package/dist/tui/components/SelectList.d.ts +14 -0
- package/dist/tui/components/SelectList.d.ts.map +1 -0
- package/dist/tui/components/SelectList.js +22 -0
- package/dist/tui/components/SelectList.js.map +1 -0
- package/dist/tui/components/TextField.d.ts +11 -0
- package/dist/tui/components/TextField.d.ts.map +1 -0
- package/dist/tui/components/TextField.js +34 -0
- package/dist/tui/components/TextField.js.map +1 -0
- package/dist/tui/lib/audit-log.d.ts +19 -0
- package/dist/tui/lib/audit-log.d.ts.map +1 -0
- package/dist/tui/lib/audit-log.js +49 -0
- package/dist/tui/lib/audit-log.js.map +1 -0
- package/dist/tui/lib/cc-permissions-audit.d.ts +24 -0
- package/dist/tui/lib/cc-permissions-audit.d.ts.map +1 -0
- package/dist/tui/lib/cc-permissions-audit.js +40 -0
- package/dist/tui/lib/cc-permissions-audit.js.map +1 -0
- package/dist/tui/lib/cc-permissions-defaults.d.ts +32 -0
- package/dist/tui/lib/cc-permissions-defaults.d.ts.map +1 -0
- package/dist/tui/lib/cc-permissions-defaults.js +171 -0
- package/dist/tui/lib/cc-permissions-defaults.js.map +1 -0
- package/dist/tui/lib/cc-permissions-io.d.ts +33 -0
- package/dist/tui/lib/cc-permissions-io.d.ts.map +1 -0
- package/dist/tui/lib/cc-permissions-io.js +165 -0
- package/dist/tui/lib/cc-permissions-io.js.map +1 -0
- package/dist/tui/lib/cc-permissions-ops.d.ts +19 -0
- package/dist/tui/lib/cc-permissions-ops.d.ts.map +1 -0
- package/dist/tui/lib/cc-permissions-ops.js +75 -0
- package/dist/tui/lib/cc-permissions-ops.js.map +1 -0
- package/dist/tui/lib/cc-permissions-scope.d.ts +15 -0
- package/dist/tui/lib/cc-permissions-scope.d.ts.map +1 -0
- package/dist/tui/lib/cc-permissions-scope.js +97 -0
- package/dist/tui/lib/cc-permissions-scope.js.map +1 -0
- package/dist/tui/lib/config-save.d.ts +14 -0
- package/dist/tui/lib/config-save.d.ts.map +1 -0
- package/dist/tui/lib/config-save.js +39 -0
- package/dist/tui/lib/config-save.js.map +1 -0
- package/dist/tui/lib/daemon-client.d.ts +67 -0
- package/dist/tui/lib/daemon-client.d.ts.map +1 -0
- package/dist/tui/lib/daemon-client.js +213 -0
- package/dist/tui/lib/daemon-client.js.map +1 -0
- package/dist/tui/lib/decision-stream.d.ts +29 -0
- package/dist/tui/lib/decision-stream.d.ts.map +1 -0
- package/dist/tui/lib/decision-stream.js +77 -0
- package/dist/tui/lib/decision-stream.js.map +1 -0
- package/dist/tui/lib/number-validate.d.ts +9 -0
- package/dist/tui/lib/number-validate.d.ts.map +1 -0
- package/dist/tui/lib/number-validate.js +12 -0
- package/dist/tui/lib/number-validate.js.map +1 -0
- package/dist/tui/lib/session-files.d.ts +9 -0
- package/dist/tui/lib/session-files.d.ts.map +1 -0
- package/dist/tui/lib/session-files.js +39 -0
- package/dist/tui/lib/session-files.js.map +1 -0
- package/dist/tui/lib/stats.d.ts +19 -0
- package/dist/tui/lib/stats.d.ts.map +1 -0
- package/dist/tui/lib/stats.js +72 -0
- package/dist/tui/lib/stats.js.map +1 -0
- package/dist/tui/lib/test-connection.d.ts +12 -0
- package/dist/tui/lib/test-connection.d.ts.map +1 -0
- package/dist/tui/lib/test-connection.js +59 -0
- package/dist/tui/lib/test-connection.js.map +1 -0
- package/dist/tui/lib/tools-policy-ops.d.ts +9 -0
- package/dist/tui/lib/tools-policy-ops.d.ts.map +1 -0
- package/dist/tui/lib/tools-policy-ops.js +30 -0
- package/dist/tui/lib/tools-policy-ops.js.map +1 -0
- package/dist/tui/lib/verified-at.d.ts +37 -0
- package/dist/tui/lib/verified-at.d.ts.map +1 -0
- package/dist/tui/lib/verified-at.js +47 -0
- package/dist/tui/lib/verified-at.js.map +1 -0
- package/dist/tui/screens/ApiKeys.d.ts +8 -0
- package/dist/tui/screens/ApiKeys.d.ts.map +1 -0
- package/dist/tui/screens/ApiKeys.js +250 -0
- package/dist/tui/screens/ApiKeys.js.map +1 -0
- package/dist/tui/screens/AuditViewer.d.ts +8 -0
- package/dist/tui/screens/AuditViewer.d.ts.map +1 -0
- package/dist/tui/screens/AuditViewer.js +56 -0
- package/dist/tui/screens/AuditViewer.js.map +1 -0
- package/dist/tui/screens/ContextIngressPolicy.d.ts +7 -0
- package/dist/tui/screens/ContextIngressPolicy.d.ts.map +1 -0
- package/dist/tui/screens/ContextIngressPolicy.js +145 -0
- package/dist/tui/screens/ContextIngressPolicy.js.map +1 -0
- package/dist/tui/screens/LiveEvents.d.ts +7 -0
- package/dist/tui/screens/LiveEvents.d.ts.map +1 -0
- package/dist/tui/screens/LiveEvents.js +72 -0
- package/dist/tui/screens/LiveEvents.js.map +1 -0
- package/dist/tui/screens/MainMenu.d.ts +11 -0
- package/dist/tui/screens/MainMenu.d.ts.map +1 -0
- package/dist/tui/screens/MainMenu.js +35 -0
- package/dist/tui/screens/MainMenu.js.map +1 -0
- package/dist/tui/screens/NativeCcPermissions.d.ts +7 -0
- package/dist/tui/screens/NativeCcPermissions.d.ts.map +1 -0
- package/dist/tui/screens/NativeCcPermissions.js +249 -0
- package/dist/tui/screens/NativeCcPermissions.js.map +1 -0
- package/dist/tui/screens/PendingEscalations.d.ts +7 -0
- package/dist/tui/screens/PendingEscalations.d.ts.map +1 -0
- package/dist/tui/screens/PendingEscalations.js +83 -0
- package/dist/tui/screens/PendingEscalations.js.map +1 -0
- package/dist/tui/screens/SecurityBaseline.d.ts +7 -0
- package/dist/tui/screens/SecurityBaseline.d.ts.map +1 -0
- package/dist/tui/screens/SecurityBaseline.js +272 -0
- package/dist/tui/screens/SecurityBaseline.js.map +1 -0
- package/dist/tui/screens/Stats.d.ts +7 -0
- package/dist/tui/screens/Stats.d.ts.map +1 -0
- package/dist/tui/screens/Stats.js +36 -0
- package/dist/tui/screens/Stats.js.map +1 -0
- package/dist/tui/screens/ToolsPolicy.d.ts +7 -0
- package/dist/tui/screens/ToolsPolicy.d.ts.map +1 -0
- package/dist/tui/screens/ToolsPolicy.js +87 -0
- package/dist/tui/screens/ToolsPolicy.js.map +1 -0
- package/dist/tui/screens/ViewConfig.d.ts +9 -0
- package/dist/tui/screens/ViewConfig.d.ts.map +1 -0
- package/dist/tui/screens/ViewConfig.js +117 -0
- package/dist/tui/screens/ViewConfig.js.map +1 -0
- package/dist/tui/strings.d.ts +97 -0
- package/dist/tui/strings.d.ts.map +1 -0
- package/dist/tui/strings.js +104 -0
- package/dist/tui/strings.js.map +1 -0
- package/dist/tui/types.d.ts +5 -0
- package/dist/tui/types.d.ts.map +1 -0
- package/dist/tui/types.js +2 -0
- package/dist/tui/types.js.map +1 -0
- package/package.json +74 -0
|
@@ -0,0 +1,511 @@
|
|
|
1
|
+
import * as crypto from 'crypto';
|
|
2
|
+
import { DEFAULT_CONFIG } from '../shared/config-schema.js';
|
|
3
|
+
import { canonicalizeKey } from './allowlist.js';
|
|
4
|
+
import { routeResponse } from './confidence-router.js';
|
|
5
|
+
import { getCurrentConfig, resolveToolPolicy } from './tool-policy.js';
|
|
6
|
+
import { createSession, getSessionLookupContext, addResourceAllow, addResourceBlock, isResourceBlocked, transitionState, } from './session-state.js';
|
|
7
|
+
import { scanToolOutput } from './vge-client.js';
|
|
8
|
+
import { analysisAuditFields, resolveAnalysisSource } from './analysis-source.js';
|
|
9
|
+
import { normalizeToolResponse } from './tool-response-normalizer.js';
|
|
10
|
+
import { ResponseCache } from './response-cache.js';
|
|
11
|
+
import { logPostToolKillTurn, logPostToolOutputScanFailedOpen, logPostToolOutputScanSkippedFailOpen, logToolOutputAnalyzed, logToolOutputEscalated, } from './audit-logger.js';
|
|
12
|
+
import { buildConversationFromTranscript } from './conversation-context.js';
|
|
13
|
+
import { conversationDecisionTimeoutMs } from './decision-timeout.js';
|
|
14
|
+
import { describeVgeBlockReason, isExplicitVgeBlock } from './blocking-decision-triggers.js';
|
|
15
|
+
import { createOrJoinBlockingDecision, waitForDecision, } from './decision-broker.js';
|
|
16
|
+
import { createPostToolDecisionEscrow, renderActivePostToolDecisionForParentAgent, renderPostToolEscrowStopReason, } from './posttool-decision-escrow.js';
|
|
17
|
+
import { consumePostToolAllowOnce, grantPostToolLocalFallbackAllowSession, isPostToolLocalFallbackAllowed, satisfyReadReplayFromToolInput, } from './posttool-decision-state.js';
|
|
18
|
+
import { hasActivePreToolConversationDecision } from './pretool-decision-escrow.js';
|
|
19
|
+
import { decisionOwnerFromHookPayload } from './decision-owner.js';
|
|
20
|
+
import { debugLogger } from './debug-logger.js';
|
|
21
|
+
import { recordPostToolScanFailure, recordPostToolScanSkipped } from './decision-metrics.js';
|
|
22
|
+
import { isFailOpenEligibleVgeFailure } from './vge-scan-failure-policy.js';
|
|
23
|
+
import { getPostToolBackpressureDecision, recordVgeOverloadFailure, recordVgeOverloadSuccess, releaseHalfOpenProbe, } from './vge-overload-backpressure.js';
|
|
24
|
+
import { resourceLabelForPostToolPrompt, renderBlockedPostToolOutput, renderFramedPostToolOutput, renderQuarantinedPostToolOutput, } from './posttool-render.js';
|
|
25
|
+
const responseCache = new ResponseCache();
|
|
26
|
+
export function prunePostToolResponseCache() {
|
|
27
|
+
responseCache.prune();
|
|
28
|
+
}
|
|
29
|
+
function sleep(ms) {
|
|
30
|
+
return ms > 0 ? new Promise((resolve) => setTimeout(resolve, ms)) : Promise.resolve();
|
|
31
|
+
}
|
|
32
|
+
function branchScores(vgeResult) {
|
|
33
|
+
return {
|
|
34
|
+
heuristics: vgeResult.branches.heuristics?.score ?? 0,
|
|
35
|
+
semantic: vgeResult.branches.semantic?.score ?? 0,
|
|
36
|
+
llmGuard: vgeResult.branches.llmGuard?.score ?? 0,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
function userBlockedResult() {
|
|
40
|
+
return {
|
|
41
|
+
decision: 'BLOCKED',
|
|
42
|
+
score: 0,
|
|
43
|
+
branches: {},
|
|
44
|
+
blockMessage: 'This tool output was previously blocked by user decision.',
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
function localPostToolScanFailureResult(reason) {
|
|
48
|
+
return {
|
|
49
|
+
decision: 'BLOCKED',
|
|
50
|
+
score: 0,
|
|
51
|
+
branches: {},
|
|
52
|
+
localFallbackReason: `posttool_scan_${reason}`,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
function maybeSatisfyReadReplay(payload) {
|
|
56
|
+
if (payload.tool_name === 'Read') {
|
|
57
|
+
satisfyReadReplayFromToolInput(payload.session_id, payload.tool_input, decisionOwnerFromHookPayload(payload));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
function warnAnalysisSourceIssue(payload, analysisSource) {
|
|
61
|
+
if (analysisSource.credentialPath === true) {
|
|
62
|
+
debugLogger().warn({
|
|
63
|
+
event: 'posttool_analysis_source_credential_path',
|
|
64
|
+
sessionId: payload.session_id,
|
|
65
|
+
toolName: payload.tool_name,
|
|
66
|
+
sourceKind: analysisSource.sourceKind,
|
|
67
|
+
sourcePath: analysisSource.sourcePath,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
if (analysisSource.fallbackReason) {
|
|
71
|
+
debugLogger().warn({
|
|
72
|
+
event: 'posttool_analysis_source_fallback',
|
|
73
|
+
sessionId: payload.session_id,
|
|
74
|
+
toolName: payload.tool_name,
|
|
75
|
+
sourceKind: analysisSource.sourceKind,
|
|
76
|
+
fallbackReason: analysisSource.fallbackReason,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
export async function enforcePostTool(payload) {
|
|
81
|
+
const owner = decisionOwnerFromHookPayload(payload);
|
|
82
|
+
const toolPolicy = resolveToolPolicy(payload.tool_name);
|
|
83
|
+
const contextBeforeCreate = getSessionLookupContext(payload.session_id);
|
|
84
|
+
const session = contextBeforeCreate.data ?? createSession(payload.session_id, null);
|
|
85
|
+
const context = contextBeforeCreate.data
|
|
86
|
+
? contextBeforeCreate
|
|
87
|
+
: getSessionLookupContext(payload.session_id);
|
|
88
|
+
const resourceId = canonicalizeKey(payload.tool_name, payload.tool_input);
|
|
89
|
+
const userAllowlisted = session.allowlist.has(resourceId);
|
|
90
|
+
const allowlistEscalationId = session.allowlistEscalationIds.get(resourceId) ?? null;
|
|
91
|
+
const analysisSource = resolveAnalysisSource(payload);
|
|
92
|
+
warnAnalysisSourceIssue(payload, analysisSource);
|
|
93
|
+
const normalized = normalizeToolResponse(analysisSource.source, payload.tool_error);
|
|
94
|
+
const config = getCurrentConfig() ?? DEFAULT_CONFIG;
|
|
95
|
+
const isSubagentToolOutput = owner.kind === 'subagent' || context.isSubagent;
|
|
96
|
+
if (payload.tool_name === 'Agent') {
|
|
97
|
+
const pendingPostToolDecision = renderActivePostToolDecisionForParentAgent(payload.session_id);
|
|
98
|
+
if (pendingPostToolDecision) {
|
|
99
|
+
const stopReason = [
|
|
100
|
+
'VGE Agent Guard: a subagent has a pending VGE decision.',
|
|
101
|
+
'The parent Agent result is withheld until the decision is resolved.',
|
|
102
|
+
'',
|
|
103
|
+
pendingPostToolDecision,
|
|
104
|
+
].join('\n');
|
|
105
|
+
logPostToolKillTurn({
|
|
106
|
+
sessionId: payload.session_id,
|
|
107
|
+
toolName: payload.tool_name,
|
|
108
|
+
resourceId,
|
|
109
|
+
routerOutcome: 'ESCALATE',
|
|
110
|
+
originalSizeBytes: normalized.contentBytes,
|
|
111
|
+
originalHash: normalized.contentHash,
|
|
112
|
+
synthesizedBy: 'policy_engine',
|
|
113
|
+
killReason: 'pending_subagent_decision',
|
|
114
|
+
});
|
|
115
|
+
return {
|
|
116
|
+
ccOutput: {
|
|
117
|
+
continue: false,
|
|
118
|
+
stopReason,
|
|
119
|
+
hookSpecificOutput: { hookEventName: 'PostToolUse', additionalContext: stopReason },
|
|
120
|
+
},
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
if (isResourceBlocked(session, resourceId)) {
|
|
125
|
+
return {
|
|
126
|
+
ccOutput: renderBlockedPostToolOutput({
|
|
127
|
+
payload,
|
|
128
|
+
resourceId,
|
|
129
|
+
vgeResult: userBlockedResult(),
|
|
130
|
+
routerOutcome: 'ESCALATE',
|
|
131
|
+
originalSizeBytes: normalized.contentBytes,
|
|
132
|
+
originalHash: normalized.contentHash,
|
|
133
|
+
actionTaken: 'user_blocklist_redacted',
|
|
134
|
+
failReason: 'user_block',
|
|
135
|
+
analysisSource,
|
|
136
|
+
}),
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
if (!userAllowlisted &&
|
|
140
|
+
consumePostToolAllowOnce({
|
|
141
|
+
sessionId: payload.session_id,
|
|
142
|
+
owner,
|
|
143
|
+
toolName: payload.tool_name,
|
|
144
|
+
resourceId,
|
|
145
|
+
contentHash: normalized.contentHash,
|
|
146
|
+
})) {
|
|
147
|
+
maybeSatisfyReadReplay(payload);
|
|
148
|
+
return { ccOutput: null };
|
|
149
|
+
}
|
|
150
|
+
if (!toolPolicy.analyze_output) {
|
|
151
|
+
logToolOutputAnalyzed({
|
|
152
|
+
sessionId: payload.session_id,
|
|
153
|
+
toolName: payload.tool_name,
|
|
154
|
+
resourceId,
|
|
155
|
+
escalationId: allowlistEscalationId,
|
|
156
|
+
userAllowlisted: false,
|
|
157
|
+
routerOutcome: 'ALLOW',
|
|
158
|
+
enforcementTaken: 'none',
|
|
159
|
+
...analysisAuditFields(analysisSource),
|
|
160
|
+
});
|
|
161
|
+
maybeSatisfyReadReplay(payload);
|
|
162
|
+
return { ccOutput: null };
|
|
163
|
+
}
|
|
164
|
+
const conversation = buildConversationFromTranscript(payload.transcript_path);
|
|
165
|
+
const cacheKey = `${resourceId}:sha256:${normalized.contentHash}`;
|
|
166
|
+
const cached = userAllowlisted ? null : responseCache.get(cacheKey);
|
|
167
|
+
let vgeResult = cached;
|
|
168
|
+
if (!cached) {
|
|
169
|
+
const canUseBackpressure = config.policy.vge_failure_mode.posttool_output === 'fail_open' &&
|
|
170
|
+
!(isSubagentToolOutput && config.policy.subagent_output_analysis === 'off');
|
|
171
|
+
const backpressure = canUseBackpressure
|
|
172
|
+
? getPostToolBackpressureDecision({
|
|
173
|
+
stage: 'posttool_output',
|
|
174
|
+
toolName: payload.tool_name,
|
|
175
|
+
config: config.policy.vge_overload_backpressure.posttool_output,
|
|
176
|
+
})
|
|
177
|
+
: { kind: 'allow' };
|
|
178
|
+
if (backpressure.kind === 'skip') {
|
|
179
|
+
transitionState(payload.session_id, 'caution');
|
|
180
|
+
recordPostToolScanSkipped(backpressure.reason);
|
|
181
|
+
logPostToolOutputScanSkippedFailOpen({
|
|
182
|
+
sessionId: payload.session_id,
|
|
183
|
+
toolName: payload.tool_name,
|
|
184
|
+
resourceId,
|
|
185
|
+
skipReason: backpressure.reason,
|
|
186
|
+
cooldownRemainingMs: backpressure.cooldownRemainingMs,
|
|
187
|
+
triggerFailureReason: backpressure.triggerFailureReason,
|
|
188
|
+
triggerHttpStatus: backpressure.triggerHttpStatus,
|
|
189
|
+
originalHash: normalized.contentHash,
|
|
190
|
+
originalSizeBytes: normalized.contentBytes,
|
|
191
|
+
});
|
|
192
|
+
return { ccOutput: null };
|
|
193
|
+
}
|
|
194
|
+
const probeId = backpressure.kind === 'probe' ? backpressure.probeId : null;
|
|
195
|
+
if (backpressure.kind === 'probe')
|
|
196
|
+
await sleep(backpressure.halfOpenJitterMs);
|
|
197
|
+
const scan = await scanToolOutput(normalized.textToAnalyze, payload.tool_name, resourceId, payload.session_id, {
|
|
198
|
+
userAllowlisted,
|
|
199
|
+
toolInput: payload.tool_input,
|
|
200
|
+
toolResultContent: normalized.toolResultContent,
|
|
201
|
+
toolResultIsError: normalized.isError,
|
|
202
|
+
escalationId: allowlistEscalationId,
|
|
203
|
+
subagent: owner.kind === 'subagent' || context.isSubagent,
|
|
204
|
+
agentId: payload.agent_id,
|
|
205
|
+
agentType: payload.agent_type,
|
|
206
|
+
parentSessionId: context.parentSessionId,
|
|
207
|
+
conversation,
|
|
208
|
+
}).finally(() => {
|
|
209
|
+
if (probeId)
|
|
210
|
+
releaseHalfOpenProbe('posttool_output', probeId);
|
|
211
|
+
});
|
|
212
|
+
if (scan.result)
|
|
213
|
+
recordVgeOverloadSuccess('posttool_output');
|
|
214
|
+
if (!scan.result &&
|
|
215
|
+
scan.failureReason &&
|
|
216
|
+
config.policy.vge_failure_mode.posttool_output === 'fail_open' &&
|
|
217
|
+
isFailOpenEligibleVgeFailure({ failureReason: scan.failureReason, httpStatus: scan.httpStatus })) {
|
|
218
|
+
recordPostToolScanFailure(scan.failureReason, 'fail_open');
|
|
219
|
+
// ADR-0006: network and timeout failures fail open but do not open overload cooldown.
|
|
220
|
+
const cooldown = recordVgeOverloadFailure({
|
|
221
|
+
stage: 'posttool_output',
|
|
222
|
+
failure: {
|
|
223
|
+
failureReason: scan.failureReason,
|
|
224
|
+
httpStatus: scan.httpStatus,
|
|
225
|
+
retryAfterMs: scan.retryAfterMs,
|
|
226
|
+
},
|
|
227
|
+
config: config.policy.vge_overload_backpressure.posttool_output,
|
|
228
|
+
});
|
|
229
|
+
transitionState(payload.session_id, 'caution');
|
|
230
|
+
logPostToolOutputScanFailedOpen({
|
|
231
|
+
sessionId: payload.session_id,
|
|
232
|
+
toolName: payload.tool_name,
|
|
233
|
+
resourceId,
|
|
234
|
+
failureReason: scan.failureReason,
|
|
235
|
+
httpStatus: scan.httpStatus,
|
|
236
|
+
elapsedMs: scan.elapsedMs,
|
|
237
|
+
localRequestId: scan.localRequestId,
|
|
238
|
+
attempt: scan.attempt,
|
|
239
|
+
retryAfterMs: scan.retryAfterMs,
|
|
240
|
+
...(cooldown.cooldownStarted
|
|
241
|
+
? {
|
|
242
|
+
cooldownStarted: true,
|
|
243
|
+
cooldownMs: cooldown.cooldownMs,
|
|
244
|
+
cooldownUntilMs: cooldown.cooldownUntilMs,
|
|
245
|
+
}
|
|
246
|
+
: { cooldownStarted: false }),
|
|
247
|
+
});
|
|
248
|
+
maybeSatisfyReadReplay(payload);
|
|
249
|
+
return { ccOutput: null };
|
|
250
|
+
}
|
|
251
|
+
vgeResult = scan.result ?? (scan.failureReason ? localPostToolScanFailureResult(scan.failureReason) : null);
|
|
252
|
+
if (scan.failureReason)
|
|
253
|
+
recordPostToolScanFailure(scan.failureReason);
|
|
254
|
+
if (scan.result && !userAllowlisted)
|
|
255
|
+
responseCache.set(cacheKey, scan.result);
|
|
256
|
+
}
|
|
257
|
+
if (!vgeResult) {
|
|
258
|
+
recordPostToolScanFailure('vge_error');
|
|
259
|
+
vgeResult = localPostToolScanFailureResult('vge_error');
|
|
260
|
+
}
|
|
261
|
+
const outcome = routeResponse(vgeResult);
|
|
262
|
+
if (vgeResult.localFallbackReason &&
|
|
263
|
+
isPostToolLocalFallbackAllowed({
|
|
264
|
+
sessionId: payload.session_id,
|
|
265
|
+
toolName: payload.tool_name,
|
|
266
|
+
reason: vgeResult.localFallbackReason,
|
|
267
|
+
})) {
|
|
268
|
+
logToolOutputAnalyzed({
|
|
269
|
+
sessionId: payload.session_id,
|
|
270
|
+
toolName: payload.tool_name,
|
|
271
|
+
resourceId,
|
|
272
|
+
escalationId: allowlistEscalationId,
|
|
273
|
+
userAllowlisted: true,
|
|
274
|
+
routerOutcome: outcome,
|
|
275
|
+
enforcementTaken: 'none',
|
|
276
|
+
...analysisAuditFields(analysisSource),
|
|
277
|
+
});
|
|
278
|
+
maybeSatisfyReadReplay(payload);
|
|
279
|
+
return { ccOutput: null };
|
|
280
|
+
}
|
|
281
|
+
if (isSubagentToolOutput && config.policy.subagent_output_analysis === 'off') {
|
|
282
|
+
logToolOutputAnalyzed({
|
|
283
|
+
sessionId: payload.session_id,
|
|
284
|
+
toolName: payload.tool_name,
|
|
285
|
+
resourceId,
|
|
286
|
+
escalationId: allowlistEscalationId,
|
|
287
|
+
userAllowlisted,
|
|
288
|
+
routerOutcome: outcome,
|
|
289
|
+
enforcementTaken: 'none',
|
|
290
|
+
...analysisAuditFields(analysisSource),
|
|
291
|
+
});
|
|
292
|
+
maybeSatisfyReadReplay(payload);
|
|
293
|
+
return { ccOutput: null };
|
|
294
|
+
}
|
|
295
|
+
if (userAllowlisted) {
|
|
296
|
+
logToolOutputAnalyzed({
|
|
297
|
+
sessionId: payload.session_id,
|
|
298
|
+
toolName: payload.tool_name,
|
|
299
|
+
resourceId,
|
|
300
|
+
escalationId: allowlistEscalationId,
|
|
301
|
+
userAllowlisted: true,
|
|
302
|
+
routerOutcome: outcome,
|
|
303
|
+
enforcementTaken: 'none',
|
|
304
|
+
...analysisAuditFields(analysisSource),
|
|
305
|
+
});
|
|
306
|
+
maybeSatisfyReadReplay(payload);
|
|
307
|
+
return { ccOutput: null };
|
|
308
|
+
}
|
|
309
|
+
if (outcome === 'ALLOW') {
|
|
310
|
+
logToolOutputAnalyzed({
|
|
311
|
+
sessionId: payload.session_id,
|
|
312
|
+
toolName: payload.tool_name,
|
|
313
|
+
resourceId,
|
|
314
|
+
escalationId: allowlistEscalationId,
|
|
315
|
+
userAllowlisted: false,
|
|
316
|
+
routerOutcome: outcome,
|
|
317
|
+
enforcementTaken: 'none',
|
|
318
|
+
...analysisAuditFields(analysisSource),
|
|
319
|
+
});
|
|
320
|
+
maybeSatisfyReadReplay(payload);
|
|
321
|
+
return { ccOutput: null };
|
|
322
|
+
}
|
|
323
|
+
if (outcome === 'HARD_TAINT' || outcome === 'SOFT_TAINT') {
|
|
324
|
+
transitionState(payload.session_id, outcome === 'HARD_TAINT' ? 'tainted' : 'caution');
|
|
325
|
+
logToolOutputAnalyzed({
|
|
326
|
+
sessionId: payload.session_id,
|
|
327
|
+
toolName: payload.tool_name,
|
|
328
|
+
resourceId,
|
|
329
|
+
escalationId: allowlistEscalationId,
|
|
330
|
+
userAllowlisted: false,
|
|
331
|
+
routerOutcome: outcome,
|
|
332
|
+
enforcementTaken: 'tainted',
|
|
333
|
+
...analysisAuditFields(analysisSource),
|
|
334
|
+
});
|
|
335
|
+
}
|
|
336
|
+
if (isExplicitVgeBlock(vgeResult)) {
|
|
337
|
+
logToolOutputAnalyzed({
|
|
338
|
+
sessionId: payload.session_id,
|
|
339
|
+
toolName: payload.tool_name,
|
|
340
|
+
resourceId,
|
|
341
|
+
escalationId: allowlistEscalationId,
|
|
342
|
+
userAllowlisted: false,
|
|
343
|
+
routerOutcome: outcome,
|
|
344
|
+
enforcementTaken: 'escalated',
|
|
345
|
+
...analysisAuditFields(analysisSource),
|
|
346
|
+
});
|
|
347
|
+
if (hasActivePreToolConversationDecision(payload.session_id)) {
|
|
348
|
+
return {
|
|
349
|
+
ccOutput: renderBlockedPostToolOutput({
|
|
350
|
+
payload,
|
|
351
|
+
resourceId,
|
|
352
|
+
vgeResult,
|
|
353
|
+
routerOutcome: outcome,
|
|
354
|
+
originalSizeBytes: normalized.contentBytes,
|
|
355
|
+
originalHash: normalized.contentHash,
|
|
356
|
+
actionTaken: 'session_locked',
|
|
357
|
+
failReason: 'session_locked',
|
|
358
|
+
analysisSource,
|
|
359
|
+
}),
|
|
360
|
+
};
|
|
361
|
+
}
|
|
362
|
+
const created = createOrJoinBlockingDecision({
|
|
363
|
+
sessionId: payload.session_id,
|
|
364
|
+
owner,
|
|
365
|
+
kind: 'posttool_output',
|
|
366
|
+
toolName: payload.tool_name,
|
|
367
|
+
resourceId,
|
|
368
|
+
resourceLabel: resourceLabelForPostToolPrompt(payload, resourceId),
|
|
369
|
+
reason: describeVgeBlockReason(vgeResult),
|
|
370
|
+
vgeResult,
|
|
371
|
+
timeoutMs: conversationDecisionTimeoutMs(config),
|
|
372
|
+
resolverStaleMs: config.policy.resolver_heartbeat_stale_ms,
|
|
373
|
+
});
|
|
374
|
+
if (created.type === 'fail_closed' && created.reason === 'resolver_missing') {
|
|
375
|
+
const escrowDecision = createPostToolDecisionEscrow({
|
|
376
|
+
decision: created.decision,
|
|
377
|
+
toolName: payload.tool_name,
|
|
378
|
+
resourceId,
|
|
379
|
+
routerOutcome: outcome,
|
|
380
|
+
vgeResult,
|
|
381
|
+
contentBytes: normalized.contentBytes,
|
|
382
|
+
contentHash: normalized.contentHash,
|
|
383
|
+
toolInput: payload.tool_input,
|
|
384
|
+
});
|
|
385
|
+
const decisionPrompt = renderPostToolEscrowStopReason(escrowDecision);
|
|
386
|
+
return {
|
|
387
|
+
ccOutput: renderQuarantinedPostToolOutput({
|
|
388
|
+
payload,
|
|
389
|
+
resourceId,
|
|
390
|
+
vgeResult,
|
|
391
|
+
routerOutcome: outcome,
|
|
392
|
+
originalSizeBytes: normalized.contentBytes,
|
|
393
|
+
originalHash: normalized.contentHash,
|
|
394
|
+
decisionPrompt,
|
|
395
|
+
decisionExpiresAt: created.decision.expiresAt,
|
|
396
|
+
analysisSource,
|
|
397
|
+
}),
|
|
398
|
+
};
|
|
399
|
+
}
|
|
400
|
+
if (created.type === 'fail_closed') {
|
|
401
|
+
return {
|
|
402
|
+
ccOutput: renderBlockedPostToolOutput({
|
|
403
|
+
payload,
|
|
404
|
+
resourceId,
|
|
405
|
+
vgeResult,
|
|
406
|
+
routerOutcome: outcome,
|
|
407
|
+
originalSizeBytes: normalized.contentBytes,
|
|
408
|
+
originalHash: normalized.contentHash,
|
|
409
|
+
actionTaken: created.reason,
|
|
410
|
+
failReason: created.reason,
|
|
411
|
+
analysisSource,
|
|
412
|
+
}),
|
|
413
|
+
};
|
|
414
|
+
}
|
|
415
|
+
const resolved = await waitForDecision(created.decisionId);
|
|
416
|
+
if (resolved.choice === 'allow_once')
|
|
417
|
+
return { ccOutput: null };
|
|
418
|
+
if (resolved.choice === 'allow_session') {
|
|
419
|
+
if (vgeResult.localFallbackReason) {
|
|
420
|
+
grantPostToolLocalFallbackAllowSession({
|
|
421
|
+
decisionId: created.decisionId,
|
|
422
|
+
reason: vgeResult.localFallbackReason,
|
|
423
|
+
sessionId: payload.session_id,
|
|
424
|
+
toolName: payload.tool_name,
|
|
425
|
+
});
|
|
426
|
+
}
|
|
427
|
+
else {
|
|
428
|
+
addResourceAllow(payload.session_id, resourceId, created.decisionId);
|
|
429
|
+
}
|
|
430
|
+
return { ccOutput: null };
|
|
431
|
+
}
|
|
432
|
+
if (resolved.choice === 'block') {
|
|
433
|
+
addResourceBlock(payload.session_id, resourceId, created.decisionId);
|
|
434
|
+
return {
|
|
435
|
+
ccOutput: renderBlockedPostToolOutput({
|
|
436
|
+
payload,
|
|
437
|
+
resourceId,
|
|
438
|
+
vgeResult,
|
|
439
|
+
routerOutcome: outcome,
|
|
440
|
+
originalSizeBytes: normalized.contentBytes,
|
|
441
|
+
originalHash: normalized.contentHash,
|
|
442
|
+
actionTaken: 'user_block',
|
|
443
|
+
failReason: 'user_block',
|
|
444
|
+
analysisSource,
|
|
445
|
+
}),
|
|
446
|
+
};
|
|
447
|
+
}
|
|
448
|
+
return {
|
|
449
|
+
ccOutput: renderBlockedPostToolOutput({
|
|
450
|
+
payload,
|
|
451
|
+
resourceId,
|
|
452
|
+
vgeResult,
|
|
453
|
+
routerOutcome: outcome,
|
|
454
|
+
originalSizeBytes: normalized.contentBytes,
|
|
455
|
+
originalHash: normalized.contentHash,
|
|
456
|
+
actionTaken: resolved.failClosedReason ?? 'terminal_without_choice',
|
|
457
|
+
failReason: resolved.failClosedReason ?? 'terminal_without_choice',
|
|
458
|
+
analysisSource,
|
|
459
|
+
}),
|
|
460
|
+
};
|
|
461
|
+
}
|
|
462
|
+
if (outcome === 'ESCALATE') {
|
|
463
|
+
const escalationId = `frame_${crypto.randomUUID()}`;
|
|
464
|
+
logToolOutputAnalyzed({
|
|
465
|
+
sessionId: payload.session_id,
|
|
466
|
+
toolName: payload.tool_name,
|
|
467
|
+
resourceId,
|
|
468
|
+
escalationId: allowlistEscalationId,
|
|
469
|
+
userAllowlisted: false,
|
|
470
|
+
routerOutcome: outcome,
|
|
471
|
+
enforcementTaken: 'escalated',
|
|
472
|
+
...analysisAuditFields(analysisSource),
|
|
473
|
+
});
|
|
474
|
+
logToolOutputEscalated({
|
|
475
|
+
escalationId,
|
|
476
|
+
sessionId: payload.session_id,
|
|
477
|
+
toolName: payload.tool_name,
|
|
478
|
+
resourceId,
|
|
479
|
+
analysisId: vgeResult.id ?? null,
|
|
480
|
+
branches: branchScores(vgeResult),
|
|
481
|
+
routerOutcome: outcome,
|
|
482
|
+
});
|
|
483
|
+
}
|
|
484
|
+
if (outcome === 'HARD_TAINT') {
|
|
485
|
+
return {
|
|
486
|
+
ccOutput: renderBlockedPostToolOutput({
|
|
487
|
+
payload,
|
|
488
|
+
resourceId,
|
|
489
|
+
vgeResult,
|
|
490
|
+
routerOutcome: outcome,
|
|
491
|
+
originalSizeBytes: normalized.contentBytes,
|
|
492
|
+
originalHash: normalized.contentHash,
|
|
493
|
+
actionTaken: 'hard_taint_redacted',
|
|
494
|
+
failReason: 'user_block',
|
|
495
|
+
analysisSource,
|
|
496
|
+
}),
|
|
497
|
+
};
|
|
498
|
+
}
|
|
499
|
+
return {
|
|
500
|
+
ccOutput: renderFramedPostToolOutput({
|
|
501
|
+
payload,
|
|
502
|
+
resourceId,
|
|
503
|
+
vgeResult,
|
|
504
|
+
routerOutcome: outcome,
|
|
505
|
+
originalSizeBytes: normalized.contentBytes,
|
|
506
|
+
originalHash: normalized.contentHash,
|
|
507
|
+
analysisSource,
|
|
508
|
+
}),
|
|
509
|
+
};
|
|
510
|
+
}
|
|
511
|
+
//# sourceMappingURL=posttool-enforcement.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"posttool-enforcement.js","sourceRoot":"","sources":["../../src/daemon/posttool-enforcement.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { CCPostToolPayload, GuardResponseSubset, RouterOutcome } from '../shared/types.js';
|
|
2
|
+
import { type ResolvedAnalysisSource } from './analysis-source.js';
|
|
3
|
+
import { type SynthesizedBy } from './audit-logger.js';
|
|
4
|
+
import type { BlockingDecisionFailReason } from './decision-broker.js';
|
|
5
|
+
import type { SecurityFrameVariant } from './security-frame.js';
|
|
6
|
+
export declare function frameAction(outcome: RouterOutcome): string;
|
|
7
|
+
export declare function synthesizedByForPostTool(vgeResult: GuardResponseSubset, failReason?: BlockingDecisionFailReason | 'user_block'): SynthesizedBy;
|
|
8
|
+
export declare function stopReason(reason: BlockingDecisionFailReason | 'user_block', opts?: {
|
|
9
|
+
decisionExpiresAt?: number;
|
|
10
|
+
}): string;
|
|
11
|
+
export declare function oneLine(value: string, maxLength?: number): string;
|
|
12
|
+
export declare function stringField(input: Record<string, unknown>, key: string): string | null;
|
|
13
|
+
export declare function resourceLabelForPostToolPrompt(payload: CCPostToolPayload, resourceId: string): string;
|
|
14
|
+
export declare function resolvePostToolFrameVariant(toolName: string, routerOutcome: RouterOutcome): SecurityFrameVariant;
|
|
15
|
+
export declare function renderBlockedPostToolOutput(params: {
|
|
16
|
+
payload: CCPostToolPayload;
|
|
17
|
+
resourceId: string;
|
|
18
|
+
vgeResult: GuardResponseSubset;
|
|
19
|
+
routerOutcome: RouterOutcome;
|
|
20
|
+
originalSizeBytes: number;
|
|
21
|
+
originalHash: string;
|
|
22
|
+
actionTaken: string;
|
|
23
|
+
failReason: BlockingDecisionFailReason | 'user_block';
|
|
24
|
+
analysisSource: ResolvedAnalysisSource;
|
|
25
|
+
}): unknown;
|
|
26
|
+
export declare function renderQuarantinedPostToolOutput(params: {
|
|
27
|
+
payload: CCPostToolPayload;
|
|
28
|
+
resourceId: string;
|
|
29
|
+
vgeResult: GuardResponseSubset;
|
|
30
|
+
routerOutcome: RouterOutcome;
|
|
31
|
+
originalSizeBytes: number;
|
|
32
|
+
originalHash: string;
|
|
33
|
+
decisionPrompt: string;
|
|
34
|
+
decisionExpiresAt?: number;
|
|
35
|
+
analysisSource: ResolvedAnalysisSource;
|
|
36
|
+
}): unknown;
|
|
37
|
+
export declare function neutralFailClosedFrame(payload: CCPostToolPayload): string;
|
|
38
|
+
export declare function renderPostToolFailClosedOutput(payload: CCPostToolPayload): unknown;
|
|
39
|
+
export declare function renderFramedPostToolOutput(params: {
|
|
40
|
+
payload: CCPostToolPayload;
|
|
41
|
+
resourceId: string;
|
|
42
|
+
vgeResult: GuardResponseSubset;
|
|
43
|
+
routerOutcome: RouterOutcome;
|
|
44
|
+
originalSizeBytes: number;
|
|
45
|
+
originalHash: string;
|
|
46
|
+
analysisSource: ResolvedAnalysisSource;
|
|
47
|
+
}): unknown;
|
|
48
|
+
//# sourceMappingURL=posttool-render.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"posttool-render.d.ts","sourceRoot":"","sources":["../../src/daemon/posttool-render.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAChG,OAAO,EAAuB,KAAK,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AACxF,OAAO,EAIL,KAAK,aAAa,EACnB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,sBAAsB,CAAC;AAGvE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAsChE,wBAAgB,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,MAAM,CAE1D;AAED,wBAAgB,wBAAwB,CACtC,SAAS,EAAE,mBAAmB,EAC9B,UAAU,CAAC,EAAE,0BAA0B,GAAG,YAAY,GACrD,aAAa,CAOf;AAED,wBAAgB,UAAU,CACxB,MAAM,EAAE,0BAA0B,GAAG,YAAY,EACjD,IAAI,GAAE;IAAE,iBAAiB,CAAC,EAAE,MAAM,CAAA;CAAO,GACxC,MAAM,CAkBR;AAED,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,SAAM,GAAG,MAAM,CAI9D;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAGtF;AAED,wBAAgB,8BAA8B,CAAC,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,CAarG;AAED,wBAAgB,2BAA2B,CACzC,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,aAAa,GAC3B,oBAAoB,CAItB;AAED,wBAAgB,2BAA2B,CAAC,MAAM,EAAE;IAClD,OAAO,EAAE,iBAAiB,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,mBAAmB,CAAC;IAC/B,aAAa,EAAE,aAAa,CAAC;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,0BAA0B,GAAG,YAAY,CAAC;IACtD,cAAc,EAAE,sBAAsB,CAAC;CACxC,GAAG,OAAO,CA0FV;AAED,wBAAgB,+BAA+B,CAAC,MAAM,EAAE;IACtD,OAAO,EAAE,iBAAiB,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,mBAAmB,CAAC;IAC/B,aAAa,EAAE,aAAa,CAAC;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,cAAc,EAAE,sBAAsB,CAAC;CACxC,GAAG,OAAO,CAsGV;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,iBAAiB,GAAG,MAAM,CAWzE;AAED,wBAAgB,8BAA8B,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CASlF;AAED,wBAAgB,0BAA0B,CAAC,MAAM,EAAE;IACjD,OAAO,EAAE,iBAAiB,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,mBAAmB,CAAC;IAC/B,aAAa,EAAE,aAAa,CAAC;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,sBAAsB,CAAC;CACxC,GAAG,OAAO,CA8BV"}
|