plugin-scanner 2.0.78__tar.gz → 2.0.80__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.78 → plugin_scanner-2.0.80}/PKG-INFO +1 -1
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/receipts-workspace.tsx +22 -19
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/pyproject.toml +1 -1
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/pyproject.toml.bak +1 -1
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/codex.py +36 -12
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/commands.py +622 -10
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/assets/guard-dashboard.js +3 -3
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/store.py +34 -2
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/version.py +1 -1
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_codex_install.py +81 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_runtime.py +1249 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.clusterfuzzlite/Dockerfile +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.clusterfuzzlite/build.sh +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.clusterfuzzlite/project.yaml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.clusterfuzzlite/requirements-atheris.txt +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.dockerignore +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/CODEOWNERS +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/ISSUE_TEMPLATE/bug-report.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/ISSUE_TEMPLATE/config.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/ISSUE_TEMPLATE/feature-request.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/dependabot.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/ci.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/codeql.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/dependabot-uv-lock.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/fuzz.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/harness-smoke.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/publish.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.github/workflows/scorecard.yml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.gitignore +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/.pre-commit-hooks.yaml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/CONTRIBUTING.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/Dockerfile +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/index.html +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/package.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/pnpm-lock.yaml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/public/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/public/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/public/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/public/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/public/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/public/favicon.ico +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/app.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/approval-center-layout.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/approval-center-primitives.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/approval-center-utils.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/fleet-workspace.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/guard-api.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/guard-demo.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/guard-types.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/main.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/runtime-overview.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/settings-workspace.tsx +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/styles.css +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/src/vite-env.d.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/tsconfig.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/dashboard/vite.config.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docker-requirements.txt +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/guard/approval-audit.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/guard/architecture.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/guard/get-started.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/guard/harness-support.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/guard/local-vs-cloud.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/guard/testing-matrix.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/trust/mcp-trust-draft.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/trust/plugin-trust-draft.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/docs/trust/skill-trust-local.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/fuzzers/manifest_fuzzer.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/requirements.txt +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/schemas/plugin-quality.v1.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/schemas/scan-result.v1.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/schemas/verify-result.v1.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/action_runner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/argparse_utils.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/best_practices.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/claude.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/code_quality.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/ecosystem_common.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/gemini.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/manifest.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/manifest_support.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/marketplace.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/mcp_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/opencode.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/operational_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/checks/skill_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/cli.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/cli_ui.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/config.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/base.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/claude.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/codex.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/detect.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/gemini.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/opencode.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/registry.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/ecosystems/types.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/github_reporting.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/antigravity.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/base.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/claude_code.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/copilot.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/cursor.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/gemini.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/hermes.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/mcp_servers.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/opencode.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/opencode_artifacts.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/advisory_model.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/approvals.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/bridge/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/capabilities.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/approval_commands.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/bootstrap.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/connect_flow.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/install_commands.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/product.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/prompt.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/render.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/cli/update_commands.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/codex_config.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/config.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/consumer/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/consumer/service.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/client.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/manager.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/server.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/apple-touch-icon.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/assets/index.css +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Icon_Dark.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Whole.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/favicon-16x16.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/favicon-32x32.png +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/favicon.ico +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/daemon/static/index.html +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/edge_events.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/incident.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/launcher.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/mcp_tool_calls.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/models.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/policy/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/policy/engine.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/protect.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/proxy/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/proxy/remote.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/proxy/runtime_mcp.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/proxy/stdio.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/receipts/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/receipts/manager.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/redaction.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/risk.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/runtime/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/runtime/runner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/runtime/secret_file_requests.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/runtime/surface_server.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/schemas/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/schemas/consumer_mode.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/schemas/guard_event_v1.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/schemas/surface_server.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/shims.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/store_approvals.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/store_connect.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/types.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/integrations/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/integrations/cisco_mcp_scanner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/integrations/cisco_skill_scanner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/lint_fixes.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/marketplace_support.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/models.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/path_support.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/policy.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/quality_artifact.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/repo_detect.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/reporting.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/rules/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/rules/registry.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/rules/specs.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/scanner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/submission.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/suppressions.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_domain_scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_helpers.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_mcp_scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_models.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_plugin_scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_skill_scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/trust_specs.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/verification.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/conftest.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/__init__.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/bad-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/bad-plugin/.mcp.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/bad-plugin/secrets.js +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/claude-plugin-good/.claude-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/claude-plugin-good/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/claude-plugin-good/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/claude-plugin-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/claude-plugin-good/hooks/hooks.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/claude-plugin-good/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/code-quality-bad/evil.js +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/code-quality-bad/inject.js +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/gemini-extension-good/GEMINI.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/gemini-extension-good/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/gemini-extension-good/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/gemini-extension-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/gemini-extension-good/commands/hello.toml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/gemini-extension-good/gemini-extension.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/assets/icon.svg +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/assets/logo.svg +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/assets/screenshot.svg +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/good-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/guard-codex-malicious-mcp/.codex/config.toml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/config.yaml +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/mcp_servers.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/skills/security/malicious/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/references/api-setup.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/scripts/deploy.sh +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/hermes-plugin-evil/skills/utils/benign/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malformed-json/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malicious-skill-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malicious-skill-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malicious-skill-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malicious-skill-plugin/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malicious-skill-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/malicious-skill-plugin/skills/leaky-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/mcp-canary-server.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/minimal-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/missing-fields/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/mit-license/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-ecosystem-repo/codex-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-ecosystem-repo/codex-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-ecosystem-repo/codex-plugin/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-ecosystem-repo/codex-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-ecosystem-repo/gemini-ext/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-ecosystem-repo/gemini-ext/gemini-extension.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/.agents/plugins/marketplace.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codexignore +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/skills/example/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/no-version/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/opencode-good/.opencode/commands/hello.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/opencode-good/.opencode/plugins/example.ts +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/opencode-good/LICENSE +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/opencode-good/README.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/opencode-good/SECURITY.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/opencode-good/opencode.jsonc +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/skills-missing-dir/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/skills-no-frontmatter/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/skills-no-frontmatter/skills/bad-skill/SKILL.md +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/with-marketplace/.codex-plugin/plugin.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/with-marketplace/marketplace-broken.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/fixtures/with-marketplace/marketplace.json +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test-trust-scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test-trust-specs.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_action_runner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_best_practices.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_cisco_install_surfaces.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_cli.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_code_quality.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_config.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_coverage_remaining.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_ecosystems.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_edge_cases.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_final_coverage.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_approvals.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_bootstrap.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_capabilities.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_claude_adapter.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_cli.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_codex_e2e.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_codex_proxy.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_config_paths.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_connect_flow.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_consumer_mode.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_copilot_adapter.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_copilot_proxy.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_daemon_manager.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_event_schema_v1.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_events.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_launch_env.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_opencode_proxy.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_product_flow.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_protect.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_render.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_risk.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_store_migrations.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_surface_server.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_guard_verdicts.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_hermes_adapter.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_integration.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_lint_fixes.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_live_cisco_smoke.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_manifest.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_marketplace.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_mcp_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_operational_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_policy.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_quality_artifact.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_rule_registry.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_scanner.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_schema_contracts.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_security_ops.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_skill_security.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_submission.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_trust_scoring.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_trust_specs.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_verification.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/tests/test_versioning.py +0 -0
- {plugin_scanner-2.0.78 → plugin_scanner-2.0.80}/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.80
|
|
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/ai-plugin-scanner
|
|
6
6
|
Project-URL: Repository, https://github.com/hashgraph-online/ai-plugin-scanner
|
|
@@ -19,14 +19,32 @@ type ReceiptsState =
|
|
|
19
19
|
| { kind: "ready"; items: GuardReceipt[] };
|
|
20
20
|
|
|
21
21
|
const receiptPageSize = 8;
|
|
22
|
-
const EMPTY_RECEIPTS: GuardReceipt[] = [];
|
|
23
22
|
|
|
24
23
|
export function ReceiptsWorkspace(props: { receipts: ReceiptsState }) {
|
|
24
|
+
if (props.receipts.kind === "loading") {
|
|
25
|
+
return (
|
|
26
|
+
<div className="space-y-4">
|
|
27
|
+
<div className="guard-skeleton h-8 w-64" />
|
|
28
|
+
<div className="guard-skeleton h-32 w-full" />
|
|
29
|
+
</div>
|
|
30
|
+
);
|
|
31
|
+
}
|
|
32
|
+
if (props.receipts.kind === "error") {
|
|
33
|
+
return (
|
|
34
|
+
<Surface tone="danger">
|
|
35
|
+
<p className="text-sm text-brand-purple">{props.receipts.message}</p>
|
|
36
|
+
</Surface>
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
return <ReadyReceiptsWorkspace receiptItems={props.receipts.items} />;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function ReadyReceiptsWorkspace(props: { receiptItems: GuardReceipt[] }) {
|
|
25
43
|
const [searchTerm, setSearchTerm] = useState("");
|
|
26
44
|
const [harnessFilter, setHarnessFilter] = useState("all");
|
|
27
45
|
const [decisionFilter, setDecisionFilter] = useState("all");
|
|
28
46
|
const [page, setPage] = useState(1);
|
|
29
|
-
const receiptCount = props.
|
|
47
|
+
const receiptCount = props.receiptItems.length;
|
|
30
48
|
|
|
31
49
|
const handleSearchChange = useCallback((event: ChangeEvent<HTMLInputElement>) => {
|
|
32
50
|
setSearchTerm(event.target.value);
|
|
@@ -48,7 +66,7 @@ export function ReceiptsWorkspace(props: { receipts: ReceiptsState }) {
|
|
|
48
66
|
setPage(1);
|
|
49
67
|
}, [decisionFilter, harnessFilter, searchTerm, receiptCount]);
|
|
50
68
|
|
|
51
|
-
const receiptItems = props.
|
|
69
|
+
const receiptItems = props.receiptItems;
|
|
52
70
|
|
|
53
71
|
const harnesses = useMemo(
|
|
54
72
|
() => Array.from(new Set(receiptItems.map((receipt) => receipt.harness))).sort(),
|
|
@@ -94,21 +112,6 @@ export function ReceiptsWorkspace(props: { receipts: ReceiptsState }) {
|
|
|
94
112
|
setPage((value) => Math.min(totalPages, value + 1));
|
|
95
113
|
}, [totalPages]);
|
|
96
114
|
|
|
97
|
-
if (props.receipts.kind === "loading") {
|
|
98
|
-
return (
|
|
99
|
-
<div className="space-y-4">
|
|
100
|
-
<div className="guard-skeleton h-8 w-64" />
|
|
101
|
-
<div className="guard-skeleton h-32 w-full" />
|
|
102
|
-
</div>
|
|
103
|
-
);
|
|
104
|
-
}
|
|
105
|
-
if (props.receipts.kind === "error") {
|
|
106
|
-
return (
|
|
107
|
-
<Surface tone="danger">
|
|
108
|
-
<p className="text-sm text-brand-purple">{props.receipts.message}</p>
|
|
109
|
-
</Surface>
|
|
110
|
-
);
|
|
111
|
-
}
|
|
112
115
|
if (receiptItems.length === 0) {
|
|
113
116
|
return (
|
|
114
117
|
<EmptyState
|
|
@@ -132,7 +135,7 @@ export function ReceiptsWorkspace(props: { receipts: ReceiptsState }) {
|
|
|
132
135
|
</p>
|
|
133
136
|
</div>
|
|
134
137
|
<div className="flex flex-wrap gap-2">
|
|
135
|
-
<Badge tone="info">{props.
|
|
138
|
+
<Badge tone="info">{props.receiptItems.length} saved</Badge>
|
|
136
139
|
<Tag tone="slate">{filteredReceipts.length} shown</Tag>
|
|
137
140
|
</div>
|
|
138
141
|
</div>
|
|
@@ -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.80"
|
|
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.80"
|
|
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.78 → plugin_scanner-2.0.80}/src/codex_plugin_scanner/guard/adapters/codex.py
RENAMED
|
@@ -5,6 +5,7 @@ from __future__ import annotations
|
|
|
5
5
|
import hashlib
|
|
6
6
|
import json
|
|
7
7
|
import os
|
|
8
|
+
import re
|
|
8
9
|
import shlex
|
|
9
10
|
import sys
|
|
10
11
|
from copy import deepcopy
|
|
@@ -43,11 +44,13 @@ def _read_toml(path: Path) -> dict[str, object]:
|
|
|
43
44
|
_MANAGED_HOOK_STATUS_MESSAGE = "HOL Guard checking tool action"
|
|
44
45
|
_MANAGED_PROMPT_HOOK_STATUS_MESSAGE = "HOL Guard checking prompt"
|
|
45
46
|
_MANAGED_PERMISSION_HOOK_STATUS_MESSAGE = "HOL Guard checking Codex approval request"
|
|
47
|
+
_MANAGED_POST_TOOL_HOOK_STATUS_MESSAGE = "HOL Guard checking tool result"
|
|
46
48
|
_LEGACY_MANAGED_HOOK_STATUS_MESSAGES = {
|
|
47
49
|
"HOL Guard checking Bash command",
|
|
48
50
|
_MANAGED_HOOK_STATUS_MESSAGE,
|
|
49
51
|
_MANAGED_PROMPT_HOOK_STATUS_MESSAGE,
|
|
50
52
|
_MANAGED_PERMISSION_HOOK_STATUS_MESSAGE,
|
|
53
|
+
_MANAGED_POST_TOOL_HOOK_STATUS_MESSAGE,
|
|
51
54
|
}
|
|
52
55
|
|
|
53
56
|
|
|
@@ -113,7 +116,7 @@ def _pre_tool_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
|
113
116
|
{
|
|
114
117
|
"type": "command",
|
|
115
118
|
"command": _hook_command(context),
|
|
116
|
-
"
|
|
119
|
+
"timeout": 30,
|
|
117
120
|
"statusMessage": _MANAGED_HOOK_STATUS_MESSAGE,
|
|
118
121
|
}
|
|
119
122
|
],
|
|
@@ -126,7 +129,7 @@ def _prompt_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
|
126
129
|
{
|
|
127
130
|
"type": "command",
|
|
128
131
|
"command": _hook_command(context),
|
|
129
|
-
"
|
|
132
|
+
"timeout": 30,
|
|
130
133
|
"statusMessage": _MANAGED_PROMPT_HOOK_STATUS_MESSAGE,
|
|
131
134
|
}
|
|
132
135
|
],
|
|
@@ -140,18 +143,33 @@ def _permission_request_hook_group(context: HarnessContext) -> dict[str, object]
|
|
|
140
143
|
{
|
|
141
144
|
"type": "command",
|
|
142
145
|
"command": _hook_command(context),
|
|
143
|
-
"
|
|
146
|
+
"timeout": 30,
|
|
144
147
|
"statusMessage": _MANAGED_PERMISSION_HOOK_STATUS_MESSAGE,
|
|
145
148
|
}
|
|
146
149
|
],
|
|
147
150
|
}
|
|
148
151
|
|
|
149
152
|
|
|
153
|
+
def _post_tool_hook_group(context: HarnessContext) -> dict[str, object]:
|
|
154
|
+
return {
|
|
155
|
+
"matcher": "Bash",
|
|
156
|
+
"hooks": [
|
|
157
|
+
{
|
|
158
|
+
"type": "command",
|
|
159
|
+
"command": _hook_command(context),
|
|
160
|
+
"timeout": 30,
|
|
161
|
+
"statusMessage": _MANAGED_POST_TOOL_HOOK_STATUS_MESSAGE,
|
|
162
|
+
}
|
|
163
|
+
],
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
|
|
150
167
|
def _managed_hook_groups(context: HarnessContext) -> dict[str, dict[str, object]]:
|
|
151
168
|
return {
|
|
152
169
|
"PreToolUse": _pre_tool_hook_group(context),
|
|
153
170
|
"PermissionRequest": _permission_request_hook_group(context),
|
|
154
171
|
"UserPromptSubmit": _prompt_hook_group(context),
|
|
172
|
+
"PostToolUse": _post_tool_hook_group(context),
|
|
155
173
|
}
|
|
156
174
|
|
|
157
175
|
|
|
@@ -179,14 +197,13 @@ def _is_managed_hook_command(command: object) -> bool:
|
|
|
179
197
|
if tokens[1] != "-c":
|
|
180
198
|
return False
|
|
181
199
|
code = tokens[2]
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
and "
|
|
185
|
-
and "'
|
|
186
|
-
and "'
|
|
187
|
-
and "'--harness'" in code
|
|
188
|
-
and "'codex'" in code
|
|
200
|
+
has_guard_call = (
|
|
201
|
+
re.search(r"['\"]guard['\"]", code) is not None
|
|
202
|
+
and re.search(r"['\"]hook['\"]", code) is not None
|
|
203
|
+
and re.search(r"['\"]--harness['\"]", code) is not None
|
|
204
|
+
and re.search(r"['\"]codex['\"]", code) is not None
|
|
189
205
|
)
|
|
206
|
+
return "codex_plugin_scanner.cli" in code and "main([" in code and has_guard_call
|
|
190
207
|
|
|
191
208
|
|
|
192
209
|
def _argv_targets_codex(argv: list[str]) -> bool:
|
|
@@ -249,7 +266,7 @@ def _remove_hook_groups(groups: object) -> list[object]:
|
|
|
249
266
|
def _remove_managed_hook_events(hooks: dict[str, object]) -> tuple[dict[str, object], bool]:
|
|
250
267
|
updated_hooks = dict(hooks)
|
|
251
268
|
changed = False
|
|
252
|
-
for event_name in ("PreToolUse", "PermissionRequest", "UserPromptSubmit"):
|
|
269
|
+
for event_name in ("PreToolUse", "PermissionRequest", "UserPromptSubmit", "PostToolUse"):
|
|
253
270
|
original_groups = deepcopy(updated_hooks.get(event_name))
|
|
254
271
|
remaining = _remove_hook_groups(original_groups)
|
|
255
272
|
managed_removed = isinstance(original_groups, list) and remaining != original_groups
|
|
@@ -273,6 +290,7 @@ def codex_native_hook_state(context: HarnessContext) -> dict[str, object]:
|
|
|
273
290
|
pre_tool_groups = hooks.get("PreToolUse") if isinstance(hooks, dict) else None
|
|
274
291
|
permission_groups = hooks.get("PermissionRequest") if isinstance(hooks, dict) else None
|
|
275
292
|
prompt_groups = hooks.get("UserPromptSubmit") if isinstance(hooks, dict) else None
|
|
293
|
+
post_tool_groups = hooks.get("PostToolUse") if isinstance(hooks, dict) else None
|
|
276
294
|
pre_tool_hook_installed = isinstance(pre_tool_groups, list) and any(
|
|
277
295
|
_is_managed_hook_group(group) for group in pre_tool_groups
|
|
278
296
|
)
|
|
@@ -282,7 +300,12 @@ def codex_native_hook_state(context: HarnessContext) -> dict[str, object]:
|
|
|
282
300
|
prompt_hook_installed = isinstance(prompt_groups, list) and any(
|
|
283
301
|
_is_managed_hook_group(group) for group in prompt_groups
|
|
284
302
|
)
|
|
285
|
-
|
|
303
|
+
post_tool_hook_installed = isinstance(post_tool_groups, list) and any(
|
|
304
|
+
_is_managed_hook_group(group) for group in post_tool_groups
|
|
305
|
+
)
|
|
306
|
+
managed_hook_installed = (
|
|
307
|
+
pre_tool_hook_installed and permission_hook_installed and prompt_hook_installed and post_tool_hook_installed
|
|
308
|
+
)
|
|
286
309
|
return {
|
|
287
310
|
"config_path": str(config_path),
|
|
288
311
|
"config_present": config_path.is_file(),
|
|
@@ -292,6 +315,7 @@ def codex_native_hook_state(context: HarnessContext) -> dict[str, object]:
|
|
|
292
315
|
"managed_pre_tool_hook_installed": pre_tool_hook_installed,
|
|
293
316
|
"managed_permission_request_hook_installed": permission_hook_installed,
|
|
294
317
|
"managed_prompt_hook_installed": prompt_hook_installed,
|
|
318
|
+
"managed_post_tool_hook_installed": post_tool_hook_installed,
|
|
295
319
|
"managed_hook_installed": managed_hook_installed,
|
|
296
320
|
"protection_active": isinstance(features, dict)
|
|
297
321
|
and features.get("codex_hooks") is True
|