@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,165 @@
|
|
|
1
|
+
import net from 'node:net';
|
|
2
|
+
const HOST_LABEL = '[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?';
|
|
3
|
+
const HOST_PATTERN_RE = new RegExp(`^(?:${HOST_LABEL}\\.)*${HOST_LABEL}$`);
|
|
4
|
+
const SCHEME_RE = /^[a-z][a-z0-9+.-]*$/;
|
|
5
|
+
const CONTROL_RE = /[\x00-\x1f\x7f]/;
|
|
6
|
+
const REGEX_ONLY_RE = /[\\^$+()[\]{}]/;
|
|
7
|
+
const MAX_URL_GLOB_WILDCARDS = 8;
|
|
8
|
+
export function normalizeUrlHostPattern(pattern) {
|
|
9
|
+
return pattern.trim().toLowerCase().replace(/^\[([^\]]+)\]$/, '$1');
|
|
10
|
+
}
|
|
11
|
+
export function isValidUrlHostPattern(pattern) {
|
|
12
|
+
const normalized = normalizeUrlHostPattern(pattern);
|
|
13
|
+
if (!normalized)
|
|
14
|
+
return false;
|
|
15
|
+
if (normalized.includes('://') || normalized.includes('/') || normalized.includes('\\'))
|
|
16
|
+
return false;
|
|
17
|
+
if (normalized.includes('*') && !normalized.startsWith('*.'))
|
|
18
|
+
return false;
|
|
19
|
+
if (normalized.startsWith('*.')) {
|
|
20
|
+
const suffix = normalized.slice(2);
|
|
21
|
+
return HOST_PATTERN_RE.test(suffix) && net.isIP(suffix) === 0;
|
|
22
|
+
}
|
|
23
|
+
return HOST_PATTERN_RE.test(normalized) || net.isIP(normalized) !== 0;
|
|
24
|
+
}
|
|
25
|
+
export function hostnameMatchesUrlPattern(hostname, pattern) {
|
|
26
|
+
const host = normalizeUrlHostPattern(hostname);
|
|
27
|
+
const normalizedPattern = normalizeUrlHostPattern(pattern);
|
|
28
|
+
if (!isValidUrlHostPattern(normalizedPattern))
|
|
29
|
+
return false;
|
|
30
|
+
if (host === normalizedPattern)
|
|
31
|
+
return true;
|
|
32
|
+
if (!normalizedPattern.startsWith('*.'))
|
|
33
|
+
return false;
|
|
34
|
+
const suffix = normalizedPattern.slice(2);
|
|
35
|
+
return host.endsWith(`.${suffix}`);
|
|
36
|
+
}
|
|
37
|
+
export function normalizeUrlScheme(scheme) {
|
|
38
|
+
return scheme.trim().toLowerCase().replace(/:$/, '');
|
|
39
|
+
}
|
|
40
|
+
export function isValidUrlScheme(scheme) {
|
|
41
|
+
const normalized = normalizeUrlScheme(scheme);
|
|
42
|
+
return SCHEME_RE.test(normalized) && !scheme.includes('://');
|
|
43
|
+
}
|
|
44
|
+
export function normalizeCidr(cidr) {
|
|
45
|
+
return cidr.trim().toLowerCase().replace(/^\[([^\]]+)\](\/\d+)$/, '$1$2');
|
|
46
|
+
}
|
|
47
|
+
export function isValidCidr(cidr) {
|
|
48
|
+
const normalized = normalizeCidr(cidr);
|
|
49
|
+
const [address, prefixText, extra] = normalized.split('/');
|
|
50
|
+
if (!address || !prefixText || extra !== undefined)
|
|
51
|
+
return false;
|
|
52
|
+
const ipVersion = net.isIP(address);
|
|
53
|
+
if (ipVersion === 0)
|
|
54
|
+
return false;
|
|
55
|
+
const prefix = Number(prefixText);
|
|
56
|
+
if (!Number.isInteger(prefix))
|
|
57
|
+
return false;
|
|
58
|
+
return ipVersion === 4 ? prefix >= 0 && prefix <= 32 : prefix >= 0 && prefix <= 128;
|
|
59
|
+
}
|
|
60
|
+
export function cidrContainsIp(ip, cidr) {
|
|
61
|
+
const normalizedIp = normalizeUrlHostPattern(ip);
|
|
62
|
+
const normalizedCidr = normalizeCidr(cidr);
|
|
63
|
+
const [rangeAddress, prefixText] = normalizedCidr.split('/');
|
|
64
|
+
if (!rangeAddress || !prefixText || !isValidCidr(normalizedCidr))
|
|
65
|
+
return false;
|
|
66
|
+
const ipVersion = net.isIP(normalizedIp);
|
|
67
|
+
if (ipVersion === 0 || ipVersion !== net.isIP(rangeAddress))
|
|
68
|
+
return false;
|
|
69
|
+
const prefix = Number(prefixText);
|
|
70
|
+
if (ipVersion === 4) {
|
|
71
|
+
const ipValue = ipv4ToNumber(normalizedIp);
|
|
72
|
+
const rangeValue = ipv4ToNumber(rangeAddress);
|
|
73
|
+
const mask = prefix === 0 ? 0 : (0xffffffff << (32 - prefix)) >>> 0;
|
|
74
|
+
return (ipValue & mask) === (rangeValue & mask);
|
|
75
|
+
}
|
|
76
|
+
const ipValue = ipv6ToBigInt(normalizedIp);
|
|
77
|
+
const rangeValue = ipv6ToBigInt(rangeAddress);
|
|
78
|
+
if (ipValue === null || rangeValue === null)
|
|
79
|
+
return false;
|
|
80
|
+
const hostBits = 128n - BigInt(prefix);
|
|
81
|
+
const mask = hostBits === 128n ? 0n : ((1n << 128n) - 1n) << hostBits;
|
|
82
|
+
return (ipValue & mask) === (rangeValue & mask);
|
|
83
|
+
}
|
|
84
|
+
export function normalizeUrlGlobPattern(pattern) {
|
|
85
|
+
return pattern.trim();
|
|
86
|
+
}
|
|
87
|
+
export function isValidUrlGlobPattern(pattern) {
|
|
88
|
+
const normalized = normalizeUrlGlobPattern(pattern);
|
|
89
|
+
if (!normalized || CONTROL_RE.test(normalized))
|
|
90
|
+
return false;
|
|
91
|
+
if (REGEX_ONLY_RE.test(normalized))
|
|
92
|
+
return false;
|
|
93
|
+
if (!normalized.includes('://'))
|
|
94
|
+
return false;
|
|
95
|
+
if ((normalized.match(/\*/g)?.length ?? 0) > MAX_URL_GLOB_WILDCARDS)
|
|
96
|
+
return false;
|
|
97
|
+
try {
|
|
98
|
+
const probe = normalized.replace(/\*/g, 'x');
|
|
99
|
+
new URL(probe);
|
|
100
|
+
return true;
|
|
101
|
+
}
|
|
102
|
+
catch {
|
|
103
|
+
return false;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
export function urlMatchesGlobPattern(rawUrl, pattern) {
|
|
107
|
+
if (!isValidUrlGlobPattern(pattern))
|
|
108
|
+
return false;
|
|
109
|
+
const normalizedUrl = normalizeUrlForPattern(rawUrl);
|
|
110
|
+
if (!normalizedUrl)
|
|
111
|
+
return false;
|
|
112
|
+
const escapedPattern = normalizeUrlGlobPattern(pattern)
|
|
113
|
+
.split('*')
|
|
114
|
+
.map(escapeRegex)
|
|
115
|
+
.join('.*');
|
|
116
|
+
return new RegExp(`^${escapedPattern}$`, 'i').test(normalizedUrl);
|
|
117
|
+
}
|
|
118
|
+
function ipv4ToNumber(ip) {
|
|
119
|
+
return ip.split('.').reduce((value, octet) => ((value << 8) | Number(octet)) >>> 0, 0);
|
|
120
|
+
}
|
|
121
|
+
function ipv6ToBigInt(ip) {
|
|
122
|
+
const pieces = expandIpv6(ip);
|
|
123
|
+
if (!pieces)
|
|
124
|
+
return null;
|
|
125
|
+
return pieces.reduce((value, piece) => (value << 16n) + BigInt(parseInt(piece, 16)), 0n);
|
|
126
|
+
}
|
|
127
|
+
function expandIpv6(ip) {
|
|
128
|
+
const ipv4Tail = ip.match(/(.+):(\d+\.\d+\.\d+\.\d+)$/);
|
|
129
|
+
const normalized = ipv4Tail
|
|
130
|
+
? `${ipv4Tail[1]}:${ipv4Tail[2]
|
|
131
|
+
.split('.')
|
|
132
|
+
.reduce((parts, octet, index, octets) => {
|
|
133
|
+
if (index % 2 === 0)
|
|
134
|
+
parts.push(((Number(octet) << 8) | Number(octets[index + 1])).toString(16));
|
|
135
|
+
return parts;
|
|
136
|
+
}, [])
|
|
137
|
+
.join(':')}`
|
|
138
|
+
: ip;
|
|
139
|
+
const halves = normalized.split('::');
|
|
140
|
+
if (halves.length > 2)
|
|
141
|
+
return null;
|
|
142
|
+
const left = halves[0] ? halves[0].split(':') : [];
|
|
143
|
+
const right = halves[1] ? halves[1].split(':') : [];
|
|
144
|
+
const missing = 8 - left.length - right.length;
|
|
145
|
+
if (missing < 0)
|
|
146
|
+
return null;
|
|
147
|
+
const expanded = halves.length === 1 ? left : [...left, ...Array(missing).fill('0'), ...right];
|
|
148
|
+
if (expanded.length !== 8)
|
|
149
|
+
return null;
|
|
150
|
+
return expanded.every((piece) => /^[0-9a-f]{1,4}$/i.test(piece)) ? expanded : null;
|
|
151
|
+
}
|
|
152
|
+
function normalizeUrlForPattern(rawUrl) {
|
|
153
|
+
try {
|
|
154
|
+
const url = new URL(rawUrl);
|
|
155
|
+
url.hash = '';
|
|
156
|
+
return url.toString();
|
|
157
|
+
}
|
|
158
|
+
catch {
|
|
159
|
+
return null;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
function escapeRegex(value) {
|
|
163
|
+
return value.replace(/[|\\{}()[\]^$+?.]/g, '\\$&');
|
|
164
|
+
}
|
|
165
|
+
//# sourceMappingURL=url-patterns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"url-patterns.js","sourceRoot":"","sources":["../../src/shared/url-patterns.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export type VgeApiUrlValidation = {
|
|
2
|
+
ok: true;
|
|
3
|
+
url: string;
|
|
4
|
+
} | {
|
|
5
|
+
ok: false;
|
|
6
|
+
reason: string;
|
|
7
|
+
};
|
|
8
|
+
export interface VgeApiUrlValidationOptions {
|
|
9
|
+
allowDevEndpoint?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function validateVgeApiUrl(candidate: string, opts?: VgeApiUrlValidationOptions): VgeApiUrlValidation;
|
|
12
|
+
export declare function isSafeVgeApiUrl(candidate: string, opts?: VgeApiUrlValidationOptions): boolean;
|
|
13
|
+
export declare function allowDevVgeEndpointFromEnv(): boolean;
|
|
14
|
+
export declare function validateVgeApiUrlFromEnv(candidate: string): VgeApiUrlValidation;
|
|
15
|
+
export declare function isSafeVgeApiUrlFromEnv(candidate: string): boolean;
|
|
16
|
+
//# sourceMappingURL=vge-url.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vge-url.d.ts","sourceRoot":"","sources":["../../src/shared/vge-url.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,mBAAmB,GAC3B;IAAE,EAAE,EAAE,IAAI,CAAC;IAAC,GAAG,EAAE,MAAM,CAAA;CAAE,GACzB;IAAE,EAAE,EAAE,KAAK,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAElC,MAAM,WAAW,0BAA0B;IACzC,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AA+CD,wBAAgB,iBAAiB,CAC/B,SAAS,EAAE,MAAM,EACjB,IAAI,GAAE,0BAA+B,GACpC,mBAAmB,CAmBrB;AAED,wBAAgB,eAAe,CAC7B,SAAS,EAAE,MAAM,EACjB,IAAI,GAAE,0BAA+B,GACpC,OAAO,CAET;AAED,wBAAgB,0BAA0B,IAAI,OAAO,CAEpD;AAED,wBAAgB,wBAAwB,CAAC,SAAS,EAAE,MAAM,GAAG,mBAAmB,CAE/E;AAED,wBAAgB,sBAAsB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAEjE"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
function normalizedHostname(url) {
|
|
2
|
+
return url.hostname.toLowerCase().replace(/^\[|\]$/g, '').replace(/\.$/, '');
|
|
3
|
+
}
|
|
4
|
+
function parseIpv4(hostname) {
|
|
5
|
+
if (!/^\d{1,3}(?:\.\d{1,3}){3}$/.test(hostname))
|
|
6
|
+
return null;
|
|
7
|
+
const octets = hostname.split('.').map((part) => Number(part));
|
|
8
|
+
return octets.every((octet) => Number.isInteger(octet) && octet >= 0 && octet <= 255)
|
|
9
|
+
? octets
|
|
10
|
+
: null;
|
|
11
|
+
}
|
|
12
|
+
function isRejectedIpv4(octets) {
|
|
13
|
+
const [a, b] = octets;
|
|
14
|
+
if (a === 0 ||
|
|
15
|
+
a === 10 ||
|
|
16
|
+
a === 127 ||
|
|
17
|
+
a === 100 && b >= 64 && b <= 127 ||
|
|
18
|
+
a === 169 && b === 254 ||
|
|
19
|
+
a === 192 && b === 168) {
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
return a === 172 && b >= 16 && b <= 31;
|
|
23
|
+
}
|
|
24
|
+
function isLoopbackIpv4(octets) {
|
|
25
|
+
return octets[0] === 127;
|
|
26
|
+
}
|
|
27
|
+
function isLocalDevHost(hostname) {
|
|
28
|
+
if (hostname === 'localhost')
|
|
29
|
+
return true;
|
|
30
|
+
const ipv4 = parseIpv4(hostname);
|
|
31
|
+
if (ipv4)
|
|
32
|
+
return isLoopbackIpv4(ipv4);
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
function isRejectedHost(hostname) {
|
|
36
|
+
if (hostname === 'localhost')
|
|
37
|
+
return true;
|
|
38
|
+
const ipv4 = parseIpv4(hostname);
|
|
39
|
+
if (ipv4)
|
|
40
|
+
return isRejectedIpv4(ipv4);
|
|
41
|
+
return hostname.includes(':');
|
|
42
|
+
}
|
|
43
|
+
export function validateVgeApiUrl(candidate, opts = {}) {
|
|
44
|
+
let parsed;
|
|
45
|
+
try {
|
|
46
|
+
parsed = new URL(candidate.trim());
|
|
47
|
+
}
|
|
48
|
+
catch {
|
|
49
|
+
return { ok: false, reason: 'api_url must be a valid URL' };
|
|
50
|
+
}
|
|
51
|
+
const hostname = normalizedHostname(parsed);
|
|
52
|
+
if (opts.allowDevEndpoint && parsed.protocol === 'http:' && isLocalDevHost(hostname)) {
|
|
53
|
+
return { ok: true, url: parsed.toString().replace(/\/+$/, '') };
|
|
54
|
+
}
|
|
55
|
+
if (parsed.protocol !== 'https:') {
|
|
56
|
+
return { ok: false, reason: 'api_url must use HTTPS' };
|
|
57
|
+
}
|
|
58
|
+
if (isRejectedHost(hostname)) {
|
|
59
|
+
return { ok: false, reason: 'api_url must not target localhost, loopback, private, or link-local hosts' };
|
|
60
|
+
}
|
|
61
|
+
return { ok: true, url: parsed.toString().replace(/\/+$/, '') };
|
|
62
|
+
}
|
|
63
|
+
export function isSafeVgeApiUrl(candidate, opts = {}) {
|
|
64
|
+
return validateVgeApiUrl(candidate, opts).ok;
|
|
65
|
+
}
|
|
66
|
+
export function allowDevVgeEndpointFromEnv() {
|
|
67
|
+
return process.env['VGE_ALLOW_DEV_ENDPOINT'] === '1';
|
|
68
|
+
}
|
|
69
|
+
export function validateVgeApiUrlFromEnv(candidate) {
|
|
70
|
+
return validateVgeApiUrl(candidate, { allowDevEndpoint: allowDevVgeEndpointFromEnv() });
|
|
71
|
+
}
|
|
72
|
+
export function isSafeVgeApiUrlFromEnv(candidate) {
|
|
73
|
+
return validateVgeApiUrlFromEnv(candidate).ok;
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=vge-url.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vge-url.js","sourceRoot":"","sources":["../../src/shared/vge-url.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Config } from './config-schema.js';
|
|
2
|
+
export interface VgeVerificationValues {
|
|
3
|
+
apiUrl: string;
|
|
4
|
+
apiKeyInput: string;
|
|
5
|
+
apiKeyOutput: string | null;
|
|
6
|
+
}
|
|
7
|
+
export interface VgeVerificationMetadata {
|
|
8
|
+
verified_at: string;
|
|
9
|
+
verified_api_url: string;
|
|
10
|
+
verified_input_key_fingerprint: string | null;
|
|
11
|
+
verified_output_key_fingerprint: string | null;
|
|
12
|
+
}
|
|
13
|
+
export declare function vgeKeyFingerprint(key: string | null): string | null;
|
|
14
|
+
export declare function buildVgeVerificationMetadata(input: VgeVerificationValues & {
|
|
15
|
+
verifiedAt: string;
|
|
16
|
+
}): VgeVerificationMetadata;
|
|
17
|
+
export declare function isVgeVerificationCurrent(config: Config): boolean;
|
|
18
|
+
//# sourceMappingURL=vge-verification.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vge-verification.d.ts","sourceRoot":"","sources":["../../src/shared/vge-verification.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,MAAM,WAAW,uBAAuB;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;IACzB,8BAA8B,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9C,+BAA+B,EAAE,MAAM,GAAG,IAAI,CAAC;CAChD;AAED,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,GAAG,IAAI,CAGnE;AAED,wBAAgB,4BAA4B,CAC1C,KAAK,EAAE,qBAAqB,GAAG;IAAE,UAAU,EAAE,MAAM,CAAA;CAAE,GACpD,uBAAuB,CAOzB;AAED,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAQhE"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { createHash } from 'node:crypto';
|
|
2
|
+
export function vgeKeyFingerprint(key) {
|
|
3
|
+
if (!key || key.length === 0)
|
|
4
|
+
return null;
|
|
5
|
+
return `sha256:${createHash('sha256').update(key).digest('hex')}`;
|
|
6
|
+
}
|
|
7
|
+
export function buildVgeVerificationMetadata(input) {
|
|
8
|
+
return {
|
|
9
|
+
verified_at: input.verifiedAt,
|
|
10
|
+
verified_api_url: input.apiUrl,
|
|
11
|
+
verified_input_key_fingerprint: vgeKeyFingerprint(input.apiKeyInput),
|
|
12
|
+
verified_output_key_fingerprint: vgeKeyFingerprint(input.apiKeyOutput),
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
export function isVgeVerificationCurrent(config) {
|
|
16
|
+
const vge = config.vge;
|
|
17
|
+
if (!vge.verified_at)
|
|
18
|
+
return false;
|
|
19
|
+
if (vge.verified_api_url !== vge.api_url)
|
|
20
|
+
return false;
|
|
21
|
+
return (vge.verified_input_key_fingerprint === vgeKeyFingerprint(vge.api_key_input) &&
|
|
22
|
+
vge.verified_output_key_fingerprint === vgeKeyFingerprint(vge.api_key_output));
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=vge-verification.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vge-verification.js","sourceRoot":"","sources":["../../src/shared/vge-verification.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAgBzC,MAAM,UAAU,iBAAiB,CAAC,GAAkB;IAClD,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAC1C,OAAO,UAAU,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;AACpE,CAAC;AAED,MAAM,UAAU,4BAA4B,CAC1C,KAAqD;IAErD,OAAO;QACL,WAAW,EAAE,KAAK,CAAC,UAAU;QAC7B,gBAAgB,EAAE,KAAK,CAAC,MAAM;QAC9B,8BAA8B,EAAE,iBAAiB,CAAC,KAAK,CAAC,WAAW,CAAC;QACpE,+BAA+B,EAAE,iBAAiB,CAAC,KAAK,CAAC,YAAY,CAAC;KACvE,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,MAAc;IACrD,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC;IACvB,IAAI,CAAC,GAAG,CAAC,WAAW;QAAE,OAAO,KAAK,CAAC;IACnC,IAAI,GAAG,CAAC,gBAAgB,KAAK,GAAG,CAAC,OAAO;QAAE,OAAO,KAAK,CAAC;IACvD,OAAO,CACL,GAAG,CAAC,8BAA8B,KAAK,iBAAiB,CAAC,GAAG,CAAC,aAAa,CAAC;QAC3E,GAAG,CAAC,+BAA+B,KAAK,iBAAiB,CAAC,GAAG,CAAC,cAAc,CAAC,CAC9E,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { type RuntimeLockAcquireResult, type RuntimeLockOwner } from '../shared/runtime-lock.js';
|
|
2
|
+
export interface DaemonStartOwner extends RuntimeLockOwner {
|
|
3
|
+
purpose: 'daemon-start';
|
|
4
|
+
socketPath: string;
|
|
5
|
+
binaryPath: string;
|
|
6
|
+
binarySha256: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function resolveDaemonStartLockDir(configDir?: string): string;
|
|
9
|
+
export declare function acquireDaemonStartLock(args: {
|
|
10
|
+
socketPath: string;
|
|
11
|
+
binaryPath: string;
|
|
12
|
+
}): RuntimeLockAcquireResult<DaemonStartOwner>;
|
|
13
|
+
//# sourceMappingURL=daemon-start-lock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-start-lock.d.ts","sourceRoot":"","sources":["../../src/shim/daemon-start-lock.ts"],"names":[],"mappings":"AAIA,OAAO,EAEL,KAAK,wBAAwB,EAC7B,KAAK,gBAAgB,EACtB,MAAM,2BAA2B,CAAC;AAEnC,MAAM,WAAW,gBAAiB,SAAQ,gBAAgB;IACxD,OAAO,EAAE,cAAc,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,wBAAgB,yBAAyB,CAAC,SAAS,SAAqB,GAAG,MAAM,CAEhF;AAED,wBAAgB,sBAAsB,CAAC,IAAI,EAAE;IAC3C,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB,GAAG,wBAAwB,CAAC,gBAAgB,CAAC,CAa7C"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import os from 'os';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { currentBuildStamp } from '../shared/build-stamp.js';
|
|
5
|
+
import { acquireRuntimeLock, } from '../shared/runtime-lock.js';
|
|
6
|
+
export function resolveDaemonStartLockDir(configDir = resolveConfigDir()) {
|
|
7
|
+
return path.join(configDir, 'daemon-start.lock');
|
|
8
|
+
}
|
|
9
|
+
export function acquireDaemonStartLock(args) {
|
|
10
|
+
const configDir = resolveConfigDir();
|
|
11
|
+
fs.mkdirSync(configDir, { recursive: true });
|
|
12
|
+
const stamp = currentBuildStamp(args.binaryPath);
|
|
13
|
+
return acquireRuntimeLock(resolveDaemonStartLockDir(configDir), {
|
|
14
|
+
schemaVersion: 1,
|
|
15
|
+
purpose: 'daemon-start',
|
|
16
|
+
pid: process.pid,
|
|
17
|
+
createdAt: new Date().toISOString(),
|
|
18
|
+
socketPath: args.socketPath,
|
|
19
|
+
binaryPath: stamp.binaryPath,
|
|
20
|
+
binarySha256: stamp.binarySha256,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
function resolveConfigDir() {
|
|
24
|
+
return process.env['VGE_CC_GUARD_CONFIG_DIR'] ?? path.join(os.homedir(), '.vge-cc-guard');
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=daemon-start-lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-start-lock.js","sourceRoot":"","sources":["../../src/shim/daemon-start-lock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EACL,kBAAkB,GAGnB,MAAM,2BAA2B,CAAC;AASnC,MAAM,UAAU,yBAAyB,CAAC,SAAS,GAAG,gBAAgB,EAAE;IACtE,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,IAGtC;IACC,MAAM,SAAS,GAAG,gBAAgB,EAAE,CAAC;IACrC,EAAE,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC7C,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACjD,OAAO,kBAAkB,CAAC,yBAAyB,CAAC,SAAS,CAAC,EAAE;QAC9D,aAAa,EAAE,CAAC;QAChB,OAAO,EAAE,cAAc;QACvB,GAAG,EAAE,OAAO,CAAC,GAAG;QAChB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACnC,UAAU,EAAE,IAAI,CAAC,UAAU;QAC3B,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,YAAY,EAAE,KAAK,CAAC,YAAY;KACjC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,gBAAgB;IACvB,OAAO,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,eAAe,CAAC,CAAC;AAC5F,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export declare function shouldStartInlineResolver(event: string, envValue?: string | undefined): boolean;
|
|
2
|
+
export declare function resolveRequestTimeoutMs(envValue?: string | undefined): number;
|
|
3
|
+
export interface SocketResult {
|
|
4
|
+
body: string;
|
|
5
|
+
status: number;
|
|
6
|
+
}
|
|
7
|
+
interface RetryOptions {
|
|
8
|
+
retryBudgetMs?: number;
|
|
9
|
+
backoffMs?: number[];
|
|
10
|
+
sleep?: (ms: number) => Promise<void>;
|
|
11
|
+
send?: () => Promise<SocketResult | null>;
|
|
12
|
+
}
|
|
13
|
+
export declare function sendToSocketWithRetry(socketPath: string, event: string, payload: unknown, opts?: RetryOptions): Promise<SocketResult | null>;
|
|
14
|
+
export declare function main(): Promise<void>;
|
|
15
|
+
export declare function daemonFailureExitCode(event: string): number;
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/shim/index.ts"],"names":[],"mappings":"AAYA,wBAAgB,yBAAyB,CACvC,KAAK,EAAE,MAAM,EACb,QAAQ,qBAA8C,GACrD,OAAO,CAET;AAED,wBAAgB,uBAAuB,CAAC,QAAQ,qBAA8C,GAAG,MAAM,CAKtG;AAeD,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,YAAY;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,KAAK,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,IAAI,CAAC,EAAE,MAAM,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CAAC;CAC3C;AAqCD,wBAAsB,qBAAqB,CACzC,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,OAAO,EAChB,IAAI,GAAE,YAAiB,GACtB,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CAmB9B;AA+CD,wBAAsB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAsD1C;AAED,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAE3D"}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import * as http from 'http';
|
|
2
|
+
import { ensureDaemonRunning } from './lazy-start.js';
|
|
3
|
+
import { sessionIdFromHookPayload, startInlineResolver } from './inline-resolver.js';
|
|
4
|
+
import { getIpcAddress } from '../shared/ipc-address.js';
|
|
5
|
+
import { readDaemonToken, tokenHeader } from '../shared/daemon-token.js';
|
|
6
|
+
const DEFAULT_REQUEST_TIMEOUT_MS = 125_000;
|
|
7
|
+
const MAX_REQUEST_TIMEOUT_MS = 125_000;
|
|
8
|
+
const CLAUDE_CODE_COMMAND_TIMEOUT_MS = 600_000;
|
|
9
|
+
const DEFAULT_RESTART_RETRY_BUDGET_MS = 1_000;
|
|
10
|
+
const DEFAULT_RESTART_BACKOFF_MS = [50, 100, 200, 400];
|
|
11
|
+
export function shouldStartInlineResolver(event, envValue = process.env['VGE_CC_GUARD_INLINE_RESOLVER']) {
|
|
12
|
+
return envValue === '1' && (event === 'pretool' || event === 'posttool');
|
|
13
|
+
}
|
|
14
|
+
export function resolveRequestTimeoutMs(envValue = process.env['VGE_CC_GUARD_HOOK_TIMEOUT_MS']) {
|
|
15
|
+
if (envValue === undefined || envValue.trim() === '')
|
|
16
|
+
return DEFAULT_REQUEST_TIMEOUT_MS;
|
|
17
|
+
const parsed = Number(envValue);
|
|
18
|
+
if (!Number.isInteger(parsed) || parsed <= 0)
|
|
19
|
+
return DEFAULT_REQUEST_TIMEOUT_MS;
|
|
20
|
+
return Math.min(parsed, MAX_REQUEST_TIMEOUT_MS, CLAUDE_CODE_COMMAND_TIMEOUT_MS - 1);
|
|
21
|
+
}
|
|
22
|
+
function readStdin() {
|
|
23
|
+
return new Promise((resolve, reject) => {
|
|
24
|
+
const chunks = [];
|
|
25
|
+
process.stdin.on('data', (chunk) => chunks.push(chunk));
|
|
26
|
+
process.stdin.on('end', () => resolve(Buffer.concat(chunks).toString('utf8')));
|
|
27
|
+
process.stdin.on('error', reject);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
function sleep(ms) {
|
|
31
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
32
|
+
}
|
|
33
|
+
function sendToSocket(socketPath, event, payload) {
|
|
34
|
+
return new Promise((resolve) => {
|
|
35
|
+
// Daemon routes expect the CC payload directly; event name is conveyed via URL path.
|
|
36
|
+
const body = JSON.stringify(payload);
|
|
37
|
+
const token = readDaemonToken();
|
|
38
|
+
const req = http.request({
|
|
39
|
+
socketPath,
|
|
40
|
+
path: `/v1/hooks/${event}`,
|
|
41
|
+
method: 'POST',
|
|
42
|
+
headers: {
|
|
43
|
+
'Content-Type': 'application/json',
|
|
44
|
+
'Content-Length': Buffer.byteLength(body),
|
|
45
|
+
...(token ? tokenHeader(token) : {}),
|
|
46
|
+
},
|
|
47
|
+
timeout: resolveRequestTimeoutMs(),
|
|
48
|
+
}, (res) => {
|
|
49
|
+
const chunks = [];
|
|
50
|
+
res.on('data', (c) => chunks.push(c));
|
|
51
|
+
res.on('end', () => resolve({ body: Buffer.concat(chunks).toString('utf8'), status: res.statusCode ?? 0 }));
|
|
52
|
+
});
|
|
53
|
+
req.on('error', () => resolve(null));
|
|
54
|
+
req.on('timeout', () => {
|
|
55
|
+
req.destroy();
|
|
56
|
+
resolve(null);
|
|
57
|
+
});
|
|
58
|
+
req.write(body);
|
|
59
|
+
req.end();
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
export async function sendToSocketWithRetry(socketPath, event, payload, opts = {}) {
|
|
63
|
+
const retryBudgetMs = opts.retryBudgetMs ?? DEFAULT_RESTART_RETRY_BUDGET_MS;
|
|
64
|
+
const backoffMs = opts.backoffMs ?? DEFAULT_RESTART_BACKOFF_MS;
|
|
65
|
+
const sleepFor = opts.sleep ?? sleep;
|
|
66
|
+
const send = opts.send ?? (() => sendToSocket(socketPath, event, payload));
|
|
67
|
+
let spentMs = 0;
|
|
68
|
+
let attempt = 0;
|
|
69
|
+
for (;;) {
|
|
70
|
+
const result = await send();
|
|
71
|
+
if (!shouldRetryDaemonRequest(result))
|
|
72
|
+
return result;
|
|
73
|
+
const delayMs = backoffMs[Math.min(attempt, backoffMs.length - 1)] ?? retryBudgetMs;
|
|
74
|
+
if (spentMs + delayMs > retryBudgetMs)
|
|
75
|
+
return result;
|
|
76
|
+
await sleepFor(delayMs);
|
|
77
|
+
spentMs += Math.max(delayMs, 1);
|
|
78
|
+
attempt += 1;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
function shouldRetryDaemonRequest(result) {
|
|
82
|
+
if (result === null)
|
|
83
|
+
return true;
|
|
84
|
+
if (result.status === 401)
|
|
85
|
+
return true;
|
|
86
|
+
if (result.status === 503 && responseError(result.body) === 'daemon_draining')
|
|
87
|
+
return false;
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
function responseError(body) {
|
|
91
|
+
try {
|
|
92
|
+
const parsed = JSON.parse(body);
|
|
93
|
+
return typeof parsed.error === 'string' ? parsed.error : null;
|
|
94
|
+
}
|
|
95
|
+
catch {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
// Returns true iff the response was successfully forwarded to stdout in the
|
|
100
|
+
// shape Claude Code expects. False signals a malformed/non-JSON daemon response —
|
|
101
|
+
// caller decides exit code (fail-closed for pretool, fail-open otherwise).
|
|
102
|
+
function writeResponse(event, responseText) {
|
|
103
|
+
let parsed;
|
|
104
|
+
try {
|
|
105
|
+
parsed = JSON.parse(responseText);
|
|
106
|
+
}
|
|
107
|
+
catch {
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
if (event === 'pretool') {
|
|
111
|
+
// Daemon for pretool returns CC-ready { hookSpecificOutput: {...} }.
|
|
112
|
+
// Verify the shape before claiming success — otherwise CC sees nothing
|
|
113
|
+
// and defaults to allow (fail-open). PR-review C2.
|
|
114
|
+
const hso = parsed.hookSpecificOutput;
|
|
115
|
+
if (!hso || typeof hso.permissionDecision !== 'string')
|
|
116
|
+
return false;
|
|
117
|
+
process.stdout.write(responseText.trimEnd() + '\n');
|
|
118
|
+
return true;
|
|
119
|
+
}
|
|
120
|
+
// Non-PreTool hook routes return { ccOutput: ... } and write nothing when it is null.
|
|
121
|
+
const wrapped = parsed;
|
|
122
|
+
if (wrapped.ccOutput != null) {
|
|
123
|
+
process.stdout.write(JSON.stringify(wrapped.ccOutput) + '\n');
|
|
124
|
+
}
|
|
125
|
+
return true;
|
|
126
|
+
}
|
|
127
|
+
export async function main() {
|
|
128
|
+
const event = process.argv[3];
|
|
129
|
+
if (!event) {
|
|
130
|
+
process.stderr.write('vge-cc-guard hook: missing event name\n');
|
|
131
|
+
process.exit(1);
|
|
132
|
+
}
|
|
133
|
+
let rawInput;
|
|
134
|
+
try {
|
|
135
|
+
rawInput = await readStdin();
|
|
136
|
+
}
|
|
137
|
+
catch {
|
|
138
|
+
process.stderr.write('vge-cc-guard hook: failed to read stdin\n');
|
|
139
|
+
process.exit(event === 'pretool' ? 2 : 0);
|
|
140
|
+
}
|
|
141
|
+
let payload;
|
|
142
|
+
try {
|
|
143
|
+
payload = JSON.parse(rawInput);
|
|
144
|
+
}
|
|
145
|
+
catch {
|
|
146
|
+
process.stderr.write('vge-cc-guard hook: invalid JSON on stdin\n');
|
|
147
|
+
process.exit(2);
|
|
148
|
+
}
|
|
149
|
+
await ensureDaemonRunning();
|
|
150
|
+
const socketPath = getIpcAddress();
|
|
151
|
+
const inlineResolver = shouldStartInlineResolver(event)
|
|
152
|
+
? startInlineResolver(socketPath, sessionIdFromHookPayload(event, payload))
|
|
153
|
+
: null;
|
|
154
|
+
let result;
|
|
155
|
+
try {
|
|
156
|
+
await inlineResolver?.ready;
|
|
157
|
+
result = await sendToSocketWithRetry(socketPath, event, payload);
|
|
158
|
+
}
|
|
159
|
+
finally {
|
|
160
|
+
inlineResolver?.stop();
|
|
161
|
+
}
|
|
162
|
+
if (result === null) {
|
|
163
|
+
process.exit(event === 'pretool' ? 2 : 0);
|
|
164
|
+
}
|
|
165
|
+
// Non-2xx from daemon → unparseable shape almost always; fail-closed for pretool.
|
|
166
|
+
if (result.status < 200 || result.status >= 300) {
|
|
167
|
+
process.stderr.write(`vge-cc-guard hook: daemon returned status ${result.status}\n`);
|
|
168
|
+
process.exit(event === 'pretool' ? 2 : 0);
|
|
169
|
+
}
|
|
170
|
+
const ok = writeResponse(event, result.body);
|
|
171
|
+
if (!ok) {
|
|
172
|
+
process.stderr.write('vge-cc-guard hook: malformed daemon response\n');
|
|
173
|
+
process.exit(daemonFailureExitCode(event));
|
|
174
|
+
}
|
|
175
|
+
process.exit(0);
|
|
176
|
+
}
|
|
177
|
+
export function daemonFailureExitCode(event) {
|
|
178
|
+
return event === 'pretool' ? 2 : 0;
|
|
179
|
+
}
|
|
180
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/shim/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { BlockingDecision, BlockingDecisionChoice } from '../shared/types.js';
|
|
2
|
+
interface RenderState {
|
|
3
|
+
status: string;
|
|
4
|
+
selected?: BlockingDecisionChoice;
|
|
5
|
+
invalid?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function ttyAvailable(ttyPath?: string): boolean;
|
|
8
|
+
export declare function choiceFromInlineInput(input: string): BlockingDecisionChoice | null;
|
|
9
|
+
export declare function formatInlineDecisionPrompt(decision: BlockingDecision, width?: number, state?: RenderState): string;
|
|
10
|
+
export declare function promptBlockingDecisionOnTty(decision: BlockingDecision, signal: AbortSignal, ttyPath?: string): Promise<BlockingDecisionChoice | null>;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=inline-resolver-terminal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inline-resolver-terminal.d.ts","sourceRoot":"","sources":["../../src/shim/inline-resolver-terminal.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAenF,UAAU,WAAW;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,sBAAsB,CAAC;IAClC,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,YAAY,CAAC,OAAO,SAAW,GAAG,OAAO,CAUxD;AAMD,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,MAAM,GAAG,sBAAsB,GAAG,IAAI,CAQlF;AAuED,wBAAgB,0BAA0B,CAAC,QAAQ,EAAE,gBAAgB,EAAE,KAAK,SAAM,EAAE,KAAK,CAAC,EAAE,WAAW,GAAG,MAAM,CA6B/G;AAED,wBAAgB,2BAA2B,CACzC,QAAQ,EAAE,gBAAgB,EAC1B,MAAM,EAAE,WAAW,EACnB,OAAO,SAAW,GACjB,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC,CAiExC"}
|