@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,144 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import * as childProcess from 'child_process';
|
|
3
|
+
import * as os from 'os';
|
|
4
|
+
import * as path from 'path';
|
|
5
|
+
function supportsPosixModes(platform) {
|
|
6
|
+
return platform !== 'win32';
|
|
7
|
+
}
|
|
8
|
+
function currentWindowsUser() {
|
|
9
|
+
const username = os.userInfo().username || process.env['USERNAME'];
|
|
10
|
+
if (!username)
|
|
11
|
+
throw new Error('cannot determine current Windows user for private file ACL');
|
|
12
|
+
return username;
|
|
13
|
+
}
|
|
14
|
+
function resolveIcaclsCommand() {
|
|
15
|
+
const systemRoot = process.env['SystemRoot'] || process.env['WINDIR'];
|
|
16
|
+
return systemRoot ? path.win32.join(systemRoot, 'System32', 'icacls.exe') : 'icacls';
|
|
17
|
+
}
|
|
18
|
+
function hardenWindowsAcl(filePath) {
|
|
19
|
+
const currentUser = currentWindowsUser();
|
|
20
|
+
const options = { stdio: 'pipe' };
|
|
21
|
+
const icacls = resolveIcaclsCommand();
|
|
22
|
+
// Protects against other local user accounts, not local Administrators, SYSTEM, or kernel-level malware.
|
|
23
|
+
childProcess.execFileSync(icacls, [filePath, '/inheritance:r'], options);
|
|
24
|
+
childProcess.execFileSync(icacls, [
|
|
25
|
+
filePath,
|
|
26
|
+
'/remove:g',
|
|
27
|
+
'*S-1-1-0',
|
|
28
|
+
'*S-1-5-11',
|
|
29
|
+
'*S-1-5-32-545',
|
|
30
|
+
], options);
|
|
31
|
+
childProcess.execFileSync(icacls, [
|
|
32
|
+
filePath,
|
|
33
|
+
'/grant:r',
|
|
34
|
+
`${currentUser}:(F)`,
|
|
35
|
+
'*S-1-5-18:(F)',
|
|
36
|
+
'*S-1-5-32-544:(F)',
|
|
37
|
+
], options);
|
|
38
|
+
}
|
|
39
|
+
export function chmodPrivateSync(filePath, opts = {}) {
|
|
40
|
+
const platform = opts.platform ?? process.platform;
|
|
41
|
+
if (!supportsPosixModes(platform)) {
|
|
42
|
+
hardenWindowsAcl(filePath);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
fs.chmodSync(filePath, 0o600);
|
|
46
|
+
}
|
|
47
|
+
export function chmodPrivateDirectorySync(directoryPath, opts = {}) {
|
|
48
|
+
const platform = opts.platform ?? process.platform;
|
|
49
|
+
if (!supportsPosixModes(platform)) {
|
|
50
|
+
hardenWindowsAcl(directoryPath);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
fs.chmodSync(directoryPath, 0o700);
|
|
54
|
+
}
|
|
55
|
+
function removeFailedPrivateFile(filePath) {
|
|
56
|
+
fs.rmSync(filePath, { force: true });
|
|
57
|
+
}
|
|
58
|
+
function fsyncDirectoryBestEffort(dir) {
|
|
59
|
+
try {
|
|
60
|
+
const fd = fs.openSync(dir, 'r');
|
|
61
|
+
try {
|
|
62
|
+
fs.fsyncSync(fd);
|
|
63
|
+
}
|
|
64
|
+
finally {
|
|
65
|
+
fs.closeSync(fd);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
// Some platforms and filesystems do not support fsync on directories.
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
export function writePrivateFileSync(filePath, content, opts = {}) {
|
|
73
|
+
const platform = opts.platform ?? process.platform;
|
|
74
|
+
const fd = fs.openSync(filePath, 'w', supportsPosixModes(platform) ? 0o600 : undefined);
|
|
75
|
+
try {
|
|
76
|
+
if (typeof content === 'string')
|
|
77
|
+
fs.writeSync(fd, content);
|
|
78
|
+
else
|
|
79
|
+
fs.writeSync(fd, content, 0, content.length);
|
|
80
|
+
fs.fsyncSync(fd);
|
|
81
|
+
}
|
|
82
|
+
finally {
|
|
83
|
+
fs.closeSync(fd);
|
|
84
|
+
}
|
|
85
|
+
try {
|
|
86
|
+
chmodPrivateSync(filePath, { platform });
|
|
87
|
+
}
|
|
88
|
+
catch (err) {
|
|
89
|
+
removeFailedPrivateFile(filePath);
|
|
90
|
+
throw err;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
export function writePrivateFileAtomicSync(filePath, content, opts = {}) {
|
|
94
|
+
const platform = opts.platform ?? process.platform;
|
|
95
|
+
const dir = path.dirname(filePath);
|
|
96
|
+
const tmp = path.join(dir, `.${path.basename(filePath)}.${process.pid}.${Date.now()}.tmp-${Math.random().toString(36).slice(2)}`);
|
|
97
|
+
let fd = null;
|
|
98
|
+
try {
|
|
99
|
+
fd = fs.openSync(tmp, 'w', supportsPosixModes(platform) ? 0o600 : undefined);
|
|
100
|
+
if (typeof content === 'string')
|
|
101
|
+
fs.writeSync(fd, content);
|
|
102
|
+
else
|
|
103
|
+
fs.writeSync(fd, content, 0, content.length);
|
|
104
|
+
fs.fsyncSync(fd);
|
|
105
|
+
fs.closeSync(fd);
|
|
106
|
+
fd = null;
|
|
107
|
+
chmodPrivateSync(tmp, { platform });
|
|
108
|
+
fs.renameSync(tmp, filePath);
|
|
109
|
+
chmodPrivateSync(filePath, { platform });
|
|
110
|
+
fsyncDirectoryBestEffort(dir);
|
|
111
|
+
}
|
|
112
|
+
catch (err) {
|
|
113
|
+
if (fd !== null) {
|
|
114
|
+
try {
|
|
115
|
+
fs.closeSync(fd);
|
|
116
|
+
}
|
|
117
|
+
catch { /* already closed */ }
|
|
118
|
+
}
|
|
119
|
+
removeFailedPrivateFile(tmp);
|
|
120
|
+
throw err;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
export function appendPrivateFileSync(filePath, content, opts = {}) {
|
|
124
|
+
const platform = opts.platform ?? process.platform;
|
|
125
|
+
const fd = fs.openSync(filePath, 'a', supportsPosixModes(platform) ? 0o600 : undefined);
|
|
126
|
+
try {
|
|
127
|
+
if (typeof content === 'string')
|
|
128
|
+
fs.writeSync(fd, content);
|
|
129
|
+
else
|
|
130
|
+
fs.writeSync(fd, content, 0, content.length);
|
|
131
|
+
fs.fsyncSync(fd);
|
|
132
|
+
}
|
|
133
|
+
finally {
|
|
134
|
+
fs.closeSync(fd);
|
|
135
|
+
}
|
|
136
|
+
try {
|
|
137
|
+
chmodPrivateSync(filePath, { platform });
|
|
138
|
+
}
|
|
139
|
+
catch (err) {
|
|
140
|
+
removeFailedPrivateFile(filePath);
|
|
141
|
+
throw err;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
//# sourceMappingURL=private-file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"private-file.js","sourceRoot":"","sources":["../../src/shared/private-file.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export interface RuntimeLockOwner {
|
|
2
|
+
schemaVersion: 1;
|
|
3
|
+
pid: number;
|
|
4
|
+
createdAt: string;
|
|
5
|
+
purpose: 'daemon-instance' | 'daemon-start';
|
|
6
|
+
}
|
|
7
|
+
export type RuntimeLockAcquireResult<T> = {
|
|
8
|
+
ok: true;
|
|
9
|
+
handle: RuntimeLockHandle<T>;
|
|
10
|
+
recovered?: {
|
|
11
|
+
reason: 'dead_pid' | 'invalid_owner' | 'stale_timeout';
|
|
12
|
+
previousOwner?: T;
|
|
13
|
+
};
|
|
14
|
+
} | {
|
|
15
|
+
ok: false;
|
|
16
|
+
reason: 'held' | 'owner_alive' | 'io_error';
|
|
17
|
+
owner?: T;
|
|
18
|
+
message?: string;
|
|
19
|
+
};
|
|
20
|
+
export interface RuntimeLockHandle<T> {
|
|
21
|
+
lockDir: string;
|
|
22
|
+
owner: T;
|
|
23
|
+
release: () => void;
|
|
24
|
+
}
|
|
25
|
+
export declare function isPidAlive(pid: number): boolean;
|
|
26
|
+
export declare function readRuntimeLockOwner<T>(lockDir: string): T | null;
|
|
27
|
+
export declare function acquireRuntimeLock<T extends RuntimeLockOwner>(lockDir: string, owner: T, opts?: {
|
|
28
|
+
staleAfterMs?: number;
|
|
29
|
+
}): RuntimeLockAcquireResult<T>;
|
|
30
|
+
//# sourceMappingURL=runtime-lock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-lock.d.ts","sourceRoot":"","sources":["../../src/shared/runtime-lock.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,gBAAgB;IAC/B,aAAa,EAAE,CAAC,CAAC;IACjB,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,iBAAiB,GAAG,cAAc,CAAC;CAC7C;AAED,MAAM,MAAM,wBAAwB,CAAC,CAAC,IAClC;IACE,EAAE,EAAE,IAAI,CAAC;IACT,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;IAC7B,SAAS,CAAC,EAAE;QAAE,MAAM,EAAE,UAAU,GAAG,eAAe,GAAG,eAAe,CAAC;QAAC,aAAa,CAAC,EAAE,CAAC,CAAA;KAAE,CAAC;CAC3F,GACD;IAAE,EAAE,EAAE,KAAK,CAAC;IAAC,MAAM,EAAE,MAAM,GAAG,aAAa,GAAG,UAAU,CAAC;IAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAE5F,MAAM,WAAW,iBAAiB,CAAC,CAAC;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,CAAC,CAAC;IACT,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAID,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAU/C;AAED,wBAAgB,oBAAoB,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI,CAMjE;AAED,wBAAgB,kBAAkB,CAAC,CAAC,SAAS,gBAAgB,EAC3D,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,CAAC,EACR,IAAI,GAAE;IAAE,YAAY,CAAC,EAAE,MAAM,CAAA;CAAO,GACnC,wBAAwB,CAAC,CAAC,CAAC,CAkC7B"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import os from 'os';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { writePrivateFileSync } from './private-file.js';
|
|
5
|
+
const OWNER_FILE = 'owner.json';
|
|
6
|
+
export function isPidAlive(pid) {
|
|
7
|
+
if (!Number.isInteger(pid) || pid <= 0)
|
|
8
|
+
return false;
|
|
9
|
+
try {
|
|
10
|
+
process.kill(pid, 0);
|
|
11
|
+
return true;
|
|
12
|
+
}
|
|
13
|
+
catch (err) {
|
|
14
|
+
const code = err instanceof Error && 'code' in err ? err.code : undefined;
|
|
15
|
+
if (code === 'ESRCH')
|
|
16
|
+
return false;
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export function readRuntimeLockOwner(lockDir) {
|
|
21
|
+
try {
|
|
22
|
+
return JSON.parse(fs.readFileSync(ownerPath(lockDir), 'utf8'));
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export function acquireRuntimeLock(lockDir, owner, opts = {}) {
|
|
29
|
+
if (lockDir.trim() === '') {
|
|
30
|
+
return { ok: false, reason: 'io_error', message: 'lock directory is empty' };
|
|
31
|
+
}
|
|
32
|
+
try {
|
|
33
|
+
return acquireFreshLock(lockDir, owner);
|
|
34
|
+
}
|
|
35
|
+
catch (err) {
|
|
36
|
+
if (!isFileExistsError(err)) {
|
|
37
|
+
return { ok: false, reason: 'io_error', message: errorMessage(err) };
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
const currentOwner = readRuntimeLockOwner(lockDir);
|
|
41
|
+
if (currentOwner && isPidAlive(currentOwner.pid)) {
|
|
42
|
+
return { ok: false, reason: 'owner_alive', owner: currentOwner };
|
|
43
|
+
}
|
|
44
|
+
const recovered = recoveryReason(currentOwner, opts.staleAfterMs);
|
|
45
|
+
const removed = removeRuntimeLockDir(lockDir);
|
|
46
|
+
if (!removed.ok) {
|
|
47
|
+
return { ok: false, reason: 'io_error', owner: currentOwner ?? undefined, message: removed.message };
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
const acquired = acquireFreshLock(lockDir, owner);
|
|
51
|
+
return {
|
|
52
|
+
...acquired,
|
|
53
|
+
recovered: { reason: recovered, previousOwner: currentOwner ?? undefined },
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
catch (err) {
|
|
57
|
+
if (isFileExistsError(err))
|
|
58
|
+
return { ok: false, reason: 'held', owner: readRuntimeLockOwner(lockDir) ?? undefined };
|
|
59
|
+
return { ok: false, reason: 'io_error', message: errorMessage(err) };
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
function acquireFreshLock(lockDir, owner) {
|
|
63
|
+
fs.mkdirSync(lockDir);
|
|
64
|
+
writePrivateFileSync(ownerPath(lockDir), `${JSON.stringify(owner, null, 2)}\n`);
|
|
65
|
+
return {
|
|
66
|
+
ok: true,
|
|
67
|
+
handle: {
|
|
68
|
+
lockDir,
|
|
69
|
+
owner,
|
|
70
|
+
release: () => releaseRuntimeLock(lockDir, owner),
|
|
71
|
+
},
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
function releaseRuntimeLock(lockDir, owner) {
|
|
75
|
+
const currentOwner = readRuntimeLockOwner(lockDir);
|
|
76
|
+
if (!sameRuntimeLockOwner(currentOwner, owner))
|
|
77
|
+
return;
|
|
78
|
+
removeRuntimeLockDir(lockDir);
|
|
79
|
+
}
|
|
80
|
+
function sameRuntimeLockOwner(currentOwner, owner) {
|
|
81
|
+
return currentOwner !== null
|
|
82
|
+
&& JSON.stringify(canonicalLockOwner(currentOwner)) === JSON.stringify(canonicalLockOwner(owner));
|
|
83
|
+
}
|
|
84
|
+
function canonicalLockOwner(value) {
|
|
85
|
+
if (Array.isArray(value))
|
|
86
|
+
return value.map(canonicalLockOwner);
|
|
87
|
+
if (!value || typeof value !== 'object')
|
|
88
|
+
return value;
|
|
89
|
+
return Object.fromEntries(Object.entries(value)
|
|
90
|
+
.sort(([left], [right]) => left.localeCompare(right))
|
|
91
|
+
.map(([key, entry]) => [key, canonicalLockOwner(entry)]));
|
|
92
|
+
}
|
|
93
|
+
function recoveryReason(currentOwner, staleAfterMs) {
|
|
94
|
+
if (!currentOwner)
|
|
95
|
+
return 'invalid_owner';
|
|
96
|
+
if (!isPidAlive(currentOwner.pid))
|
|
97
|
+
return 'dead_pid';
|
|
98
|
+
if (staleAfterMs !== undefined && lockAgeMs(currentOwner.createdAt) > staleAfterMs)
|
|
99
|
+
return 'stale_timeout';
|
|
100
|
+
return 'invalid_owner';
|
|
101
|
+
}
|
|
102
|
+
function lockAgeMs(createdAt) {
|
|
103
|
+
const parsed = Date.parse(createdAt);
|
|
104
|
+
if (Number.isNaN(parsed))
|
|
105
|
+
return 0;
|
|
106
|
+
return Date.now() - parsed;
|
|
107
|
+
}
|
|
108
|
+
function ownerPath(lockDir) {
|
|
109
|
+
return path.join(lockDir, OWNER_FILE);
|
|
110
|
+
}
|
|
111
|
+
function removeRuntimeLockDir(lockDir) {
|
|
112
|
+
const resolved = path.resolve(lockDir);
|
|
113
|
+
if (!canRemoveLockDir(resolved)) {
|
|
114
|
+
return { ok: false, message: `refusing to remove unsafe lock directory: ${lockDir}` };
|
|
115
|
+
}
|
|
116
|
+
try {
|
|
117
|
+
fs.rmSync(resolved, { recursive: true, force: true });
|
|
118
|
+
return { ok: true };
|
|
119
|
+
}
|
|
120
|
+
catch (err) {
|
|
121
|
+
return { ok: false, message: errorMessage(err) };
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
function canRemoveLockDir(lockDir) {
|
|
125
|
+
if (lockDir === path.parse(lockDir).root)
|
|
126
|
+
return false;
|
|
127
|
+
if (lockDir === os.homedir())
|
|
128
|
+
return false;
|
|
129
|
+
if (!path.basename(lockDir).endsWith('.lock'))
|
|
130
|
+
return false;
|
|
131
|
+
const configDir = process.env['VGE_CC_GUARD_CONFIG_DIR'];
|
|
132
|
+
if (configDir && lockDir === path.resolve(configDir))
|
|
133
|
+
return false;
|
|
134
|
+
return true;
|
|
135
|
+
}
|
|
136
|
+
function isFileExistsError(err) {
|
|
137
|
+
return err instanceof Error && 'code' in err && err.code === 'EEXIST';
|
|
138
|
+
}
|
|
139
|
+
function errorMessage(err) {
|
|
140
|
+
return err instanceof Error ? err.message : String(err);
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=runtime-lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-lock.js","sourceRoot":"","sources":["../../src/shared/runtime-lock.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"system-ca.d.ts","sourceRoot":"","sources":["../../src/shared/system-ca.ts"],"names":[],"mappings":"AAeA,wBAAgB,gBAAgB,IAAI,IAAI,CAavC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import * as tls from 'node:tls';
|
|
2
|
+
let installed = false;
|
|
3
|
+
// Merge OS keychain (`system`) and `NODE_EXTRA_CA_CERTS` (`extra`) into Node's
|
|
4
|
+
// default CA set so that fetch / undici trust corporate or self-signed roots
|
|
5
|
+
// installed by the user. Equivalent to launching Node with --use-system-ca,
|
|
6
|
+
// done at runtime so we don't need to re-exec or pollute NODE_OPTIONS.
|
|
7
|
+
//
|
|
8
|
+
// Available on Node 22.10+; we silently no-op on older runtimes.
|
|
9
|
+
export function installSystemCAs() {
|
|
10
|
+
if (installed)
|
|
11
|
+
return;
|
|
12
|
+
installed = true;
|
|
13
|
+
const t = tls;
|
|
14
|
+
if (!t.getCACertificates || !t.setDefaultCACertificates)
|
|
15
|
+
return;
|
|
16
|
+
const system = safeGet(t, 'system');
|
|
17
|
+
const extra = safeGet(t, 'extra');
|
|
18
|
+
if (system.length === 0 && extra.length === 0)
|
|
19
|
+
return;
|
|
20
|
+
const merged = [...tls.rootCertificates, ...system, ...extra];
|
|
21
|
+
t.setDefaultCACertificates(merged);
|
|
22
|
+
}
|
|
23
|
+
function safeGet(t, source) {
|
|
24
|
+
try {
|
|
25
|
+
return t.getCACertificates ? t.getCACertificates(source) : [];
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
return [];
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=system-ca.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"system-ca.js","sourceRoot":"","sources":["../../src/shared/system-ca.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,UAAU,CAAC;AAEhC,IAAI,SAAS,GAAG,KAAK,CAAC;AAOtB,+EAA+E;AAC/E,6EAA6E;AAC7E,4EAA4E;AAC5E,uEAAuE;AACvE,EAAE;AACF,iEAAiE;AACjE,MAAM,UAAU,gBAAgB;IAC9B,IAAI,SAAS;QAAE,OAAO;IACtB,SAAS,GAAG,IAAI,CAAC;IAEjB,MAAM,CAAC,GAAG,GAA2B,CAAC;IACtC,IAAI,CAAC,CAAC,CAAC,iBAAiB,IAAI,CAAC,CAAC,CAAC,wBAAwB;QAAE,OAAO;IAEhE,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IACpC,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IAClC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO;IAEtD,MAAM,MAAM,GAAG,CAAC,GAAG,GAAG,CAAC,gBAAgB,EAAE,GAAG,MAAM,EAAE,GAAG,KAAK,CAAC,CAAC;IAC9D,CAAC,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;AACrC,CAAC;AAED,SAAS,OAAO,CAAC,CAAY,EAAE,MAA0B;IACvD,IAAI,CAAC;QACH,OAAO,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAChE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
export type SessionState = 'clean' | 'caution' | 'tainted';
|
|
2
|
+
export type RouterOutcome = 'HARD_TAINT' | 'SOFT_TAINT' | 'ESCALATE' | 'ALLOW';
|
|
3
|
+
export type GateDecision = 'allow' | 'deny' | 'ask';
|
|
4
|
+
export type EscalationDecision = 'once' | 'session' | 'block' | 'quarantine';
|
|
5
|
+
export type UrlBlockDecision = 'block' | 'allow_once' | 'allow_persist';
|
|
6
|
+
export interface Escalation {
|
|
7
|
+
kind?: 'tool-output' | 'url-block';
|
|
8
|
+
escalationId: string;
|
|
9
|
+
sessionId: string;
|
|
10
|
+
toolName: string;
|
|
11
|
+
resourceId: string;
|
|
12
|
+
analysisId: string | null;
|
|
13
|
+
branches: {
|
|
14
|
+
heuristics: number;
|
|
15
|
+
semantic: number;
|
|
16
|
+
llmGuard: number;
|
|
17
|
+
};
|
|
18
|
+
routerOutcome: RouterOutcome;
|
|
19
|
+
enqueuedAt: number;
|
|
20
|
+
url?: string;
|
|
21
|
+
host?: string;
|
|
22
|
+
vgeDecision?: string;
|
|
23
|
+
vgeArbiterSignal?: string;
|
|
24
|
+
vgeRuleAction?: string;
|
|
25
|
+
vgeScore?: number;
|
|
26
|
+
vgeCategories?: string[];
|
|
27
|
+
blockMessage?: string;
|
|
28
|
+
}
|
|
29
|
+
export interface SessionData {
|
|
30
|
+
sessionId: string;
|
|
31
|
+
parentSessionId: string | null;
|
|
32
|
+
createdAt: number;
|
|
33
|
+
lastActivity: number;
|
|
34
|
+
state: SessionState;
|
|
35
|
+
allowlist: Set<string>;
|
|
36
|
+
allowlistEscalationIds: Map<string, string>;
|
|
37
|
+
blocklist: Set<string>;
|
|
38
|
+
blocklistEscalationIds: Map<string, string>;
|
|
39
|
+
pendingEscalations: Escalation[];
|
|
40
|
+
escalationCount: number;
|
|
41
|
+
urlAllowOnce: Set<string>;
|
|
42
|
+
attachmentCursors: Map<string, AttachmentCursor>;
|
|
43
|
+
attachmentSeenFingerprints: string[];
|
|
44
|
+
attachmentAllowOnce: Set<string>;
|
|
45
|
+
promptAllowOnce: Set<string>;
|
|
46
|
+
}
|
|
47
|
+
export type AttachmentScanTerminalStatus = 'allowed' | 'pending_decision' | 'blocked_by_user' | 'allowed_by_user' | 'scan_failed_to_hitl' | 'skipped_by_policy';
|
|
48
|
+
export interface AttachmentCursor {
|
|
49
|
+
offset: number;
|
|
50
|
+
}
|
|
51
|
+
export interface GuardBranches {
|
|
52
|
+
heuristics?: {
|
|
53
|
+
score: number;
|
|
54
|
+
} | null;
|
|
55
|
+
semantic?: {
|
|
56
|
+
score: number;
|
|
57
|
+
} | null;
|
|
58
|
+
llmGuard?: {
|
|
59
|
+
score: number;
|
|
60
|
+
} | null;
|
|
61
|
+
}
|
|
62
|
+
export interface GuardResponseSubset {
|
|
63
|
+
decision: 'ALLOWED' | 'BLOCKED' | 'SANITIZED';
|
|
64
|
+
score: number;
|
|
65
|
+
branches: GuardBranches;
|
|
66
|
+
arbiterSignal?: 'ALLOW' | 'BLOCK';
|
|
67
|
+
ruleAction?: 'ALLOW' | 'BLOCK' | 'LOG' | 'SANITIZE';
|
|
68
|
+
decisionFlags?: string[];
|
|
69
|
+
failOpen?: boolean;
|
|
70
|
+
id?: string;
|
|
71
|
+
blockMessage?: string;
|
|
72
|
+
threatLevel?: string;
|
|
73
|
+
confidence?: number;
|
|
74
|
+
categories?: string[];
|
|
75
|
+
localFallbackReason?: string;
|
|
76
|
+
}
|
|
77
|
+
export type BlockingDecisionKind = 'pretool_url' | 'posttool_output' | 'attachment_input' | 'prompt_input';
|
|
78
|
+
export type BlockingDecisionChoice = 'allow_once' | 'allow_session' | 'block';
|
|
79
|
+
export type BlockingDecisionStatus = 'pending' | 'resolved_allow_once' | 'resolved_allow_session' | 'resolved_block' | 'resolver_missing_fail_closed' | 'session_locked_fail_closed' | 'capacity_evicted' | 'dropped_on_restart';
|
|
80
|
+
export type DecisionOwnerKind = 'session' | 'subagent';
|
|
81
|
+
export type DecisionOwner = {
|
|
82
|
+
kind: 'session';
|
|
83
|
+
sessionId: string;
|
|
84
|
+
} | {
|
|
85
|
+
kind: 'subagent';
|
|
86
|
+
sessionId: string;
|
|
87
|
+
agentId: string;
|
|
88
|
+
agentType?: string;
|
|
89
|
+
};
|
|
90
|
+
export interface BlockingDecisionVge {
|
|
91
|
+
id: string | null;
|
|
92
|
+
decision: GuardResponseSubset['decision'] | null;
|
|
93
|
+
arbiterSignal?: GuardResponseSubset['arbiterSignal'];
|
|
94
|
+
ruleAction?: GuardResponseSubset['ruleAction'];
|
|
95
|
+
score: number;
|
|
96
|
+
categories?: string[];
|
|
97
|
+
blockMessage?: string;
|
|
98
|
+
branches: {
|
|
99
|
+
heuristics: number;
|
|
100
|
+
semantic: number;
|
|
101
|
+
llmGuard: number;
|
|
102
|
+
};
|
|
103
|
+
origin?: 'vge' | 'local_fallback';
|
|
104
|
+
}
|
|
105
|
+
export interface BlockingDecision {
|
|
106
|
+
decisionId: string;
|
|
107
|
+
dedupKey: string;
|
|
108
|
+
sessionId: string;
|
|
109
|
+
owner?: DecisionOwner;
|
|
110
|
+
kind: BlockingDecisionKind;
|
|
111
|
+
toolName: string;
|
|
112
|
+
resourceId: string;
|
|
113
|
+
resourceLabel: string;
|
|
114
|
+
reason: string;
|
|
115
|
+
createdAt: number;
|
|
116
|
+
creationSequence?: number;
|
|
117
|
+
expiresAt: number;
|
|
118
|
+
status: BlockingDecisionStatus;
|
|
119
|
+
vge: BlockingDecisionVge;
|
|
120
|
+
}
|
|
121
|
+
export interface CCBasePayload {
|
|
122
|
+
session_id: string;
|
|
123
|
+
hook_event_name: string;
|
|
124
|
+
agent_id?: string;
|
|
125
|
+
agent_type?: string;
|
|
126
|
+
cwd?: string;
|
|
127
|
+
transcript_path?: string;
|
|
128
|
+
parent_session_id?: string;
|
|
129
|
+
}
|
|
130
|
+
export interface ConversationMessage {
|
|
131
|
+
role: 'system' | 'user' | 'assistant' | 'tool';
|
|
132
|
+
content: string;
|
|
133
|
+
toolName?: string;
|
|
134
|
+
toolId?: string;
|
|
135
|
+
}
|
|
136
|
+
export interface CCSessionStartPayload extends CCBasePayload {
|
|
137
|
+
hook_event_name: 'SessionStart';
|
|
138
|
+
}
|
|
139
|
+
export interface CCSessionEndPayload extends CCBasePayload {
|
|
140
|
+
hook_event_name: 'SessionEnd';
|
|
141
|
+
}
|
|
142
|
+
export interface CCUserPromptPayload extends CCBasePayload {
|
|
143
|
+
hook_event_name: 'UserPromptSubmit';
|
|
144
|
+
prompt: string;
|
|
145
|
+
}
|
|
146
|
+
export interface CCPreToolPayload extends CCBasePayload {
|
|
147
|
+
hook_event_name: 'PreToolUse';
|
|
148
|
+
tool_name: string;
|
|
149
|
+
tool_input: Record<string, unknown>;
|
|
150
|
+
}
|
|
151
|
+
export interface CCPostToolPayload extends CCBasePayload {
|
|
152
|
+
hook_event_name: 'PostToolUse';
|
|
153
|
+
tool_name: string;
|
|
154
|
+
tool_input: Record<string, unknown>;
|
|
155
|
+
tool_response?: unknown;
|
|
156
|
+
tool_error?: unknown;
|
|
157
|
+
}
|
|
158
|
+
export interface CCSubagentStartPayload extends CCBasePayload {
|
|
159
|
+
hook_event_name: 'SubagentStart';
|
|
160
|
+
agent_id: string;
|
|
161
|
+
agent_type?: string;
|
|
162
|
+
}
|
|
163
|
+
export interface CCSubagentStopPayload extends CCBasePayload {
|
|
164
|
+
hook_event_name: 'SubagentStop';
|
|
165
|
+
agent_id: string;
|
|
166
|
+
agent_type?: string;
|
|
167
|
+
agent_transcript_path?: string;
|
|
168
|
+
last_assistant_message?: string;
|
|
169
|
+
stop_hook_active?: boolean;
|
|
170
|
+
}
|
|
171
|
+
export type CCHookPayload = CCSessionStartPayload | CCSessionEndPayload | CCUserPromptPayload | CCPreToolPayload | CCPostToolPayload | CCSubagentStartPayload | CCSubagentStopPayload;
|
|
172
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/shared/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/shared/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function normalizeUrlAllowlistPattern(pattern: string): string;
|
|
2
|
+
export declare function isValidUrlAllowlistPattern(pattern: string): boolean;
|
|
3
|
+
export declare function hostnameMatchesPattern(hostname: string, pattern: string): boolean;
|
|
4
|
+
//# sourceMappingURL=url-allowlist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"url-allowlist.d.ts","sourceRoot":"","sources":["../../src/shared/url-allowlist.ts"],"names":[],"mappings":"AAGA,wBAAgB,4BAA4B,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAEpE;AAED,wBAAgB,0BAA0B,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAYnE;AAED,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CASjF"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
const HOST_LABEL = '[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?';
|
|
2
|
+
const HOST_PATTERN_RE = new RegExp(`^(?:${HOST_LABEL}\\.)+${HOST_LABEL}$`);
|
|
3
|
+
export function normalizeUrlAllowlistPattern(pattern) {
|
|
4
|
+
return pattern.trim().toLowerCase();
|
|
5
|
+
}
|
|
6
|
+
export function isValidUrlAllowlistPattern(pattern) {
|
|
7
|
+
const normalized = normalizeUrlAllowlistPattern(pattern);
|
|
8
|
+
if (!normalized)
|
|
9
|
+
return false;
|
|
10
|
+
if (normalized.includes('://') || normalized.includes('/') || normalized.includes('\\')) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
if (normalized.includes('*') && !normalized.startsWith('*.'))
|
|
14
|
+
return false;
|
|
15
|
+
if (normalized.startsWith('*.')) {
|
|
16
|
+
const suffix = normalized.slice(2);
|
|
17
|
+
return HOST_PATTERN_RE.test(suffix);
|
|
18
|
+
}
|
|
19
|
+
return HOST_PATTERN_RE.test(normalized);
|
|
20
|
+
}
|
|
21
|
+
export function hostnameMatchesPattern(hostname, pattern) {
|
|
22
|
+
const host = normalizeUrlAllowlistPattern(hostname);
|
|
23
|
+
const normalizedPattern = normalizeUrlAllowlistPattern(pattern);
|
|
24
|
+
if (!isValidUrlAllowlistPattern(normalizedPattern))
|
|
25
|
+
return false;
|
|
26
|
+
if (host === normalizedPattern)
|
|
27
|
+
return true;
|
|
28
|
+
if (!normalizedPattern.startsWith('*.'))
|
|
29
|
+
return host === normalizedPattern;
|
|
30
|
+
const suffix = normalizedPattern.slice(2);
|
|
31
|
+
return host.endsWith(`.${suffix}`);
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=url-allowlist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"url-allowlist.js","sourceRoot":"","sources":["../../src/shared/url-allowlist.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,GAAG,sCAAsC,CAAC;AAC1D,MAAM,eAAe,GAAG,IAAI,MAAM,CAAC,OAAO,UAAU,QAAQ,UAAU,GAAG,CAAC,CAAC;AAE3E,MAAM,UAAU,4BAA4B,CAAC,OAAe;IAC1D,OAAO,OAAO,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AACtC,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAC,OAAe;IACxD,MAAM,UAAU,GAAG,4BAA4B,CAAC,OAAO,CAAC,CAAC;IACzD,IAAI,CAAC,UAAU;QAAE,OAAO,KAAK,CAAC;IAC9B,IAAI,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACxF,OAAO,KAAK,CAAC;IACf,CAAC;IACD,IAAI,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,KAAK,CAAC;IAC3E,IAAI,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,OAAO,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IACD,OAAO,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,QAAgB,EAAE,OAAe;IACtE,MAAM,IAAI,GAAG,4BAA4B,CAAC,QAAQ,CAAC,CAAC;IACpD,MAAM,iBAAiB,GAAG,4BAA4B,CAAC,OAAO,CAAC,CAAC;IAChE,IAAI,CAAC,0BAA0B,CAAC,iBAAiB,CAAC;QAAE,OAAO,KAAK,CAAC;IACjE,IAAI,IAAI,KAAK,iBAAiB;QAAE,OAAO,IAAI,CAAC;IAC5C,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,KAAK,iBAAiB,CAAC;IAE3E,MAAM,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC1C,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,MAAM,EAAE,CAAC,CAAC;AACrC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export declare function normalizeUrlHostPattern(pattern: string): string;
|
|
2
|
+
export declare function isValidUrlHostPattern(pattern: string): boolean;
|
|
3
|
+
export declare function hostnameMatchesUrlPattern(hostname: string, pattern: string): boolean;
|
|
4
|
+
export declare function normalizeUrlScheme(scheme: string): string;
|
|
5
|
+
export declare function isValidUrlScheme(scheme: string): boolean;
|
|
6
|
+
export declare function normalizeCidr(cidr: string): string;
|
|
7
|
+
export declare function isValidCidr(cidr: string): boolean;
|
|
8
|
+
export declare function cidrContainsIp(ip: string, cidr: string): boolean;
|
|
9
|
+
export declare function normalizeUrlGlobPattern(pattern: string): string;
|
|
10
|
+
export declare function isValidUrlGlobPattern(pattern: string): boolean;
|
|
11
|
+
export declare function urlMatchesGlobPattern(rawUrl: string, pattern: string): boolean;
|
|
12
|
+
//# sourceMappingURL=url-patterns.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"url-patterns.d.ts","sourceRoot":"","sources":["../../src/shared/url-patterns.ts"],"names":[],"mappings":"AASA,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAE/D;AAED,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAU9D;AAED,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CASpF;AAED,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAEzD;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAGxD;AAED,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAElD;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAYjD;AAED,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAuBhE;AAED,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAE/D;AAED,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAa9D;AAED,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAU9E"}
|