plugin-scanner 2.0.370__tar.gz → 2.0.372__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.370 → plugin_scanner-2.0.372}/PKG-INFO +1 -1
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/pyproject.toml +1 -1
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/pyproject.toml.bak +1 -1
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/scripts/codex-auto-resume-smoke.py +5 -2
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/codex.py +5 -3
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/commands.py +31 -2
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/codex_resume.py +25 -1
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/manager.py +22 -1
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/server.py +1 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/version.py +1 -1
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approvals.py +14 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_install.py +21 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_resume_endpoints.py +66 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_daemon_manager.py +77 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_daemon_registry.py +8 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.clusterfuzzlite/Dockerfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.clusterfuzzlite/build.sh +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.clusterfuzzlite/project.yaml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.clusterfuzzlite/requirements-atheris.txt +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.dockerignore +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/CODEOWNERS +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/ISSUE_TEMPLATE/bug-report.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/ISSUE_TEMPLATE/config.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/ISSUE_TEMPLATE/feature-request.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/dependabot.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/ci.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/codeql.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/dependabot-uv-lock.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/fuzz.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/harness-smoke.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/publish.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/workflows/scorecard.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.gitignore +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.pre-commit-hooks.yaml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/CONTRIBUTING.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/Dockerfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/PRODUCT.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/e2e/fixture-states.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/e2e/proof-dir.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/e2e/scrg172-states.spec.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/e2e/static-server.mjs +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/index.html +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/playwright.config.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/pnpm-lock.yaml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/public/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/public/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/public/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/public/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/public/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/public/favicon.ico +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/app-detail-phase11.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/app-detail-workspace.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/app-routing.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/app.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-layout.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-layout.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-mobile.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-primitives.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-review-cards.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-utils.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-gate-utils.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-gate.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-scopes.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-scopes.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/apps/app-catalog.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/apps/app-detail-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/audit-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/clear-policy-payload.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/clear-policy-payload.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/compare-time-periods.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/data-flow-evidence-card.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/error-boundary.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/app-tab.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/categories.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/category-tab.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-action-detail.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-action-list.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-analytics-panel.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-clear-modal.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-copy.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-detail.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-export-drawer.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-export.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-export.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-filter-bar.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-filters.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-filters.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-insight-strip.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-metrics.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-metrics.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-pagination.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-pagination.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-perf.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-period.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-sort.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-sort.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-story.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-types.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-url-state.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-url-state.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/evidence-view-shell.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/explore-tab.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/index.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/plain-english.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/evidence/story-tab.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/feed-health-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/fleet-workspace-phase11.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/fleet-workspace.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/fleet-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/guard-api.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/guard-api.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/guard-demo.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/guard-types.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/help-modal.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/history-analytics.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/history-charts.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/history-export.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/home-dashboard.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/home-dashboard.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/home-protection-module.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/main.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/phase09-review.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/policy-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/queue-chip-filter.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/queue-state.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/queue-state.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/receipts-workspace.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/receipts-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/review-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/risk-signal-cards.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/risk-signal-cards.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/runtime-overview.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/runtime-overview.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/scanner-evidence-badge.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/scrg159-170.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/scrg171-172.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/security-fixes.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/settings-workspace-phase11.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/settings-workspace.test.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/settings-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/styles.css +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/supply-chain-firewall-panel.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/supply-chain-firewall-views.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/supply-chain-manager-card.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/supply-chain-workspace.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/totp-enrollment-qr-panel.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/use-debounce.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/use-focus-trap.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/use-keyboard-shortcut.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/use-reduced-motion.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/use-route-focus.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/vite-env.d.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/watched-app-card.tsx +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/tsconfig.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/vite.config.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docker-requirements.txt +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/architecture.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/get-started.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/harness-support.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/incident-response.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/local-vs-cloud.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/release-checklist.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/remediation.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/smoke-tests.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/guard/testing-matrix.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/trust/mcp-trust-draft.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/trust/plugin-trust-draft.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/docs/trust/skill-trust-local.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/fuzzers/manifest_fuzzer.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/requirements.txt +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/schemas/plugin-quality.v1.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/schemas/scan-result.v1.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/schemas/verify-result.v1.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/action_runner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/argparse_utils.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/best_practices.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/claude.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/code_quality.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/ecosystem_common.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/gemini.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/manifest.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/manifest_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/marketplace.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/mcp_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/opencode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/operational_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/checks/skill_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/cli.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/cli_ui.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/config.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/base.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/claude.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/codex.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/detect.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/gemini.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/opencode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/registry.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/ecosystems/types.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/github_reporting.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/access_graph_events.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/antigravity.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/base.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/claude_code.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/cloud_identity.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/contracts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/copilot.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/cursor.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/gemini.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/hermes.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/mcp_servers.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/openclaw.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/openclaw_config.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/openclaw_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/opencode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/opencode_artifacts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/advisory_model.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/approval_gate.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/approval_gate_state.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/approvals.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/bridge/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/capabilities.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/approval_commands.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/approval_gate_prompt.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/bootstrap.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/connect_flow.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/docs.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/install_commands.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/product.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/prompt.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/render.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/update_commands.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/codex_app_server.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/codex_config.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/config.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/consumer/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/consumer/service.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/client.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-catalog.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-detail-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/audit-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/feed-health-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/fleet-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/help-modal.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/home-dashboard.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/policy-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/runtime-overview.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/settings-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/supply-chain-workspace.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/use-focus-trap.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/guard-dashboard.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/assets/index.css +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/favicon.ico +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/static/index.html +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/desktop_notifications.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/edge_events.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/harness_usage.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/incident.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/insights.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/inventory_cisco.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/inventory_contract.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/launcher.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/local_supply_chain.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/mcp_tool_calls.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/models.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/policy/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/policy/engine.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/product_model.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/protect.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/provenance.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/proxy/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/proxy/remote.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/proxy/runtime_mcp.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/proxy/stdio.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/receipts/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/receipts/manager.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/redaction.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/risk.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/action_identity.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/actions.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/advisory_escalation.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/advisory_matchers.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/cisco_evidence.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/cisco_preflight.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/composition_rules.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/data_flow.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/data_flow_rules.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/data_flow_variables.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/decisions.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/detectors.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/false_positive_rules.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/js_semver.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/mcp_protection.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/package_intent.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/package_intent_common.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/package_intent_parser.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/package_manifest_diff.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/persistence_rules.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/prompt_injection.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/runner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/safe_decode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/sandbox.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/scanner_cache.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/secret_file_requests.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/secret_sensitivity.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/secret_sources.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/sed_scripts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/shell_commands.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/signals.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/skill_protection.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_base.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_models.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_runtime.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain_package_eval.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/supply_chain_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/surface_server.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/temp_files.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/runtime/threat_intel.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/schemas/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/schemas/consumer_mode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/schemas/guard_event_v1.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/schemas/guard_product_model_v1.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/schemas/surface_server.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/shims.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store_approvals.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store_connect.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store_evidence.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store_resume.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store_supply_chain.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/store_threat_intel.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/totp.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/types.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/integrations/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/integrations/cisco_mcp_scanner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/integrations/cisco_skill_scanner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/lint_fixes.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/marketplace_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/models.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/path_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/policy.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/quality_artifact.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/repo_detect.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/reporting.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/rules/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/rules/registry.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/rules/specs.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/scanner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/submission.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/suppressions.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_domain_scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_helpers.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_mcp_scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_models.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_plugin_scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_skill_scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/trust_specs.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/verification.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/conftest.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/__init__.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/bad-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/bad-plugin/.mcp.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/bad-plugin/secrets.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/claude-plugin-good/.claude-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/claude-plugin-good/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/claude-plugin-good/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/claude-plugin-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/claude-plugin-good/hooks/hooks.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/claude-plugin-good/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/code-quality-bad/evil.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/code-quality-bad/inject.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/gemini-extension-good/GEMINI.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/gemini-extension-good/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/gemini-extension-good/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/gemini-extension-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/gemini-extension-good/commands/hello.toml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/gemini-extension-good/gemini-extension.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/assets/icon.svg +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/assets/logo.svg +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/assets/screenshot.svg +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/good-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-codex-malicious-mcp/.codex/config.toml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/benign-docs-fake-token.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/benign-health-endpoint.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/benign-nvmrc-fake-creds.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/benign-source-search.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/canary-exfil-encoded.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/canary-exfil.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/expected-decisions.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-dockerfile.txt +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-encoded-shell-exfil.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-github-action.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-mcp-delete.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-mcp-secret-read.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-mcp-skill-exfil.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-npm-postinstall.js +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-prompt-env-read.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-prompt-guard-bypass.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-prompt-npmrc-read.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/malicious-python-setup.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/guard-red-team/smoke-evidence-template.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/config.yaml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/mcp_servers.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/skills/security/malicious/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/references/api-setup.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/scripts/deploy.sh +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/hermes-plugin-evil/skills/utils/benign/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malformed-json/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malicious-skill-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malicious-skill-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malicious-skill-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malicious-skill-plugin/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malicious-skill-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/malicious-skill-plugin/skills/leaky-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/mcp-canary-server.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/minimal-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/missing-fields/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/mit-license/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-ecosystem-repo/codex-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-ecosystem-repo/codex-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-ecosystem-repo/codex-plugin/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-ecosystem-repo/codex-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-ecosystem-repo/gemini-ext/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-ecosystem-repo/gemini-ext/gemini-extension.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/.agents/plugins/marketplace.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/no-version/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/opencode-good/.opencode/commands/hello.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/opencode-good/.opencode/plugins/example.ts +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/opencode-good/LICENSE +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/opencode-good/README.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/opencode-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/opencode-good/opencode.jsonc +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/skills-missing-dir/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/skills-no-frontmatter/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/skills-no-frontmatter/skills/bad-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/benign-npm-controls-package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/benign-npm-package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/benign-pnpm-package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/benign-pyproject.toml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/critical-base-image-Dockerfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/malicious-Dockerfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/malicious-action.yml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/malicious-npm-env-fs-network-package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/malicious-npm-obfuscated-package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/malicious-npm-package.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/supply-chain/malicious-setup.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/cargo-safe/Cargo.lock +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/cargo-safe/Cargo.toml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/cargo-vulnerable/Cargo.lock +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/cargo-vulnerable/Cargo.toml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/composer-safe/composer.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/composer-safe/composer.lock +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/composer-vulnerable/composer.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/composer-vulnerable/composer.lock +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/go-safe/go.mod +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/go-vulnerable/go.mod +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/gradle-safe/build.gradle +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/gradle-safe/gradle.lockfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/gradle-vulnerable/build.gradle +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/gradle-vulnerable/gradle.lockfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/maven-safe/pom.xml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/maven-vulnerable/pom.xml +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/rubygems-safe/Gemfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/rubygems-safe/Gemfile.lock +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile.lock +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/with-marketplace/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/with-marketplace/marketplace-broken.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/fixtures/with-marketplace/marketplace.json +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/guard_python_phase12_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/guard_tier2_phase13_support.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test-trust-scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test-trust-specs.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_action_runner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_best_practices.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_cisco_install_surfaces.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_cli.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_code_quality.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_config.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_coverage_remaining.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_cursor_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_ecosystems.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_edge_cases.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_final_coverage.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_gemini_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_access_graph.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_action_identity.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_advisory_escalation.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_continuity.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_copy_commands.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_decisions.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_gate.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_store_dedup.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_store_phase14.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_approval_store_scale.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_bootstrap.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_bypass_detector.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_canary_fixtures.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_capabilities.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_cisco_evidence.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_cisco_runtime_cli.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_claude_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_cli.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_cloud_local_sync.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_auto_resume_smoke.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_e2e.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_proxy.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_resume_commands.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_config_paths.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_connect_flow.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_consumer_mode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_copilot_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_copilot_proxy.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_daemon_cli.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_daemon_perf.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_daemon_repair_perf.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_daemon_wake.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_data_flow.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_decision_propagation.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_desktop_notifications.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_detector_fp.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_docs.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_event_schema_v1.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_events.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_evidence_api_contract.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_evidence_store.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_harness_contracts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_harness_setup.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_harness_smoke.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_hashnet_mcp_canaries.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_headless_daemon_api.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_insights.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_inventory_cisco.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_inventory_contract.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_js_lab_phase11.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_js_lockfile_resolution_phase11.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_js_package_hook_phase11.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_js_package_intent_phase11.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_js_semver_phase11.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_js_supply_chain_phase11.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_launch_env.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_local_supply_chain_audit_phase16.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_local_supply_chain_phase15.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_mcp_detectors.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_mcp_package_proxy_phase14.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_mcp_protection.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_opencode_proxy.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_package_hook.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_package_hook_phase14.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_package_intent.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_package_resume_phase14.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_package_shims.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase03_local_install.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase03_remainder.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase04_failure_modes.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase04_harness_contracts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase04_harness_ux.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase05_approval_memory.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_phase07_harness_coverage_matrix.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_policy_dedup.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_product_flow.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_product_model_contracts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_prompt_injection.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_protect.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_provenance.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_python_lab_phase12.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_python_package_hook_phase12.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_python_package_intent_phase12.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_python_supply_chain_heuristics_phase12.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_python_supply_chain_phase12.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_queue_api_contract.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_queue_contract.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_receipt_p5_fields.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_receipt_persistence.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_red_team.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_red_team_e2e.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_redaction.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_registry_broker_skills_canaries.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_render.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_resolution_copy.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_risk.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime_action_harnesses.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime_actions.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime_actions_phase14.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime_decisions.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime_detectors.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_runtime_signals.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_safe_decode.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_sandbox.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_settings_api.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_settings_presets.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_shim_truth.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_skill_protection.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_skill_protection_phase14.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_store_migrations.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_supply_chain.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_supply_chain_bundle.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_supply_chain_daemon.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_supply_chain_evaluator.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_supply_chain_sync.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_surface_server.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_threat_intel.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_tier2_labs_phase13.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_tier2_package_intent_phase13.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_tier2_supply_chain_phase13.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_verdicts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_web_recovery.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_wrapper_flows.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_hermes_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_integration.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_lint_fixes.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_live_cisco_smoke.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_manifest.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_marketplace.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_mcp_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_openclaw_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_opencode_adapter.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_operational_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_policy.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_quality_artifact.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_rule_registry.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_scanner.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_schema_contracts.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_security_ops.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_skill_security.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_submission.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_trust_scoring.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_trust_specs.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_verification.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_versioning.py +0 -0
- {plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/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.372
|
|
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.372"
|
|
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.372"
|
|
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"
|
|
@@ -156,7 +156,7 @@ def _run_scenario_in_dir(*, decision: str, args: argparse.Namespace, temp_dir: P
|
|
|
156
156
|
daemon_port=daemon.port,
|
|
157
157
|
codex_home=args.codex_home,
|
|
158
158
|
socket_path=socket_path,
|
|
159
|
-
operation_status="
|
|
159
|
+
operation_status="waiting_on_approval",
|
|
160
160
|
)
|
|
161
161
|
action_path = "approve" if decision == "allow" else "block"
|
|
162
162
|
approval_payload = _post_json(
|
|
@@ -540,7 +540,10 @@ def _queue_pending_request(
|
|
|
540
540
|
"codex_app_server_socket": str(socket_path),
|
|
541
541
|
"command_text": _proof_command(),
|
|
542
542
|
"tool_name": "Bash",
|
|
543
|
-
"event": "
|
|
543
|
+
"event": "PostToolUse",
|
|
544
|
+
"hook_event_name": "PostToolUse",
|
|
545
|
+
"codex_hook_waits_for_browser_approval": True,
|
|
546
|
+
"codex_browser_wait_deadline_at": "2000-01-01T00:00:00+00:00",
|
|
544
547
|
},
|
|
545
548
|
now=now,
|
|
546
549
|
)
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/adapters/codex.py
RENAMED
|
@@ -157,16 +157,18 @@ def _strict_json_object(path: Path, *, label: str) -> dict[str, object]:
|
|
|
157
157
|
|
|
158
158
|
|
|
159
159
|
def _hook_command_parts(context: HarnessContext) -> tuple[str, ...]:
|
|
160
|
+
resolved_home = context.home_dir.resolve()
|
|
161
|
+
resolved_user_home = Path.home().resolve()
|
|
160
162
|
guard_args = [
|
|
161
163
|
"guard",
|
|
162
164
|
"hook",
|
|
163
|
-
"--guard-home",
|
|
164
|
-
str(context.guard_home),
|
|
165
165
|
"--harness",
|
|
166
166
|
"codex",
|
|
167
167
|
]
|
|
168
|
-
if
|
|
168
|
+
if resolved_home != resolved_user_home:
|
|
169
169
|
guard_args.extend(["--home", str(context.home_dir)])
|
|
170
|
+
if context.guard_home.resolve() != resolved_home:
|
|
171
|
+
guard_args.extend(["--guard-home", str(context.guard_home)])
|
|
170
172
|
if context.workspace_dir is not None:
|
|
171
173
|
guard_args.extend(["--workspace", str(context.workspace_dir)])
|
|
172
174
|
return (sys.executable, "-m", "codex_plugin_scanner.cli", *guard_args)
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/cli/commands.py
RENAMED
|
@@ -2732,10 +2732,11 @@ def run_guard_command(
|
|
|
2732
2732
|
"tool_name": str(payload.get("tool_name", "")),
|
|
2733
2733
|
"hook_name": "permissionRequest",
|
|
2734
2734
|
"hook_event_name": "PermissionRequest",
|
|
2735
|
-
|
|
2735
|
+
**_codex_browser_wait_metadata(
|
|
2736
2736
|
args=args,
|
|
2737
2737
|
event_name="PermissionRequest",
|
|
2738
2738
|
policy_action=policy_action,
|
|
2739
|
+
config=config,
|
|
2739
2740
|
),
|
|
2740
2741
|
"command_text": _hook_command_text(payload),
|
|
2741
2742
|
"workspace": str(runtime_workspace) if runtime_workspace else None,
|
|
@@ -3206,10 +3207,11 @@ def run_guard_command(
|
|
|
3206
3207
|
"tool_name": str(payload.get("tool_name", "")),
|
|
3207
3208
|
"event": str(payload.get("event", "")),
|
|
3208
3209
|
"hook_event_name": event_name,
|
|
3209
|
-
|
|
3210
|
+
**_codex_browser_wait_metadata(
|
|
3210
3211
|
args=args,
|
|
3211
3212
|
event_name=event_name,
|
|
3212
3213
|
policy_action=policy_action,
|
|
3214
|
+
config=config,
|
|
3213
3215
|
),
|
|
3214
3216
|
"command_text": _hook_command_text(payload),
|
|
3215
3217
|
"workspace": str(workspace) if workspace else None,
|
|
@@ -3672,6 +3674,33 @@ def _codex_hook_waits_for_browser_approval(
|
|
|
3672
3674
|
)
|
|
3673
3675
|
|
|
3674
3676
|
|
|
3677
|
+
def _codex_browser_wait_metadata(
|
|
3678
|
+
*,
|
|
3679
|
+
args: argparse.Namespace,
|
|
3680
|
+
event_name: str,
|
|
3681
|
+
policy_action: str,
|
|
3682
|
+
config: GuardConfig,
|
|
3683
|
+
) -> dict[str, object]:
|
|
3684
|
+
waits_for_browser = _codex_hook_waits_for_browser_approval(
|
|
3685
|
+
args=args,
|
|
3686
|
+
event_name=event_name,
|
|
3687
|
+
policy_action=policy_action,
|
|
3688
|
+
)
|
|
3689
|
+
if not waits_for_browser:
|
|
3690
|
+
return {"codex_hook_waits_for_browser_approval": False}
|
|
3691
|
+
wait_timeout_seconds = max(config.approval_wait_timeout_seconds, 0)
|
|
3692
|
+
if event_name == "UserPromptSubmit":
|
|
3693
|
+
wait_timeout_seconds = min(wait_timeout_seconds, _CODEX_PROMPT_APPROVAL_WAIT_MAX_SECONDS)
|
|
3694
|
+
started_at = datetime.now(timezone.utc)
|
|
3695
|
+
deadline_at = started_at + timedelta(seconds=wait_timeout_seconds)
|
|
3696
|
+
return {
|
|
3697
|
+
"codex_hook_waits_for_browser_approval": True,
|
|
3698
|
+
"codex_browser_wait_started_at": started_at.isoformat(),
|
|
3699
|
+
"codex_browser_wait_deadline_at": deadline_at.isoformat(),
|
|
3700
|
+
"codex_browser_wait_timeout_seconds": wait_timeout_seconds,
|
|
3701
|
+
}
|
|
3702
|
+
|
|
3703
|
+
|
|
3675
3704
|
def _update_codex_browser_operation_status(
|
|
3676
3705
|
response_payload: dict[str, object],
|
|
3677
3706
|
daemon_client: object | None,
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/codex_resume.py
RENAMED
|
@@ -4,6 +4,7 @@ from __future__ import annotations
|
|
|
4
4
|
|
|
5
5
|
import shutil
|
|
6
6
|
from collections.abc import Mapping
|
|
7
|
+
from datetime import datetime, timezone
|
|
7
8
|
|
|
8
9
|
from .codex_app_server import default_codex_app_server_socket_available, resume_codex_thread_for_request
|
|
9
10
|
from .store import GuardStore
|
|
@@ -126,7 +127,7 @@ def defer_request_resume_to_live_hook(
|
|
|
126
127
|
if str(operation.get("status")) != "waiting_on_approval":
|
|
127
128
|
return None
|
|
128
129
|
metadata = operation.get("metadata")
|
|
129
|
-
if not isinstance(metadata, Mapping) or metadata
|
|
130
|
+
if not isinstance(metadata, Mapping) or not _live_hook_wait_is_active(metadata=metadata, now=now):
|
|
130
131
|
return None
|
|
131
132
|
resume = get_request_resume_status(store, request_id=request_id, now=now)
|
|
132
133
|
if resume is None:
|
|
@@ -185,6 +186,29 @@ def inspect_codex_resume_capabilities(store: GuardStore) -> dict[str, object]:
|
|
|
185
186
|
}
|
|
186
187
|
|
|
187
188
|
|
|
189
|
+
def _live_hook_wait_is_active(*, metadata: Mapping[str, object], now: str) -> bool:
|
|
190
|
+
if metadata.get("codex_hook_waits_for_browser_approval") is not True:
|
|
191
|
+
return False
|
|
192
|
+
deadline = _first_string(metadata, ("codex_browser_wait_deadline_at", "browser_wait_deadline_at"))
|
|
193
|
+
if deadline is None:
|
|
194
|
+
return False
|
|
195
|
+
deadline_at = _parse_timestamp(deadline)
|
|
196
|
+
now_at = _parse_timestamp(now)
|
|
197
|
+
if deadline_at is None or now_at is None:
|
|
198
|
+
return False
|
|
199
|
+
return now_at <= deadline_at
|
|
200
|
+
|
|
201
|
+
|
|
202
|
+
def _parse_timestamp(value: str) -> datetime | None:
|
|
203
|
+
try:
|
|
204
|
+
parsed = datetime.fromisoformat(value.replace("Z", "+00:00"))
|
|
205
|
+
except ValueError:
|
|
206
|
+
return None
|
|
207
|
+
if parsed.tzinfo is None:
|
|
208
|
+
return parsed.replace(tzinfo=timezone.utc)
|
|
209
|
+
return parsed.astimezone(timezone.utc)
|
|
210
|
+
|
|
211
|
+
|
|
188
212
|
def _finalize_resume_attempt(
|
|
189
213
|
*,
|
|
190
214
|
store: GuardStore,
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/manager.py
RENAMED
|
@@ -132,10 +132,18 @@ def load_guard_daemon_url(guard_home: Path) -> str | None:
|
|
|
132
132
|
port = payload.get("port")
|
|
133
133
|
if not isinstance(port, int):
|
|
134
134
|
return None
|
|
135
|
+
pid = payload.get("pid")
|
|
136
|
+
if not isinstance(pid, int) or pid <= 0 or not _guard_daemon_pid_is_running(pid):
|
|
137
|
+
return None
|
|
135
138
|
url = f"http://127.0.0.1:{port}"
|
|
136
139
|
try:
|
|
137
140
|
with urllib.request.urlopen(f"{url}/healthz", timeout=1) as response:
|
|
138
|
-
|
|
141
|
+
raw_payload = response.read().decode("utf-8")
|
|
142
|
+
if response.status != 200 or not _healthz_payload_is_current(raw_payload):
|
|
143
|
+
return None
|
|
144
|
+
if _healthz_payload_matches_guard_home(raw_payload, guard_home):
|
|
145
|
+
return url
|
|
146
|
+
if _guard_daemon_pid_matches_command(pid, expected_guard_home=guard_home):
|
|
139
147
|
return url
|
|
140
148
|
except (OSError, ValueError, urllib.error.URLError):
|
|
141
149
|
return None
|
|
@@ -819,3 +827,16 @@ def _healthz_payload_is_current(raw_payload: str) -> bool:
|
|
|
819
827
|
return False
|
|
820
828
|
table_names = {table for table in tables if isinstance(table, str)}
|
|
821
829
|
return REQUIRED_DAEMON_TABLES.issubset(table_names)
|
|
830
|
+
|
|
831
|
+
|
|
832
|
+
def _healthz_payload_matches_guard_home(raw_payload: str, guard_home: Path) -> bool:
|
|
833
|
+
payload = json.loads(raw_payload)
|
|
834
|
+
if not isinstance(payload, dict):
|
|
835
|
+
return False
|
|
836
|
+
payload_guard_home = payload.get("guard_home")
|
|
837
|
+
if not isinstance(payload_guard_home, str) or not payload_guard_home.strip():
|
|
838
|
+
return False
|
|
839
|
+
try:
|
|
840
|
+
return Path(payload_guard_home).resolve() == guard_home.resolve()
|
|
841
|
+
except OSError:
|
|
842
|
+
return Path(payload_guard_home) == guard_home
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/src/codex_plugin_scanner/guard/daemon/server.py
RENAMED
|
@@ -451,6 +451,7 @@ class _GuardDaemonHandler(BaseHTTPRequestHandler):
|
|
|
451
451
|
"tables": store.list_table_names(),
|
|
452
452
|
"compatibility_version": GUARD_DAEMON_COMPATIBILITY_VERSION,
|
|
453
453
|
"package_version": __version__,
|
|
454
|
+
"guard_home": str(store.guard_home.resolve()),
|
|
454
455
|
}
|
|
455
456
|
)
|
|
456
457
|
return
|
|
@@ -1155,12 +1155,19 @@ class TestGuardApprovals:
|
|
|
1155
1155
|
"_load_state",
|
|
1156
1156
|
lambda _guard_home: {
|
|
1157
1157
|
"port": 5530,
|
|
1158
|
+
"pid": 12345,
|
|
1158
1159
|
"auth_token": "token-123",
|
|
1159
1160
|
"compatibility_version": daemon_manager_module.GUARD_DAEMON_COMPATIBILITY_VERSION,
|
|
1160
1161
|
"source_root": daemon_manager_module._current_guard_daemon_source_root(),
|
|
1161
1162
|
"runtime_fingerprint": daemon_manager_module._current_guard_daemon_runtime_fingerprint(),
|
|
1162
1163
|
},
|
|
1163
1164
|
)
|
|
1165
|
+
monkeypatch.setattr(daemon_manager_module, "_guard_daemon_pid_is_running", lambda _pid: True)
|
|
1166
|
+
monkeypatch.setattr(
|
|
1167
|
+
daemon_manager_module,
|
|
1168
|
+
"_guard_daemon_pid_matches_command",
|
|
1169
|
+
lambda _pid, expected_guard_home=None: True,
|
|
1170
|
+
)
|
|
1164
1171
|
monkeypatch.setattr(
|
|
1165
1172
|
daemon_manager_module.urllib.request,
|
|
1166
1173
|
"urlopen",
|
|
@@ -1195,12 +1202,19 @@ class TestGuardApprovals:
|
|
|
1195
1202
|
"_load_state",
|
|
1196
1203
|
lambda _guard_home: {
|
|
1197
1204
|
"port": 5530,
|
|
1205
|
+
"pid": 12345,
|
|
1198
1206
|
"auth_token": "token-123",
|
|
1199
1207
|
"compatibility_version": daemon_manager_module.GUARD_DAEMON_COMPATIBILITY_VERSION,
|
|
1200
1208
|
"source_root": daemon_manager_module._current_guard_daemon_source_root(),
|
|
1201
1209
|
"runtime_fingerprint": daemon_manager_module._current_guard_daemon_runtime_fingerprint(),
|
|
1202
1210
|
},
|
|
1203
1211
|
)
|
|
1212
|
+
monkeypatch.setattr(daemon_manager_module, "_guard_daemon_pid_is_running", lambda _pid: True)
|
|
1213
|
+
monkeypatch.setattr(
|
|
1214
|
+
daemon_manager_module,
|
|
1215
|
+
"_guard_daemon_pid_matches_command",
|
|
1216
|
+
lambda _pid, expected_guard_home=None: True,
|
|
1217
|
+
)
|
|
1204
1218
|
monkeypatch.setattr(
|
|
1205
1219
|
daemon_manager_module.urllib.request,
|
|
1206
1220
|
"urlopen",
|
|
@@ -53,6 +53,27 @@ env = { API_BASE = "https://hol.org", FEATURE_FLAG = "1" }
|
|
|
53
53
|
)
|
|
54
54
|
|
|
55
55
|
|
|
56
|
+
def test_guard_codex_hook_command_does_not_pin_custom_guard_home_in_real_global_config(
|
|
57
|
+
tmp_path,
|
|
58
|
+
monkeypatch,
|
|
59
|
+
):
|
|
60
|
+
home_dir = tmp_path / "home"
|
|
61
|
+
workspace_dir = tmp_path / "workspace"
|
|
62
|
+
stale_guard_home = tmp_path / "pytest-stale-guard-home"
|
|
63
|
+
monkeypatch.setattr(codex_adapter.Path, "home", lambda: home_dir)
|
|
64
|
+
|
|
65
|
+
command = codex_adapter._hook_command(
|
|
66
|
+
HarnessContext(
|
|
67
|
+
home_dir=home_dir,
|
|
68
|
+
workspace_dir=workspace_dir,
|
|
69
|
+
guard_home=stale_guard_home,
|
|
70
|
+
)
|
|
71
|
+
)
|
|
72
|
+
|
|
73
|
+
assert "--guard-home" not in shlex.split(command)
|
|
74
|
+
assert str(stale_guard_home) not in command
|
|
75
|
+
|
|
76
|
+
|
|
56
77
|
def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_path, capsys):
|
|
57
78
|
home_dir = tmp_path / "home"
|
|
58
79
|
workspace_dir = tmp_path / "workspace"
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/tests/test_guard_codex_resume_endpoints.py
RENAMED
|
@@ -96,6 +96,7 @@ def _seed_codex_operation(
|
|
|
96
96
|
command_text: str | None = None,
|
|
97
97
|
hook_event_name: str | None = None,
|
|
98
98
|
waits_for_browser_approval: bool | None = None,
|
|
99
|
+
browser_wait_deadline_at: str | None = None,
|
|
99
100
|
status: str = "waiting_on_approval",
|
|
100
101
|
) -> None:
|
|
101
102
|
session = store.upsert_guard_session(
|
|
@@ -125,6 +126,8 @@ def _seed_codex_operation(
|
|
|
125
126
|
metadata["hook_event_name"] = hook_event_name
|
|
126
127
|
if waits_for_browser_approval is not None:
|
|
127
128
|
metadata["codex_hook_waits_for_browser_approval"] = waits_for_browser_approval
|
|
129
|
+
if browser_wait_deadline_at is not None:
|
|
130
|
+
metadata["codex_browser_wait_deadline_at"] = browser_wait_deadline_at
|
|
128
131
|
store.upsert_guard_operation(
|
|
129
132
|
operation_id=f"operation-{request_id}",
|
|
130
133
|
session_id=str(session["session_id"]),
|
|
@@ -273,6 +276,7 @@ def test_codex_approve_defers_headless_resume_while_live_hook_waits(
|
|
|
273
276
|
thread_id="live-session-1",
|
|
274
277
|
hook_event_name="PostToolUse",
|
|
275
278
|
waits_for_browser_approval=True,
|
|
279
|
+
browser_wait_deadline_at="2999-01-01T00:00:00+00:00",
|
|
276
280
|
status="waiting_on_approval",
|
|
277
281
|
)
|
|
278
282
|
daemon = GuardDaemonServer(store, host="127.0.0.1", port=0)
|
|
@@ -294,6 +298,66 @@ def test_codex_approve_defers_headless_resume_while_live_hook_waits(
|
|
|
294
298
|
assert "original Codex action continue" in payload["codex_resume"]["message"]
|
|
295
299
|
|
|
296
300
|
|
|
301
|
+
def test_codex_approve_stale_live_hook_wait_starts_headless_resume(
|
|
302
|
+
tmp_path: Path,
|
|
303
|
+
monkeypatch: pytest.MonkeyPatch,
|
|
304
|
+
) -> None:
|
|
305
|
+
launched: list[list[str]] = []
|
|
306
|
+
|
|
307
|
+
class _FakeProcess:
|
|
308
|
+
pid = 1031
|
|
309
|
+
|
|
310
|
+
def _fake_popen(command, **_kwargs):
|
|
311
|
+
launched.append(command)
|
|
312
|
+
return _FakeProcess()
|
|
313
|
+
|
|
314
|
+
monkeypatch.setattr(
|
|
315
|
+
codex_app_server_module.shutil,
|
|
316
|
+
"which",
|
|
317
|
+
lambda command: "/usr/bin/codex" if command == "codex" else None,
|
|
318
|
+
)
|
|
319
|
+
monkeypatch.setattr(codex_app_server_module.subprocess, "Popen", _fake_popen)
|
|
320
|
+
|
|
321
|
+
workspace = tmp_path / "workspace"
|
|
322
|
+
codex_home = tmp_path / "codex-home"
|
|
323
|
+
workspace.mkdir()
|
|
324
|
+
codex_home.mkdir()
|
|
325
|
+
store = GuardStore(tmp_path / "guard-home")
|
|
326
|
+
store.add_approval_request(_request("req-stale-live"), "2026-05-19T10:00:00+00:00")
|
|
327
|
+
_seed_codex_operation(
|
|
328
|
+
store,
|
|
329
|
+
request_id="req-stale-live",
|
|
330
|
+
socket_path=None,
|
|
331
|
+
thread_id="stale-live-session-1",
|
|
332
|
+
workspace=str(workspace),
|
|
333
|
+
codex_home=str(codex_home),
|
|
334
|
+
command_text="npm install minimist@1.2.8",
|
|
335
|
+
hook_event_name="PostToolUse",
|
|
336
|
+
waits_for_browser_approval=True,
|
|
337
|
+
browser_wait_deadline_at="2000-01-01T00:00:00+00:00",
|
|
338
|
+
status="waiting_on_approval",
|
|
339
|
+
)
|
|
340
|
+
daemon = GuardDaemonServer(store, host="127.0.0.1", port=0)
|
|
341
|
+
daemon.start()
|
|
342
|
+
|
|
343
|
+
try:
|
|
344
|
+
payload = _post_json(
|
|
345
|
+
daemon.port,
|
|
346
|
+
daemon._server.auth_token,
|
|
347
|
+
"/v1/requests/req-stale-live/approve",
|
|
348
|
+
{"scope": "artifact", "reason": "reviewed"},
|
|
349
|
+
)
|
|
350
|
+
finally:
|
|
351
|
+
daemon.stop()
|
|
352
|
+
|
|
353
|
+
assert payload["resolved"] is True
|
|
354
|
+
assert payload["codex_resume"]["status"] == "sent"
|
|
355
|
+
assert payload["codex_resume"]["reason"] == "headless_resume_started"
|
|
356
|
+
assert payload["codex_resume"]["strategy"] == "codex-headless-exec"
|
|
357
|
+
assert launched[0][:5] == ["/usr/bin/codex", "exec", "resume", "--json", "--skip-git-repo-check"]
|
|
358
|
+
assert "stale-live-session-1" in launched[0]
|
|
359
|
+
|
|
360
|
+
|
|
297
361
|
def test_codex_block_does_not_defer_to_live_hook_waiting_on_browser_decision(
|
|
298
362
|
tmp_path: Path,
|
|
299
363
|
) -> None:
|
|
@@ -307,6 +371,7 @@ def test_codex_block_does_not_defer_to_live_hook_waiting_on_browser_decision(
|
|
|
307
371
|
thread_id="live-block-session-1",
|
|
308
372
|
hook_event_name="PostToolUse",
|
|
309
373
|
waits_for_browser_approval=True,
|
|
374
|
+
browser_wait_deadline_at="2999-01-01T00:00:00+00:00",
|
|
310
375
|
status="waiting_on_approval",
|
|
311
376
|
)
|
|
312
377
|
daemon = GuardDaemonServer(store, host="127.0.0.1", port=0)
|
|
@@ -405,6 +470,7 @@ def test_codex_deferred_live_hook_resume_retry_reports_missing_chat_channel(
|
|
|
405
470
|
thread_id="live-session-retry-1",
|
|
406
471
|
hook_event_name="PostToolUse",
|
|
407
472
|
waits_for_browser_approval=True,
|
|
473
|
+
browser_wait_deadline_at="2999-01-01T00:00:00+00:00",
|
|
408
474
|
status="waiting_on_approval",
|
|
409
475
|
)
|
|
410
476
|
daemon = GuardDaemonServer(store, host="127.0.0.1", port=0)
|
|
@@ -39,6 +39,83 @@ def test_clear_guard_daemon_state_preserves_auth_token_file(tmp_path):
|
|
|
39
39
|
assert daemon_manager_module._auth_token_path(guard_home).read_text(encoding="utf-8") == "secret-token"
|
|
40
40
|
|
|
41
41
|
|
|
42
|
+
def test_load_guard_daemon_url_rejects_live_port_when_state_pid_is_not_guard_daemon(tmp_path, monkeypatch):
|
|
43
|
+
guard_home = tmp_path / "guard-home"
|
|
44
|
+
other_guard_home = tmp_path / "other-guard-home"
|
|
45
|
+
daemon_manager_module.write_guard_daemon_state(guard_home, 4833, "secret-token")
|
|
46
|
+
|
|
47
|
+
class FakeResponse:
|
|
48
|
+
status = 200
|
|
49
|
+
|
|
50
|
+
def __enter__(self) -> FakeResponse:
|
|
51
|
+
return self
|
|
52
|
+
|
|
53
|
+
def __exit__(self, exc_type, exc, tb) -> None:
|
|
54
|
+
return None
|
|
55
|
+
|
|
56
|
+
def read(self) -> bytes:
|
|
57
|
+
return json.dumps(
|
|
58
|
+
{
|
|
59
|
+
"ok": True,
|
|
60
|
+
"tables": ["guard_connect_states"],
|
|
61
|
+
"compatibility_version": daemon_manager_module.GUARD_DAEMON_COMPATIBILITY_VERSION,
|
|
62
|
+
"guard_home": str(other_guard_home),
|
|
63
|
+
}
|
|
64
|
+
).encode("utf-8")
|
|
65
|
+
|
|
66
|
+
monkeypatch.setattr(daemon_manager_module, "_guard_daemon_pid_is_running", lambda _pid: True)
|
|
67
|
+
monkeypatch.setattr(
|
|
68
|
+
daemon_manager_module,
|
|
69
|
+
"_guard_daemon_pid_matches_command",
|
|
70
|
+
lambda _pid, expected_guard_home=None: False,
|
|
71
|
+
)
|
|
72
|
+
monkeypatch.setattr(
|
|
73
|
+
daemon_manager_module.urllib.request,
|
|
74
|
+
"urlopen",
|
|
75
|
+
lambda *_args, **_kwargs: FakeResponse(),
|
|
76
|
+
)
|
|
77
|
+
|
|
78
|
+
assert daemon_manager_module.load_guard_daemon_url(guard_home) is None
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
def test_load_guard_daemon_url_accepts_matching_healthz_guard_home_for_in_process_daemon(tmp_path, monkeypatch):
|
|
82
|
+
guard_home = tmp_path / "guard-home"
|
|
83
|
+
daemon_manager_module.write_guard_daemon_state(guard_home, 4833, "secret-token")
|
|
84
|
+
|
|
85
|
+
class FakeResponse:
|
|
86
|
+
status = 200
|
|
87
|
+
|
|
88
|
+
def __enter__(self) -> FakeResponse:
|
|
89
|
+
return self
|
|
90
|
+
|
|
91
|
+
def __exit__(self, exc_type, exc, tb) -> None:
|
|
92
|
+
return None
|
|
93
|
+
|
|
94
|
+
def read(self) -> bytes:
|
|
95
|
+
return json.dumps(
|
|
96
|
+
{
|
|
97
|
+
"ok": True,
|
|
98
|
+
"tables": ["guard_connect_states"],
|
|
99
|
+
"compatibility_version": daemon_manager_module.GUARD_DAEMON_COMPATIBILITY_VERSION,
|
|
100
|
+
"guard_home": str(guard_home),
|
|
101
|
+
}
|
|
102
|
+
).encode("utf-8")
|
|
103
|
+
|
|
104
|
+
monkeypatch.setattr(daemon_manager_module, "_guard_daemon_pid_is_running", lambda _pid: True)
|
|
105
|
+
monkeypatch.setattr(
|
|
106
|
+
daemon_manager_module,
|
|
107
|
+
"_guard_daemon_pid_matches_command",
|
|
108
|
+
lambda _pid, expected_guard_home=None: False,
|
|
109
|
+
)
|
|
110
|
+
monkeypatch.setattr(
|
|
111
|
+
daemon_manager_module.urllib.request,
|
|
112
|
+
"urlopen",
|
|
113
|
+
lambda *_args, **_kwargs: FakeResponse(),
|
|
114
|
+
)
|
|
115
|
+
|
|
116
|
+
assert daemon_manager_module.load_guard_daemon_url(guard_home) == "http://127.0.0.1:4833"
|
|
117
|
+
|
|
118
|
+
|
|
42
119
|
def test_write_guard_daemon_state_hardens_permissions_on_open_descriptor(tmp_path, monkeypatch):
|
|
43
120
|
guard_home = tmp_path / "guard-home"
|
|
44
121
|
fchmod_calls: list[tuple[int, int]] = []
|
|
@@ -119,3 +119,11 @@ class TestHealthzEndpoint:
|
|
|
119
119
|
assert "tables" in payload
|
|
120
120
|
finally:
|
|
121
121
|
server.stop()
|
|
122
|
+
|
|
123
|
+
def test_healthz_includes_guard_home_for_daemon_identity(self, tmp_path: Path) -> None:
|
|
124
|
+
url, server = self._start_server(tmp_path)
|
|
125
|
+
try:
|
|
126
|
+
payload = self._get_healthz(url)
|
|
127
|
+
assert payload["guard_home"] == str((tmp_path / "guard-home").resolve())
|
|
128
|
+
finally:
|
|
129
|
+
server.stop()
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/.github/ISSUE_TEMPLATE/feature-request.yml
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/app-detail-workspace.test.ts
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-layout.test.ts
RENAMED
|
File without changes
|
|
File without changes
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-mobile.test.ts
RENAMED
|
File without changes
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-primitives.tsx
RENAMED
|
File without changes
|
{plugin_scanner-2.0.370 → plugin_scanner-2.0.372}/dashboard/src/approval-center-review-cards.tsx
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|