plugin-scanner 2.0.363__tar.gz → 2.0.365__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.363 → plugin_scanner-2.0.365}/PKG-INFO +1 -1
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/pyproject.toml +1 -1
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/pyproject.toml.bak +1 -1
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/codex.py +161 -7
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/mcp_servers.py +2 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/update_commands.py +3 -2
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/server.py +24 -2
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/version.py +1 -1
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_cli.py +2 -3
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_codex_install.py +64 -19
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_headless_daemon_api.py +73 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_launch_env.py +6 -4
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.clusterfuzzlite/Dockerfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.clusterfuzzlite/build.sh +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.clusterfuzzlite/project.yaml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.clusterfuzzlite/requirements-atheris.txt +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.dockerignore +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/CODEOWNERS +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/ISSUE_TEMPLATE/bug-report.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/ISSUE_TEMPLATE/config.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/ISSUE_TEMPLATE/feature-request.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/dependabot.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/ci.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/codeql.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/dependabot-uv-lock.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/fuzz.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/harness-smoke.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/publish.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.github/workflows/scorecard.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.gitignore +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/.pre-commit-hooks.yaml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/CONTRIBUTING.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/Dockerfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/PRODUCT.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/e2e/fixture-states.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/e2e/proof-dir.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/e2e/scrg172-states.spec.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/e2e/static-server.mjs +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/index.html +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/playwright.config.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/pnpm-lock.yaml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/public/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/public/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/public/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/public/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/public/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/public/favicon.ico +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/app-detail-phase11.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/app-detail-workspace.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/app-routing.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/app.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-center-layout.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-center-layout.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-center-mobile.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-center-primitives.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-center-review-cards.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-center-utils.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-gate-utils.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-gate.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-scopes.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/approval-scopes.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/apps/app-catalog.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/apps/app-detail-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/audit-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/clear-policy-payload.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/clear-policy-payload.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/compare-time-periods.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/data-flow-evidence-card.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/error-boundary.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/app-tab.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/categories.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/category-tab.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-action-detail.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-action-list.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-analytics-panel.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-clear-modal.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-copy.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-detail.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-export-drawer.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-export.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-export.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-filter-bar.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-filters.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-filters.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-insight-strip.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-metrics.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-metrics.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-pagination.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-pagination.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-perf.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-period.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-sort.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-sort.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-story.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-types.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-url-state.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-url-state.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/evidence-view-shell.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/explore-tab.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/index.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/plain-english.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/evidence/story-tab.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/feed-health-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/fleet-workspace-phase11.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/fleet-workspace.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/fleet-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/guard-api.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/guard-api.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/guard-demo.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/guard-types.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/help-modal.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/history-analytics.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/history-charts.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/history-export.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/home-dashboard.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/home-dashboard.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/home-protection-module.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/main.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/phase09-review.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/policy-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/queue-chip-filter.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/queue-state.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/queue-state.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/receipts-workspace.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/receipts-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/review-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/risk-signal-cards.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/risk-signal-cards.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/runtime-overview.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/runtime-overview.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/scanner-evidence-badge.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/scrg159-170.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/scrg171-172.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/security-fixes.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/settings-workspace-phase11.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/settings-workspace.test.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/settings-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/styles.css +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/supply-chain-workspace.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/totp-enrollment-qr-panel.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/use-debounce.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/use-focus-trap.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/use-keyboard-shortcut.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/use-reduced-motion.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/use-route-focus.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/vite-env.d.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/src/watched-app-card.tsx +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/tsconfig.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/dashboard/vite.config.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docker-requirements.txt +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/architecture.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/get-started.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/harness-support.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/incident-response.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/local-vs-cloud.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/release-checklist.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/remediation.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/smoke-tests.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/guard/testing-matrix.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/trust/mcp-trust-draft.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/trust/plugin-trust-draft.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/docs/trust/skill-trust-local.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/fuzzers/manifest_fuzzer.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/requirements.txt +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/schemas/plugin-quality.v1.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/schemas/scan-result.v1.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/schemas/verify-result.v1.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/scripts/codex-auto-resume-smoke.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/action_runner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/argparse_utils.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/best_practices.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/claude.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/code_quality.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/ecosystem_common.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/gemini.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/manifest.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/manifest_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/marketplace.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/mcp_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/opencode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/operational_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/checks/skill_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/cli.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/cli_ui.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/config.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/base.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/claude.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/codex.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/detect.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/gemini.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/opencode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/registry.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/ecosystems/types.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/github_reporting.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/access_graph_events.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/antigravity.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/base.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/claude_code.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/cloud_identity.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/contracts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/copilot.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/cursor.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/gemini.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/hermes.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/openclaw.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/openclaw_config.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/openclaw_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/opencode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/opencode_artifacts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/advisory_model.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/approval_gate.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/approval_gate_state.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/approvals.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/bridge/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/capabilities.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/approval_commands.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/approval_gate_prompt.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/bootstrap.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/commands.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/connect_flow.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/docs.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/install_commands.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/product.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/prompt.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/cli/render.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/codex_app_server.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/codex_config.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/codex_resume.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/config.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/consumer/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/consumer/service.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/client.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/manager.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-catalog.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-detail-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/audit-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/feed-health-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/fleet-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/help-modal.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/home-dashboard.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/policy-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/runtime-overview.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/settings-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/supply-chain-workspace.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/use-focus-trap.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/guard-dashboard.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/assets/index.css +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/favicon.ico +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/static/index.html +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/desktop_notifications.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/edge_events.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/harness_usage.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/incident.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/insights.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/inventory_cisco.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/inventory_contract.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/launcher.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/local_supply_chain.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/mcp_tool_calls.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/models.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/policy/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/policy/engine.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/product_model.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/protect.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/provenance.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/proxy/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/proxy/remote.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/proxy/runtime_mcp.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/proxy/stdio.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/receipts/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/receipts/manager.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/redaction.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/risk.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/action_identity.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/actions.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/advisory_escalation.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/advisory_matchers.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/cisco_evidence.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/cisco_preflight.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/composition_rules.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/data_flow.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/data_flow_rules.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/data_flow_variables.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/decisions.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/detectors.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/false_positive_rules.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/js_semver.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/mcp_protection.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/package_intent.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/package_intent_common.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/package_intent_parser.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/package_manifest_diff.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/persistence_rules.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/prompt_injection.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/runner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/safe_decode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/sandbox.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/scanner_cache.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/secret_file_requests.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/secret_sensitivity.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/secret_sources.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/sed_scripts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/shell_commands.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/signals.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/skill_protection.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_base.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_models.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_runtime.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain_package_eval.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/supply_chain_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/surface_server.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/temp_files.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/runtime/threat_intel.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/schemas/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/schemas/consumer_mode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/schemas/guard_event_v1.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/schemas/guard_product_model_v1.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/schemas/surface_server.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/shims.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store_approvals.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store_connect.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store_evidence.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store_resume.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store_supply_chain.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/store_threat_intel.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/totp.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/types.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/integrations/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/integrations/cisco_mcp_scanner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/integrations/cisco_skill_scanner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/lint_fixes.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/marketplace_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/models.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/path_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/policy.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/quality_artifact.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/repo_detect.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/reporting.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/rules/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/rules/registry.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/rules/specs.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/scanner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/submission.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/suppressions.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_domain_scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_helpers.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_mcp_scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_models.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_plugin_scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_skill_scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/trust_specs.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/verification.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/conftest.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/__init__.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/bad-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/bad-plugin/.mcp.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/bad-plugin/secrets.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/claude-plugin-good/.claude-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/claude-plugin-good/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/claude-plugin-good/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/claude-plugin-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/claude-plugin-good/hooks/hooks.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/claude-plugin-good/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/code-quality-bad/evil.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/code-quality-bad/inject.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/gemini-extension-good/GEMINI.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/gemini-extension-good/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/gemini-extension-good/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/gemini-extension-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/gemini-extension-good/commands/hello.toml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/gemini-extension-good/gemini-extension.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/assets/icon.svg +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/assets/logo.svg +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/assets/screenshot.svg +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/good-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-codex-malicious-mcp/.codex/config.toml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/benign-docs-fake-token.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/benign-health-endpoint.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/benign-nvmrc-fake-creds.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/benign-source-search.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/canary-exfil-encoded.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/canary-exfil.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/expected-decisions.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-dockerfile.txt +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-encoded-shell-exfil.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-github-action.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-mcp-delete.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-mcp-secret-read.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-mcp-skill-exfil.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-npm-postinstall.js +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-prompt-env-read.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-prompt-guard-bypass.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-prompt-npmrc-read.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/malicious-python-setup.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/guard-red-team/smoke-evidence-template.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/config.yaml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/mcp_servers.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/skills/security/malicious/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/references/api-setup.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/scripts/deploy.sh +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/hermes-plugin-evil/skills/utils/benign/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malformed-json/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malicious-skill-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malicious-skill-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malicious-skill-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malicious-skill-plugin/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malicious-skill-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/malicious-skill-plugin/skills/leaky-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/mcp-canary-server.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/minimal-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/missing-fields/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/mit-license/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-ecosystem-repo/codex-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-ecosystem-repo/codex-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-ecosystem-repo/codex-plugin/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-ecosystem-repo/codex-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-ecosystem-repo/gemini-ext/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-ecosystem-repo/gemini-ext/gemini-extension.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/.agents/plugins/marketplace.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/no-version/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/opencode-good/.opencode/commands/hello.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/opencode-good/.opencode/plugins/example.ts +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/opencode-good/LICENSE +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/opencode-good/README.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/opencode-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/opencode-good/opencode.jsonc +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/skills-missing-dir/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/skills-no-frontmatter/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/skills-no-frontmatter/skills/bad-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/benign-npm-controls-package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/benign-npm-package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/benign-pnpm-package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/benign-pyproject.toml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/critical-base-image-Dockerfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/malicious-Dockerfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/malicious-action.yml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/malicious-npm-env-fs-network-package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/malicious-npm-obfuscated-package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/malicious-npm-package.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/supply-chain/malicious-setup.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/cargo-safe/Cargo.lock +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/cargo-safe/Cargo.toml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/cargo-vulnerable/Cargo.lock +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/cargo-vulnerable/Cargo.toml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/composer-safe/composer.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/composer-safe/composer.lock +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/composer-vulnerable/composer.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/composer-vulnerable/composer.lock +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/go-safe/go.mod +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/go-vulnerable/go.mod +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/gradle-safe/build.gradle +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/gradle-safe/gradle.lockfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/gradle-vulnerable/build.gradle +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/gradle-vulnerable/gradle.lockfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/maven-safe/pom.xml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/maven-vulnerable/pom.xml +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/rubygems-safe/Gemfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/rubygems-safe/Gemfile.lock +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile.lock +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/with-marketplace/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/with-marketplace/marketplace-broken.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/fixtures/with-marketplace/marketplace.json +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/guard_python_phase12_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/guard_tier2_phase13_support.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test-trust-scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test-trust-specs.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_action_runner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_best_practices.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_cisco_install_surfaces.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_cli.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_code_quality.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_config.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_coverage_remaining.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_cursor_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_ecosystems.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_edge_cases.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_final_coverage.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_gemini_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_access_graph.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_action_identity.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_advisory_escalation.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_continuity.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_copy_commands.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_decisions.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_gate.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_store_dedup.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_store_phase14.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approval_store_scale.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_approvals.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_bootstrap.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_bypass_detector.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_canary_fixtures.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_capabilities.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_cisco_evidence.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_cisco_runtime_cli.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_claude_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_cloud_local_sync.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_codex_auto_resume_smoke.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_codex_e2e.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_codex_proxy.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_codex_resume_commands.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_codex_resume_endpoints.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_config_paths.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_connect_flow.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_consumer_mode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_copilot_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_copilot_proxy.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_daemon_cli.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_daemon_manager.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_daemon_perf.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_daemon_registry.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_daemon_repair_perf.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_daemon_wake.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_data_flow.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_decision_propagation.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_desktop_notifications.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_detector_fp.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_docs.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_event_schema_v1.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_events.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_evidence_api_contract.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_evidence_store.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_harness_contracts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_harness_setup.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_harness_smoke.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_hashnet_mcp_canaries.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_insights.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_inventory_cisco.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_inventory_contract.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_js_lab_phase11.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_js_lockfile_resolution_phase11.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_js_package_hook_phase11.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_js_package_intent_phase11.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_js_semver_phase11.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_js_supply_chain_phase11.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_local_supply_chain_audit_phase16.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_local_supply_chain_phase15.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_mcp_detectors.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_mcp_package_proxy_phase14.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_mcp_protection.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_opencode_proxy.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_package_hook.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_package_hook_phase14.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_package_intent.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_package_resume_phase14.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_package_shims.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase03_local_install.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase03_remainder.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase04_failure_modes.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase04_harness_contracts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase04_harness_ux.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase05_approval_memory.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_phase07_harness_coverage_matrix.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_policy_dedup.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_product_flow.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_product_model_contracts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_prompt_injection.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_protect.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_provenance.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_python_lab_phase12.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_python_package_hook_phase12.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_python_package_intent_phase12.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_python_supply_chain_heuristics_phase12.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_python_supply_chain_phase12.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_queue_api_contract.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_queue_contract.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_receipt_p5_fields.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_receipt_persistence.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_red_team.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_red_team_e2e.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_redaction.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_registry_broker_skills_canaries.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_render.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_resolution_copy.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_risk.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime_action_harnesses.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime_actions.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime_actions_phase14.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime_decisions.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime_detectors.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_runtime_signals.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_safe_decode.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_sandbox.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_settings_api.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_settings_presets.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_shim_truth.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_skill_protection.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_skill_protection_phase14.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_store_migrations.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_supply_chain.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_supply_chain_bundle.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_supply_chain_daemon.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_supply_chain_evaluator.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_supply_chain_sync.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_surface_server.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_threat_intel.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_tier2_labs_phase13.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_tier2_package_intent_phase13.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_tier2_supply_chain_phase13.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_verdicts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_web_recovery.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_guard_wrapper_flows.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_hermes_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_integration.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_lint_fixes.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_live_cisco_smoke.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_manifest.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_marketplace.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_mcp_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_openclaw_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_opencode_adapter.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_operational_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_policy.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_quality_artifact.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_rule_registry.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_scanner.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_schema_contracts.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_security_ops.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_skill_security.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_submission.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_trust_scoring.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_trust_specs.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_verification.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/tests/test_versioning.py +0 -0
- {plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/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.365
|
|
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.365"
|
|
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.365"
|
|
8
8
|
description = "Protect local AI harnesses with HOL Guard and run scanner checks for Codex, Claude, Cursor, Gemini, and OpenCode."
|
|
9
9
|
readme = "README.md"
|
|
10
10
|
license = "Apache-2.0"
|
{plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/adapters/codex.py
RENAMED
|
@@ -41,6 +41,80 @@ def _read_toml(path: Path) -> dict[str, object]:
|
|
|
41
41
|
return {}
|
|
42
42
|
|
|
43
43
|
|
|
44
|
+
def _artifact_from_guard_proxy_args(
|
|
45
|
+
*,
|
|
46
|
+
args: tuple[str, ...],
|
|
47
|
+
fallback_name: str,
|
|
48
|
+
fallback_scope: str,
|
|
49
|
+
fallback_config_path: Path,
|
|
50
|
+
harness: str,
|
|
51
|
+
) -> GuardArtifact | None:
|
|
52
|
+
"""Expose the wrapped server for status/review without re-wrapping it."""
|
|
53
|
+
|
|
54
|
+
parsed = _parse_guard_proxy_args(args)
|
|
55
|
+
command = parsed.get("command")
|
|
56
|
+
if command is None:
|
|
57
|
+
return None
|
|
58
|
+
name = parsed.get("server-name") or fallback_name
|
|
59
|
+
source_scope = parsed.get("source-scope") or fallback_scope
|
|
60
|
+
config_path = parsed.get("config-path") or str(fallback_config_path)
|
|
61
|
+
transport = parsed.get("transport") or "stdio"
|
|
62
|
+
server_args = tuple(parsed.get("arg", ()))
|
|
63
|
+
env_keys = tuple(sorted(parsed.get("server-env-key", ())))
|
|
64
|
+
return GuardArtifact(
|
|
65
|
+
artifact_id=f"codex:{source_scope}:{name}",
|
|
66
|
+
name=name,
|
|
67
|
+
harness=harness,
|
|
68
|
+
artifact_type="mcp_server",
|
|
69
|
+
source_scope=source_scope,
|
|
70
|
+
config_path=config_path,
|
|
71
|
+
command=command,
|
|
72
|
+
args=server_args,
|
|
73
|
+
transport=transport,
|
|
74
|
+
metadata={
|
|
75
|
+
"env": {},
|
|
76
|
+
"env_keys": list(env_keys),
|
|
77
|
+
"guard_managed_proxy": True,
|
|
78
|
+
},
|
|
79
|
+
)
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
def _parse_guard_proxy_args(args: tuple[str, ...]) -> dict[str, str | tuple[str, ...]]:
|
|
83
|
+
parsed: dict[str, str | tuple[str, ...]] = {}
|
|
84
|
+
repeated: dict[str, list[str]] = {"arg": [], "server-env-key": []}
|
|
85
|
+
index = 0
|
|
86
|
+
while index < len(args):
|
|
87
|
+
token = args[index]
|
|
88
|
+
if not token.startswith("--"):
|
|
89
|
+
index += 1
|
|
90
|
+
continue
|
|
91
|
+
key_value = token[2:]
|
|
92
|
+
if "=" in key_value:
|
|
93
|
+
key, value = key_value.split("=", 1)
|
|
94
|
+
if key in repeated:
|
|
95
|
+
repeated[key].append(value)
|
|
96
|
+
else:
|
|
97
|
+
parsed[key] = value
|
|
98
|
+
index += 1
|
|
99
|
+
continue
|
|
100
|
+
key = key_value
|
|
101
|
+
if key in repeated:
|
|
102
|
+
if index + 1 < len(args):
|
|
103
|
+
repeated[key].append(args[index + 1])
|
|
104
|
+
index += 2
|
|
105
|
+
else:
|
|
106
|
+
index += 1
|
|
107
|
+
continue
|
|
108
|
+
if index + 1 < len(args) and not args[index + 1].startswith("--"):
|
|
109
|
+
parsed[key] = args[index + 1]
|
|
110
|
+
index += 2
|
|
111
|
+
else:
|
|
112
|
+
index += 1
|
|
113
|
+
for key, values in repeated.items():
|
|
114
|
+
parsed[key] = tuple(values)
|
|
115
|
+
return parsed
|
|
116
|
+
|
|
117
|
+
|
|
44
118
|
_MANAGED_HOOK_STATUS_MESSAGE = "HOL Guard checking tool action"
|
|
45
119
|
_MANAGED_PROMPT_HOOK_STATUS_MESSAGE = "HOL Guard checking prompt"
|
|
46
120
|
_MANAGED_PERMISSION_HOOK_STATUS_MESSAGE = "HOL Guard checking Codex approval request"
|
|
@@ -480,8 +554,6 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
480
554
|
return "global"
|
|
481
555
|
|
|
482
556
|
def policy_path(self, context: HarnessContext) -> Path:
|
|
483
|
-
if context.workspace_dir is not None:
|
|
484
|
-
return context.workspace_dir / ".codex" / "config.toml"
|
|
485
557
|
return context.home_dir / ".codex" / "config.toml"
|
|
486
558
|
|
|
487
559
|
@staticmethod
|
|
@@ -524,6 +596,15 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
524
596
|
command = server_config.get("command")
|
|
525
597
|
args = tuple(str(value) for value in server_config.get("args", []) if isinstance(value, str))
|
|
526
598
|
if is_guard_proxy_command(command if isinstance(command, str) else None, args):
|
|
599
|
+
proxy_artifact = _artifact_from_guard_proxy_args(
|
|
600
|
+
args=args,
|
|
601
|
+
fallback_name=name,
|
|
602
|
+
fallback_scope=scope,
|
|
603
|
+
fallback_config_path=config_path,
|
|
604
|
+
harness=self.harness,
|
|
605
|
+
)
|
|
606
|
+
if proxy_artifact is not None:
|
|
607
|
+
artifacts.append(proxy_artifact)
|
|
527
608
|
continue
|
|
528
609
|
url = server_config.get("url")
|
|
529
610
|
env = server_config.get("env")
|
|
@@ -639,15 +720,24 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
639
720
|
features["hooks"] = True
|
|
640
721
|
hook_payload["features"] = features
|
|
641
722
|
self._install_config_hooks(hook_payload, context)
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
723
|
+
workspace_payload = (
|
|
724
|
+
read_toml_payload(context.workspace_dir / ".codex" / "config.toml")
|
|
725
|
+
if context.workspace_dir is not None
|
|
726
|
+
else {}
|
|
727
|
+
)
|
|
728
|
+
workspace_servers = workspace_payload.get("mcp_servers")
|
|
729
|
+
existing_workspace_server_names = (
|
|
730
|
+
{name for name, value in workspace_servers.items() if isinstance(name, str) and isinstance(value, dict)}
|
|
731
|
+
if isinstance(workspace_servers, dict)
|
|
732
|
+
else set()
|
|
733
|
+
)
|
|
645
734
|
for server in managed_servers:
|
|
646
735
|
if self._should_skip_workspace_override(
|
|
647
736
|
context=context,
|
|
648
737
|
server=server,
|
|
649
738
|
existing_workspace_server_names=existing_workspace_server_names,
|
|
650
739
|
):
|
|
740
|
+
mcp_servers.pop(server.name, None)
|
|
651
741
|
continue
|
|
652
742
|
mcp_servers[server.name] = self._proxy_server_entry(context, server)
|
|
653
743
|
payload["mcp_servers"] = mcp_servers
|
|
@@ -660,6 +750,11 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
660
750
|
skip_config_path=hook_config_path,
|
|
661
751
|
)
|
|
662
752
|
self._remove_managed_hooks_from_alternate_configs(context, skip_config_path=hook_config_path)
|
|
753
|
+
self._remove_managed_mcp_servers_from_alternate_configs(
|
|
754
|
+
context,
|
|
755
|
+
managed_servers=managed_servers,
|
|
756
|
+
skip_config_path=target_config_path,
|
|
757
|
+
)
|
|
663
758
|
hooks_path = self._remove_json_hook_files(context, payloads=hook_payloads)
|
|
664
759
|
shell_guard_paths = self._install_shell_guards(context)
|
|
665
760
|
shim_manifest = install_guard_shim(self.harness, context)
|
|
@@ -694,6 +789,11 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
694
789
|
backup_path.unlink()
|
|
695
790
|
hooks_path = self._remove_hooks(context)
|
|
696
791
|
self._remove_managed_hooks_from_alternate_configs(context, skip_config_path=target_config_path)
|
|
792
|
+
self._remove_managed_mcp_servers_from_alternate_configs(
|
|
793
|
+
context,
|
|
794
|
+
managed_servers=(),
|
|
795
|
+
skip_config_path=target_config_path,
|
|
796
|
+
)
|
|
697
797
|
self._uninstall_shell_guard(context)
|
|
698
798
|
shim_manifest = remove_guard_shim(self.harness, context)
|
|
699
799
|
return {
|
|
@@ -730,8 +830,6 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
730
830
|
|
|
731
831
|
@staticmethod
|
|
732
832
|
def _target_config_path(context: HarnessContext) -> Path:
|
|
733
|
-
if context.workspace_dir is not None:
|
|
734
|
-
return context.workspace_dir / ".codex" / "config.toml"
|
|
735
833
|
return context.home_dir / ".codex" / "config.toml"
|
|
736
834
|
|
|
737
835
|
@staticmethod
|
|
@@ -809,6 +907,15 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
809
907
|
config_payload = read_toml_payload(config_path)
|
|
810
908
|
hooks = config_payload.get("hooks")
|
|
811
909
|
if not isinstance(hooks, dict):
|
|
910
|
+
features = config_payload.get("features")
|
|
911
|
+
if isinstance(features, dict):
|
|
912
|
+
features.pop("hooks", None)
|
|
913
|
+
features.pop("codex_hooks", None)
|
|
914
|
+
if features:
|
|
915
|
+
config_payload["features"] = features
|
|
916
|
+
else:
|
|
917
|
+
config_payload.pop("features", None)
|
|
918
|
+
write_toml_payload(config_path, config_payload)
|
|
812
919
|
continue
|
|
813
920
|
cleaned_hooks, managed_removed = _remove_managed_hook_events(hooks)
|
|
814
921
|
if not managed_removed:
|
|
@@ -817,6 +924,53 @@ class CodexHarnessAdapter(HarnessAdapter):
|
|
|
817
924
|
config_payload["hooks"] = cleaned_hooks
|
|
818
925
|
else:
|
|
819
926
|
config_payload.pop("hooks", None)
|
|
927
|
+
features = config_payload.get("features")
|
|
928
|
+
if isinstance(features, dict):
|
|
929
|
+
features.pop("hooks", None)
|
|
930
|
+
features.pop("codex_hooks", None)
|
|
931
|
+
if not features:
|
|
932
|
+
config_payload.pop("features", None)
|
|
933
|
+
write_toml_payload(config_path, config_payload)
|
|
934
|
+
|
|
935
|
+
def _remove_managed_mcp_servers_from_alternate_configs(
|
|
936
|
+
self,
|
|
937
|
+
context: HarnessContext,
|
|
938
|
+
*,
|
|
939
|
+
managed_servers: tuple[ManagedMcpServer, ...],
|
|
940
|
+
skip_config_path: Path,
|
|
941
|
+
) -> None:
|
|
942
|
+
managed_names_by_path: dict[Path, set[str]] = {}
|
|
943
|
+
for server in managed_servers:
|
|
944
|
+
managed_names_by_path.setdefault(Path(server.config_path), set()).add(server.name)
|
|
945
|
+
for config_path, _hooks_path in self._config_hook_pairs(context):
|
|
946
|
+
if config_path == skip_config_path or not config_path.is_file():
|
|
947
|
+
continue
|
|
948
|
+
config_payload = read_toml_payload(config_path)
|
|
949
|
+
mcp_servers = config_payload.get("mcp_servers")
|
|
950
|
+
if not isinstance(mcp_servers, dict):
|
|
951
|
+
continue
|
|
952
|
+
names = managed_names_by_path.get(config_path, set())
|
|
953
|
+
changed = False
|
|
954
|
+
cleaned_servers: dict[str, object] = {}
|
|
955
|
+
for name, server_config in mcp_servers.items():
|
|
956
|
+
if (
|
|
957
|
+
isinstance(name, str)
|
|
958
|
+
and name in names
|
|
959
|
+
and isinstance(server_config, dict)
|
|
960
|
+
and not is_guard_proxy_command(
|
|
961
|
+
server_config.get("command") if isinstance(server_config.get("command"), str) else None,
|
|
962
|
+
tuple(str(value) for value in server_config.get("args", []) if isinstance(value, str)),
|
|
963
|
+
)
|
|
964
|
+
):
|
|
965
|
+
changed = True
|
|
966
|
+
continue
|
|
967
|
+
cleaned_servers[name] = server_config
|
|
968
|
+
if not changed:
|
|
969
|
+
continue
|
|
970
|
+
if cleaned_servers:
|
|
971
|
+
config_payload["mcp_servers"] = cleaned_servers
|
|
972
|
+
else:
|
|
973
|
+
config_payload.pop("mcp_servers", None)
|
|
820
974
|
write_toml_payload(config_path, config_payload)
|
|
821
975
|
|
|
822
976
|
def _remove_json_hook_files(
|
|
@@ -157,6 +157,8 @@ def proxy_process_env(server_env: dict[str, str]) -> dict[str, str]:
|
|
|
157
157
|
def _managed_stdio_server(artifact: GuardArtifact) -> ManagedMcpServer | None:
|
|
158
158
|
if artifact.artifact_type != "mcp_server":
|
|
159
159
|
return None
|
|
160
|
+
if _bool_metadata(artifact.metadata.get("guard_managed_proxy"), default=False):
|
|
161
|
+
return None
|
|
160
162
|
if artifact.command is None or not artifact.name.strip():
|
|
161
163
|
return None
|
|
162
164
|
if is_guard_proxy_command(artifact.command, artifact.args):
|
|
@@ -418,9 +418,9 @@ def _codex_backup_repair_target(context: HarnessContext) -> tuple[HarnessContext
|
|
|
418
418
|
|
|
419
419
|
|
|
420
420
|
def _codex_backup_repair_contexts(context: HarnessContext) -> tuple[HarnessContext, ...]:
|
|
421
|
-
contexts: list[HarnessContext] = [context]
|
|
422
421
|
if context.workspace_dir is not None:
|
|
423
|
-
return
|
|
422
|
+
return (context,)
|
|
423
|
+
contexts: list[HarnessContext] = []
|
|
424
424
|
home_dir = context.home_dir.resolve()
|
|
425
425
|
seen_workspaces: set[Path] = set()
|
|
426
426
|
current_dir = Path.cwd().resolve()
|
|
@@ -435,6 +435,7 @@ def _codex_backup_repair_contexts(context: HarnessContext) -> tuple[HarnessConte
|
|
|
435
435
|
guard_home=context.guard_home,
|
|
436
436
|
)
|
|
437
437
|
)
|
|
438
|
+
contexts.append(context)
|
|
438
439
|
return tuple(contexts)
|
|
439
440
|
|
|
440
441
|
|
{plugin_scanner-2.0.363 → plugin_scanner-2.0.365}/src/codex_plugin_scanner/guard/daemon/server.py
RENAMED
|
@@ -106,6 +106,13 @@ from .manager import (
|
|
|
106
106
|
write_guard_daemon_state,
|
|
107
107
|
)
|
|
108
108
|
|
|
109
|
+
_HEADLESS_CLOUD_SYNC_STATE_LOCK = threading.Lock()
|
|
110
|
+
_HEADLESS_CLOUD_SYNC_IN_FLIGHT: set[str] = set()
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
def _headless_cloud_sync_store_key(store: GuardStore) -> str:
|
|
114
|
+
return str(store.guard_home.expanduser().resolve())
|
|
115
|
+
|
|
109
116
|
|
|
110
117
|
def _build_snapshot_payload(context: HarnessContext) -> dict[str, object]:
|
|
111
118
|
"""Return a lightweight snapshot dict including package manager shim coverage."""
|
|
@@ -363,9 +370,24 @@ def _queue_headless_cloud_sync(
|
|
|
363
370
|
"status": "not_configured",
|
|
364
371
|
"message": "Guard Cloud sync is not paired on this machine.",
|
|
365
372
|
}
|
|
373
|
+
store_key = _headless_cloud_sync_store_key(store)
|
|
374
|
+
with _HEADLESS_CLOUD_SYNC_STATE_LOCK:
|
|
375
|
+
if store_key in _HEADLESS_CLOUD_SYNC_IN_FLIGHT:
|
|
376
|
+
return {
|
|
377
|
+
"status": "in_progress",
|
|
378
|
+
"message": "Guard Cloud sync already running.",
|
|
379
|
+
}
|
|
380
|
+
_HEADLESS_CLOUD_SYNC_IN_FLIGHT.add(store_key)
|
|
381
|
+
|
|
382
|
+
def _run_and_finalize() -> None:
|
|
383
|
+
try:
|
|
384
|
+
_run_headless_cloud_sync(store=store)
|
|
385
|
+
finally:
|
|
386
|
+
with _HEADLESS_CLOUD_SYNC_STATE_LOCK:
|
|
387
|
+
_HEADLESS_CLOUD_SYNC_IN_FLIGHT.discard(store_key)
|
|
388
|
+
|
|
366
389
|
threading.Thread(
|
|
367
|
-
target=
|
|
368
|
-
kwargs={"store": store},
|
|
390
|
+
target=_run_and_finalize,
|
|
369
391
|
daemon=True,
|
|
370
392
|
name="guard-headless-app-cloud-sync",
|
|
371
393
|
).start()
|
|
@@ -4042,7 +4042,7 @@ args = ["-lc", "echo hi"]
|
|
|
4042
4042
|
assert "hooks = true" in config_text
|
|
4043
4043
|
assert "codex_hooks" not in config_text
|
|
4044
4044
|
assert hooks_payload["PreToolUse"]
|
|
4045
|
-
assert
|
|
4045
|
+
assert (workspace_dir / ".codex" / "config.toml").exists() is False
|
|
4046
4046
|
|
|
4047
4047
|
def test_guard_update_repairs_malformed_codex_config(self, tmp_path, monkeypatch, capsys):
|
|
4048
4048
|
home_dir = tmp_path / "home"
|
|
@@ -4352,9 +4352,8 @@ args = ["-lc", "echo hi"]
|
|
|
4352
4352
|
assert output["status"] == "current"
|
|
4353
4353
|
assert output["managed_install"]["workspace"] == str(workspace_dir)
|
|
4354
4354
|
assert output["managed_install"]["active"] is True
|
|
4355
|
-
assert (workspace_dir / ".codex" / "config.toml").is_file()
|
|
4356
4355
|
assert _read_codex_hooks(home_dir / ".codex" / "config.toml")["PreToolUse"]
|
|
4357
|
-
assert
|
|
4356
|
+
assert (workspace_dir / ".codex" / "config.toml").exists() is False
|
|
4358
4357
|
|
|
4359
4358
|
def test_guard_doctor_warns_when_codex_native_hooks_are_missing(self, tmp_path, monkeypatch, capsys):
|
|
4360
4359
|
home_dir = tmp_path / "home"
|
|
@@ -17,6 +17,7 @@ from codex_plugin_scanner.cli import main
|
|
|
17
17
|
from codex_plugin_scanner.guard.adapters import codex as codex_adapter
|
|
18
18
|
from codex_plugin_scanner.guard.adapters.base import HarnessContext
|
|
19
19
|
from codex_plugin_scanner.guard.adapters.codex import CodexHarnessAdapter
|
|
20
|
+
from codex_plugin_scanner.guard.adapters.mcp_servers import managed_stdio_servers
|
|
20
21
|
from codex_plugin_scanner.guard.codex_config import dump_toml
|
|
21
22
|
|
|
22
23
|
|
|
@@ -72,17 +73,17 @@ def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_pa
|
|
|
72
73
|
output = json.loads(capsys.readouterr().out)
|
|
73
74
|
managed_install = output["managed_install"]
|
|
74
75
|
manifest = managed_install["manifest"]
|
|
75
|
-
config_text = (
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
workspace_config = tomllib.loads(config_text)
|
|
76
|
+
config_text = (home_dir / ".codex" / "config.toml").read_text(encoding="utf-8")
|
|
77
|
+
config_payload = tomllib.loads(config_text)
|
|
78
|
+
workspace_config = tomllib.loads((workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8"))
|
|
79
79
|
hooks_path = home_dir / ".codex" / "hooks.json"
|
|
80
80
|
hooks_payload = config_payload["hooks"]
|
|
81
81
|
|
|
82
82
|
assert rc == 0
|
|
83
83
|
assert managed_install["active"] is True
|
|
84
84
|
assert manifest["mode"] == "codex-mcp-proxy"
|
|
85
|
-
assert manifest["managed_config_path"] == str(
|
|
85
|
+
assert manifest["managed_config_path"] == str(home_dir / ".codex" / "config.toml")
|
|
86
|
+
assert manifest["managed_hook_config_path"] == str(home_dir / ".codex" / "config.toml")
|
|
86
87
|
assert manifest["managed_hooks_path"] == str(hooks_path)
|
|
87
88
|
assert manifest["managed_shell_guard_path"] == str(home_dir / "managed" / "codex" / "codex-zshenv-guard.zsh")
|
|
88
89
|
assert manifest["managed_shell_guard_paths"] == {
|
|
@@ -95,10 +96,12 @@ def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_pa
|
|
|
95
96
|
assert "--server-name" in config_text
|
|
96
97
|
assert "guard" in config_text
|
|
97
98
|
assert "codex-mcp-proxy" in config_text
|
|
98
|
-
assert "hooks = true" in
|
|
99
|
-
assert "codex_hooks" not in
|
|
99
|
+
assert "hooks = true" in config_text
|
|
100
|
+
assert "codex_hooks" not in config_text
|
|
100
101
|
assert workspace_config["approval_policy"] == "never"
|
|
102
|
+
assert "features" not in workspace_config
|
|
101
103
|
assert "hooks" not in workspace_config
|
|
104
|
+
assert "mcp_servers" not in workspace_config
|
|
102
105
|
assert hooks_path.exists() is False
|
|
103
106
|
assert (workspace_dir / ".codex" / "hooks.json").exists() is False
|
|
104
107
|
assert 'API_BASE = "https://hol.org"' in config_text
|
|
@@ -139,6 +142,43 @@ def test_guard_install_codex_rewrites_workspace_config_with_proxy_entries(tmp_pa
|
|
|
139
142
|
assert ".npmrc" in shell_guard_text
|
|
140
143
|
|
|
141
144
|
|
|
145
|
+
def test_guard_install_codex_detects_wrapped_servers_without_rewrapping(tmp_path, capsys):
|
|
146
|
+
home_dir = tmp_path / "home"
|
|
147
|
+
workspace_dir = tmp_path / "workspace"
|
|
148
|
+
_build_guard_fixture(home_dir, workspace_dir)
|
|
149
|
+
|
|
150
|
+
rc = main(
|
|
151
|
+
[
|
|
152
|
+
"guard",
|
|
153
|
+
"install",
|
|
154
|
+
"codex",
|
|
155
|
+
"--home",
|
|
156
|
+
str(home_dir),
|
|
157
|
+
"--workspace",
|
|
158
|
+
str(workspace_dir),
|
|
159
|
+
"--json",
|
|
160
|
+
]
|
|
161
|
+
)
|
|
162
|
+
json.loads(capsys.readouterr().out)
|
|
163
|
+
|
|
164
|
+
detection = CodexHarnessAdapter().detect(
|
|
165
|
+
HarnessContext(
|
|
166
|
+
home_dir=home_dir,
|
|
167
|
+
workspace_dir=workspace_dir,
|
|
168
|
+
guard_home=home_dir,
|
|
169
|
+
)
|
|
170
|
+
)
|
|
171
|
+
artifacts = {artifact.artifact_id: artifact for artifact in detection.artifacts}
|
|
172
|
+
|
|
173
|
+
assert rc == 0
|
|
174
|
+
assert "codex:global:global_tools" in artifacts
|
|
175
|
+
assert "codex:project:workspace_skill" in artifacts
|
|
176
|
+
assert artifacts["codex:project:workspace_skill"].command == "node"
|
|
177
|
+
assert artifacts["codex:project:workspace_skill"].args == ("workspace-skill.js",)
|
|
178
|
+
assert artifacts["codex:project:workspace_skill"].metadata["guard_managed_proxy"] is True
|
|
179
|
+
assert managed_stdio_servers(detection) == ()
|
|
180
|
+
|
|
181
|
+
|
|
142
182
|
def test_guard_install_codex_replaces_existing_zshenv_guard_block(tmp_path, capsys):
|
|
143
183
|
home_dir = tmp_path / "home"
|
|
144
184
|
workspace_dir = tmp_path / "workspace"
|
|
@@ -376,7 +416,7 @@ def test_guard_apps_connect_codex_defaults_to_project_scope_when_local_codex_con
|
|
|
376
416
|
assert rc == 0
|
|
377
417
|
assert output["managed_install"]["active"] is True
|
|
378
418
|
assert output["managed_install"]["workspace"] == str(workspace_dir)
|
|
379
|
-
assert output["managed_install"]["manifest"]["managed_config_path"] == str(
|
|
419
|
+
assert output["managed_install"]["manifest"]["managed_config_path"] == str(home_dir / ".codex" / "config.toml")
|
|
380
420
|
|
|
381
421
|
|
|
382
422
|
def test_guard_apps_connect_codex_stays_global_without_local_codex_config(
|
|
@@ -423,7 +463,6 @@ def test_guard_uninstall_codex_restores_original_workspace_config(tmp_path, caps
|
|
|
423
463
|
home_dir = tmp_path / "home"
|
|
424
464
|
workspace_dir = tmp_path / "workspace"
|
|
425
465
|
_build_guard_fixture(home_dir, workspace_dir)
|
|
426
|
-
original_text = (workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8")
|
|
427
466
|
|
|
428
467
|
install_rc = main(
|
|
429
468
|
[
|
|
@@ -455,7 +494,8 @@ def test_guard_uninstall_codex_restores_original_workspace_config(tmp_path, caps
|
|
|
455
494
|
assert install_rc == 0
|
|
456
495
|
assert uninstall_rc == 0
|
|
457
496
|
assert uninstall_output["managed_install"]["active"] is False
|
|
458
|
-
|
|
497
|
+
workspace_payload = tomllib.loads((workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8"))
|
|
498
|
+
assert workspace_payload == {"approval_policy": "never"}
|
|
459
499
|
assert (workspace_dir / ".codex" / "hooks.json").exists() is False
|
|
460
500
|
|
|
461
501
|
|
|
@@ -1413,7 +1453,7 @@ args = ["server.py", "--marker-path", "marker.json"]
|
|
|
1413
1453
|
]
|
|
1414
1454
|
)
|
|
1415
1455
|
json.loads(capsys.readouterr().out)
|
|
1416
|
-
config_text = (
|
|
1456
|
+
config_text = (home_dir / ".codex" / "config.toml").read_text(encoding="utf-8")
|
|
1417
1457
|
|
|
1418
1458
|
assert rc == 0
|
|
1419
1459
|
assert "--arg=--marker-path" in config_text
|
|
@@ -1423,7 +1463,6 @@ def test_guard_reinstall_codex_preserves_original_backup(tmp_path, capsys):
|
|
|
1423
1463
|
home_dir = tmp_path / "home"
|
|
1424
1464
|
workspace_dir = tmp_path / "workspace"
|
|
1425
1465
|
_build_guard_fixture(home_dir, workspace_dir)
|
|
1426
|
-
original_text = (workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8")
|
|
1427
1466
|
|
|
1428
1467
|
first_install = main(
|
|
1429
1468
|
[
|
|
@@ -1470,7 +1509,8 @@ def test_guard_reinstall_codex_preserves_original_backup(tmp_path, capsys):
|
|
|
1470
1509
|
assert second_install == 0
|
|
1471
1510
|
assert uninstall_rc == 0
|
|
1472
1511
|
assert backup_path.exists() is False
|
|
1473
|
-
|
|
1512
|
+
workspace_payload = tomllib.loads((workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8"))
|
|
1513
|
+
assert workspace_payload == {"approval_policy": "never"}
|
|
1474
1514
|
|
|
1475
1515
|
|
|
1476
1516
|
def test_guard_install_codex_preserves_inline_tables_inside_arrays(tmp_path, capsys):
|
|
@@ -1504,13 +1544,17 @@ args = ["workspace-skill.js"]
|
|
|
1504
1544
|
json.loads(capsys.readouterr().out)
|
|
1505
1545
|
|
|
1506
1546
|
with (workspace_dir / ".codex" / "config.toml").open("rb") as handle:
|
|
1507
|
-
|
|
1547
|
+
workspace_payload = tomllib.load(handle)
|
|
1548
|
+
with (home_dir / ".codex" / "config.toml").open("rb") as handle:
|
|
1549
|
+
global_payload = tomllib.load(handle)
|
|
1508
1550
|
|
|
1509
1551
|
assert rc == 0
|
|
1510
|
-
assert
|
|
1552
|
+
assert workspace_payload["profiles"] == [
|
|
1511
1553
|
{"name": "default", "mode": "safe"},
|
|
1512
1554
|
{"name": "strict", "mode": "review"},
|
|
1513
1555
|
]
|
|
1556
|
+
assert "mcp_servers" not in workspace_payload
|
|
1557
|
+
assert "workspace_skill" in global_payload["mcp_servers"]
|
|
1514
1558
|
|
|
1515
1559
|
|
|
1516
1560
|
def test_guard_reinstall_codex_refreshes_backup_after_completed_uninstall(tmp_path, capsys):
|
|
@@ -1590,7 +1634,8 @@ args = ["edited-workspace-skill.js"]
|
|
|
1590
1634
|
assert second_uninstall == 0
|
|
1591
1635
|
assert backup_path == Path(second_output["managed_install"]["manifest"]["backup_path"])
|
|
1592
1636
|
assert backup_path.exists() is False
|
|
1593
|
-
|
|
1637
|
+
workspace_payload = tomllib.loads((workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8"))
|
|
1638
|
+
assert workspace_payload == {"approval_policy": "never"}
|
|
1594
1639
|
|
|
1595
1640
|
|
|
1596
1641
|
def test_guard_install_codex_proxy_entry_boots_outside_dev_shell_when_pythonpath_is_required(
|
|
@@ -1627,7 +1672,7 @@ args = [{str(canary_path)!r}, "--marker-path", {str(marker_path)!r}]
|
|
|
1627
1672
|
)
|
|
1628
1673
|
json.loads(capsys.readouterr().out)
|
|
1629
1674
|
|
|
1630
|
-
with (
|
|
1675
|
+
with (home_dir / ".codex" / "config.toml").open("rb") as handle:
|
|
1631
1676
|
payload = tomllib.load(handle)
|
|
1632
1677
|
proxy_entry = payload["mcp_servers"]["danger_lab"]
|
|
1633
1678
|
proxy_env = dict(proxy_entry.get("env", {}))
|
|
@@ -1682,7 +1727,7 @@ env = { PYTHONPATH = "app/src", API_BASE = "https://hol.org" }
|
|
|
1682
1727
|
)
|
|
1683
1728
|
json.loads(capsys.readouterr().out)
|
|
1684
1729
|
|
|
1685
|
-
with (
|
|
1730
|
+
with (home_dir / ".codex" / "config.toml").open("rb") as handle:
|
|
1686
1731
|
payload = tomllib.load(handle)
|
|
1687
1732
|
proxy_env = payload["mcp_servers"]["danger_lab"]["env"]
|
|
1688
1733
|
|
|
@@ -1722,7 +1767,7 @@ env = { PYTHONPATH = "" }
|
|
|
1722
1767
|
)
|
|
1723
1768
|
json.loads(capsys.readouterr().out)
|
|
1724
1769
|
|
|
1725
|
-
with (
|
|
1770
|
+
with (home_dir / ".codex" / "config.toml").open("rb") as handle:
|
|
1726
1771
|
payload = tomllib.load(handle)
|
|
1727
1772
|
proxy_env = payload["mcp_servers"]["danger_lab"]["env"]
|
|
1728
1773
|
|
|
@@ -734,6 +734,79 @@ def test_headless_app_scan_syncs_receipt_to_cloud_when_connected(
|
|
|
734
734
|
assert sync_calls == [True]
|
|
735
735
|
|
|
736
736
|
|
|
737
|
+
def test_headless_app_scan_does_not_spawn_unbounded_cloud_sync_threads(
|
|
738
|
+
tmp_path: Path,
|
|
739
|
+
monkeypatch: pytest.MonkeyPatch,
|
|
740
|
+
) -> None:
|
|
741
|
+
store = GuardStore(tmp_path / "guard-home")
|
|
742
|
+
store.set_sync_credentials(
|
|
743
|
+
"https://hol.org/api/guard/receipts/sync",
|
|
744
|
+
"cloud-token",
|
|
745
|
+
"2026-05-23T17:18:00.000Z",
|
|
746
|
+
workspace_id="workspace-1",
|
|
747
|
+
)
|
|
748
|
+
sync_calls: list[int] = []
|
|
749
|
+
sync_started = threading.Event()
|
|
750
|
+
sync_release = threading.Event()
|
|
751
|
+
|
|
752
|
+
def blocking_sync_receipts(current_store: GuardStore) -> dict[str, object]:
|
|
753
|
+
assert current_store is store
|
|
754
|
+
sync_calls.append(1)
|
|
755
|
+
sync_started.set()
|
|
756
|
+
sync_release.wait(timeout=5)
|
|
757
|
+
return {
|
|
758
|
+
"synced_at": "2026-05-23T17:18:40.061Z",
|
|
759
|
+
"receipts_stored": 1,
|
|
760
|
+
}
|
|
761
|
+
|
|
762
|
+
monkeypatch.setattr(daemon_server, "sync_receipts", blocking_sync_receipts, raising=False)
|
|
763
|
+
|
|
764
|
+
daemon = GuardDaemonServer(store, host="127.0.0.1", port=0)
|
|
765
|
+
daemon.start()
|
|
766
|
+
try:
|
|
767
|
+
token = _dashboard_token_for(store)
|
|
768
|
+
first_status, first_payload = _read_json_response(
|
|
769
|
+
_request(
|
|
770
|
+
daemon.port,
|
|
771
|
+
"/v1/apps/test",
|
|
772
|
+
token=token,
|
|
773
|
+
payload={
|
|
774
|
+
"harness": "opencode",
|
|
775
|
+
"operation": "scan",
|
|
776
|
+
"workspace_id": "workspace-1",
|
|
777
|
+
},
|
|
778
|
+
),
|
|
779
|
+
)
|
|
780
|
+
assert sync_started.wait(timeout=2)
|
|
781
|
+
second_status, second_payload = _read_json_response(
|
|
782
|
+
_request(
|
|
783
|
+
daemon.port,
|
|
784
|
+
"/v1/apps/test",
|
|
785
|
+
token=token,
|
|
786
|
+
payload={
|
|
787
|
+
"harness": "opencode",
|
|
788
|
+
"operation": "scan",
|
|
789
|
+
"workspace_id": "workspace-1",
|
|
790
|
+
},
|
|
791
|
+
),
|
|
792
|
+
)
|
|
793
|
+
finally:
|
|
794
|
+
sync_release.set()
|
|
795
|
+
daemon.stop()
|
|
796
|
+
|
|
797
|
+
assert first_status == 200
|
|
798
|
+
assert first_payload["cloud_sync"] == {
|
|
799
|
+
"status": "queued",
|
|
800
|
+
"message": "Guard Cloud sync started.",
|
|
801
|
+
}
|
|
802
|
+
assert second_status == 200
|
|
803
|
+
assert second_payload["cloud_sync"] == {
|
|
804
|
+
"status": "in_progress",
|
|
805
|
+
"message": "Guard Cloud sync already running.",
|
|
806
|
+
}
|
|
807
|
+
assert len(sync_calls) == 1
|
|
808
|
+
|
|
809
|
+
|
|
737
810
|
def test_headless_policy_sync_persists_policy_and_receipt(tmp_path: Path) -> None:
|
|
738
811
|
store = GuardStore(tmp_path / "guard-home")
|
|
739
812
|
daemon = GuardDaemonServer(store, host="127.0.0.1", port=0)
|
|
@@ -675,13 +675,15 @@ url = "https://workspace.example/mcp"
|
|
|
675
675
|
]
|
|
676
676
|
)
|
|
677
677
|
json.loads(capsys.readouterr().out)
|
|
678
|
-
with (
|
|
678
|
+
with (home_dir / ".codex" / "config.toml").open("rb") as handle:
|
|
679
679
|
payload = tomllib.load(handle)
|
|
680
|
-
|
|
680
|
+
global_servers = payload["mcp_servers"]
|
|
681
|
+
workspace_payload = tomllib.loads((workspace_dir / ".codex" / "config.toml").read_text(encoding="utf-8"))
|
|
681
682
|
|
|
682
683
|
assert rc == 0
|
|
683
|
-
assert
|
|
684
|
-
assert
|
|
684
|
+
assert workspace_payload["mcp_servers"]["shared"]["url"] == "https://workspace.example/mcp"
|
|
685
|
+
assert "shared" not in global_servers
|
|
686
|
+
assert global_servers["global_only"]["command"] == os.sys.executable
|
|
685
687
|
|
|
686
688
|
|
|
687
689
|
def test_guard_run_launches_hermes_with_guard_overlay_paths(monkeypatch, tmp_path, capsys):
|
|
File without changes
|
|
File without changes
|