@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,138 @@
|
|
|
1
|
+
import { execFile } from 'child_process';
|
|
2
|
+
import * as fs from 'fs';
|
|
3
|
+
import * as os from 'os';
|
|
4
|
+
import * as path from 'path';
|
|
5
|
+
const STDERR_PREVIEW_MAX = 512;
|
|
6
|
+
export const CC_CONTRACT_PROBE_UPDATED_MARKER = 'VGE_CC_GUARD_UPDATED_TOOL_OUTPUT_OK';
|
|
7
|
+
const CC_CONTRACT_PROBE_RAW_MARKER = 'VGE_CC_GUARD_PROBE_RAW_OUTPUT';
|
|
8
|
+
function defaultTempDir() {
|
|
9
|
+
return fs.mkdtempSync(path.join(os.tmpdir(), 'vge-cc-contract-probe-'));
|
|
10
|
+
}
|
|
11
|
+
function stderrPreview(value) {
|
|
12
|
+
if (!value)
|
|
13
|
+
return undefined;
|
|
14
|
+
return value.length > STDERR_PREVIEW_MAX ? value.slice(0, STDERR_PREVIEW_MAX) : value;
|
|
15
|
+
}
|
|
16
|
+
function errorPreview(error) {
|
|
17
|
+
if (error instanceof Error)
|
|
18
|
+
return stderrPreview(error.message);
|
|
19
|
+
return stderrPreview(String(error));
|
|
20
|
+
}
|
|
21
|
+
export function execFileProbeRunner(request) {
|
|
22
|
+
return new Promise((resolve) => {
|
|
23
|
+
const child = execFile(request.binaryPath, request.args, {
|
|
24
|
+
cwd: request.cwd,
|
|
25
|
+
encoding: 'utf8',
|
|
26
|
+
maxBuffer: 1024 * 1024,
|
|
27
|
+
timeout: request.timeoutMs,
|
|
28
|
+
}, (error, stdout, stderr) => {
|
|
29
|
+
const maybeError = error;
|
|
30
|
+
resolve({
|
|
31
|
+
exitCode: typeof maybeError?.code === 'number' ? maybeError.code : maybeError ? 1 : 0,
|
|
32
|
+
stdout,
|
|
33
|
+
stderr,
|
|
34
|
+
timedOut: Boolean(maybeError?.killed && maybeError.signal === 'SIGTERM'),
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
child.stdin?.end();
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
export function prepareClaudeCodeContractProbe(cwd) {
|
|
41
|
+
const hookScript = path.join(cwd, 'posttool-contract-hook.cjs');
|
|
42
|
+
const settingsPath = path.join(cwd, 'settings.json');
|
|
43
|
+
const hookSource = [
|
|
44
|
+
`const marker = ${JSON.stringify(CC_CONTRACT_PROBE_UPDATED_MARKER)};`,
|
|
45
|
+
'process.stdout.write(JSON.stringify({',
|
|
46
|
+
' hookSpecificOutput: {',
|
|
47
|
+
' hookEventName: "PostToolUse",',
|
|
48
|
+
' updatedToolOutput: { stdout: `${marker}\\n`, stderr: "", interrupted: false, isImage: false },',
|
|
49
|
+
' },',
|
|
50
|
+
'}));',
|
|
51
|
+
'',
|
|
52
|
+
].join('\n');
|
|
53
|
+
fs.writeFileSync(hookScript, hookSource, { mode: 0o700 });
|
|
54
|
+
fs.writeFileSync(settingsPath, JSON.stringify({
|
|
55
|
+
hooks: {
|
|
56
|
+
PostToolUse: [
|
|
57
|
+
{
|
|
58
|
+
matcher: 'Bash',
|
|
59
|
+
hooks: [{ type: 'command', command: `${JSON.stringify(process.execPath)} ${JSON.stringify(hookScript)}` }],
|
|
60
|
+
},
|
|
61
|
+
],
|
|
62
|
+
},
|
|
63
|
+
}, null, 2), { mode: 0o600 });
|
|
64
|
+
return {
|
|
65
|
+
expectedMarker: CC_CONTRACT_PROBE_UPDATED_MARKER,
|
|
66
|
+
args: [
|
|
67
|
+
'--print',
|
|
68
|
+
'--output-format=stream-json',
|
|
69
|
+
'--verbose',
|
|
70
|
+
'--include-hook-events',
|
|
71
|
+
'--no-session-persistence',
|
|
72
|
+
'--setting-sources',
|
|
73
|
+
'project',
|
|
74
|
+
'--settings',
|
|
75
|
+
settingsPath,
|
|
76
|
+
'--model',
|
|
77
|
+
'haiku',
|
|
78
|
+
'--disable-slash-commands',
|
|
79
|
+
'--tools',
|
|
80
|
+
'Bash',
|
|
81
|
+
'--allowedTools',
|
|
82
|
+
'Bash(printf *)',
|
|
83
|
+
'--permission-mode',
|
|
84
|
+
'bypassPermissions',
|
|
85
|
+
'--max-budget-usd',
|
|
86
|
+
'0.05',
|
|
87
|
+
`Use the Bash tool exactly once to run: printf '${CC_CONTRACT_PROBE_RAW_MARKER}\\n'. Do not run any other command.`,
|
|
88
|
+
],
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
export async function runCcContractProbe(opts) {
|
|
92
|
+
if (!opts.binaryPath)
|
|
93
|
+
return { ok: false, reason: 'binary_missing' };
|
|
94
|
+
const makeTempDir = opts.makeTempDir ?? defaultTempDir;
|
|
95
|
+
const runProcess = opts.runProcess ?? execFileProbeRunner;
|
|
96
|
+
const cwd = makeTempDir();
|
|
97
|
+
try {
|
|
98
|
+
const plan = opts.prepareCwd?.(cwd) ?? {
|
|
99
|
+
args: opts.args ?? [],
|
|
100
|
+
expectedMarker: opts.expectedMarker ?? CC_CONTRACT_PROBE_UPDATED_MARKER,
|
|
101
|
+
};
|
|
102
|
+
const probe = await runProcess({
|
|
103
|
+
binaryPath: opts.binaryPath,
|
|
104
|
+
args: plan.args,
|
|
105
|
+
cwd,
|
|
106
|
+
timeoutMs: opts.timeoutMs,
|
|
107
|
+
});
|
|
108
|
+
if (probe.timedOut) {
|
|
109
|
+
return { ok: false, reason: 'timeout', stderrPreview: stderrPreview(probe.stderr) };
|
|
110
|
+
}
|
|
111
|
+
if (probe.exitCode !== 0) {
|
|
112
|
+
return {
|
|
113
|
+
ok: false,
|
|
114
|
+
reason: 'exit_nonzero',
|
|
115
|
+
exitCode: probe.exitCode ?? undefined,
|
|
116
|
+
stderrPreview: stderrPreview(probe.stderr),
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
if (!probe.stdout.includes(plan.expectedMarker)) {
|
|
120
|
+
return { ok: false, reason: 'shape_mismatch' };
|
|
121
|
+
}
|
|
122
|
+
return {
|
|
123
|
+
ok: true,
|
|
124
|
+
evidence: {
|
|
125
|
+
binaryPath: opts.binaryPath,
|
|
126
|
+
marker: plan.expectedMarker,
|
|
127
|
+
checkedAt: new Date().toISOString(),
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
catch (err) {
|
|
132
|
+
return { ok: false, reason: 'io_error', stderrPreview: errorPreview(err) };
|
|
133
|
+
}
|
|
134
|
+
finally {
|
|
135
|
+
fs.rmSync(cwd, { recursive: true, force: true });
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
//# sourceMappingURL=cc-contract-probe.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cc-contract-probe.js","sourceRoot":"","sources":["../../src/daemon/cc-contract-probe.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { getCcContractHealth, type CcContractHealth } from './cc-contract-status.js';
|
|
2
|
+
export declare function createCcContractRuntimeMonitor(readHealth?: typeof getCcContractHealth): {
|
|
3
|
+
observe: () => CcContractHealth;
|
|
4
|
+
};
|
|
5
|
+
export declare const ccContractRuntimeMonitor: {
|
|
6
|
+
observe: () => CcContractHealth;
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=cc-contract-runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cc-contract-runtime.d.ts","sourceRoot":"","sources":["../../src/daemon/cc-contract-runtime.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,mBAAmB,EACnB,KAAK,gBAAgB,EACtB,MAAM,yBAAyB,CAAC;AAyBjC,wBAAgB,8BAA8B,CAAC,UAAU,6BAAsB,GAAG;IAChF,OAAO,EAAE,MAAM,gBAAgB,CAAC;CACjC,CAuBA;AAED,eAAO,MAAM,wBAAwB;aA1B1B,MAAM,gBAAgB;CA0BuC,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { appendEvent } from '../shared/audit-writer.js';
|
|
2
|
+
import { CC_BINARY_SHA_PREFIX_LEN, getCcContractHealth, } from './cc-contract-status.js';
|
|
3
|
+
function availabilityFor(health) {
|
|
4
|
+
return health.l0RedactionAvailable ? 'healthy' : 'degraded';
|
|
5
|
+
}
|
|
6
|
+
function logContractTransition(eventType, health) {
|
|
7
|
+
appendEvent({
|
|
8
|
+
event_type: eventType,
|
|
9
|
+
reason: health.reason,
|
|
10
|
+
claude_version: health.claudeVersion,
|
|
11
|
+
binary_path: health.binaryPath,
|
|
12
|
+
binary_sha256_prefix: health.binarySha256?.slice(0, CC_BINARY_SHA_PREFIX_LEN) ?? null,
|
|
13
|
+
live_contract: health.liveContract,
|
|
14
|
+
l0_redaction_available: health.l0RedactionAvailable,
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
export function createCcContractRuntimeMonitor(readHealth = getCcContractHealth) {
|
|
18
|
+
let lastObserved = null;
|
|
19
|
+
return {
|
|
20
|
+
observe() {
|
|
21
|
+
const health = readHealth();
|
|
22
|
+
const availability = availabilityFor(health);
|
|
23
|
+
const observed = { availability, reason: health.reason };
|
|
24
|
+
if (!lastObserved && availability === 'degraded') {
|
|
25
|
+
logContractTransition('cc_contract_degraded', health);
|
|
26
|
+
}
|
|
27
|
+
else if (lastObserved?.availability === 'degraded' && availability === 'healthy') {
|
|
28
|
+
logContractTransition('cc_contract_recovered', health);
|
|
29
|
+
}
|
|
30
|
+
else if (lastObserved?.availability === 'healthy' && availability === 'degraded') {
|
|
31
|
+
logContractTransition('cc_contract_degraded', health);
|
|
32
|
+
}
|
|
33
|
+
else if (lastObserved?.availability === 'degraded' && availability === 'degraded' && lastObserved.reason !== health.reason) {
|
|
34
|
+
logContractTransition('cc_contract_degraded', health);
|
|
35
|
+
}
|
|
36
|
+
lastObserved = observed;
|
|
37
|
+
return health;
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
export const ccContractRuntimeMonitor = createCcContractRuntimeMonitor();
|
|
42
|
+
//# sourceMappingURL=cc-contract-runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cc-contract-runtime.js","sourceRoot":"","sources":["../../src/daemon/cc-contract-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EACL,wBAAwB,EACxB,mBAAmB,GAEpB,MAAM,yBAAyB,CAAC;AASjC,SAAS,eAAe,CAAC,MAAwB;IAC/C,OAAO,MAAM,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC;AAC9D,CAAC;AAED,SAAS,qBAAqB,CAAC,SAA2D,EAAE,MAAwB;IAClH,WAAW,CAAC;QACV,UAAU,EAAE,SAAS;QACrB,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,cAAc,EAAE,MAAM,CAAC,aAAa;QACpC,WAAW,EAAE,MAAM,CAAC,UAAU;QAC9B,oBAAoB,EAAE,MAAM,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,EAAE,wBAAwB,CAAC,IAAI,IAAI;QACrF,aAAa,EAAE,MAAM,CAAC,YAAY;QAClC,sBAAsB,EAAE,MAAM,CAAC,oBAAoB;KACpD,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,8BAA8B,CAAC,UAAU,GAAG,mBAAmB;IAG7E,IAAI,YAAY,GAA4B,IAAI,CAAC;IAEjD,OAAO;QACL,OAAO;YACL,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;YAC5B,MAAM,YAAY,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;YAC7C,MAAM,QAAQ,GAAG,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;YAEzD,IAAI,CAAC,YAAY,IAAI,YAAY,KAAK,UAAU,EAAE,CAAC;gBACjD,qBAAqB,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;YACxD,CAAC;iBAAM,IAAI,YAAY,EAAE,YAAY,KAAK,UAAU,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;gBACnF,qBAAqB,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;YACzD,CAAC;iBAAM,IAAI,YAAY,EAAE,YAAY,KAAK,SAAS,IAAI,YAAY,KAAK,UAAU,EAAE,CAAC;gBACnF,qBAAqB,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;YACxD,CAAC;iBAAM,IAAI,YAAY,EAAE,YAAY,KAAK,UAAU,IAAI,YAAY,KAAK,UAAU,IAAI,YAAY,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,CAAC;gBAC7H,qBAAqB,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;YACxD,CAAC;YAED,YAAY,GAAG,QAAQ,CAAC;YACxB,OAAO,MAAM,CAAC;QAChB,CAAC;KACF,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,8BAA8B,EAAE,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export type CcContractState = 'healthy' | 'degraded' | 'failed';
|
|
2
|
+
export interface CcContractStatus {
|
|
3
|
+
status: CcContractState;
|
|
4
|
+
claudeVersion: string;
|
|
5
|
+
checkedAt: string;
|
|
6
|
+
binaryPath?: string | null;
|
|
7
|
+
binarySha256?: string | null;
|
|
8
|
+
liveContract?: 'passed' | 'skipped' | 'failed';
|
|
9
|
+
reason?: string;
|
|
10
|
+
}
|
|
11
|
+
export type CcContractHealthReason = 'healthy' | 'status_missing' | 'status_not_healthy' | 'version_unknown' | 'version_mismatch' | 'binary_missing' | 'binary_path_mismatch' | 'binary_sha_mismatch' | 'live_contract_not_passed' | 'dev_override';
|
|
12
|
+
export type CcContractRuntimeReason = CcContractHealthReason | 'unknown';
|
|
13
|
+
export declare const CC_BINARY_SHA_PREFIX_LEN = 12;
|
|
14
|
+
export declare function parseCcContractHealthReason(reason: unknown): CcContractRuntimeReason;
|
|
15
|
+
export declare function ccContractNextAction(reason: CcContractRuntimeReason): string;
|
|
16
|
+
export interface CcContractHealth {
|
|
17
|
+
l0RedactionAvailable: boolean;
|
|
18
|
+
state: CcContractState;
|
|
19
|
+
reason: CcContractHealthReason;
|
|
20
|
+
claudeVersion: string | null;
|
|
21
|
+
binaryPath: string | null;
|
|
22
|
+
binarySha256: string | null;
|
|
23
|
+
checkedAt: string | null;
|
|
24
|
+
statusPath: string;
|
|
25
|
+
liveContract: 'passed' | 'skipped' | 'failed' | null;
|
|
26
|
+
}
|
|
27
|
+
export declare function ccContractStatusPath(): string;
|
|
28
|
+
export declare function resolveClaudeBinary(opts?: {
|
|
29
|
+
envPath?: string;
|
|
30
|
+
platform?: NodeJS.Platform;
|
|
31
|
+
}): string | null;
|
|
32
|
+
export declare function getClaudeVersion(): string | null;
|
|
33
|
+
export declare function readCcContractStatus(): CcContractStatus | null;
|
|
34
|
+
export declare function getCcContractHealth(): CcContractHealth;
|
|
35
|
+
export declare function isCcContractHealthyForCurrentVersion(): boolean;
|
|
36
|
+
export declare function writeCcContractStatus(status: CcContractStatus): string;
|
|
37
|
+
export declare function createCcContractStatus(opts?: {
|
|
38
|
+
assumeLivePassed?: boolean;
|
|
39
|
+
}): CcContractStatus;
|
|
40
|
+
//# sourceMappingURL=cc-contract-status.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cc-contract-status.d.ts","sourceRoot":"","sources":["../../src/daemon/cc-contract-status.ts"],"names":[],"mappings":"AAOA,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG,UAAU,GAAG,QAAQ,CAAC;AAEhE,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,eAAe,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,YAAY,CAAC,EAAE,QAAQ,GAAG,SAAS,GAAG,QAAQ,CAAC;IAC/C,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,MAAM,sBAAsB,GAC9B,SAAS,GACT,gBAAgB,GAChB,oBAAoB,GACpB,iBAAiB,GACjB,kBAAkB,GAClB,gBAAgB,GAChB,sBAAsB,GACtB,qBAAqB,GACrB,0BAA0B,GAC1B,cAAc,CAAC;AAEnB,MAAM,MAAM,uBAAuB,GAAG,sBAAsB,GAAG,SAAS,CAAC;AAEzE,eAAO,MAAM,wBAAwB,KAAK,CAAC;AAe3C,wBAAgB,2BAA2B,CAAC,MAAM,EAAE,OAAO,GAAG,uBAAuB,CAIpF;AAED,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,uBAAuB,GAAG,MAAM,CAU5E;AAED,MAAM,WAAW,gBAAgB;IAC/B,oBAAoB,EAAE,OAAO,CAAC;IAC9B,KAAK,EAAE,eAAe,CAAC;IACvB,MAAM,EAAE,sBAAsB,CAAC;IAC/B,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,QAAQ,GAAG,SAAS,GAAG,QAAQ,GAAG,IAAI,CAAC;CACtD;AAaD,wBAAgB,oBAAoB,IAAI,MAAM,CAE7C;AAcD,wBAAgB,mBAAmB,CAAC,IAAI,GAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAA;CAAO,GAAG,MAAM,GAAG,IAAI,CAe9G;AAcD,wBAAgB,gBAAgB,IAAI,MAAM,GAAG,IAAI,CAqBhD;AAED,wBAAgB,oBAAoB,IAAI,gBAAgB,GAAG,IAAI,CAM9D;AAqBD,wBAAgB,mBAAmB,IAAI,gBAAgB,CAuDtD;AAED,wBAAgB,oCAAoC,IAAI,OAAO,CAE9D;AAoBD,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,gBAAgB,GAAG,MAAM,CAKtE;AAED,wBAAgB,sBAAsB,CAAC,IAAI,GAAE;IAAE,gBAAgB,CAAC,EAAE,OAAO,CAAA;CAAO,GAAG,gBAAgB,CA6BlG"}
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
import * as crypto from 'crypto';
|
|
2
|
+
import fs from 'fs';
|
|
3
|
+
import * as os from 'os';
|
|
4
|
+
import * as path from 'path';
|
|
5
|
+
import { execFileSync } from 'child_process';
|
|
6
|
+
import { writePrivateFileSync } from '../shared/private-file.js';
|
|
7
|
+
export const CC_BINARY_SHA_PREFIX_LEN = 12;
|
|
8
|
+
const CC_CONTRACT_HEALTH_REASONS = new Set([
|
|
9
|
+
'healthy',
|
|
10
|
+
'status_missing',
|
|
11
|
+
'status_not_healthy',
|
|
12
|
+
'version_unknown',
|
|
13
|
+
'version_mismatch',
|
|
14
|
+
'binary_missing',
|
|
15
|
+
'binary_path_mismatch',
|
|
16
|
+
'binary_sha_mismatch',
|
|
17
|
+
'live_contract_not_passed',
|
|
18
|
+
'dev_override',
|
|
19
|
+
]);
|
|
20
|
+
export function parseCcContractHealthReason(reason) {
|
|
21
|
+
return typeof reason === 'string' && CC_CONTRACT_HEALTH_REASONS.has(reason)
|
|
22
|
+
? reason
|
|
23
|
+
: 'unknown';
|
|
24
|
+
}
|
|
25
|
+
export function ccContractNextAction(reason) {
|
|
26
|
+
if (reason === 'healthy')
|
|
27
|
+
return 'No action needed.';
|
|
28
|
+
if (reason === 'dev_override')
|
|
29
|
+
return 'Development override is active; do not use for production trust.';
|
|
30
|
+
if (reason === 'version_unknown' || reason === 'binary_missing') {
|
|
31
|
+
return 'Ensure Claude Code is installed and on PATH.';
|
|
32
|
+
}
|
|
33
|
+
if (reason === 'binary_path_mismatch' || reason === 'binary_sha_mismatch' || reason === 'version_mismatch') {
|
|
34
|
+
return 'Run doctor --cc-contract after verifying this Claude Code binary.';
|
|
35
|
+
}
|
|
36
|
+
return 'Run doctor --cc-contract after live contract verification.';
|
|
37
|
+
}
|
|
38
|
+
const CLAUDE_VERSION_CACHE_TTL_MS = 60_000;
|
|
39
|
+
let cachedClaudeVersion;
|
|
40
|
+
let cachedClaudeFingerprint;
|
|
41
|
+
function configDir() {
|
|
42
|
+
return process.env['VGE_CC_GUARD_CONFIG_DIR'] ?? path.join(os.homedir(), '.vge-cc-guard');
|
|
43
|
+
}
|
|
44
|
+
export function ccContractStatusPath() {
|
|
45
|
+
return path.join(configDir(), 'cc-contract-status.json');
|
|
46
|
+
}
|
|
47
|
+
function isExecutable(filePath, platform = process.platform) {
|
|
48
|
+
try {
|
|
49
|
+
const stat = fs.statSync(filePath);
|
|
50
|
+
if (!stat.isFile())
|
|
51
|
+
return false;
|
|
52
|
+
if (platform === 'win32')
|
|
53
|
+
return true;
|
|
54
|
+
fs.accessSync(filePath, fs.constants.X_OK);
|
|
55
|
+
return true;
|
|
56
|
+
}
|
|
57
|
+
catch {
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
export function resolveClaudeBinary(opts = {}) {
|
|
62
|
+
const envPath = opts.envPath ?? process.env['PATH'] ?? '';
|
|
63
|
+
const platform = opts.platform ?? process.platform;
|
|
64
|
+
for (const dir of envPath.split(path.delimiter)) {
|
|
65
|
+
if (!dir)
|
|
66
|
+
continue;
|
|
67
|
+
const candidate = path.join(dir, 'claude');
|
|
68
|
+
// PRD_10 owns Windows PATHEXT and claude.exe activation.
|
|
69
|
+
if (!isExecutable(candidate, platform))
|
|
70
|
+
continue;
|
|
71
|
+
try {
|
|
72
|
+
return fs.realpathSync(candidate);
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
return candidate;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
function readClaudeVersionFromBinary(binaryPath) {
|
|
81
|
+
try {
|
|
82
|
+
return execFileSync(binaryPath, ['--version'], {
|
|
83
|
+
encoding: 'utf-8',
|
|
84
|
+
stdio: ['ignore', 'pipe', 'ignore'],
|
|
85
|
+
timeout: 1500,
|
|
86
|
+
}).trim();
|
|
87
|
+
}
|
|
88
|
+
catch {
|
|
89
|
+
return null;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
export function getClaudeVersion() {
|
|
93
|
+
if (cachedClaudeVersion && cachedClaudeVersion.expiresAt > Date.now()) {
|
|
94
|
+
return cachedClaudeVersion.value;
|
|
95
|
+
}
|
|
96
|
+
const override = process.env['VGE_CC_GUARD_CC_VERSION_OVERRIDE'];
|
|
97
|
+
if (override) {
|
|
98
|
+
cachedClaudeVersion = { value: override, expiresAt: Date.now() + CLAUDE_VERSION_CACHE_TTL_MS };
|
|
99
|
+
return override;
|
|
100
|
+
}
|
|
101
|
+
const binaryPath = resolveClaudeBinary();
|
|
102
|
+
if (!binaryPath) {
|
|
103
|
+
cachedClaudeVersion = { value: null, expiresAt: Date.now() + CLAUDE_VERSION_CACHE_TTL_MS };
|
|
104
|
+
return null;
|
|
105
|
+
}
|
|
106
|
+
const value = readClaudeVersionFromBinary(binaryPath);
|
|
107
|
+
if (value) {
|
|
108
|
+
cachedClaudeVersion = { value, expiresAt: Date.now() + CLAUDE_VERSION_CACHE_TTL_MS };
|
|
109
|
+
return value;
|
|
110
|
+
}
|
|
111
|
+
cachedClaudeVersion = { value: null, expiresAt: Date.now() + CLAUDE_VERSION_CACHE_TTL_MS };
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
export function readCcContractStatus() {
|
|
115
|
+
try {
|
|
116
|
+
return JSON.parse(fs.readFileSync(ccContractStatusPath(), 'utf-8'));
|
|
117
|
+
}
|
|
118
|
+
catch {
|
|
119
|
+
return null;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
function degradedHealth(params) {
|
|
123
|
+
return {
|
|
124
|
+
l0RedactionAvailable: false,
|
|
125
|
+
state: params.status?.status === 'failed' ? 'failed' : 'degraded',
|
|
126
|
+
reason: params.reason,
|
|
127
|
+
claudeVersion: params.claudeVersion,
|
|
128
|
+
binaryPath: params.fingerprint?.path ?? null,
|
|
129
|
+
binarySha256: params.fingerprint?.sha256 ?? null,
|
|
130
|
+
checkedAt: params.status?.checkedAt ?? null,
|
|
131
|
+
statusPath: ccContractStatusPath(),
|
|
132
|
+
liveContract: params.status?.liveContract ?? null,
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
export function getCcContractHealth() {
|
|
136
|
+
const status = readCcContractStatus();
|
|
137
|
+
const currentVersion = getClaudeVersion();
|
|
138
|
+
const fingerprint = getCachedClaudeFingerprint();
|
|
139
|
+
if (process.env['VGE_CC_GUARD_L0_DEV_OVERRIDE'] === '1') {
|
|
140
|
+
return {
|
|
141
|
+
l0RedactionAvailable: true,
|
|
142
|
+
state: 'healthy',
|
|
143
|
+
reason: 'dev_override',
|
|
144
|
+
claudeVersion: currentVersion,
|
|
145
|
+
binaryPath: fingerprint?.path ?? null,
|
|
146
|
+
binarySha256: fingerprint?.sha256 ?? null,
|
|
147
|
+
checkedAt: status?.checkedAt ?? null,
|
|
148
|
+
statusPath: ccContractStatusPath(),
|
|
149
|
+
liveContract: status?.liveContract ?? null,
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
if (!status)
|
|
153
|
+
return degradedHealth({ reason: 'status_missing', status, claudeVersion: currentVersion, fingerprint });
|
|
154
|
+
if (status.status !== 'healthy') {
|
|
155
|
+
return degradedHealth({ reason: 'status_not_healthy', status, claudeVersion: currentVersion, fingerprint });
|
|
156
|
+
}
|
|
157
|
+
if (currentVersion === null) {
|
|
158
|
+
return degradedHealth({ reason: 'version_unknown', status, claudeVersion: currentVersion, fingerprint });
|
|
159
|
+
}
|
|
160
|
+
if (status.claudeVersion !== currentVersion) {
|
|
161
|
+
return degradedHealth({ reason: 'version_mismatch', status, claudeVersion: currentVersion, fingerprint });
|
|
162
|
+
}
|
|
163
|
+
if (status.binaryPath || status.binarySha256) {
|
|
164
|
+
if (!fingerprint)
|
|
165
|
+
return degradedHealth({ reason: 'binary_missing', status, claudeVersion: currentVersion, fingerprint });
|
|
166
|
+
if (status.binaryPath !== fingerprint.path) {
|
|
167
|
+
return degradedHealth({ reason: 'binary_path_mismatch', status, claudeVersion: currentVersion, fingerprint });
|
|
168
|
+
}
|
|
169
|
+
if (status.binarySha256 && status.binarySha256 !== fingerprint.sha256) {
|
|
170
|
+
return degradedHealth({ reason: 'binary_sha_mismatch', status, claudeVersion: currentVersion, fingerprint });
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
if (status.liveContract !== 'passed') {
|
|
174
|
+
return degradedHealth({ reason: 'live_contract_not_passed', status, claudeVersion: currentVersion, fingerprint });
|
|
175
|
+
}
|
|
176
|
+
return {
|
|
177
|
+
l0RedactionAvailable: true,
|
|
178
|
+
state: 'healthy',
|
|
179
|
+
reason: 'healthy',
|
|
180
|
+
claudeVersion: currentVersion,
|
|
181
|
+
binaryPath: fingerprint?.path ?? null,
|
|
182
|
+
binarySha256: fingerprint?.sha256 ?? null,
|
|
183
|
+
checkedAt: status.checkedAt,
|
|
184
|
+
statusPath: ccContractStatusPath(),
|
|
185
|
+
liveContract: status.liveContract,
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
export function isCcContractHealthyForCurrentVersion() {
|
|
189
|
+
return getCcContractHealth().l0RedactionAvailable;
|
|
190
|
+
}
|
|
191
|
+
function sha256(filePath) {
|
|
192
|
+
try {
|
|
193
|
+
return crypto.createHash('sha256').update(fs.readFileSync(filePath)).digest('hex');
|
|
194
|
+
}
|
|
195
|
+
catch {
|
|
196
|
+
return null;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
function getCachedClaudeFingerprint() {
|
|
200
|
+
if (cachedClaudeFingerprint && cachedClaudeFingerprint.expiresAt > Date.now()) {
|
|
201
|
+
return cachedClaudeFingerprint.value;
|
|
202
|
+
}
|
|
203
|
+
const binaryPath = resolveClaudeBinary();
|
|
204
|
+
const value = binaryPath ? { path: binaryPath, sha256: sha256(binaryPath) } : null;
|
|
205
|
+
cachedClaudeFingerprint = { value, expiresAt: Date.now() + CLAUDE_VERSION_CACHE_TTL_MS };
|
|
206
|
+
return value;
|
|
207
|
+
}
|
|
208
|
+
export function writeCcContractStatus(status) {
|
|
209
|
+
const target = ccContractStatusPath();
|
|
210
|
+
fs.mkdirSync(path.dirname(target), { recursive: true });
|
|
211
|
+
writePrivateFileSync(target, JSON.stringify(status, null, 2));
|
|
212
|
+
return target;
|
|
213
|
+
}
|
|
214
|
+
export function createCcContractStatus(opts = {}) {
|
|
215
|
+
const binaryPath = resolveClaudeBinary();
|
|
216
|
+
const claudeVersion = process.env['VGE_CC_GUARD_CC_VERSION_OVERRIDE']
|
|
217
|
+
?? (binaryPath ? readClaudeVersionFromBinary(binaryPath) : null);
|
|
218
|
+
if (!claudeVersion) {
|
|
219
|
+
return {
|
|
220
|
+
status: 'failed',
|
|
221
|
+
claudeVersion: 'unknown',
|
|
222
|
+
checkedAt: new Date().toISOString(),
|
|
223
|
+
binaryPath,
|
|
224
|
+
binarySha256: binaryPath ? sha256(binaryPath) : null,
|
|
225
|
+
liveContract: 'failed',
|
|
226
|
+
reason: 'claude binary not found',
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
const liveContract = opts.assumeLivePassed ? 'passed' : 'skipped';
|
|
230
|
+
return {
|
|
231
|
+
status: liveContract === 'passed' ? 'healthy' : 'degraded',
|
|
232
|
+
claudeVersion,
|
|
233
|
+
checkedAt: new Date().toISOString(),
|
|
234
|
+
binaryPath,
|
|
235
|
+
binarySha256: binaryPath ? sha256(binaryPath) : null,
|
|
236
|
+
liveContract,
|
|
237
|
+
reason: liveContract === 'passed'
|
|
238
|
+
? 'live contract marked passed by explicit doctor flag'
|
|
239
|
+
: 'live contract was not run',
|
|
240
|
+
};
|
|
241
|
+
}
|
|
242
|
+
//# sourceMappingURL=cc-contract-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cc-contract-status.js","sourceRoot":"","sources":["../../src/daemon/cc-contract-status.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"confidence-router.d.ts","sourceRoot":"","sources":["../../src/daemon/confidence-router.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAS7E,wBAAgB,aAAa,CAAC,QAAQ,EAAE,mBAAmB,GAAG,aAAa,CAoB1E"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { isVgeAnalysisUnavailable } from './blocking-decision-triggers.js';
|
|
2
|
+
const BRANCH_THRESHOLDS = {
|
|
3
|
+
heuristics: 50,
|
|
4
|
+
semantic: 50,
|
|
5
|
+
llmGuard: 55,
|
|
6
|
+
};
|
|
7
|
+
export function routeResponse(response) {
|
|
8
|
+
// Step 1: VGE policy pre-check (exact order per PRD §7.7)
|
|
9
|
+
if (isVgeAnalysisUnavailable(response))
|
|
10
|
+
return 'SOFT_TAINT';
|
|
11
|
+
if (response.ruleAction === 'BLOCK')
|
|
12
|
+
return 'ESCALATE';
|
|
13
|
+
if (response.decision === 'BLOCKED')
|
|
14
|
+
return 'ESCALATE';
|
|
15
|
+
if (response.arbiterSignal === 'BLOCK')
|
|
16
|
+
return 'ESCALATE';
|
|
17
|
+
// Step 2: Count agreed branches
|
|
18
|
+
const agreedBranches = [
|
|
19
|
+
(response.branches.heuristics?.score ?? 0) >= BRANCH_THRESHOLDS.heuristics,
|
|
20
|
+
(response.branches.semantic?.score ?? 0) >= BRANCH_THRESHOLDS.semantic,
|
|
21
|
+
(response.branches.llmGuard?.score ?? 0) >= BRANCH_THRESHOLDS.llmGuard,
|
|
22
|
+
].filter(Boolean).length;
|
|
23
|
+
// Step 3: Route
|
|
24
|
+
if (agreedBranches >= 2)
|
|
25
|
+
return 'ESCALATE';
|
|
26
|
+
if (agreedBranches === 1 && response.score >= 90)
|
|
27
|
+
return 'ESCALATE';
|
|
28
|
+
if (agreedBranches === 1 && response.score >= 55)
|
|
29
|
+
return 'ESCALATE';
|
|
30
|
+
if (agreedBranches === 1)
|
|
31
|
+
return 'SOFT_TAINT';
|
|
32
|
+
return 'ALLOW';
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=confidence-router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"confidence-router.js","sourceRoot":"","sources":["../../src/daemon/confidence-router.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,MAAM,iCAAiC,CAAC;AAE3E,MAAM,iBAAiB,GAAG;IACxB,UAAU,EAAE,EAAE;IACd,QAAQ,EAAE,EAAE;IACZ,QAAQ,EAAE,EAAE;CACJ,CAAC;AAEX,MAAM,UAAU,aAAa,CAAC,QAA6B;IACzD,0DAA0D;IAC1D,IAAI,wBAAwB,CAAC,QAAQ,CAAC;QAAE,OAAO,YAAY,CAAC;IAC5D,IAAI,QAAQ,CAAC,UAAU,KAAK,OAAO;QAAE,OAAO,UAAU,CAAC;IACvD,IAAI,QAAQ,CAAC,QAAQ,KAAK,SAAS;QAAE,OAAO,UAAU,CAAC;IACvD,IAAI,QAAQ,CAAC,aAAa,KAAK,OAAO;QAAE,OAAO,UAAU,CAAC;IAE1D,gCAAgC;IAChC,MAAM,cAAc,GAAG;QACrB,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,EAAE,KAAK,IAAI,CAAC,CAAC,IAAI,iBAAiB,CAAC,UAAU;QAC1E,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,CAAC,IAAI,iBAAiB,CAAC,QAAQ;QACtE,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,CAAC,IAAI,iBAAiB,CAAC,QAAQ;KACvE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC;IAEzB,gBAAgB;IAChB,IAAI,cAAc,IAAI,CAAC;QAAE,OAAO,UAAU,CAAC;IAC3C,IAAI,cAAc,KAAK,CAAC,IAAI,QAAQ,CAAC,KAAK,IAAI,EAAE;QAAE,OAAO,UAAU,CAAC;IACpE,IAAI,cAAc,KAAK,CAAC,IAAI,QAAQ,CAAC,KAAK,IAAI,EAAE;QAAE,OAAO,UAAU,CAAC;IACpE,IAAI,cAAc,KAAK,CAAC;QAAE,OAAO,YAAY,CAAC;IAC9C,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { ConversationMessage } from '../shared/types.js';
|
|
2
|
+
export interface FreshAttachment {
|
|
3
|
+
content: string;
|
|
4
|
+
contentBytes: number;
|
|
5
|
+
contentChars: number;
|
|
6
|
+
contentHash: string;
|
|
7
|
+
displayPath: string;
|
|
8
|
+
endOffset: number;
|
|
9
|
+
filePath: string;
|
|
10
|
+
offset: number;
|
|
11
|
+
recordFingerprint: string;
|
|
12
|
+
resourceId: string;
|
|
13
|
+
transcriptPath: string;
|
|
14
|
+
}
|
|
15
|
+
export interface FreshAttachmentExtraction {
|
|
16
|
+
attachments: FreshAttachment[];
|
|
17
|
+
cursorReset: boolean;
|
|
18
|
+
nextOffset: number;
|
|
19
|
+
}
|
|
20
|
+
export declare function normalizeConversation(messages: ConversationMessage[]): ConversationMessage[];
|
|
21
|
+
export declare function buildConversationFromTranscript(transcriptPath: unknown): ConversationMessage[];
|
|
22
|
+
export declare function extractFreshAttachments(params: {
|
|
23
|
+
transcriptPath: unknown;
|
|
24
|
+
sessionId: string;
|
|
25
|
+
cursorOffset: number;
|
|
26
|
+
seenFingerprints: Set<string>;
|
|
27
|
+
}): FreshAttachmentExtraction;
|
|
28
|
+
//# sourceMappingURL=conversation-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conversation-context.d.ts","sourceRoot":"","sources":["../../src/daemon/conversation-context.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAa9D,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,iBAAiB,EAAE,MAAM,CAAC;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,yBAAyB;IACxC,WAAW,EAAE,eAAe,EAAE,CAAC;IAC/B,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;CACpB;AAuKD,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAqB5F;AAED,wBAAgB,+BAA+B,CAAC,cAAc,EAAE,OAAO,GAAG,mBAAmB,EAAE,CAc9F;AAED,wBAAgB,uBAAuB,CAAC,MAAM,EAAE;IAC9C,cAAc,EAAE,OAAO,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;CAC/B,GAAG,yBAAyB,CAyD5B"}
|