plugin-scanner 2.0.374__tar.gz → 2.0.376__tar.gz
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.
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/PKG-INFO +1 -1
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/pyproject.toml +1 -1
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/pyproject.toml.bak +1 -1
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/codex.py +14 -32
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/install_commands.py +5 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/render.py +3 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/server.py +72 -7
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/launcher.py +7 -3
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/runner.py +45 -2
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/version.py +1 -1
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_cloud_local_sync.py +108 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_codex_install.py +6 -1
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_harness_setup.py +26 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_headless_daemon_api.py +131 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.clusterfuzzlite/Dockerfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.clusterfuzzlite/build.sh +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.clusterfuzzlite/project.yaml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.clusterfuzzlite/requirements-atheris.txt +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.dockerignore +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/CODEOWNERS +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/ISSUE_TEMPLATE/bug-report.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/ISSUE_TEMPLATE/config.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/ISSUE_TEMPLATE/feature-request.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/dependabot.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/ci.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/codeql.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/dependabot-uv-lock.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/fuzz.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/harness-smoke.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/publish.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.github/workflows/scorecard.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.gitignore +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/.pre-commit-hooks.yaml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/CONTRIBUTING.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/Dockerfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/PRODUCT.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/e2e/fixture-states.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/e2e/proof-dir.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/e2e/scrg172-states.spec.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/e2e/static-server.mjs +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/index.html +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/playwright.config.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/pnpm-lock.yaml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/public/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/public/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/public/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/public/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/public/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/public/favicon.ico +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/app-detail-phase11.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/app-detail-workspace.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/app-routing.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/app.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-center-layout.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-center-layout.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-center-mobile.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-center-primitives.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-center-review-cards.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-center-utils.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-gate-utils.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-gate.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-scopes.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/approval-scopes.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/apps/app-catalog.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/apps/app-detail-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/audit-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/clear-policy-payload.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/clear-policy-payload.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/compare-time-periods.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/data-flow-evidence-card.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/error-boundary.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/app-tab.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/categories.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/category-tab.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-action-detail.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-action-list.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-analytics-panel.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-clear-modal.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-copy.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-detail.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-export-drawer.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-export.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-export.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-filter-bar.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-filters.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-filters.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-insight-strip.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-metrics.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-metrics.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-pagination.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-pagination.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-perf.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-period.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-sort.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-sort.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-story.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-types.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-url-state.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-url-state.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/evidence-view-shell.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/explore-tab.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/index.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/plain-english.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/evidence/story-tab.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/feed-health-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/fleet-workspace-phase11.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/fleet-workspace.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/fleet-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/guard-api.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/guard-api.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/guard-demo.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/guard-types.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/help-modal.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/history-analytics.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/history-charts.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/history-export.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/home-dashboard.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/home-dashboard.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/home-protection-module.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/main.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/phase09-review.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/policy-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/queue-chip-filter.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/queue-state.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/queue-state.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/receipts-workspace.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/receipts-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/review-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/risk-signal-cards.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/risk-signal-cards.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/runtime-overview.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/runtime-overview.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/scanner-evidence-badge.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/scrg159-170.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/scrg171-172.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/security-fixes.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/settings-workspace-phase11.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/settings-workspace.test.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/settings-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/styles.css +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/supply-chain-firewall-panel.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/supply-chain-firewall-views.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/supply-chain-manager-card.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/supply-chain-workspace.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/totp-enrollment-qr-panel.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/use-debounce.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/use-focus-trap.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/use-keyboard-shortcut.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/use-reduced-motion.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/use-route-focus.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/vite-env.d.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/src/watched-app-card.tsx +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/tsconfig.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/dashboard/vite.config.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docker-requirements.txt +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/architecture.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/get-started.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/harness-support.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/incident-response.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/local-vs-cloud.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/release-checklist.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/remediation.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/smoke-tests.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/guard/testing-matrix.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/trust/mcp-trust-draft.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/trust/plugin-trust-draft.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/docs/trust/skill-trust-local.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/fuzzers/manifest_fuzzer.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/requirements.txt +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/schemas/plugin-quality.v1.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/schemas/scan-result.v1.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/schemas/verify-result.v1.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/scripts/codex-auto-resume-smoke.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/action_runner.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/argparse_utils.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/best_practices.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/claude.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/code_quality.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/ecosystem_common.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/gemini.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/manifest.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/manifest_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/marketplace.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/mcp_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/opencode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/operational_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/checks/skill_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/cli.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/cli_ui.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/config.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/base.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/claude.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/codex.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/detect.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/gemini.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/opencode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/registry.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/ecosystems/types.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/github_reporting.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/access_graph_events.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/antigravity.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/base.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/claude_code.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/cloud_identity.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/contracts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/copilot.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/cursor.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/gemini.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/hermes.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/mcp_servers.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/openclaw.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/openclaw_config.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/openclaw_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/opencode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/opencode_artifacts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/advisory_model.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/approval_gate.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/approval_gate_state.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/approvals.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/bridge/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/capabilities.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/approval_commands.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/approval_gate_prompt.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/bootstrap.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/commands.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/connect_flow.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/docs.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/product.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/prompt.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/update_commands.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/codex_app_server.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/codex_config.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/codex_resume.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/config.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/consumer/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/consumer/service.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/client.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/manager.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-catalog.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-detail-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/audit-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/feed-health-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/fleet-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/help-modal.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/home-dashboard.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/policy-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/runtime-overview.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/settings-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/supply-chain-workspace.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/use-focus-trap.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/guard-dashboard.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/assets/index.css +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/favicon.ico +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/static/index.html +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/desktop_notifications.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/edge_events.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/harness_usage.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/incident.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/insights.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/inventory_cisco.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/inventory_contract.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/local_supply_chain.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/mcp_tool_calls.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/models.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/policy/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/policy/engine.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/product_model.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/protect.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/provenance.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/proxy/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/proxy/remote.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/proxy/runtime_mcp.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/proxy/stdio.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/receipts/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/receipts/manager.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/redaction.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/risk.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/action_identity.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/actions.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/advisory_escalation.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/advisory_matchers.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/cisco_evidence.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/cisco_preflight.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/composition_rules.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/data_flow.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/data_flow_rules.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/data_flow_variables.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/decisions.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/detectors.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/false_positive_rules.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/js_semver.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/mcp_protection.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/package_intent.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/package_intent_common.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/package_intent_parser.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/package_manifest_diff.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/persistence_rules.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/prompt_injection.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/safe_decode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/sandbox.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/scanner_cache.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/secret_file_requests.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/secret_sensitivity.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/secret_sources.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/sed_scripts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/shell_commands.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/signals.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/skill_protection.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_base.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_models.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_runtime.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain_package_eval.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/supply_chain_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/surface_server.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/temp_files.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/threat_intel.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/schemas/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/schemas/consumer_mode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/schemas/guard_event_v1.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/schemas/guard_product_model_v1.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/schemas/surface_server.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/shims.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store_approvals.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store_connect.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store_evidence.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store_resume.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store_supply_chain.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/store_threat_intel.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/totp.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/types.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/integrations/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/integrations/cisco_mcp_scanner.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/integrations/cisco_skill_scanner.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/lint_fixes.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/marketplace_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/models.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/path_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/policy.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/quality_artifact.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/repo_detect.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/reporting.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/rules/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/rules/registry.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/rules/specs.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/scanner.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/submission.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/suppressions.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_domain_scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_helpers.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_mcp_scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_models.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_plugin_scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_skill_scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/trust_specs.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/verification.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/conftest.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/__init__.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/bad-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/bad-plugin/.mcp.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/bad-plugin/secrets.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/claude-plugin-good/.claude-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/claude-plugin-good/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/claude-plugin-good/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/claude-plugin-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/claude-plugin-good/hooks/hooks.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/claude-plugin-good/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/code-quality-bad/evil.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/code-quality-bad/inject.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/gemini-extension-good/GEMINI.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/gemini-extension-good/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/gemini-extension-good/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/gemini-extension-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/gemini-extension-good/commands/hello.toml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/gemini-extension-good/gemini-extension.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/assets/icon.svg +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/assets/logo.svg +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/assets/screenshot.svg +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/good-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-codex-malicious-mcp/.codex/config.toml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/benign-docs-fake-token.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/benign-health-endpoint.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/benign-nvmrc-fake-creds.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/benign-source-search.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/canary-exfil-encoded.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/canary-exfil.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/expected-decisions.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-dockerfile.txt +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-encoded-shell-exfil.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-github-action.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-mcp-delete.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-mcp-secret-read.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-mcp-skill-exfil.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-npm-postinstall.js +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-prompt-env-read.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-prompt-guard-bypass.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-prompt-npmrc-read.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/malicious-python-setup.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/guard-red-team/smoke-evidence-template.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/config.yaml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/mcp_servers.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/skills/security/malicious/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/references/api-setup.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/scripts/deploy.sh +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/hermes-plugin-evil/skills/utils/benign/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malformed-json/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malicious-skill-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malicious-skill-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malicious-skill-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malicious-skill-plugin/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malicious-skill-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/malicious-skill-plugin/skills/leaky-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/mcp-canary-server.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/minimal-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/missing-fields/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/mit-license/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-ecosystem-repo/codex-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-ecosystem-repo/codex-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-ecosystem-repo/codex-plugin/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-ecosystem-repo/codex-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-ecosystem-repo/gemini-ext/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-ecosystem-repo/gemini-ext/gemini-extension.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/.agents/plugins/marketplace.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/no-version/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/opencode-good/.opencode/commands/hello.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/opencode-good/.opencode/plugins/example.ts +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/opencode-good/LICENSE +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/opencode-good/README.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/opencode-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/opencode-good/opencode.jsonc +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/skills-missing-dir/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/skills-no-frontmatter/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/skills-no-frontmatter/skills/bad-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/benign-npm-controls-package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/benign-npm-package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/benign-pnpm-package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/benign-pyproject.toml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/critical-base-image-Dockerfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/malicious-Dockerfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/malicious-action.yml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/malicious-npm-env-fs-network-package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/malicious-npm-obfuscated-package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/malicious-npm-package.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/supply-chain/malicious-setup.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/cargo-safe/Cargo.lock +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/cargo-safe/Cargo.toml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/cargo-vulnerable/Cargo.lock +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/cargo-vulnerable/Cargo.toml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/composer-safe/composer.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/composer-safe/composer.lock +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/composer-vulnerable/composer.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/composer-vulnerable/composer.lock +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/go-safe/go.mod +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/go-vulnerable/go.mod +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/gradle-safe/build.gradle +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/gradle-safe/gradle.lockfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/gradle-vulnerable/build.gradle +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/gradle-vulnerable/gradle.lockfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/maven-safe/pom.xml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/maven-vulnerable/pom.xml +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/rubygems-safe/Gemfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/rubygems-safe/Gemfile.lock +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile.lock +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/with-marketplace/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/with-marketplace/marketplace-broken.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/fixtures/with-marketplace/marketplace.json +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/guard_python_phase12_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/guard_tier2_phase13_support.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test-trust-scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test-trust-specs.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_action_runner.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_best_practices.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_cisco_install_surfaces.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_cli.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_code_quality.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_config.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_coverage_remaining.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_cursor_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_ecosystems.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_edge_cases.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_final_coverage.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_gemini_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_access_graph.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_action_identity.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_advisory_escalation.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_continuity.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_copy_commands.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_decisions.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_gate.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_store_dedup.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_store_phase14.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approval_store_scale.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_approvals.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_bootstrap.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_bypass_detector.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_canary_fixtures.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_capabilities.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_cisco_evidence.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_cisco_runtime_cli.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_claude_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_cli.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_codex_auto_resume_smoke.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_codex_e2e.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_codex_proxy.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_codex_resume_commands.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_codex_resume_endpoints.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_config_paths.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_connect_flow.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_consumer_mode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_copilot_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_copilot_proxy.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_daemon_cli.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_daemon_manager.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_daemon_perf.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_daemon_registry.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_daemon_repair_perf.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_daemon_wake.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_data_flow.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_decision_propagation.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_desktop_notifications.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_detector_fp.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_docs.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_event_schema_v1.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_events.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_evidence_api_contract.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_evidence_store.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_harness_contracts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_harness_smoke.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_hashnet_mcp_canaries.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_insights.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_inventory_cisco.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_inventory_contract.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_js_lab_phase11.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_js_lockfile_resolution_phase11.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_js_package_hook_phase11.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_js_package_intent_phase11.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_js_semver_phase11.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_js_supply_chain_phase11.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_launch_env.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_local_supply_chain_audit_phase16.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_local_supply_chain_phase15.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_mcp_detectors.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_mcp_package_proxy_phase14.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_mcp_protection.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_opencode_proxy.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_package_hook.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_package_hook_phase14.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_package_intent.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_package_resume_phase14.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_package_shims.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase03_local_install.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase03_remainder.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase04_failure_modes.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase04_harness_contracts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase04_harness_ux.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase05_approval_memory.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_phase07_harness_coverage_matrix.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_policy_dedup.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_product_flow.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_product_model_contracts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_prompt_injection.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_protect.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_provenance.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_python_lab_phase12.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_python_package_hook_phase12.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_python_package_intent_phase12.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_python_supply_chain_heuristics_phase12.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_python_supply_chain_phase12.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_queue_api_contract.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_queue_contract.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_receipt_p5_fields.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_receipt_persistence.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_red_team.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_red_team_e2e.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_redaction.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_registry_broker_skills_canaries.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_render.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_resolution_copy.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_risk.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime_action_harnesses.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime_actions.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime_actions_phase14.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime_decisions.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime_detectors.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_runtime_signals.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_safe_decode.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_sandbox.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_settings_api.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_settings_presets.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_shim_truth.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_skill_protection.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_skill_protection_phase14.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_store_migrations.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_supply_chain.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_supply_chain_bundle.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_supply_chain_daemon.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_supply_chain_evaluator.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_supply_chain_sync.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_surface_server.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_threat_intel.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_tier2_labs_phase13.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_tier2_package_intent_phase13.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_tier2_supply_chain_phase13.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_verdicts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_web_recovery.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_guard_wrapper_flows.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_hermes_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_integration.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_lint_fixes.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_live_cisco_smoke.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_manifest.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_marketplace.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_mcp_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_openclaw_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_opencode_adapter.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_operational_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_policy.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_quality_artifact.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_rule_registry.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_scanner.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_schema_contracts.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_security_ops.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_skill_security.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_submission.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_trust_scoring.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_trust_specs.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_verification.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/tests/test_versioning.py +0 -0
- {plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/uv.lock +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: plugin-scanner
|
|
3
|
-
Version: 2.0.
|
|
3
|
+
Version: 2.0.376
|
|
4
4
|
Summary: Lint, verify, and gate plugin ecosystems for maintainers, CI, and publish workflows.
|
|
5
5
|
Project-URL: Homepage, https://github.com/hashgraph-online/hol-guard
|
|
6
6
|
Project-URL: Repository, https://github.com/hashgraph-online/hol-guard
|
|
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "plugin-scanner"
|
|
7
|
-
version = "2.0.
|
|
7
|
+
version = "2.0.376"
|
|
8
8
|
description = "Lint, verify, and gate plugin ecosystems for maintainers, CI, and publish workflows."
|
|
9
9
|
readme = "README.md"
|
|
10
10
|
license = "Apache-2.0"
|
|
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "hol-guard"
|
|
7
|
-
version = "2.0.
|
|
7
|
+
version = "2.0.376"
|
|
8
8
|
description = "Protect local AI harnesses with HOL Guard and run scanner checks for Codex, Claude, Cursor, Gemini, and OpenCode."
|
|
9
9
|
readme = "README.md"
|
|
10
10
|
license = "Apache-2.0"
|
{plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/adapters/codex.py
RENAMED
|
@@ -178,58 +178,40 @@ def _hook_command(context: HarnessContext) -> str:
|
|
|
178
178
|
return shlex.join(_hook_command_parts(context))
|
|
179
179
|
|
|
180
180
|
|
|
181
|
+
def _managed_hook_entry(context: HarnessContext, status_message: str) -> dict[str, object]:
|
|
182
|
+
return {
|
|
183
|
+
"type": "command",
|
|
184
|
+
"command": _hook_command(context),
|
|
185
|
+
"timeout": 30,
|
|
186
|
+
"statusMessage": status_message,
|
|
187
|
+
"env": merge_guard_launcher_env(pin_package=True),
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
|
|
181
191
|
def _pre_tool_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
182
192
|
return {
|
|
183
193
|
"matcher": _CODEX_GUARD_TOOL_MATCHER,
|
|
184
|
-
"hooks": [
|
|
185
|
-
{
|
|
186
|
-
"type": "command",
|
|
187
|
-
"command": _hook_command(context),
|
|
188
|
-
"timeout": 30,
|
|
189
|
-
"statusMessage": _MANAGED_HOOK_STATUS_MESSAGE,
|
|
190
|
-
}
|
|
191
|
-
],
|
|
194
|
+
"hooks": [_managed_hook_entry(context, _MANAGED_HOOK_STATUS_MESSAGE)],
|
|
192
195
|
}
|
|
193
196
|
|
|
194
197
|
|
|
195
198
|
def _prompt_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
196
199
|
return {
|
|
197
|
-
"hooks": [
|
|
198
|
-
{
|
|
199
|
-
"type": "command",
|
|
200
|
-
"command": _hook_command(context),
|
|
201
|
-
"timeout": 30,
|
|
202
|
-
"statusMessage": _MANAGED_PROMPT_HOOK_STATUS_MESSAGE,
|
|
203
|
-
}
|
|
204
|
-
],
|
|
200
|
+
"hooks": [_managed_hook_entry(context, _MANAGED_PROMPT_HOOK_STATUS_MESSAGE)],
|
|
205
201
|
}
|
|
206
202
|
|
|
207
203
|
|
|
208
204
|
def _permission_request_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
209
205
|
return {
|
|
210
206
|
"matcher": _CODEX_GUARD_PERMISSION_MATCHER,
|
|
211
|
-
"hooks": [
|
|
212
|
-
{
|
|
213
|
-
"type": "command",
|
|
214
|
-
"command": _hook_command(context),
|
|
215
|
-
"timeout": 30,
|
|
216
|
-
"statusMessage": _MANAGED_PERMISSION_HOOK_STATUS_MESSAGE,
|
|
217
|
-
}
|
|
218
|
-
],
|
|
207
|
+
"hooks": [_managed_hook_entry(context, _MANAGED_PERMISSION_HOOK_STATUS_MESSAGE)],
|
|
219
208
|
}
|
|
220
209
|
|
|
221
210
|
|
|
222
211
|
def _post_tool_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
223
212
|
return {
|
|
224
213
|
"matcher": "Bash",
|
|
225
|
-
"hooks": [
|
|
226
|
-
{
|
|
227
|
-
"type": "command",
|
|
228
|
-
"command": _hook_command(context),
|
|
229
|
-
"timeout": 30,
|
|
230
|
-
"statusMessage": _MANAGED_POST_TOOL_HOOK_STATUS_MESSAGE,
|
|
231
|
-
}
|
|
232
|
-
],
|
|
214
|
+
"hooks": [_managed_hook_entry(context, _MANAGED_POST_TOOL_HOOK_STATUS_MESSAGE)],
|
|
233
215
|
}
|
|
234
216
|
|
|
235
217
|
|
|
@@ -119,6 +119,11 @@ def build_harness_setup_plan(
|
|
|
119
119
|
"steps": [step.to_dict() for step in steps],
|
|
120
120
|
"workspace": str(context.workspace_dir) if context.workspace_dir is not None else None,
|
|
121
121
|
}
|
|
122
|
+
if dry_run and action in {"connect", "repair"}:
|
|
123
|
+
payload["dry_run_effect"] = (
|
|
124
|
+
"No app config was changed and Guard Cloud was not connected. "
|
|
125
|
+
f"Run hol-guard apps {action} {adapter.harness} without --dry-run to finish setup."
|
|
126
|
+
)
|
|
122
127
|
if action == "uninstall":
|
|
123
128
|
confirmation_phrase = uninstall_confirmation_token(adapter.harness)
|
|
124
129
|
payload["confirmation_phrase"] = confirmation_phrase
|
{plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/cli/render.py
RENAMED
|
@@ -837,6 +837,9 @@ def _render_apps(console: Console, payload: dict[str, object]) -> None:
|
|
|
837
837
|
_render_managed_install(console, payload)
|
|
838
838
|
else:
|
|
839
839
|
_render_fallback(console, payload)
|
|
840
|
+
dry_run_effect = payload.get("dry_run_effect")
|
|
841
|
+
if isinstance(dry_run_effect, str) and dry_run_effect:
|
|
842
|
+
console.print(Panel(dry_run_effect, title="Dry run", border_style="yellow"))
|
|
840
843
|
cloud_app = payload.get("cloud_app")
|
|
841
844
|
if not isinstance(cloud_app, dict):
|
|
842
845
|
return
|
{plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/daemon/server.py
RENAMED
|
@@ -1120,23 +1120,34 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1120
1120
|
harness=adapter.harness,
|
|
1121
1121
|
action_path=token_action_path,
|
|
1122
1122
|
handoff_token=handoff_token,
|
|
1123
|
+
auto_start=True,
|
|
1123
1124
|
include_dashboard_session_token=True,
|
|
1124
1125
|
local_origin=local_origin,
|
|
1125
1126
|
workspace_id=self._optional_string(decoded.get("workspace_id")) or "",
|
|
1126
1127
|
)
|
|
1127
1128
|
return
|
|
1128
|
-
|
|
1129
|
+
is_document_navigation = self._browser_document_navigation_is_allowed()
|
|
1130
|
+
is_hosted_referrer = self._hosted_dashboard_referrer_is_allowed()
|
|
1131
|
+
workspace_id = self._optional_string(handoff_query.get("workspaceId", [None])[-1]) or ""
|
|
1132
|
+
self._apply_cloud_app_sync_credentials(
|
|
1133
|
+
sync_url=self._optional_string(handoff_query.get("syncUrl", [None])[-1]),
|
|
1134
|
+
sync_token=self._optional_string(handoff_query.get("syncToken", [None])[-1]),
|
|
1135
|
+
workspace_id=self._optional_string(handoff_query.get("syncWorkspaceId", [None])[-1]) or workspace_id,
|
|
1136
|
+
)
|
|
1137
|
+
navigation_allowed = is_hosted_referrer or is_document_navigation
|
|
1138
|
+
if action_path in _CLOUD_APP_HANDOFF_ACTIONS and (navigation_allowed or workspace_id):
|
|
1129
1139
|
self._write_cloud_app_handoff_page(
|
|
1130
1140
|
harness=adapter.harness,
|
|
1131
1141
|
action_path=action_path,
|
|
1132
1142
|
handoff_token=self._cloud_app_handoff_token(
|
|
1133
1143
|
harness=adapter.harness,
|
|
1134
1144
|
action_path=action_path,
|
|
1135
|
-
workspace_id=
|
|
1145
|
+
workspace_id=workspace_id,
|
|
1136
1146
|
),
|
|
1137
|
-
|
|
1147
|
+
auto_start=navigation_allowed,
|
|
1148
|
+
include_dashboard_session_token=is_document_navigation or not navigation_allowed,
|
|
1138
1149
|
local_origin=local_origin,
|
|
1139
|
-
workspace_id=
|
|
1150
|
+
workspace_id=workspace_id,
|
|
1140
1151
|
)
|
|
1141
1152
|
return
|
|
1142
1153
|
cloud_params: dict[str, str] = {"guardDaemon": local_origin}
|
|
@@ -1163,6 +1174,17 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1163
1174
|
or self._optional_string(payload.get("workspaceId"))
|
|
1164
1175
|
or ""
|
|
1165
1176
|
)
|
|
1177
|
+
self._apply_cloud_app_sync_credentials(
|
|
1178
|
+
sync_url=self._optional_string(payload.get("sync_url")) or self._optional_string(payload.get("syncUrl")),
|
|
1179
|
+
sync_token=(
|
|
1180
|
+
self._optional_string(payload.get("sync_token")) or self._optional_string(payload.get("syncToken"))
|
|
1181
|
+
),
|
|
1182
|
+
workspace_id=(
|
|
1183
|
+
self._optional_string(payload.get("sync_workspace_id"))
|
|
1184
|
+
or self._optional_string(payload.get("syncWorkspaceId"))
|
|
1185
|
+
or workspace_id
|
|
1186
|
+
),
|
|
1187
|
+
)
|
|
1166
1188
|
local_origin = self._local_daemon_origin()
|
|
1167
1189
|
handoff_token = self._cloud_app_handoff_token(
|
|
1168
1190
|
harness=adapter.harness,
|
|
@@ -1184,6 +1206,26 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1184
1206
|
},
|
|
1185
1207
|
)
|
|
1186
1208
|
|
|
1209
|
+
def _apply_cloud_app_sync_credentials(
|
|
1210
|
+
self,
|
|
1211
|
+
*,
|
|
1212
|
+
sync_url: str | None,
|
|
1213
|
+
sync_token: str | None,
|
|
1214
|
+
workspace_id: str,
|
|
1215
|
+
) -> None:
|
|
1216
|
+
if sync_url is None or sync_token is None or not workspace_id:
|
|
1217
|
+
return
|
|
1218
|
+
parsed = urlparse(sync_url)
|
|
1219
|
+
sync_origin = f"{parsed.scheme}://{parsed.netloc}"
|
|
1220
|
+
if sync_origin not in _HOSTED_GUARD_DASHBOARD_ORIGINS or not parsed.path.endswith("/api/guard/receipts/sync"):
|
|
1221
|
+
return
|
|
1222
|
+
self.server.store.set_sync_credentials( # type: ignore[attr-defined]
|
|
1223
|
+
sync_url=sync_url,
|
|
1224
|
+
token=sync_token,
|
|
1225
|
+
now=_now(),
|
|
1226
|
+
workspace_id=workspace_id,
|
|
1227
|
+
)
|
|
1228
|
+
|
|
1187
1229
|
def _cloud_app_handoff_token(
|
|
1188
1230
|
self,
|
|
1189
1231
|
*,
|
|
@@ -1250,6 +1292,7 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1250
1292
|
harness: str,
|
|
1251
1293
|
action_path: str,
|
|
1252
1294
|
handoff_token: str,
|
|
1295
|
+
auto_start: bool,
|
|
1253
1296
|
include_dashboard_session_token: bool,
|
|
1254
1297
|
local_origin: str,
|
|
1255
1298
|
workspace_id: str,
|
|
@@ -1263,6 +1306,7 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1263
1306
|
"localOrigin": local_origin,
|
|
1264
1307
|
"operation": operation,
|
|
1265
1308
|
"redirectBase": redirect_base,
|
|
1309
|
+
"autoStart": auto_start,
|
|
1266
1310
|
"workspaceId": workspace_id,
|
|
1267
1311
|
}
|
|
1268
1312
|
success_fragment_args = ""
|
|
@@ -1333,6 +1377,7 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1333
1377
|
padding: 14px 18px;
|
|
1334
1378
|
}}
|
|
1335
1379
|
button:disabled {{ cursor: wait; opacity: .72; }}
|
|
1380
|
+
button[hidden] {{ display: none; }}
|
|
1336
1381
|
</style>
|
|
1337
1382
|
</head>
|
|
1338
1383
|
<body>
|
|
@@ -1344,11 +1389,14 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1344
1389
|
then it will return you to HOL Cloud.
|
|
1345
1390
|
</p>
|
|
1346
1391
|
<div id="status" class="status">Starting local Guard setup...</div>
|
|
1392
|
+
<button id="continue" type="button" disabled>Continue setup</button>
|
|
1347
1393
|
</main>
|
|
1348
1394
|
<script id="guard-handoff-data" type="application/json">{script_payload}</script>
|
|
1349
1395
|
<script>
|
|
1350
1396
|
const data = JSON.parse(document.getElementById('guard-handoff-data').textContent);
|
|
1351
1397
|
const statusNode = document.getElementById('status');
|
|
1398
|
+
const continueButton = document.getElementById('continue');
|
|
1399
|
+
window.history.replaceState(null, '', `${{data.localOrigin}}/v1/apps/${{data.harness}}/cloud`);
|
|
1352
1400
|
const finish = (params, fragmentOnlyParams = {{}}) => {{
|
|
1353
1401
|
const query = new URLSearchParams(params);
|
|
1354
1402
|
const fragment = new URLSearchParams(params);
|
|
@@ -1405,7 +1453,17 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1405
1453
|
fail(error instanceof Error ? error.message : 'Local Guard setup failed');
|
|
1406
1454
|
}}
|
|
1407
1455
|
}};
|
|
1408
|
-
|
|
1456
|
+
if (data.autoStart) {{
|
|
1457
|
+
continueButton.hidden = true;
|
|
1458
|
+
completeSetup();
|
|
1459
|
+
}} else {{
|
|
1460
|
+
statusNode.textContent = 'Ready to connect this browser to local Guard.';
|
|
1461
|
+
continueButton.disabled = false;
|
|
1462
|
+
continueButton.addEventListener('click', () => {{
|
|
1463
|
+
continueButton.disabled = true;
|
|
1464
|
+
completeSetup();
|
|
1465
|
+
}}, {{ once: true }});
|
|
1466
|
+
}}
|
|
1409
1467
|
</script>
|
|
1410
1468
|
</body>
|
|
1411
1469
|
</html>"""
|
|
@@ -1436,8 +1494,15 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
1436
1494
|
signature = _dashboard_session_signature(payload, self.server.auth_token) # type: ignore[attr-defined]
|
|
1437
1495
|
return f"gld1.{payload}.{signature}"
|
|
1438
1496
|
|
|
1439
|
-
def
|
|
1440
|
-
|
|
1497
|
+
def _browser_document_navigation_is_allowed(self) -> bool:
|
|
1498
|
+
fetch_mode = (self.headers.get("Sec-Fetch-Mode") or "").strip().lower()
|
|
1499
|
+
fetch_dest = (self.headers.get("Sec-Fetch-Dest") or "").strip().lower()
|
|
1500
|
+
fetch_site = (self.headers.get("Sec-Fetch-Site") or "").strip().lower()
|
|
1501
|
+
return (
|
|
1502
|
+
fetch_mode == "navigate"
|
|
1503
|
+
and fetch_dest in {"document", ""}
|
|
1504
|
+
and fetch_site in {"cross-site", "same-site", "none", ""}
|
|
1505
|
+
)
|
|
1441
1506
|
|
|
1442
1507
|
def _hosted_dashboard_referrer_is_allowed(self) -> bool:
|
|
1443
1508
|
referrer = self.headers.get("Referer")
|
{plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/launcher.py
RENAMED
|
@@ -7,11 +7,15 @@ from collections.abc import Mapping
|
|
|
7
7
|
from pathlib import Path
|
|
8
8
|
|
|
9
9
|
|
|
10
|
-
def merge_guard_launcher_env(env: Mapping[str, str] | None = None) -> dict[str, str]:
|
|
11
|
-
"""Preserve launcher import context
|
|
10
|
+
def merge_guard_launcher_env(env: Mapping[str, str] | None = None, *, pin_package: bool = False) -> dict[str, str]:
|
|
11
|
+
"""Preserve launcher import context while optionally pinning the current package."""
|
|
12
12
|
|
|
13
13
|
merged: dict[str, str] = {}
|
|
14
|
-
pythonpath =
|
|
14
|
+
pythonpath = (
|
|
15
|
+
str(Path(__file__).resolve().parents[2])
|
|
16
|
+
if pin_package
|
|
17
|
+
else _normalize_launcher_pythonpath(os.environ.get("PYTHONPATH"))
|
|
18
|
+
)
|
|
15
19
|
if pythonpath:
|
|
16
20
|
merged["PYTHONPATH"] = pythonpath
|
|
17
21
|
if env is None:
|
{plugin_scanner-2.0.374 → plugin_scanner-2.0.376}/src/codex_plugin_scanner/guard/runtime/runner.py
RENAMED
|
@@ -2253,6 +2253,11 @@ def _cloud_runtime_session_payload(store: GuardStore, session: dict[str, object]
|
|
|
2253
2253
|
workspace=workspace,
|
|
2254
2254
|
generated_at=updated_at,
|
|
2255
2255
|
)
|
|
2256
|
+
local_identity = _cloud_local_identity_payload(
|
|
2257
|
+
device_id,
|
|
2258
|
+
daemon_version=_optional_string(session.get("client_version") or session.get("clientVersion")) or __version__,
|
|
2259
|
+
observed_at=updated_at,
|
|
2260
|
+
)
|
|
2256
2261
|
return {
|
|
2257
2262
|
"sessionId": session_id,
|
|
2258
2263
|
"harness": _optional_string(session.get("harness")) or "hol-guard",
|
|
@@ -2264,7 +2269,8 @@ def _cloud_runtime_session_payload(store: GuardStore, session: dict[str, object]
|
|
|
2264
2269
|
"clientVersion": _optional_string(session.get("client_version") or session.get("clientVersion")) or __version__,
|
|
2265
2270
|
"deviceId": device_id,
|
|
2266
2271
|
"deviceName": device_name,
|
|
2267
|
-
"localIdentity":
|
|
2272
|
+
"localIdentity": local_identity,
|
|
2273
|
+
"localIdentitySource": _cloud_local_identity_source_payload(local_identity),
|
|
2268
2274
|
"packageManagerCoverage": package_manager_coverage,
|
|
2269
2275
|
"workspace": workspace,
|
|
2270
2276
|
"capabilities": capabilities,
|
|
@@ -2274,13 +2280,22 @@ def _cloud_runtime_session_payload(store: GuardStore, session: dict[str, object]
|
|
|
2274
2280
|
}
|
|
2275
2281
|
|
|
2276
2282
|
|
|
2277
|
-
def _cloud_local_identity_payload(
|
|
2283
|
+
def _cloud_local_identity_payload(
|
|
2284
|
+
device_id: str,
|
|
2285
|
+
*,
|
|
2286
|
+
daemon_version: str,
|
|
2287
|
+
observed_at: str,
|
|
2288
|
+
) -> dict[str, object]:
|
|
2278
2289
|
hostname = _safe_hostname()
|
|
2279
2290
|
private_ip = _safe_private_ip()
|
|
2291
|
+
if private_ip is None:
|
|
2292
|
+
private_ip = _safe_private_ipv6()
|
|
2280
2293
|
payload: dict[str, object] = {
|
|
2281
2294
|
"daemonId": device_id,
|
|
2295
|
+
"daemonVersion": daemon_version,
|
|
2282
2296
|
"daemonStatus": "healthy",
|
|
2283
2297
|
"relayState": "online",
|
|
2298
|
+
"lastSyncedAt": observed_at,
|
|
2284
2299
|
}
|
|
2285
2300
|
if hostname is not None:
|
|
2286
2301
|
payload["hostname"] = hostname
|
|
@@ -2290,6 +2305,24 @@ def _cloud_local_identity_payload(device_id: str) -> dict[str, object]:
|
|
|
2290
2305
|
return payload
|
|
2291
2306
|
|
|
2292
2307
|
|
|
2308
|
+
def _cloud_local_identity_source_payload(local_identity: dict[str, object]) -> dict[str, str]:
|
|
2309
|
+
source: dict[str, str] = {
|
|
2310
|
+
"daemonId": "local-guard",
|
|
2311
|
+
"daemonVersion": "local-guard",
|
|
2312
|
+
"daemonStatus": "local-guard",
|
|
2313
|
+
"relayState": "local-guard",
|
|
2314
|
+
}
|
|
2315
|
+
if "hostname" in local_identity:
|
|
2316
|
+
source["hostname"] = "local-guard"
|
|
2317
|
+
if "ipAddress" in local_identity:
|
|
2318
|
+
source["ipAddress"] = "local-guard"
|
|
2319
|
+
if "privateIpAddress" in local_identity:
|
|
2320
|
+
source["privateIpAddress"] = "local-guard"
|
|
2321
|
+
if "publicIpAddress" in local_identity:
|
|
2322
|
+
source["publicIpAddress"] = "local-guard"
|
|
2323
|
+
return source
|
|
2324
|
+
|
|
2325
|
+
|
|
2293
2326
|
def _safe_hostname() -> str | None:
|
|
2294
2327
|
with suppress(OSError):
|
|
2295
2328
|
hostname = socket.gethostname().strip()
|
|
@@ -2311,6 +2344,16 @@ def _safe_private_ip() -> str | None:
|
|
|
2311
2344
|
return None
|
|
2312
2345
|
|
|
2313
2346
|
|
|
2347
|
+
def _safe_private_ipv6() -> str | None:
|
|
2348
|
+
with suppress(OSError):
|
|
2349
|
+
addresses = socket.getaddrinfo(socket.gethostname(), None, socket.AF_INET6)
|
|
2350
|
+
for entry in addresses:
|
|
2351
|
+
candidate = entry[4][0]
|
|
2352
|
+
if isinstance(candidate, str) and candidate and candidate != "::1":
|
|
2353
|
+
return candidate[:128]
|
|
2354
|
+
return None
|
|
2355
|
+
|
|
2356
|
+
|
|
2314
2357
|
def _cloud_sync_receipt_fingerprint(receipt: dict[str, object]) -> str:
|
|
2315
2358
|
encoded_receipt = json.dumps(receipt, sort_keys=True, separators=(",", ":"), default=str)
|
|
2316
2359
|
return hashlib.sha256(encoded_receipt.encode("utf-8")).hexdigest()
|
|
@@ -679,8 +679,14 @@ def test_sync_runtime_session_emits_package_manager_coverage_payload(
|
|
|
679
679
|
assert session_payload["deviceId"] == store.get_or_create_installation_id()
|
|
680
680
|
assert session_payload["deviceName"] == store.get_device_metadata()["device_label"]
|
|
681
681
|
assert session_payload["localIdentity"]["daemonId"] == store.get_or_create_installation_id()
|
|
682
|
+
assert session_payload["localIdentity"]["daemonVersion"] == guard_runner_module.__version__
|
|
682
683
|
assert session_payload["localIdentity"]["daemonStatus"] == "healthy"
|
|
683
684
|
assert session_payload["localIdentity"]["relayState"] == "online"
|
|
685
|
+
assert session_payload["localIdentity"]["lastSyncedAt"] == "2026-04-24T00:01:00+00:00"
|
|
686
|
+
assert session_payload["localIdentitySource"]["daemonId"] == "local-guard"
|
|
687
|
+
assert session_payload["localIdentitySource"]["daemonVersion"] == "local-guard"
|
|
688
|
+
assert session_payload["localIdentitySource"]["daemonStatus"] == "local-guard"
|
|
689
|
+
assert session_payload["localIdentitySource"]["relayState"] == "local-guard"
|
|
684
690
|
assert session_payload["packageManagerCoverage"] == {
|
|
685
691
|
"generatedAt": "2026-04-24T00:01:00+00:00",
|
|
686
692
|
"configuredManagers": ["npm"],
|
|
@@ -694,3 +700,105 @@ def test_sync_runtime_session_emits_package_manager_coverage_payload(
|
|
|
694
700
|
"nextRefreshAt": "2026-04-24T00:15:00+00:00",
|
|
695
701
|
},
|
|
696
702
|
}
|
|
703
|
+
|
|
704
|
+
|
|
705
|
+
def test_sync_runtime_session_prefers_ipv6_private_identity_when_ipv4_unavailable(
|
|
706
|
+
tmp_path: Path,
|
|
707
|
+
monkeypatch: pytest.MonkeyPatch,
|
|
708
|
+
) -> None:
|
|
709
|
+
store = GuardStore(tmp_path / "guard-home")
|
|
710
|
+
store.set_sync_credentials(
|
|
711
|
+
"https://hol.org/api/guard/receipts/sync",
|
|
712
|
+
"token-ipv6",
|
|
713
|
+
"2026-04-24T00:00:00+00:00",
|
|
714
|
+
workspace_id="workspace-alpha",
|
|
715
|
+
)
|
|
716
|
+
monkeypatch.setattr(guard_runner_module, "_safe_private_ip", lambda: None)
|
|
717
|
+
monkeypatch.setattr(guard_runner_module, "_safe_private_ipv6", lambda: "fd00::42")
|
|
718
|
+
captured_body: dict[str, object] = {}
|
|
719
|
+
|
|
720
|
+
def _runtime_sync_response(**kwargs):
|
|
721
|
+
request = kwargs["request"]
|
|
722
|
+
captured_body.update(json.loads(request.data.decode("utf-8")))
|
|
723
|
+
return {"syncedAt": "2026-04-24T00:01:00+00:00", "items": []}
|
|
724
|
+
|
|
725
|
+
monkeypatch.setattr(
|
|
726
|
+
guard_runner_module,
|
|
727
|
+
"_urlopen_json_with_timeout_retry",
|
|
728
|
+
_runtime_sync_response,
|
|
729
|
+
)
|
|
730
|
+
|
|
731
|
+
guard_runner_module.sync_runtime_session(
|
|
732
|
+
store,
|
|
733
|
+
session={
|
|
734
|
+
"harness": "codex",
|
|
735
|
+
"surface": "cli",
|
|
736
|
+
"status": "active",
|
|
737
|
+
"updatedAt": "2026-04-24T00:01:00+00:00",
|
|
738
|
+
"workspace": str(tmp_path / "workspace"),
|
|
739
|
+
},
|
|
740
|
+
)
|
|
741
|
+
|
|
742
|
+
session_payload = captured_body["session"]
|
|
743
|
+
assert isinstance(session_payload, dict)
|
|
744
|
+
assert session_payload["localIdentity"]["ipAddress"] == "fd00::42"
|
|
745
|
+
assert session_payload["localIdentity"]["privateIpAddress"] == "fd00::42"
|
|
746
|
+
assert session_payload["localIdentitySource"]["privateIpAddress"] == "local-guard"
|
|
747
|
+
|
|
748
|
+
|
|
749
|
+
def test_sync_runtime_session_keeps_local_identity_when_package_coverage_missing(
|
|
750
|
+
tmp_path: Path,
|
|
751
|
+
monkeypatch: pytest.MonkeyPatch,
|
|
752
|
+
) -> None:
|
|
753
|
+
store = GuardStore(tmp_path / "guard-home")
|
|
754
|
+
store.set_sync_credentials(
|
|
755
|
+
"https://hol.org/api/guard/receipts/sync",
|
|
756
|
+
"token-no-coverage",
|
|
757
|
+
"2026-04-24T00:00:00+00:00",
|
|
758
|
+
workspace_id="workspace-alpha",
|
|
759
|
+
)
|
|
760
|
+
monkeypatch.setattr(
|
|
761
|
+
guard_runner_module,
|
|
762
|
+
"package_shim_cloud_coverage",
|
|
763
|
+
lambda *_args, **_kwargs: {
|
|
764
|
+
"generatedAt": "2026-04-24T00:01:00+00:00",
|
|
765
|
+
"configuredManagers": [],
|
|
766
|
+
"protectedManagers": [],
|
|
767
|
+
"missingManagers": [],
|
|
768
|
+
"pathActive": False,
|
|
769
|
+
"bypasses": [],
|
|
770
|
+
"staleIntel": {
|
|
771
|
+
"status": "unknown",
|
|
772
|
+
"lastSyncedAt": None,
|
|
773
|
+
"nextRefreshAt": None,
|
|
774
|
+
},
|
|
775
|
+
},
|
|
776
|
+
)
|
|
777
|
+
captured_body: dict[str, object] = {}
|
|
778
|
+
|
|
779
|
+
def _runtime_sync_response(**kwargs):
|
|
780
|
+
request = kwargs["request"]
|
|
781
|
+
captured_body.update(json.loads(request.data.decode("utf-8")))
|
|
782
|
+
return {"syncedAt": "2026-04-24T00:01:00+00:00", "items": []}
|
|
783
|
+
|
|
784
|
+
monkeypatch.setattr(
|
|
785
|
+
guard_runner_module,
|
|
786
|
+
"_urlopen_json_with_timeout_retry",
|
|
787
|
+
_runtime_sync_response,
|
|
788
|
+
)
|
|
789
|
+
|
|
790
|
+
guard_runner_module.sync_runtime_session(
|
|
791
|
+
store,
|
|
792
|
+
session={
|
|
793
|
+
"harness": "codex",
|
|
794
|
+
"surface": "cli",
|
|
795
|
+
"status": "active",
|
|
796
|
+
"updatedAt": "2026-04-24T00:01:00+00:00",
|
|
797
|
+
"workspace": str(tmp_path / "workspace"),
|
|
798
|
+
},
|
|
799
|
+
)
|
|
800
|
+
|
|
801
|
+
session_payload = captured_body["session"]
|
|
802
|
+
assert isinstance(session_payload, dict)
|
|
803
|
+
assert session_payload["localIdentity"]["daemonId"] == store.get_or_create_installation_id()
|
|
804
|
+
assert session_payload["localIdentitySource"]["daemonId"] == "local-guard"
|
|
@@ -74,9 +74,11 @@ def test_guard_codex_hook_command_does_not_pin_custom_guard_home_in_real_global_
|
|
|
74
74
|
assert str(stale_guard_home) not in command
|
|
75
75
|
|
|
76
76
|
|
|
77
|
-
def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_path, capsys):
|
|
77
|
+
def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_path, capsys, monkeypatch):
|
|
78
78
|
home_dir = tmp_path / "home"
|
|
79
79
|
workspace_dir = tmp_path / "workspace"
|
|
80
|
+
source_root = str(Path(__file__).resolve().parents[1] / "src")
|
|
81
|
+
monkeypatch.setenv("PYTHONPATH", str(tmp_path / "stale-site-packages"))
|
|
80
82
|
_build_guard_fixture(home_dir, workspace_dir)
|
|
81
83
|
|
|
82
84
|
rc = main(
|
|
@@ -136,16 +138,19 @@ def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_pa
|
|
|
136
138
|
assert "codex_plugin_scanner.cli" in prompt_handler["command"]
|
|
137
139
|
assert "hook" in prompt_handler["command"]
|
|
138
140
|
assert "codex" in prompt_handler["command"]
|
|
141
|
+
assert prompt_handler["env"]["PYTHONPATH"] == source_root
|
|
139
142
|
handler = hooks_payload["PreToolUse"][0]["hooks"][0]
|
|
140
143
|
assert handler["type"] == "command"
|
|
141
144
|
assert "codex_plugin_scanner.cli" in handler["command"]
|
|
142
145
|
assert "hook" in handler["command"]
|
|
143
146
|
assert "codex" in handler["command"]
|
|
147
|
+
assert handler["env"]["PYTHONPATH"] == source_root
|
|
144
148
|
permission_handler = hooks_payload["PermissionRequest"][0]["hooks"][0]
|
|
145
149
|
assert permission_handler["type"] == "command"
|
|
146
150
|
assert "codex_plugin_scanner.cli" in permission_handler["command"]
|
|
147
151
|
assert "hook" in permission_handler["command"]
|
|
148
152
|
assert "codex" in permission_handler["command"]
|
|
153
|
+
assert permission_handler["env"]["PYTHONPATH"] == source_root
|
|
149
154
|
zshenv_text = (home_dir / ".zshenv").read_text(encoding="utf-8")
|
|
150
155
|
shell_guard_text = (home_dir / "managed" / "codex" / "codex-zshenv-guard.zsh").read_text(encoding="utf-8")
|
|
151
156
|
bash_guard_text = (home_dir / "managed" / "codex" / "codex-bashenv-guard.bash").read_text(encoding="utf-8")
|
|
@@ -301,6 +301,32 @@ def test_apps_test_alias_uses_safe_verification(tmp_path: Path, capsys: pytest.C
|
|
|
301
301
|
assert payload["verification"]["writes_config"] is False
|
|
302
302
|
|
|
303
303
|
|
|
304
|
+
def test_apps_repair_dry_run_explains_that_cloud_is_not_connected(
|
|
305
|
+
tmp_path: Path,
|
|
306
|
+
capsys: pytest.CaptureFixture[str],
|
|
307
|
+
) -> None:
|
|
308
|
+
args = argparse.Namespace(
|
|
309
|
+
guard_command="apps",
|
|
310
|
+
apps_command="repair",
|
|
311
|
+
harness="codex",
|
|
312
|
+
dry_run=True,
|
|
313
|
+
home=str(tmp_path / "home"),
|
|
314
|
+
guard_home=str(tmp_path / "guard-home"),
|
|
315
|
+
workspace=str(tmp_path / "workspace"),
|
|
316
|
+
json=True,
|
|
317
|
+
)
|
|
318
|
+
|
|
319
|
+
exit_code = run_guard_command(args)
|
|
320
|
+
|
|
321
|
+
assert exit_code == 0
|
|
322
|
+
payload = json.loads(capsys.readouterr().out)
|
|
323
|
+
assert payload["dry_run"] is True
|
|
324
|
+
assert payload["dry_run_effect"] == (
|
|
325
|
+
"No app config was changed and Guard Cloud was not connected. "
|
|
326
|
+
"Run hol-guard apps repair codex without --dry-run to finish setup."
|
|
327
|
+
)
|
|
328
|
+
|
|
329
|
+
|
|
304
330
|
def test_apps_subcommand_preserves_parent_flags(tmp_path: Path) -> None:
|
|
305
331
|
parser = argparse.ArgumentParser()
|
|
306
332
|
add_guard_root_parser(parser)
|