plugin-scanner 2.0.543__tar.gz → 2.0.544__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.
Files changed (791) hide show
  1. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/PKG-INFO +1 -1
  2. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/pyproject.toml +1 -1
  3. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/pyproject.toml.bak +1 -1
  4. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/cli.py +26 -8
  5. plugin_scanner-2.0.544/src/codex_plugin_scanner/guard/contracts/__init__.py +1 -0
  6. plugin_scanner-2.0.544/src/codex_plugin_scanner/guard/contracts/supply_chain_decision_evidence_v1.py +109 -0
  7. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/protect.py +12 -27
  8. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain_package_eval.py +80 -47
  9. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/version.py +1 -1
  10. plugin_scanner-2.0.544/tests/bundle_first_cloud.py +12 -0
  11. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_cli.py +1 -1
  12. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_local_supply_chain_phase15.py +3 -0
  13. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_mcp_package_proxy_phase14.py +3 -0
  14. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_package_hook.py +3 -0
  15. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_package_hook_phase14.py +4 -1
  16. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_package_shims.py +185 -113
  17. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_protect.py +112 -25
  18. plugin_scanner-2.0.544/tests/test_guard_supply_chain_decision_contract.py +226 -0
  19. plugin_scanner-2.0.544/tests/test_guard_supply_chain_disclosure_reasons.py +208 -0
  20. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_supply_chain_evaluator.py +91 -9
  21. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.clusterfuzzlite/Dockerfile +0 -0
  22. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.clusterfuzzlite/build.sh +0 -0
  23. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.clusterfuzzlite/project.yaml +0 -0
  24. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.clusterfuzzlite/requirements-atheris.txt +0 -0
  25. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.dockerignore +0 -0
  26. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.factory/droids/hol-guard-runner.md +0 -0
  27. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.factory/skills/hol-guard/SKILL.md +0 -0
  28. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/CODEOWNERS +0 -0
  29. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/ISSUE_TEMPLATE/bug-report.yml +0 -0
  30. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/ISSUE_TEMPLATE/config.yml +0 -0
  31. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/ISSUE_TEMPLATE/feature-request.yml +0 -0
  32. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/dependabot.yml +0 -0
  33. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/pr-bodies/claude-permission-request-visible.md +0 -0
  34. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/ci.yml +0 -0
  35. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/codeql.yml +0 -0
  36. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/dependabot-uv-lock.yml +0 -0
  37. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/fuzz.yml +0 -0
  38. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/harness-smoke.yml +0 -0
  39. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/publish.yml +0 -0
  40. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/scorecard.yml +0 -0
  41. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.github/workflows/security-gates.yml +0 -0
  42. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.gitignore +0 -0
  43. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/.pre-commit-hooks.yaml +0 -0
  44. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/CONTRIBUTING.md +0 -0
  45. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/Dockerfile +0 -0
  46. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/LICENSE +0 -0
  47. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/PRODUCT.md +0 -0
  48. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/README.md +0 -0
  49. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/SECURITY.md +0 -0
  50. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/e2e/fixture-states.ts +0 -0
  51. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/e2e/proof-dir.ts +0 -0
  52. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/e2e/scrg172-states.spec.ts +0 -0
  53. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/e2e/static-server.mjs +0 -0
  54. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/index.html +0 -0
  55. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/package.json +0 -0
  56. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/playwright.config.ts +0 -0
  57. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/pnpm-lock.yaml +0 -0
  58. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/public/apple-touch-icon.png +0 -0
  59. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/public/brand/Logo_Icon_Dark.png +0 -0
  60. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/public/brand/Logo_Whole.png +0 -0
  61. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/public/favicon-16x16.png +0 -0
  62. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/public/favicon-32x32.png +0 -0
  63. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/public/favicon.ico +0 -0
  64. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-analytics.ts +0 -0
  65. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-content.test.ts +0 -0
  66. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-content.ts +0 -0
  67. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-design.test.ts +0 -0
  68. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-external-links.test.ts +0 -0
  69. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-external-links.ts +0 -0
  70. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-types.ts +0 -0
  71. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/about-workspace.tsx +0 -0
  72. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/about-external-link.tsx +0 -0
  73. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/about-footer.tsx +0 -0
  74. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/about-hero.tsx +0 -0
  75. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/about-runtime-proof-strip.tsx +0 -0
  76. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/data-boundary-panel.tsx +0 -0
  77. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/ecosystem-programs.tsx +0 -0
  78. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/open-standards-map.tsx +0 -0
  79. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/pathway-grid.tsx +0 -0
  80. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/section-shell.tsx +0 -0
  81. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/tracked-action-button.tsx +0 -0
  82. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/about/components/trust-contract-panel.tsx +0 -0
  83. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/app-detail-phase11.test.ts +0 -0
  84. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/app-detail-workspace.test.ts +0 -0
  85. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/app-routing.test.ts +0 -0
  86. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/app.tsx +0 -0
  87. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-center-layout.test.ts +0 -0
  88. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-center-layout.tsx +0 -0
  89. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-center-mobile.test.ts +0 -0
  90. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-center-primitives.tsx +0 -0
  91. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-center-review-cards.tsx +0 -0
  92. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-center-utils.ts +0 -0
  93. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-gate-utils.ts +0 -0
  94. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-gate.test.ts +0 -0
  95. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-proof-modal.tsx +0 -0
  96. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-scopes.test.ts +0 -0
  97. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/approval-scopes.ts +0 -0
  98. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/apps/app-catalog.ts +0 -0
  99. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/apps/app-detail-workspace.tsx +0 -0
  100. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/audit-workspace.tsx +0 -0
  101. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/clear-policy-payload.test.ts +0 -0
  102. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/clear-policy-payload.ts +0 -0
  103. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/compare-time-periods.tsx +0 -0
  104. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/data-flow-evidence-card.tsx +0 -0
  105. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/error-boundary.tsx +0 -0
  106. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/app-tab.tsx +0 -0
  107. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/breakdown-card.tsx +0 -0
  108. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/categories.tsx +0 -0
  109. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/category-tab.tsx +0 -0
  110. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/decision-badge.tsx +0 -0
  111. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-action-detail.tsx +0 -0
  112. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-action-list.tsx +0 -0
  113. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-activity-heatmap-mini.tsx +0 -0
  114. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-activity-heatmap.test.ts +0 -0
  115. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-activity-heatmap.tsx +0 -0
  116. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-analytics-panel.tsx +0 -0
  117. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-clear-modal.tsx +0 -0
  118. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-copy.test.ts +0 -0
  119. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-data-provenance-strip.tsx +0 -0
  120. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-detail.test.ts +0 -0
  121. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-export-drawer.tsx +0 -0
  122. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-export.test.ts +0 -0
  123. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-export.ts +0 -0
  124. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-filter-bar.tsx +0 -0
  125. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-filters.test.ts +0 -0
  126. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-filters.ts +0 -0
  127. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-format.test.ts +0 -0
  128. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-format.ts +0 -0
  129. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-hero.tsx +0 -0
  130. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insight-strip.tsx +0 -0
  131. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-headline-bento.test.ts +0 -0
  132. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-headline-bento.tsx +0 -0
  133. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-home-preview.test.ts +0 -0
  134. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-home-preview.tsx +0 -0
  135. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-layout.test.ts +0 -0
  136. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-share-button.tsx +0 -0
  137. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-share-errors.ts +0 -0
  138. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-share-modal.tsx +0 -0
  139. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-share-sheet.tsx +0 -0
  140. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-insights-surface.tsx +0 -0
  141. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-metrics.test.ts +0 -0
  142. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-metrics.ts +0 -0
  143. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-pagination.test.ts +0 -0
  144. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-pagination.ts +0 -0
  145. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-perf.test.ts +0 -0
  146. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-period.ts +0 -0
  147. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-share-bar.tsx +0 -0
  148. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-sort.test.ts +0 -0
  149. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-sort.ts +0 -0
  150. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-story.test.ts +0 -0
  151. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-table.tsx +0 -0
  152. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-trend-chart.test.ts +0 -0
  153. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-trend-chart.tsx +0 -0
  154. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-types.ts +0 -0
  155. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-url-state.test.ts +0 -0
  156. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-url-state.ts +0 -0
  157. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/evidence-view-shell.tsx +0 -0
  158. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/explore-tab.tsx +0 -0
  159. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/guard-stat-metric.tsx +0 -0
  160. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/index.ts +0 -0
  161. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/plain-english.ts +0 -0
  162. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/scoped-evidence-table.test.ts +0 -0
  163. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/scoped-evidence-table.tsx +0 -0
  164. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/sparkline.tsx +0 -0
  165. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/story-tab.tsx +0 -0
  166. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/evidence/use-receipt-analytics.ts +0 -0
  167. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/feed-health-workspace.tsx +0 -0
  168. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/fleet-workspace-phase11.test.ts +0 -0
  169. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/fleet-workspace.test.ts +0 -0
  170. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/fleet-workspace.tsx +0 -0
  171. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-api.test.ts +0 -0
  172. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-api.ts +0 -0
  173. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-demo.ts +0 -0
  174. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-modal-layer.tsx +0 -0
  175. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-types.ts +0 -0
  176. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-update-panel.tsx +0 -0
  177. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/guard-update.test.ts +0 -0
  178. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/help-modal.tsx +0 -0
  179. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/history-analytics.tsx +0 -0
  180. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/history-charts.tsx +0 -0
  181. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/history-export.ts +0 -0
  182. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/home-dashboard.test.ts +0 -0
  183. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/home-dashboard.tsx +0 -0
  184. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/home-protection-module.tsx +0 -0
  185. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/main.tsx +0 -0
  186. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/package-firewall-connect.test.tsx +0 -0
  187. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/phase09-review.test.ts +0 -0
  188. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/policy-workspace.tsx +0 -0
  189. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/queue-chip-filter.tsx +0 -0
  190. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/queue-state.test.ts +0 -0
  191. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/queue-state.ts +0 -0
  192. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/receipts-workspace.test.ts +0 -0
  193. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/receipts-workspace.tsx +0 -0
  194. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/review-workspace.tsx +0 -0
  195. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/risk-signal-cards.test.ts +0 -0
  196. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/risk-signal-cards.tsx +0 -0
  197. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/runtime-overview.test.ts +0 -0
  198. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/runtime-overview.tsx +0 -0
  199. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/scanner-evidence-badge.tsx +0 -0
  200. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/scrg159-170.test.ts +0 -0
  201. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/scrg171-172.test.ts +0 -0
  202. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/security-fixes.test.ts +0 -0
  203. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings/settings-ia.test.ts +0 -0
  204. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings/settings-ia.tsx +0 -0
  205. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings/settings-row-primitives.tsx +0 -0
  206. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings/settings-section-shell.tsx +0 -0
  207. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings-workspace-phase11.test.ts +0 -0
  208. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings-workspace.test.ts +0 -0
  209. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/settings-workspace.tsx +0 -0
  210. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/styles.css +0 -0
  211. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/supply-chain-bundle-panel.tsx +0 -0
  212. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/supply-chain-firewall-panel.tsx +0 -0
  213. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/supply-chain-firewall-views.tsx +0 -0
  214. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/supply-chain-hub-workspace.tsx +0 -0
  215. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/supply-chain-workspace.tsx +0 -0
  216. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/totp-enrollment-qr-panel.tsx +0 -0
  217. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/use-debounce.ts +0 -0
  218. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/use-focus-trap.ts +0 -0
  219. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/use-keyboard-shortcut.ts +0 -0
  220. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/use-reduced-motion.ts +0 -0
  221. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/use-resolved-approval-gate.ts +0 -0
  222. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/use-route-focus.ts +0 -0
  223. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/vite-env.d.ts +0 -0
  224. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/watched-app-card.tsx +0 -0
  225. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/src/workspace-page-header.tsx +0 -0
  226. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/tsconfig.json +0 -0
  227. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/dashboard/vite.config.ts +0 -0
  228. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docker-requirements.txt +0 -0
  229. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/SKILL.md +0 -0
  230. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/architecture.md +0 -0
  231. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/cursor-local-cloud-contract.md +0 -0
  232. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/get-started.md +0 -0
  233. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/harness-support.md +0 -0
  234. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/incident-response.md +0 -0
  235. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/local-vs-cloud.md +0 -0
  236. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/release-checklist.md +0 -0
  237. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/remediation.md +0 -0
  238. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/guard/testing-matrix.md +0 -0
  239. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/trust/mcp-trust-draft.md +0 -0
  240. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/trust/plugin-trust-draft.md +0 -0
  241. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/docs/trust/skill-trust-local.md +0 -0
  242. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/fuzzers/manifest_fuzzer.py +0 -0
  243. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/pr-body.md +0 -0
  244. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/requirements.txt +0 -0
  245. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/schemas/plugin-quality.v1.json +0 -0
  246. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/schemas/scan-result.v1.json +0 -0
  247. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/schemas/verify-result.v1.json +0 -0
  248. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/scripts/codex-auto-resume-smoke.py +0 -0
  249. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/scripts/e2e-cursor-hook-smoke.py +0 -0
  250. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/__init__.py +0 -0
  251. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/action_runner.py +0 -0
  252. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/argparse_utils.py +0 -0
  253. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/__init__.py +0 -0
  254. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/best_practices.py +0 -0
  255. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/claude.py +0 -0
  256. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/code_quality.py +0 -0
  257. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/ecosystem_common.py +0 -0
  258. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/gemini.py +0 -0
  259. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/manifest.py +0 -0
  260. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/manifest_support.py +0 -0
  261. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/marketplace.py +0 -0
  262. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/mcp_security.py +0 -0
  263. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/opencode.py +0 -0
  264. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/operational_security.py +0 -0
  265. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/security.py +0 -0
  266. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/checks/skill_security.py +0 -0
  267. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/cli_ui.py +0 -0
  268. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/config.py +0 -0
  269. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/__init__.py +0 -0
  270. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/base.py +0 -0
  271. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/claude.py +0 -0
  272. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/codex.py +0 -0
  273. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/detect.py +0 -0
  274. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/gemini.py +0 -0
  275. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/opencode.py +0 -0
  276. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/registry.py +0 -0
  277. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/ecosystems/types.py +0 -0
  278. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/github_reporting.py +0 -0
  279. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/__init__.py +0 -0
  280. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/access_graph_events.py +0 -0
  281. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/__init__.py +0 -0
  282. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/antigravity.py +0 -0
  283. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/base.py +0 -0
  284. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/claude_code.py +0 -0
  285. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/claude_daemon_hook_bridge.py +0 -0
  286. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/cloud_identity.py +0 -0
  287. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/codex.py +0 -0
  288. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/contracts.py +0 -0
  289. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/copilot.py +0 -0
  290. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/cursor.py +0 -0
  291. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/cursor_cli.py +0 -0
  292. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/cursor_hooks.py +0 -0
  293. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/cursor_native_approval.py +0 -0
  294. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/gemini.py +0 -0
  295. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/hermes.py +0 -0
  296. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/hook_python.py +0 -0
  297. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/mcp_servers.py +0 -0
  298. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/openclaw.py +0 -0
  299. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/openclaw_config.py +0 -0
  300. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/openclaw_support.py +0 -0
  301. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/opencode.py +0 -0
  302. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/opencode_artifacts.py +0 -0
  303. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/adapters/opencode_pretool.py +0 -0
  304. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/advisory_model.py +0 -0
  305. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/approval_gate.py +0 -0
  306. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/approval_gate_state.py +0 -0
  307. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/approvals.py +0 -0
  308. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/bridge/__init__.py +0 -0
  309. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/capabilities.py +0 -0
  310. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/__init__.py +0 -0
  311. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/approval_commands.py +0 -0
  312. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/approval_gate_prompt.py +0 -0
  313. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/bootstrap.py +0 -0
  314. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/commands.py +0 -0
  315. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/connect_flow.py +0 -0
  316. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/cursor_actions.py +0 -0
  317. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/dashboard_sync.py +0 -0
  318. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/docs.py +0 -0
  319. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/install_commands.py +0 -0
  320. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/oauth_client.py +0 -0
  321. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/product.py +0 -0
  322. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/prompt.py +0 -0
  323. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/remote_pair_flow.py +0 -0
  324. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/render.py +0 -0
  325. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/cli/update_commands.py +0 -0
  326. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/codex_app_server.py +0 -0
  327. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/codex_config.py +0 -0
  328. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/codex_resume.py +0 -0
  329. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/config.py +0 -0
  330. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/consumer/__init__.py +0 -0
  331. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/consumer/service.py +0 -0
  332. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/__init__.py +0 -0
  333. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/client.py +0 -0
  334. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/dashboard_update.py +0 -0
  335. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/dashboard_update_runner.py +0 -0
  336. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/manager.py +0 -0
  337. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/server.py +0 -0
  338. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/apple-touch-icon.png +0 -0
  339. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/about-workspace.js +0 -0
  340. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-catalog.js +0 -0
  341. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/app-detail-workspace.js +0 -0
  342. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/audit-workspace.js +0 -0
  343. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/feed-health-workspace.js +0 -0
  344. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/fleet-workspace.js +0 -0
  345. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/help-modal.js +0 -0
  346. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/home-dashboard.js +0 -0
  347. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/policy-workspace.js +0 -0
  348. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/runtime-overview.js +0 -0
  349. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/settings-workspace.js +0 -0
  350. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/supply-chain-hub-workspace.js +0 -0
  351. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/supply-chain-workspace.js +0 -0
  352. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/chunks/use-resolved-approval-gate.js +0 -0
  353. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/guard-dashboard.js +0 -0
  354. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/assets/index.css +0 -0
  355. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Icon_Dark.png +0 -0
  356. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/brand/Logo_Whole.png +0 -0
  357. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/favicon-16x16.png +0 -0
  358. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/favicon-32x32.png +0 -0
  359. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/favicon.ico +0 -0
  360. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/daemon/static/index.html +0 -0
  361. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/desktop_notifications.py +0 -0
  362. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/edge_events.py +0 -0
  363. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/harness_usage.py +0 -0
  364. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/incident.py +0 -0
  365. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/insights.py +0 -0
  366. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/insights_share.py +0 -0
  367. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/inventory_cisco.py +0 -0
  368. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/inventory_contract.py +0 -0
  369. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/launcher.py +0 -0
  370. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/local_dashboard_session.py +0 -0
  371. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/local_supply_chain.py +0 -0
  372. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/mcp_tool_calls.py +0 -0
  373. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/models.py +0 -0
  374. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/package_firewall_entitlement.py +0 -0
  375. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/policy/__init__.py +0 -0
  376. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/policy/engine.py +0 -0
  377. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/policy_bundle_parser.py +0 -0
  378. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/product_model.py +0 -0
  379. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/provenance.py +0 -0
  380. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/proxy/__init__.py +0 -0
  381. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/proxy/remote.py +0 -0
  382. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/proxy/runtime_mcp.py +0 -0
  383. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/proxy/stdio.py +0 -0
  384. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/receipts/__init__.py +0 -0
  385. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/receipts/manager.py +0 -0
  386. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/redaction.py +0 -0
  387. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/remote_pairing_constants.py +0 -0
  388. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/risk.py +0 -0
  389. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/__init__.py +0 -0
  390. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/action_identity.py +0 -0
  391. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/actions.py +0 -0
  392. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/advisory_escalation.py +0 -0
  393. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/advisory_matchers.py +0 -0
  394. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/cisco_evidence.py +0 -0
  395. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/cisco_preflight.py +0 -0
  396. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/composition_rules.py +0 -0
  397. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/data_flow.py +0 -0
  398. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/data_flow_rules.py +0 -0
  399. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/data_flow_variables.py +0 -0
  400. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/decisions.py +0 -0
  401. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/detectors.py +0 -0
  402. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/false_positive_rules.py +0 -0
  403. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/harness_attribution.py +0 -0
  404. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/js_semver.py +0 -0
  405. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/mcp_protection.py +0 -0
  406. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/package_intent.py +0 -0
  407. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/package_intent_common.py +0 -0
  408. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/package_intent_parser.py +0 -0
  409. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/package_manifest_diff.py +0 -0
  410. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/persistence_rules.py +0 -0
  411. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/prompt_injection.py +0 -0
  412. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/runner.py +0 -0
  413. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/safe_decode.py +0 -0
  414. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/sandbox.py +0 -0
  415. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/scanner_cache.py +0 -0
  416. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/secret_file_requests.py +0 -0
  417. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/secret_sensitivity.py +0 -0
  418. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/secret_sources.py +0 -0
  419. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/sed_scripts.py +0 -0
  420. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/shell_commands.py +0 -0
  421. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/signals.py +0 -0
  422. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/skill_protection.py +0 -0
  423. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain.py +0 -0
  424. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle.py +0 -0
  425. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_base.py +0 -0
  426. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_models.py +0 -0
  427. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain_bundle_runtime.py +0 -0
  428. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/supply_chain_support.py +0 -0
  429. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/surface_server.py +0 -0
  430. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/temp_files.py +0 -0
  431. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/runtime/threat_intel.py +0 -0
  432. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/schemas/__init__.py +0 -0
  433. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/schemas/consumer_mode.py +0 -0
  434. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/schemas/guard_event_v1.py +0 -0
  435. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/schemas/guard_product_model_v1.json +0 -0
  436. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/schemas/surface_server.py +0 -0
  437. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/shims.py +0 -0
  438. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/stable_digest.py +0 -0
  439. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store.py +0 -0
  440. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store_approvals.py +0 -0
  441. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store_connect.py +0 -0
  442. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store_evidence.py +0 -0
  443. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store_resume.py +0 -0
  444. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store_supply_chain.py +0 -0
  445. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/store_threat_intel.py +0 -0
  446. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/totp.py +0 -0
  447. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/guard/types.py +0 -0
  448. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/integrations/__init__.py +0 -0
  449. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/integrations/cisco_mcp_scanner.py +0 -0
  450. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/integrations/cisco_skill_scanner.py +0 -0
  451. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/lint_fixes.py +0 -0
  452. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/marketplace_support.py +0 -0
  453. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/models.py +0 -0
  454. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/path_support.py +0 -0
  455. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/policy.py +0 -0
  456. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/quality_artifact.py +0 -0
  457. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/repo_detect.py +0 -0
  458. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/reporting.py +0 -0
  459. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/rules/__init__.py +0 -0
  460. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/rules/registry.py +0 -0
  461. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/rules/specs.py +0 -0
  462. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/scanner.py +0 -0
  463. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/submission.py +0 -0
  464. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/suppressions.py +0 -0
  465. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_domain_scoring.py +0 -0
  466. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_helpers.py +0 -0
  467. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_mcp_scoring.py +0 -0
  468. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_models.py +0 -0
  469. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_plugin_scoring.py +0 -0
  470. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_scoring.py +0 -0
  471. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_skill_scoring.py +0 -0
  472. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/trust_specs.py +0 -0
  473. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/src/codex_plugin_scanner/verification.py +0 -0
  474. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/__init__.py +0 -0
  475. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/conftest.py +0 -0
  476. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/e2e_droid_exec.py +0 -0
  477. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/__init__.py +0 -0
  478. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/bad-plugin/.codex-plugin/plugin.json +0 -0
  479. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/bad-plugin/.mcp.json +0 -0
  480. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/bad-plugin/secrets.js +0 -0
  481. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/claude-plugin-good/.claude-plugin/plugin.json +0 -0
  482. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/claude-plugin-good/LICENSE +0 -0
  483. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/claude-plugin-good/README.md +0 -0
  484. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/claude-plugin-good/SECURITY.md +0 -0
  485. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/claude-plugin-good/hooks/hooks.json +0 -0
  486. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/claude-plugin-good/skills/example/SKILL.md +0 -0
  487. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/code-quality-bad/evil.js +0 -0
  488. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/code-quality-bad/inject.js +0 -0
  489. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/benign-echo.json +0 -0
  490. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/benign-health-check.json +0 -0
  491. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/expected-permissions.json +0 -0
  492. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/malicious-aws-credentials-read.json +0 -0
  493. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/malicious-canary-exfil-shell.json +0 -0
  494. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/malicious-env-read.json +0 -0
  495. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/cursor-hooks/malicious-mcp-secret-read.json +0 -0
  496. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/gemini-extension-good/GEMINI.md +0 -0
  497. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/gemini-extension-good/LICENSE +0 -0
  498. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/gemini-extension-good/README.md +0 -0
  499. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/gemini-extension-good/SECURITY.md +0 -0
  500. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/gemini-extension-good/commands/hello.toml +0 -0
  501. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/gemini-extension-good/gemini-extension.json +0 -0
  502. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/.codex-plugin/plugin.json +0 -0
  503. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/.codexignore +0 -0
  504. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/LICENSE +0 -0
  505. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/README.md +0 -0
  506. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/SECURITY.md +0 -0
  507. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/assets/icon.svg +0 -0
  508. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/assets/logo.svg +0 -0
  509. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/assets/screenshot.svg +0 -0
  510. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/good-plugin/skills/example/SKILL.md +0 -0
  511. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/README.md +0 -0
  512. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/benign-docs-fake-token.py +0 -0
  513. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/benign-health-endpoint.py +0 -0
  514. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/benign-nvmrc-fake-creds.py +0 -0
  515. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/benign-source-search.py +0 -0
  516. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/canary-exfil-encoded.py +0 -0
  517. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/canary-exfil.py +0 -0
  518. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/expected-decisions.json +0 -0
  519. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-dockerfile.txt +0 -0
  520. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-encoded-shell-exfil.py +0 -0
  521. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-github-action.yml +0 -0
  522. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-mcp-delete.md +0 -0
  523. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-mcp-secret-read.md +0 -0
  524. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-mcp-skill-exfil.md +0 -0
  525. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-npm-postinstall.js +0 -0
  526. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-prompt-env-read.md +0 -0
  527. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-prompt-guard-bypass.md +0 -0
  528. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-prompt-npmrc-read.md +0 -0
  529. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/malicious-python-setup.py +0 -0
  530. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/guard-red-team/smoke-evidence-template.json +0 -0
  531. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/config.yaml +0 -0
  532. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/mcp_servers.json +0 -0
  533. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/skills/security/malicious/SKILL.md +0 -0
  534. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/SKILL.md +0 -0
  535. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/references/api-setup.md +0 -0
  536. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/skills/stealth/sneaky/scripts/deploy.sh +0 -0
  537. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/hermes-plugin-evil/skills/utils/benign/SKILL.md +0 -0
  538. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malformed-json/.codex-plugin/plugin.json +0 -0
  539. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malicious-skill-plugin/.codex-plugin/plugin.json +0 -0
  540. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malicious-skill-plugin/.codexignore +0 -0
  541. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malicious-skill-plugin/LICENSE +0 -0
  542. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malicious-skill-plugin/README.md +0 -0
  543. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malicious-skill-plugin/SECURITY.md +0 -0
  544. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/malicious-skill-plugin/skills/leaky-skill/SKILL.md +0 -0
  545. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/mcp-canary-server.py +0 -0
  546. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/minimal-plugin/.codex-plugin/plugin.json +0 -0
  547. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/missing-fields/.codex-plugin/plugin.json +0 -0
  548. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/mit-license/LICENSE +0 -0
  549. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-ecosystem-repo/codex-plugin/.codex-plugin/plugin.json +0 -0
  550. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-ecosystem-repo/codex-plugin/LICENSE +0 -0
  551. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-ecosystem-repo/codex-plugin/README.md +0 -0
  552. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-ecosystem-repo/codex-plugin/SECURITY.md +0 -0
  553. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-ecosystem-repo/gemini-ext/README.md +0 -0
  554. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-ecosystem-repo/gemini-ext/gemini-extension.json +0 -0
  555. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/.agents/plugins/marketplace.json +0 -0
  556. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codex-plugin/plugin.json +0 -0
  557. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/.codexignore +0 -0
  558. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/LICENSE +0 -0
  559. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/README.md +0 -0
  560. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/SECURITY.md +0 -0
  561. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/alpha-plugin/skills/example/SKILL.md +0 -0
  562. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/.codex-plugin/plugin.json +0 -0
  563. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/multi-plugin-repo/plugins/beta-plugin/skills/example/SKILL.md +0 -0
  564. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/no-version/.codex-plugin/plugin.json +0 -0
  565. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/opencode-good/.opencode/commands/hello.md +0 -0
  566. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/opencode-good/.opencode/plugins/example.ts +0 -0
  567. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/opencode-good/LICENSE +0 -0
  568. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/opencode-good/README.md +0 -0
  569. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/opencode-good/SECURITY.md +0 -0
  570. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/opencode-good/opencode.jsonc +0 -0
  571. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/skills-missing-dir/.codex-plugin/plugin.json +0 -0
  572. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/skills-no-frontmatter/.codex-plugin/plugin.json +0 -0
  573. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/skills-no-frontmatter/skills/bad-skill/SKILL.md +0 -0
  574. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/benign-npm-controls-package.json +0 -0
  575. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/benign-npm-package.json +0 -0
  576. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/benign-pnpm-package.json +0 -0
  577. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/benign-pyproject.toml +0 -0
  578. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/critical-base-image-Dockerfile +0 -0
  579. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/malicious-Dockerfile +0 -0
  580. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/malicious-action.yml +0 -0
  581. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/malicious-npm-env-fs-network-package.json +0 -0
  582. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/malicious-npm-obfuscated-package.json +0 -0
  583. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/malicious-npm-package.json +0 -0
  584. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/supply-chain/malicious-setup.py +0 -0
  585. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/cargo-safe/Cargo.lock +0 -0
  586. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/cargo-safe/Cargo.toml +0 -0
  587. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/cargo-vulnerable/Cargo.lock +0 -0
  588. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/cargo-vulnerable/Cargo.toml +0 -0
  589. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/composer-safe/composer.json +0 -0
  590. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/composer-safe/composer.lock +0 -0
  591. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/composer-vulnerable/composer.json +0 -0
  592. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/composer-vulnerable/composer.lock +0 -0
  593. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/go-safe/go.mod +0 -0
  594. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/go-vulnerable/go.mod +0 -0
  595. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/gradle-safe/build.gradle +0 -0
  596. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/gradle-safe/gradle.lockfile +0 -0
  597. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/gradle-vulnerable/build.gradle +0 -0
  598. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/gradle-vulnerable/gradle.lockfile +0 -0
  599. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/maven-safe/pom.xml +0 -0
  600. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/maven-vulnerable/pom.xml +0 -0
  601. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/rubygems-safe/Gemfile +0 -0
  602. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/rubygems-safe/Gemfile.lock +0 -0
  603. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile +0 -0
  604. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/tier2/rubygems-vulnerable/Gemfile.lock +0 -0
  605. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/with-marketplace/.codex-plugin/plugin.json +0 -0
  606. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/with-marketplace/marketplace-broken.json +0 -0
  607. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/fixtures/with-marketplace/marketplace.json +0 -0
  608. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/guard_python_phase12_support.py +0 -0
  609. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/guard_tier2_phase13_support.py +0 -0
  610. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test-trust-scoring.py +0 -0
  611. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test-trust-specs.py +0 -0
  612. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_action_runner.py +0 -0
  613. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_best_practices.py +0 -0
  614. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cisco_install_surfaces.py +0 -0
  615. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_claude_daemon_hook_bridge.py +0 -0
  616. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cli.py +0 -0
  617. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_code_quality.py +0 -0
  618. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_config.py +0 -0
  619. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_coverage_remaining.py +0 -0
  620. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cursor_adapter.py +0 -0
  621. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cursor_cli.py +0 -0
  622. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cursor_completion_gates.py +0 -0
  623. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cursor_headless_fixtures.py +0 -0
  624. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cursor_hooks.py +0 -0
  625. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_cursor_local_actions.py +0 -0
  626. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_dashboard_update.py +0 -0
  627. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_ecosystems.py +0 -0
  628. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_edge_cases.py +0 -0
  629. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_final_coverage.py +0 -0
  630. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_gemini_adapter.py +0 -0
  631. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_access_graph.py +0 -0
  632. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_action_identity.py +0 -0
  633. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_advisory_escalation.py +0 -0
  634. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_continuity.py +0 -0
  635. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_copy_commands.py +0 -0
  636. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_decisions.py +0 -0
  637. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_gate.py +0 -0
  638. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_store_dedup.py +0 -0
  639. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_store_phase14.py +0 -0
  640. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approval_store_scale.py +0 -0
  641. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_approvals.py +0 -0
  642. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_auto_first_sync.py +0 -0
  643. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_bootstrap.py +0 -0
  644. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_bridge.py +0 -0
  645. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_bypass_detector.py +0 -0
  646. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_canary_fixtures.py +0 -0
  647. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_capabilities.py +0 -0
  648. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_cisco_evidence.py +0 -0
  649. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_cisco_runtime_cli.py +0 -0
  650. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_claude_adapter.py +0 -0
  651. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_cloud_local_sync.py +0 -0
  652. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_app_server.py +0 -0
  653. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_auto_resume_smoke.py +0 -0
  654. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_e2e.py +0 -0
  655. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_install.py +0 -0
  656. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_proxy.py +0 -0
  657. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_resume_commands.py +0 -0
  658. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_codex_resume_endpoints.py +0 -0
  659. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_config_paths.py +0 -0
  660. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_connect_flow.py +0 -0
  661. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_consumer_mode.py +0 -0
  662. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_copilot_adapter.py +0 -0
  663. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_copilot_proxy.py +0 -0
  664. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_daemon_cli.py +0 -0
  665. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_daemon_manager.py +0 -0
  666. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_daemon_perf.py +0 -0
  667. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_daemon_registry.py +0 -0
  668. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_daemon_repair_perf.py +0 -0
  669. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_daemon_wake.py +0 -0
  670. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_data_flow.py +0 -0
  671. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_decision_propagation.py +0 -0
  672. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_desktop_notifications.py +0 -0
  673. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_detector_fp.py +0 -0
  674. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_docs.py +0 -0
  675. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_event_schema_v1.py +0 -0
  676. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_events.py +0 -0
  677. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_evidence_api_contract.py +0 -0
  678. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_evidence_store.py +0 -0
  679. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_harness_contracts.py +0 -0
  680. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_harness_setup.py +0 -0
  681. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_harness_smoke.py +0 -0
  682. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_hashnet_mcp_canaries.py +0 -0
  683. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_headless_daemon_api.py +0 -0
  684. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_insights.py +0 -0
  685. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_install_workspace.py +0 -0
  686. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_inventory_cisco.py +0 -0
  687. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_inventory_contract.py +0 -0
  688. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_js_lab_phase11.py +0 -0
  689. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_js_lockfile_resolution_phase11.py +0 -0
  690. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_js_package_hook_phase11.py +0 -0
  691. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_js_package_intent_phase11.py +0 -0
  692. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_js_semver_phase11.py +0 -0
  693. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_js_supply_chain_phase11.py +0 -0
  694. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_launch_env.py +0 -0
  695. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_legacy_token_fixtures.py +0 -0
  696. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_local_supply_chain_audit_phase16.py +0 -0
  697. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_mcp_detectors.py +0 -0
  698. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_mcp_protection.py +0 -0
  699. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_oauth_client.py +0 -0
  700. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_oauth_device_connect.py +0 -0
  701. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_opencode_proxy.py +0 -0
  702. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_package_intent.py +0 -0
  703. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_package_resume_phase14.py +0 -0
  704. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_package_shims_cli.py +0 -0
  705. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase03_local_install.py +0 -0
  706. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase03_remainder.py +0 -0
  707. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase04_failure_modes.py +0 -0
  708. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase04_harness_contracts.py +0 -0
  709. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase04_harness_ux.py +0 -0
  710. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase05_approval_memory.py +0 -0
  711. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_phase07_harness_coverage_matrix.py +0 -0
  712. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_policy_dedup.py +0 -0
  713. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_product_flow.py +0 -0
  714. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_product_model_contracts.py +0 -0
  715. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_prompt_injection.py +0 -0
  716. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_provenance.py +0 -0
  717. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_python_lab_phase12.py +0 -0
  718. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_python_package_hook_phase12.py +0 -0
  719. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_python_package_intent_phase12.py +0 -0
  720. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_python_supply_chain_heuristics_phase12.py +0 -0
  721. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_python_supply_chain_phase12.py +0 -0
  722. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_queue_api_contract.py +0 -0
  723. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_queue_contract.py +0 -0
  724. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_receipt_p5_fields.py +0 -0
  725. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_receipt_persistence.py +0 -0
  726. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_red_team.py +0 -0
  727. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_red_team_e2e.py +0 -0
  728. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_redaction.py +0 -0
  729. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_registry_broker_skills_canaries.py +0 -0
  730. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_remote_pair_flow.py +0 -0
  731. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_render.py +0 -0
  732. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_resolution_copy.py +0 -0
  733. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_risk.py +0 -0
  734. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime.py +0 -0
  735. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime_action_harnesses.py +0 -0
  736. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime_actions.py +0 -0
  737. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime_actions_phase14.py +0 -0
  738. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime_decisions.py +0 -0
  739. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime_detectors.py +0 -0
  740. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_runtime_signals.py +0 -0
  741. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_safe_decode.py +0 -0
  742. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_sandbox.py +0 -0
  743. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_settings_api.py +0 -0
  744. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_settings_presets.py +0 -0
  745. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_shim_truth.py +0 -0
  746. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_skill_protection.py +0 -0
  747. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_skill_protection_phase14.py +0 -0
  748. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_source_view_secret_fixtures.py +0 -0
  749. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_stable_digest.py +0 -0
  750. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_store_migrations.py +0 -0
  751. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_supply_chain.py +0 -0
  752. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_supply_chain_bundle.py +0 -0
  753. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_supply_chain_daemon.py +0 -0
  754. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_supply_chain_sync.py +0 -0
  755. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_surface_server.py +0 -0
  756. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_threat_intel.py +0 -0
  757. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_tier2_labs_phase13.py +0 -0
  758. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_tier2_package_intent_phase13.py +0 -0
  759. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_tier2_supply_chain_phase13.py +0 -0
  760. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_verdicts.py +0 -0
  761. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_web_recovery.py +0 -0
  762. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_guard_wrapper_flows.py +0 -0
  763. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_harness_attribution.py +0 -0
  764. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_hermes_adapter.py +0 -0
  765. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_insights_share.py +0 -0
  766. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_integration.py +0 -0
  767. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_lint_fixes.py +0 -0
  768. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_live_cisco_smoke.py +0 -0
  769. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_manifest.py +0 -0
  770. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_marketplace.py +0 -0
  771. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_mcp_security.py +0 -0
  772. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_openclaw_adapter.py +0 -0
  773. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_opencode_adapter.py +0 -0
  774. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_opencode_hook_python.py +0 -0
  775. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_opencode_pretool.py +0 -0
  776. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_operational_security.py +0 -0
  777. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_policy.py +0 -0
  778. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_policy_bundle_parser.py +0 -0
  779. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_quality_artifact.py +0 -0
  780. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_rule_registry.py +0 -0
  781. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_scanner.py +0 -0
  782. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_schema_contracts.py +0 -0
  783. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_security.py +0 -0
  784. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_security_ops.py +0 -0
  785. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_skill_security.py +0 -0
  786. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_submission.py +0 -0
  787. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_trust_scoring.py +0 -0
  788. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_trust_specs.py +0 -0
  789. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_verification.py +0 -0
  790. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/tests/test_versioning.py +0 -0
  791. {plugin_scanner-2.0.543 → plugin_scanner-2.0.544}/uv.lock +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: plugin-scanner
3
- Version: 2.0.543
3
+ Version: 2.0.544
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.543"
7
+ version = "2.0.544"
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.543"
7
+ version = "2.0.544"
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"
@@ -71,10 +71,6 @@ def _is_guard_program(program_name: str) -> bool:
71
71
  return normalized_name in {"plugin-guard"}
72
72
 
73
73
 
74
- def _is_hol_guard_binary(program_name: str) -> bool:
75
- return Path(program_name).stem.lower() == "hol-guard"
76
-
77
-
78
74
  def _is_scanner_program(program_name: str) -> bool:
79
75
  normalized_name = Path(program_name).stem.lower()
80
76
  return normalized_name in {"plugin-scanner", "plugin-ecosystem-scanner"}
@@ -184,8 +180,19 @@ def _build_parser(program_name: str, *, program_mode: str) -> argparse.ArgumentP
184
180
  return parser
185
181
 
186
182
 
187
- def _resolve_legacy_args(argv: list[str] | None, *, program_mode: str) -> list[str] | None:
183
+ def _is_hol_guard_program(program_name: str) -> bool:
184
+ return Path(program_name).stem.lower() == "hol-guard"
185
+
186
+
187
+ def _resolve_legacy_args(
188
+ argv: list[str] | None,
189
+ *,
190
+ program_mode: str,
191
+ program_name: str = "",
192
+ ) -> list[str] | None:
188
193
  if not argv:
194
+ if program_mode == "combined" and _is_hol_guard_program(program_name):
195
+ return ["guard"]
189
196
  return argv
190
197
  if program_mode == "guard":
191
198
  if argv[0] == "guard":
@@ -261,6 +268,15 @@ def _resolve_legacy_args(argv: list[str] | None, *, program_mode: str) -> list[s
261
268
  "bridge",
262
269
  "daemon",
263
270
  "hook",
271
+ "admin",
272
+ "cloud",
273
+ "supply-chain",
274
+ "service",
275
+ "codex-mcp-proxy",
276
+ "opencode-mcp-proxy",
277
+ "copilot-mcp-proxy",
278
+ "cursor-mcp-proxy",
279
+ "hermes-mcp-proxy",
264
280
  }
265
281
  if program_mode == "combined" and argv[0] in _guard_subcommands and "--format" not in argv:
266
282
  return ["guard", *argv]
@@ -552,9 +568,11 @@ def main(argv: list[str] | None = None) -> int:
552
568
  else:
553
569
  program_mode = "combined"
554
570
  parser = _build_parser(program_name, program_mode=program_mode)
555
- resolved_argv = _resolve_legacy_args(argv or sys.argv[1:], program_mode=program_mode)
556
- if _is_hol_guard_binary(program_name) and not resolved_argv:
557
- parser.error("the following arguments are required: command")
571
+ resolved_argv = _resolve_legacy_args(
572
+ argv or sys.argv[1:],
573
+ program_mode=program_mode,
574
+ program_name=program_name,
575
+ )
558
576
  args = parser.parse_args(resolved_argv)
559
577
  if getattr(args, "list_ecosystems", False):
560
578
  for ecosystem in list_supported_ecosystems():
@@ -0,0 +1 @@
1
+ """Guard shared contract helpers."""
@@ -0,0 +1,109 @@
1
+ """Shared Guard supply-chain decision evidence contract v1."""
2
+
3
+ from __future__ import annotations
4
+
5
+ from collections.abc import Mapping
6
+
7
+ from codex_plugin_scanner.guard.runtime.supply_chain_package_eval import PackageRequestEvaluation
8
+
9
+ DECISION_EVIDENCE_CONTRACT_VERSION = "guard-supply-chain-decision-evidence.v1"
10
+
11
+ DECISION_VALUES = frozenset({"allow", "monitor", "warn", "ask", "block"})
12
+ ENFORCEMENT_VALUES = frozenset({"premium_cloud", "local_fallback", "upgrade_required", "free_local", "offline_cached"})
13
+ ENTITLEMENT_VALUES = frozenset({"premium", "free", "limit_reached"})
14
+ CACHE_STATUS_VALUES = frozenset({"miss", "stale", "upgrade-gated", "hit", "empty"})
15
+
16
+ REQUIRED_DECISION_EVIDENCE_FIELDS = (
17
+ "contractVersion",
18
+ "decision",
19
+ "recommendation",
20
+ "enforcement",
21
+ "entitlementState",
22
+ "cacheStatus",
23
+ "policyVersion",
24
+ "packageIntentHash",
25
+ "commandShape",
26
+ "reasons",
27
+ "evidenceIds",
28
+ )
29
+
30
+
31
+ def validate_decision_evidence_v1(payload: Mapping[str, object]) -> list[str]:
32
+ errors: list[str] = []
33
+ missing = {field for field in REQUIRED_DECISION_EVIDENCE_FIELDS if field not in payload}
34
+ for field in missing:
35
+ errors.append(f"missing field: {field}")
36
+ contract_version = payload.get("contractVersion")
37
+ if "contractVersion" not in missing and contract_version != DECISION_EVIDENCE_CONTRACT_VERSION:
38
+ errors.append(f"unexpected contractVersion: {contract_version!r}")
39
+ decision = payload.get("decision")
40
+ if "decision" not in missing and decision not in DECISION_VALUES:
41
+ errors.append(f"invalid decision: {decision!r}")
42
+ recommendation = payload.get("recommendation")
43
+ if recommendation not in DECISION_VALUES:
44
+ errors.append(f"invalid recommendation: {recommendation!r}")
45
+ enforcement = payload.get("enforcement")
46
+ if "enforcement" not in missing and enforcement not in ENFORCEMENT_VALUES:
47
+ errors.append(f"invalid enforcement: {enforcement!r}")
48
+ entitlement_state = payload.get("entitlementState")
49
+ if "entitlementState" not in missing and entitlement_state not in ENTITLEMENT_VALUES:
50
+ errors.append(f"invalid entitlementState: {entitlement_state!r}")
51
+ cache_status = payload.get("cacheStatus")
52
+ if "cacheStatus" not in missing and cache_status not in CACHE_STATUS_VALUES:
53
+ errors.append(f"invalid cacheStatus: {cache_status!r}")
54
+ command_shape = payload.get("commandShape")
55
+ if not isinstance(command_shape, dict):
56
+ errors.append("commandShape must be an object")
57
+ elif not isinstance(command_shape.get("redacted"), bool):
58
+ errors.append("commandShape.redacted must be boolean")
59
+ reasons = payload.get("reasons")
60
+ if not isinstance(reasons, list):
61
+ errors.append("reasons must be an array")
62
+ evidence_ids = payload.get("evidenceIds")
63
+ if not isinstance(evidence_ids, list):
64
+ errors.append("evidenceIds must be an array")
65
+ return errors
66
+
67
+
68
+ def package_evaluation_to_decision_evidence_v1(
69
+ evaluation: PackageRequestEvaluation,
70
+ *,
71
+ command_shape: Mapping[str, object],
72
+ package_intent_hash: str,
73
+ recommendation: str | None = None,
74
+ ) -> dict[str, object]:
75
+ resolved_recommendation = recommendation or evaluation.decision
76
+ return {
77
+ "contractVersion": DECISION_EVIDENCE_CONTRACT_VERSION,
78
+ "decision": evaluation.decision,
79
+ "recommendation": resolved_recommendation,
80
+ "enforcement": evaluation.enforcement,
81
+ "entitlementState": evaluation.entitlement_state,
82
+ "cacheStatus": evaluation.cache_status,
83
+ "policyVersion": evaluation.policy_version,
84
+ "packageIntentHash": package_intent_hash,
85
+ "commandShape": dict(command_shape),
86
+ "reasons": [dict(item) for item in evaluation.reasons],
87
+ "evidenceIds": list(evaluation.evidence_ids),
88
+ }
89
+
90
+
91
+ def cloud_evaluate_response_to_decision_evidence_v1(
92
+ response: Mapping[str, object],
93
+ *,
94
+ package_intent_hash: str,
95
+ command_shape: Mapping[str, object],
96
+ ) -> dict[str, object]:
97
+ return {
98
+ "contractVersion": DECISION_EVIDENCE_CONTRACT_VERSION,
99
+ "decision": response.get("decision"),
100
+ "recommendation": response.get("recommendation", response.get("decision")),
101
+ "enforcement": response.get("enforcement"),
102
+ "entitlementState": response.get("entitlementState"),
103
+ "cacheStatus": response.get("cacheStatus"),
104
+ "policyVersion": response.get("policyVersion"),
105
+ "packageIntentHash": package_intent_hash,
106
+ "commandShape": dict(command_shape),
107
+ "reasons": list(response.get("reasons") or []),
108
+ "evidenceIds": list(response.get("evidenceIds") or []),
109
+ }
@@ -123,6 +123,18 @@ def build_protect_payload(
123
123
  if len(command) == 0:
124
124
  raise ValueError("Guard protect requires a command to wrap.")
125
125
  request = parse_protect_command(command)
126
+ package_payload = build_package_protect_payload(
127
+ command=command,
128
+ store=store,
129
+ workspace_dir=workspace_dir,
130
+ dry_run=dry_run,
131
+ now=now,
132
+ config=config,
133
+ unsafe_raw_output=unsafe_raw_output,
134
+ timeout_seconds=_protect_command_timeout_seconds(),
135
+ )
136
+ if package_payload is not None:
137
+ return package_payload
126
138
  advisories = store.list_cached_advisories(limit=None)
127
139
  verdict = evaluate_protect_request(request, advisories)
128
140
  receipt = _build_install_receipt(request, verdict)
@@ -136,33 +148,6 @@ def build_protect_payload(
136
148
  "receipt": receipt.to_dict(),
137
149
  "matched_advisories": list(verdict.matched_advisories),
138
150
  }
139
- if verdict.blocking:
140
- store.add_receipt(receipt)
141
- store.add_event(
142
- f"install_time_{verdict.action}",
143
- {
144
- "artifact_id": request.targets[0].artifact_id,
145
- "artifact_name": request.targets[0].artifact_name,
146
- "executor": request.executor,
147
- "install_kind": request.install_kind,
148
- "action": verdict.action,
149
- "risk_signals": list(verdict.risk_signals),
150
- },
151
- now,
152
- )
153
- return (payload, 2)
154
- package_payload = build_package_protect_payload(
155
- command=command,
156
- store=store,
157
- workspace_dir=workspace_dir,
158
- dry_run=dry_run,
159
- now=now,
160
- config=config,
161
- unsafe_raw_output=unsafe_raw_output,
162
- timeout_seconds=_protect_command_timeout_seconds(),
163
- )
164
- if package_payload is not None:
165
- return package_payload
166
151
  if verdict.blocking or dry_run:
167
152
  store.add_receipt(receipt)
168
153
  store.add_event(
@@ -249,53 +249,6 @@ def evaluate_package_request_artifact(
249
249
  if bundle_response is not None
250
250
  else None
251
251
  )
252
- if bundle_evaluation is not None and bundle_meta is not None and bundle_evaluation.decision != "monitor":
253
- result = _finalize_evaluation(
254
- bundle_evaluation, package_intent_hash=package_intent_hash, workspace_fingerprint=workspace_fingerprint
255
- )
256
- store.cache_supply_chain_evaluation(
257
- workspace_id=workspace_id or bundle_payload["bundle"]["workspaceId"],
258
- package_intent_hash=package_intent_hash,
259
- feed_snapshot_hash=bundle_meta["feed_snapshot_hash"],
260
- policy_hash=bundle_meta["policy_hash"],
261
- scoring_version=bundle_meta["scoring_version"],
262
- bundle_version=bundle_meta["bundle_version"],
263
- decision=result.to_cache_dict(),
264
- now=now_value,
265
- )
266
- _persist_evidence(store=store, artifact=artifact, evaluation=result, now=now_value)
267
- if result.refresh_required:
268
- store.add_event(
269
- "supply_chain_bundle_refresh_requested",
270
- {
271
- "artifact_id": artifact.artifact_id,
272
- "artifact_name": artifact.name,
273
- "reason": "feed_stale",
274
- },
275
- now_value,
276
- )
277
- return result
278
- if (
279
- bundle_evaluation is not None
280
- and bundle_evaluation.refresh_required
281
- and not bool(store.get_oauth_local_credential_health().get("configured"))
282
- ):
283
- fallback = _finalize_evaluation(
284
- bundle_evaluation,
285
- package_intent_hash=package_intent_hash,
286
- workspace_fingerprint=workspace_fingerprint,
287
- )
288
- _persist_evidence(store=store, artifact=artifact, evaluation=fallback, now=now_value)
289
- store.add_event(
290
- "supply_chain_bundle_refresh_requested",
291
- {
292
- "artifact_id": artifact.artifact_id,
293
- "artifact_name": artifact.name,
294
- "reason": "feed_stale",
295
- },
296
- now_value,
297
- )
298
- return fallback
299
252
  if not _artifact_has_package_material(artifact, targets):
300
253
  no_material_result = _empty_package_material_result(
301
254
  artifact=artifact,
@@ -306,6 +259,9 @@ def evaluate_package_request_artifact(
306
259
  )
307
260
  _persist_evidence(store=store, artifact=artifact, evaluation=no_material_result, now=now_value)
308
261
  return no_material_result
262
+ bundle_defer_eligible = bundle_evaluation is not None and (
263
+ bundle_evaluation.decision == "block" or not bundle_evaluation.refresh_required
264
+ )
309
265
  cloud_result, cloud_fallback_reason = _evaluate_with_cloud(
310
266
  artifact=artifact,
311
267
  targets=targets,
@@ -313,8 +269,17 @@ def evaluate_package_request_artifact(
313
269
  workspace_id=workspace_id,
314
270
  workspace_fingerprint=workspace_fingerprint,
315
271
  bundle_meta=bundle_meta,
272
+ bundle_defer_eligible=bundle_defer_eligible,
316
273
  store=store,
317
274
  )
275
+ if cloud_result is not None and _cloud_result_should_defer_to_bundle(
276
+ cloud_result, bundle_evaluation=bundle_evaluation
277
+ ):
278
+ if cloud_fallback_reason is None and cloud_result.reasons:
279
+ first_reason = cloud_result.reasons[0]
280
+ if isinstance(first_reason, dict):
281
+ cloud_fallback_reason = dict(first_reason)
282
+ cloud_result = None
318
283
  if cloud_result is not None:
319
284
  upgraded = cloud_result
320
285
  if cloud_result.enforcement == "upgrade_required":
@@ -345,12 +310,52 @@ def evaluate_package_request_artifact(
345
310
  )
346
311
  _persist_evidence(store=store, artifact=artifact, evaluation=upgraded, now=now_value)
347
312
  return upgraded
313
+ if (
314
+ bundle_evaluation is not None
315
+ and bundle_evaluation.refresh_required
316
+ and not bool(store.get_oauth_local_credential_health().get("configured"))
317
+ ):
318
+ fallback = _finalize_evaluation(
319
+ bundle_evaluation,
320
+ package_intent_hash=package_intent_hash,
321
+ workspace_fingerprint=workspace_fingerprint,
322
+ )
323
+ _persist_evidence(store=store, artifact=artifact, evaluation=fallback, now=now_value)
324
+ store.add_event(
325
+ "supply_chain_bundle_refresh_requested",
326
+ {
327
+ "artifact_id": artifact.artifact_id,
328
+ "artifact_name": artifact.name,
329
+ "reason": "feed_stale",
330
+ },
331
+ now_value,
332
+ )
333
+ return fallback
348
334
  if bundle_evaluation is not None:
349
335
  fallback = _finalize_evaluation(
350
336
  bundle_evaluation, package_intent_hash=package_intent_hash, workspace_fingerprint=workspace_fingerprint
351
337
  )
352
338
  if cloud_fallback_reason is not None:
353
339
  fallback = _with_additional_reason(fallback, cloud_fallback_reason)
340
+ if bundle_meta is not None and bundle_evaluation.decision != "monitor" and isinstance(bundle_payload, dict):
341
+ cache_workspace_id = workspace_id
342
+ if cache_workspace_id is None:
343
+ bundle_section = bundle_payload.get("bundle")
344
+ if isinstance(bundle_section, dict):
345
+ bundle_workspace_id = bundle_section.get("workspaceId")
346
+ if isinstance(bundle_workspace_id, str) and bundle_workspace_id:
347
+ cache_workspace_id = bundle_workspace_id
348
+ if cache_workspace_id:
349
+ store.cache_supply_chain_evaluation(
350
+ workspace_id=cache_workspace_id,
351
+ package_intent_hash=package_intent_hash,
352
+ feed_snapshot_hash=bundle_meta["feed_snapshot_hash"],
353
+ policy_hash=bundle_meta["policy_hash"],
354
+ scoring_version=bundle_meta["scoring_version"],
355
+ bundle_version=bundle_meta["bundle_version"],
356
+ decision=fallback.to_cache_dict(),
357
+ now=now_value,
358
+ )
354
359
  _persist_evidence(store=store, artifact=artifact, evaluation=fallback, now=now_value)
355
360
  if fallback.refresh_required:
356
361
  store.add_event(
@@ -594,6 +599,7 @@ def _evaluate_with_cloud(
594
599
  workspace_id: str | None,
595
600
  workspace_fingerprint: str | None,
596
601
  bundle_meta: dict[str, str] | None,
602
+ bundle_defer_eligible: bool,
597
603
  store: GuardStore,
598
604
  ) -> tuple[PackageRequestEvaluation | None, dict[str, object] | None]:
599
605
  if workspace_id is None or workspace_fingerprint is None:
@@ -610,6 +616,13 @@ def _evaluate_with_cloud(
610
616
  try:
611
617
  auth_context = _resolve_guard_sync_auth_context(store)
612
618
  except GuardSyncAuthorizationExpiredError:
619
+ if bundle_meta is not None and bundle_defer_eligible and resolve_fail_closed_decision() != "block":
620
+ return None, _cloud_fallback_reason(
621
+ code="cloud_auth_error",
622
+ message=(
623
+ "Guard cloud evaluation was not authorized, so Guard fell back to signed bundle intelligence."
624
+ ),
625
+ )
613
626
  return (
614
627
  _cloud_fail_closed_evaluation(
615
628
  code="cloud_auth_error",
@@ -3567,6 +3580,26 @@ def _with_additional_reason(
3567
3580
  return replace(evaluation, reasons=updated_reasons, packages=tuple(updated_packages))
3568
3581
 
3569
3582
 
3583
+ def _cloud_result_should_defer_to_bundle(
3584
+ evaluation: PackageRequestEvaluation,
3585
+ *,
3586
+ bundle_evaluation: _EvaluationDraft | None,
3587
+ ) -> bool:
3588
+ if bundle_evaluation is None:
3589
+ return False
3590
+ if not (bundle_evaluation.decision == "block" or not bundle_evaluation.refresh_required):
3591
+ return False
3592
+ reason_codes = {str(reason.get("code") or "") for reason in evaluation.reasons if isinstance(reason, dict)}
3593
+ if evaluation.decision == "block" and evaluation.policy_action == "block":
3594
+ if "cloud_validation_error" in reason_codes and "cloud_timeout" not in reason_codes:
3595
+ return False
3596
+ return False
3597
+ defer_codes = {"cloud_auth_error", "cloud_http_error", "cloud_timeout"}
3598
+ if not any(code in defer_codes for code in reason_codes):
3599
+ return False
3600
+ return _decision_rank(bundle_evaluation.decision) > _decision_rank(evaluation.decision)
3601
+
3602
+
3570
3603
  def _cloud_fallback_reason(*, code: str, message: str) -> dict[str, object]:
3571
3604
  return {
3572
3605
  "code": code,
@@ -1,3 +1,3 @@
1
1
  """Single source of truth for tool version."""
2
2
 
3
- __version__ = "2.0.543"
3
+ __version__ = "2.0.544"
@@ -0,0 +1,12 @@
1
+ """Force bundle-first evaluation in integration tests that seed offline bundles."""
2
+
3
+ from __future__ import annotations
4
+
5
+ import pytest
6
+
7
+ from tests.test_guard_supply_chain_evaluator import _force_cloud_fallback
8
+
9
+
10
+ @pytest.fixture
11
+ def bundle_first_cloud(monkeypatch: pytest.MonkeyPatch) -> None:
12
+ _force_cloud_fallback(monkeypatch)
@@ -726,7 +726,7 @@ class TestGuardCli:
726
726
  main([])
727
727
 
728
728
  assert exc_info.value.code == 2
729
- assert "Run `hol-guard --help` to inspect available Guard commands." in capsys.readouterr().err
729
+ assert "Run `hol-guard guard --help` to inspect available Guard commands." in capsys.readouterr().err
730
730
 
731
731
  def test_guard_detect_reports_supported_harnesses(self, tmp_path, capsys):
732
732
  home_dir = tmp_path / "home"
@@ -23,6 +23,9 @@ from codex_plugin_scanner.guard.config import load_guard_config
23
23
  from codex_plugin_scanner.guard.protect import build_protect_payload
24
24
  from codex_plugin_scanner.guard.store import GuardStore
25
25
 
26
+ pytest_plugins = ["tests.bundle_first_cloud"]
27
+ pytestmark = pytest.mark.usefixtures("bundle_first_cloud")
28
+
26
29
  WORKSPACE_ID = "workspace-alpha"
27
30
 
28
31
 
@@ -27,6 +27,9 @@ from codex_plugin_scanner.guard.runtime.package_intent import (
27
27
  )
28
28
  from codex_plugin_scanner.guard.store import GuardStore
29
29
 
30
+ pytest_plugins = ["tests.bundle_first_cloud"]
31
+ pytestmark = pytest.mark.usefixtures("bundle_first_cloud")
32
+
30
33
  WORKSPACE_ID = "workspace-alpha"
31
34
 
32
35
 
@@ -18,6 +18,9 @@ from codex_plugin_scanner.guard.cli import commands as guard_commands_module
18
18
  from codex_plugin_scanner.guard.runtime.signals import RiskSignalV2
19
19
  from codex_plugin_scanner.guard.store import GuardStore
20
20
 
21
+ pytest_plugins = ["tests.bundle_first_cloud"]
22
+ pytestmark = pytest.mark.usefixtures("bundle_first_cloud")
23
+
21
24
  WORKSPACE_ID = "workspace-alpha"
22
25
 
23
26
 
@@ -22,6 +22,9 @@ from codex_plugin_scanner.guard.approvals import apply_approval_resolution
22
22
  from codex_plugin_scanner.guard.cli import commands as guard_commands_module
23
23
  from codex_plugin_scanner.guard.store import GuardStore
24
24
 
25
+ pytest_plugins = ["tests.bundle_first_cloud"]
26
+ pytestmark = pytest.mark.usefixtures("bundle_first_cloud")
27
+
25
28
  WORKSPACE_ID = "workspace-alpha"
26
29
 
27
30
 
@@ -445,4 +448,4 @@ def test_phase14_claude_daemon_hook_bridge_queues_package_install_without_node(t
445
448
  assert "minimist@1.2.8" in result.stdout
446
449
  assert payload["hookSpecificOutput"]["hookEventName"] == "PreToolUse"
447
450
  assert payload["hookSpecificOutput"]["permissionDecision"] == "ask"
448
- assert "policy-review-1" in payload["hookSpecificOutput"]["permissionDecisionReason"]
451
+ assert "minimist@1.2.8" in payload["hookSpecificOutput"]["permissionDecisionReason"]