@clear-capabilities/agentic-security-scanner 0.74.0

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 (331) hide show
  1. package/CHANGELOG.md +1580 -0
  2. package/bin/.agentic-security/findings.json +1577 -0
  3. package/bin/.agentic-security/last-scan.json +1577 -0
  4. package/bin/.agentic-security/last-scan.json.sig +1 -0
  5. package/bin/.agentic-security/scan-history.json +465 -0
  6. package/bin/.agentic-security/streak.json +25 -0
  7. package/bin/agentic-security-audit.js +198 -0
  8. package/bin/agentic-security-consistency.js +80 -0
  9. package/bin/agentic-security-diff.js +136 -0
  10. package/bin/agentic-security-lsp.js +12 -0
  11. package/bin/agentic-security-mcp.js +40 -0
  12. package/bin/agentic-security-rule.js +153 -0
  13. package/bin/agentic-security.js +1683 -0
  14. package/dist/117.index.js +207 -0
  15. package/dist/178.index.js +250 -0
  16. package/dist/218.index.js +793 -0
  17. package/dist/227.index.js +192 -0
  18. package/dist/301.index.js +167 -0
  19. package/dist/384.index.js +18 -0
  20. package/dist/476.index.js +126 -0
  21. package/dist/513.index.js +373 -0
  22. package/dist/520.index.js +13 -0
  23. package/dist/601.index.js +1038 -0
  24. package/dist/634.index.js +1892 -0
  25. package/dist/637.index.js +216 -0
  26. package/dist/660.index.js +131 -0
  27. package/dist/675.index.js +451 -0
  28. package/dist/826.index.js +188 -0
  29. package/dist/830.index.js +133 -0
  30. package/dist/agentic-security.mjs +272 -0
  31. package/dist/agentic-security.mjs.sha256 +1 -0
  32. package/dist/calibration-seed.json +27 -0
  33. package/package.json +77 -0
  34. package/src/.agentic-security/findings.json +80844 -0
  35. package/src/.agentic-security/last-scan.json +80844 -0
  36. package/src/.agentic-security/last-scan.json.sig +1 -0
  37. package/src/.agentic-security/scan-history.json +8408 -0
  38. package/src/.agentic-security/streak.json +26 -0
  39. package/src/badge.js +188 -0
  40. package/src/compare.js +203 -0
  41. package/src/dataflow/.agentic-security/findings.json +3487 -0
  42. package/src/dataflow/.agentic-security/last-scan.json +3487 -0
  43. package/src/dataflow/.agentic-security/last-scan.json.sig +1 -0
  44. package/src/dataflow/.agentic-security/scan-history.json +735 -0
  45. package/src/dataflow/.agentic-security/streak.json +24 -0
  46. package/src/dataflow/CLAUDE.md +38 -0
  47. package/src/dataflow/access-paths.js +172 -0
  48. package/src/dataflow/async-sequencing.js +177 -0
  49. package/src/dataflow/backward.js +201 -0
  50. package/src/dataflow/catalog-expanded.js +485 -0
  51. package/src/dataflow/catalog.js +659 -0
  52. package/src/dataflow/cross-repo.js +219 -0
  53. package/src/dataflow/engine.js +588 -0
  54. package/src/dataflow/exception-flow.js +116 -0
  55. package/src/dataflow/exploit-prover.js +187 -0
  56. package/src/dataflow/higher-order.js +221 -0
  57. package/src/dataflow/ifds.js +347 -0
  58. package/src/dataflow/implicit-flow.js +129 -0
  59. package/src/dataflow/incremental.js +229 -0
  60. package/src/dataflow/index.js +181 -0
  61. package/src/dataflow/numeric-domain.js +192 -0
  62. package/src/dataflow/path-feasibility.js +114 -0
  63. package/src/dataflow/points-to.js +337 -0
  64. package/src/dataflow/polyglot.js +190 -0
  65. package/src/dataflow/proven-clean.js +159 -0
  66. package/src/dataflow/receiver-context.js +76 -0
  67. package/src/dataflow/sanitizer-proof.js +154 -0
  68. package/src/dataflow/soft-taint.js +140 -0
  69. package/src/dataflow/string-domain.js +234 -0
  70. package/src/dataflow/stub-aware-filter.js +100 -0
  71. package/src/dataflow/summaries.js +132 -0
  72. package/src/dataflow/symbolic-exec.js +238 -0
  73. package/src/dataflow/tabulation.js +135 -0
  74. package/src/engine.js +7763 -0
  75. package/src/history-scan.js +229 -0
  76. package/src/index.js +3 -0
  77. package/src/integrations/.agentic-security/findings.json +1504 -0
  78. package/src/integrations/.agentic-security/last-scan.json +1504 -0
  79. package/src/integrations/.agentic-security/scan-history.json +40 -0
  80. package/src/integrations/.agentic-security/streak.json +21 -0
  81. package/src/integrations/index.js +321 -0
  82. package/src/integrations/tickets.js +200 -0
  83. package/src/ir/.agentic-security/findings.json +3036 -0
  84. package/src/ir/.agentic-security/last-scan.json +3036 -0
  85. package/src/ir/.agentic-security/last-scan.json.sig +1 -0
  86. package/src/ir/.agentic-security/scan-history.json +364 -0
  87. package/src/ir/.agentic-security/streak.json +23 -0
  88. package/src/ir/CLAUDE.md +172 -0
  89. package/src/ir/callgraph.js +73 -0
  90. package/src/ir/class-hierarchy.js +195 -0
  91. package/src/ir/index.js +152 -0
  92. package/src/ir/parser-cs.js +260 -0
  93. package/src/ir/parser-java.js +286 -0
  94. package/src/ir/parser-js.js +413 -0
  95. package/src/ir/parser-kt.js +258 -0
  96. package/src/ir/parser-py-cst.js +136 -0
  97. package/src/ir/parser-py.helper.py +501 -0
  98. package/src/ir/parser-py.js +312 -0
  99. package/src/ir/ssa.js +315 -0
  100. package/src/ir/type-stubs.js +288 -0
  101. package/src/leaderboard.js +152 -0
  102. package/src/llm-validator/.agentic-security/findings.json +1891 -0
  103. package/src/llm-validator/.agentic-security/last-scan.json +1891 -0
  104. package/src/llm-validator/.agentic-security/last-scan.json.sig +1 -0
  105. package/src/llm-validator/.agentic-security/scan-history.json +168 -0
  106. package/src/llm-validator/.agentic-security/streak.json +20 -0
  107. package/src/llm-validator/consistency.js +141 -0
  108. package/src/llm-validator/index.js +437 -0
  109. package/src/lsp/.agentic-security/findings.json +28 -0
  110. package/src/lsp/.agentic-security/last-scan.json +28 -0
  111. package/src/lsp/.agentic-security/scan-history.json +79 -0
  112. package/src/lsp/.agentic-security/streak.json +22 -0
  113. package/src/lsp/server.js +275 -0
  114. package/src/mcp/.agentic-security/findings.json +8358 -0
  115. package/src/mcp/.agentic-security/last-scan.json +8358 -0
  116. package/src/mcp/.agentic-security/last-scan.json.sig +1 -0
  117. package/src/mcp/.agentic-security/scan-history.json +1125 -0
  118. package/src/mcp/.agentic-security/streak.json +22 -0
  119. package/src/mcp/CLAUDE.md +54 -0
  120. package/src/mcp/audit.js +136 -0
  121. package/src/mcp/redact.js +75 -0
  122. package/src/mcp/server.js +158 -0
  123. package/src/mcp/stdio.js +83 -0
  124. package/src/mcp/tools.js +940 -0
  125. package/src/mcp/validate.js +49 -0
  126. package/src/personality.js +164 -0
  127. package/src/poc-video.js +239 -0
  128. package/src/posture/.agentic-security/findings.json +51239 -0
  129. package/src/posture/.agentic-security/last-scan.json +51239 -0
  130. package/src/posture/.agentic-security/last-scan.json.sig +1 -0
  131. package/src/posture/.agentic-security/scan-history.json +5557 -0
  132. package/src/posture/.agentic-security/streak.json +24 -0
  133. package/src/posture/CLAUDE.md +42 -0
  134. package/src/posture/adversarial-self-test.js +114 -0
  135. package/src/posture/adversary-agent.js +204 -0
  136. package/src/posture/agents-memory.js +135 -0
  137. package/src/posture/ai-code-fingerprint.js +171 -0
  138. package/src/posture/aibom.js +284 -0
  139. package/src/posture/api-inventory.js +96 -0
  140. package/src/posture/attack-playbooks.js +305 -0
  141. package/src/posture/auditor-agent.js +115 -0
  142. package/src/posture/auth-posture-import.js +135 -0
  143. package/src/posture/baseline-compare.js +114 -0
  144. package/src/posture/blast-radius.js +836 -0
  145. package/src/posture/bounty-prediction.js +141 -0
  146. package/src/posture/business-logic.js +239 -0
  147. package/src/posture/calibration-drift.js +93 -0
  148. package/src/posture/calibration-seed.json +27 -0
  149. package/src/posture/calibration.js +204 -0
  150. package/src/posture/clustering.js +75 -0
  151. package/src/posture/concurrency-checker.js +265 -0
  152. package/src/posture/confidence.js +65 -0
  153. package/src/posture/container-runtime.js +149 -0
  154. package/src/posture/counterfactual.js +109 -0
  155. package/src/posture/cross-lang-graphql.js +165 -0
  156. package/src/posture/cross-lang-grpc.js +166 -0
  157. package/src/posture/cross-lang-meta.js +101 -0
  158. package/src/posture/cross-lang-openapi.js +187 -0
  159. package/src/posture/cross-lang-orm.js +153 -0
  160. package/src/posture/cross-lang-queues.js +210 -0
  161. package/src/posture/crown-jewels.js +110 -0
  162. package/src/posture/custom-rules.js +361 -0
  163. package/src/posture/cve-alert-daemon.js +433 -0
  164. package/src/posture/cve-lookup.js +129 -0
  165. package/src/posture/dead-code.js +430 -0
  166. package/src/posture/defender-agent.js +158 -0
  167. package/src/posture/deploy-platform.js +204 -0
  168. package/src/posture/detector-fuzz.js +61 -0
  169. package/src/posture/deterministic.js +99 -0
  170. package/src/posture/drift.js +165 -0
  171. package/src/posture/epss.js +156 -0
  172. package/src/posture/exploitability-probability.js +212 -0
  173. package/src/posture/exploitability.js +121 -0
  174. package/src/posture/feature-flags.js +110 -0
  175. package/src/posture/finding-defaults.js +132 -0
  176. package/src/posture/fix-history.js +411 -0
  177. package/src/posture/fix-plan.js +121 -0
  178. package/src/posture/fix-verify-loop.js +157 -0
  179. package/src/posture/fix-verify.js +130 -0
  180. package/src/posture/flow-narration.js +105 -0
  181. package/src/posture/grader-calibration.js +156 -0
  182. package/src/posture/harness-discovery.js +113 -0
  183. package/src/posture/holdout-eval.js +144 -0
  184. package/src/posture/iac-reachability.js +163 -0
  185. package/src/posture/iam-policy.js +128 -0
  186. package/src/posture/integrity.js +97 -0
  187. package/src/posture/learning.js +166 -0
  188. package/src/posture/license-policy.js +109 -0
  189. package/src/posture/llm-redteam-prompts.js +418 -0
  190. package/src/posture/llm-redteam.js +303 -0
  191. package/src/posture/material-change.js +163 -0
  192. package/src/posture/mitigation-composite.js +55 -0
  193. package/src/posture/mttr.js +91 -0
  194. package/src/posture/network-policy-import.js +126 -0
  195. package/src/posture/path-predicates.js +99 -0
  196. package/src/posture/persona-prioritization.js +153 -0
  197. package/src/posture/poc-cwe-map.js +51 -0
  198. package/src/posture/poc-generator.js +500 -0
  199. package/src/posture/policy-gate.js +174 -0
  200. package/src/posture/pre-incident-archaeology.js +110 -0
  201. package/src/posture/profile.js +93 -0
  202. package/src/posture/reachability-filter.js +42 -0
  203. package/src/posture/regression-test-gen.js +200 -0
  204. package/src/posture/reverse-blast-radius.js +110 -0
  205. package/src/posture/router.js +109 -0
  206. package/src/posture/rule-overrides.js +198 -0
  207. package/src/posture/rule-pack-signing.js +209 -0
  208. package/src/posture/rule-packs.js +143 -0
  209. package/src/posture/rule-synthesis.js +108 -0
  210. package/src/posture/ruleset-version.js +71 -0
  211. package/src/posture/sbom.js +129 -0
  212. package/src/posture/schema-aware-bridge.js +207 -0
  213. package/src/posture/security-trend.js +87 -0
  214. package/src/posture/semantic-clone.js +114 -0
  215. package/src/posture/specification-mining.js +170 -0
  216. package/src/posture/stable-id.js +75 -0
  217. package/src/posture/stack-playbook.js +229 -0
  218. package/src/posture/streak.js +249 -0
  219. package/src/posture/suppressions.js +135 -0
  220. package/src/posture/telemetry-ingest.js +112 -0
  221. package/src/posture/threat-model.js +145 -0
  222. package/src/posture/three-agent-pipeline.js +74 -0
  223. package/src/posture/triage.js +146 -0
  224. package/src/posture/trust-boundary-diagram.js +115 -0
  225. package/src/posture/type-narrowing.js +129 -0
  226. package/src/posture/validator-metrics.js +179 -0
  227. package/src/posture/verifier-ephemeral.js +118 -0
  228. package/src/posture/verifier-target.js +147 -0
  229. package/src/posture/verifier.js +257 -0
  230. package/src/posture/version.js +75 -0
  231. package/src/posture/waf-ingest.js +200 -0
  232. package/src/posture/why-fired.js +141 -0
  233. package/src/pr-comment.js +172 -0
  234. package/src/pr-delta.js +198 -0
  235. package/src/report/.agentic-security/findings.json +79 -0
  236. package/src/report/.agentic-security/last-scan.json +79 -0
  237. package/src/report/.agentic-security/last-scan.json.sig +1 -0
  238. package/src/report/.agentic-security/scan-history.json +332 -0
  239. package/src/report/.agentic-security/streak.json +23 -0
  240. package/src/report/index.js +1136 -0
  241. package/src/report/mascot.js +42 -0
  242. package/src/runScan.js +141 -0
  243. package/src/sast/.agentic-security/findings.json +5051 -0
  244. package/src/sast/.agentic-security/last-scan.json +5051 -0
  245. package/src/sast/.agentic-security/last-scan.json.sig +1 -0
  246. package/src/sast/.agentic-security/scan-history.json +788 -0
  247. package/src/sast/.agentic-security/streak.json +23 -0
  248. package/src/sast/CLAUDE.md +39 -0
  249. package/src/sast/_comment-strip.js +46 -0
  250. package/src/sast/agent-tool-escalation.js +131 -0
  251. package/src/sast/auth-provider.js +171 -0
  252. package/src/sast/authz.js +236 -0
  253. package/src/sast/bench-shape/.agentic-security/findings.json +28 -0
  254. package/src/sast/bench-shape/.agentic-security/last-scan.json +28 -0
  255. package/src/sast/bench-shape/.agentic-security/scan-history.json +24 -0
  256. package/src/sast/bench-shape/.agentic-security/streak.json +22 -0
  257. package/src/sast/bench-shape/index.js +62 -0
  258. package/src/sast/claude-hook-injection.js +199 -0
  259. package/src/sast/claude-md-prompt-injection.js +170 -0
  260. package/src/sast/claude-settings.js +165 -0
  261. package/src/sast/client-side.js +149 -0
  262. package/src/sast/cpp-bench-extras.js +122 -0
  263. package/src/sast/cpp-dataflow.js +430 -0
  264. package/src/sast/cpp.js +248 -0
  265. package/src/sast/csharp.js +152 -0
  266. package/src/sast/csrf.js +82 -0
  267. package/src/sast/dart-flutter.js +173 -0
  268. package/src/sast/db-rls.js +147 -0
  269. package/src/sast/db-taint.js +215 -0
  270. package/src/sast/defi-deep.js +242 -0
  271. package/src/sast/deserialization-gadgets.js +113 -0
  272. package/src/sast/django-hardening.js +230 -0
  273. package/src/sast/env-hygiene.js +125 -0
  274. package/src/sast/fastapi-hardening.js +145 -0
  275. package/src/sast/go-extended.js +84 -0
  276. package/src/sast/host-header.js +106 -0
  277. package/src/sast/index.js +17 -0
  278. package/src/sast/java-ast-folding.js +561 -0
  279. package/src/sast/java-bench-extras.js +708 -0
  280. package/src/sast/java-collection-passthrough.js +178 -0
  281. package/src/sast/java-constant-fold.js +244 -0
  282. package/src/sast/java-deserialization.js +125 -0
  283. package/src/sast/jndi.js +104 -0
  284. package/src/sast/juliet-shape.js +324 -0
  285. package/src/sast/jwt-exp.js +104 -0
  286. package/src/sast/kotlin.js +82 -0
  287. package/src/sast/laravel-hardening.js +198 -0
  288. package/src/sast/ldap-injection.js +100 -0
  289. package/src/sast/llm-owasp.js +465 -0
  290. package/src/sast/llm-stored-prompt.js +103 -0
  291. package/src/sast/llm-trading-agent.js +161 -0
  292. package/src/sast/llm.js +308 -0
  293. package/src/sast/logic.js +140 -0
  294. package/src/sast/mass-assignment.js +101 -0
  295. package/src/sast/mcp-audit.js +242 -0
  296. package/src/sast/mobile-manifest.js +195 -0
  297. package/src/sast/model-load.js +164 -0
  298. package/src/sast/mutation-xss.js +87 -0
  299. package/src/sast/nosql-injection.js +82 -0
  300. package/src/sast/open-redirect.js +119 -0
  301. package/src/sast/php.js +91 -0
  302. package/src/sast/pipeline.js +122 -0
  303. package/src/sast/primary-cwe-java.js +155 -0
  304. package/src/sast/prompt-firewall.js +151 -0
  305. package/src/sast/prompt-template.js +157 -0
  306. package/src/sast/prototype-pollution.js +112 -0
  307. package/src/sast/python-sinks.js +195 -0
  308. package/src/sast/quarkus-hardening.js +102 -0
  309. package/src/sast/rag-poisoning.js +118 -0
  310. package/src/sast/rate-limit.js +128 -0
  311. package/src/sast/response-splitting.js +138 -0
  312. package/src/sast/ruby.js +108 -0
  313. package/src/sast/rust.js +105 -0
  314. package/src/sast/solidity.js +167 -0
  315. package/src/sast/springboot-hardening.js +186 -0
  316. package/src/sast/ssrf-cloud-metadata.js +80 -0
  317. package/src/sast/ssti.js +116 -0
  318. package/src/sast/swift.js +162 -0
  319. package/src/sast/toctou.js +95 -0
  320. package/src/sast/webhook.js +101 -0
  321. package/src/sast/xpath-injection.js +51 -0
  322. package/src/sast/xxe.js +140 -0
  323. package/src/sast/zip-slip.js +200 -0
  324. package/src/sca/base-images.json +45 -0
  325. package/src/sca/container.js +107 -0
  326. package/src/sca/dep-confusion.js +134 -0
  327. package/src/sca/index.js +6 -0
  328. package/src/sca/popular-packages.json +41 -0
  329. package/src/sca/sarif-ingest.js +187 -0
  330. package/src/sca/vuln-function-hints.json +89 -0
  331. package/src/secrets/index.js +4 -0
@@ -0,0 +1,373 @@
1
+ export const id = 513;
2
+ export const ids = [513,117];
3
+ export const modules = {
4
+
5
+ /***/ 3117:
6
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
7
+
8
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
9
+ /* harmony export */ iI: () => (/* binding */ summarizeForBadge),
10
+ /* harmony export */ renderBadge: () => (/* binding */ renderBadge)
11
+ /* harmony export */ });
12
+ /* unused harmony exports badgeFromScanRoot, renderSvg, _internal */
13
+ /* harmony import */ var node_fs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3024);
14
+ /* harmony import */ var node_path__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6760);
15
+ // Live SVG badge generator (v0.72).
16
+ //
17
+ // Every repo can drop a badge in its README pulling from the latest scan:
18
+ //
19
+ // ![agentic-security](https://agentic-security.dev/badge?repo=<slug>)
20
+ //
21
+ // or self-hosted via the CLI subcommand emitting an inline <img> URL or
22
+ // a static SVG. The badge format borrows from shields.io for visual
23
+ // consistency. Reads from .agentic-security/last-scan.json or accepts a
24
+ // scan object directly.
25
+ //
26
+ // Output formats:
27
+ // - 'svg' — inline SVG string (default; the bytes you'd serve)
28
+ // - 'json' — { label, count, color, severity } for a frontend renderer
29
+ //
30
+ // Style variants:
31
+ // - 'flat' — shields.io flat
32
+ // - 'for-the-badge' — caps + thicker
33
+ //
34
+ // Color is driven by the highest non-zero severity:
35
+ // critical → red
36
+ // high → orange
37
+ // medium → yellow
38
+ // low → blue
39
+ // info → lightgrey
40
+ // none → brightgreen
41
+
42
+
43
+
44
+
45
+ const COLORS = {
46
+ critical: '#e05d44', // red
47
+ high: '#fe7d37', // orange
48
+ medium: '#dfb317', // yellow
49
+ low: '#007ec6', // blue
50
+ info: '#9f9f9f', // grey
51
+ none: '#4c1', // brightgreen
52
+ label: '#555',
53
+ };
54
+
55
+ const SEVERITIES = ['critical', 'high', 'medium', 'low', 'info'];
56
+
57
+ function _readLastScan(scanRoot) {
58
+ if (!scanRoot) return null;
59
+ const fp = node_path__WEBPACK_IMPORTED_MODULE_1__.join(scanRoot, '.agentic-security', 'last-scan.json');
60
+ if (!node_fs__WEBPACK_IMPORTED_MODULE_0__.existsSync(fp)) return null;
61
+ try { return JSON.parse(node_fs__WEBPACK_IMPORTED_MODULE_0__.readFileSync(fp, 'utf8')); }
62
+ catch { return null; }
63
+ }
64
+
65
+ function _ageString(ts) {
66
+ if (!ts) return null;
67
+ const ageMs = Date.now() - new Date(ts).getTime();
68
+ if (isNaN(ageMs) || ageMs < 0) return null;
69
+ const min = Math.floor(ageMs / 60_000);
70
+ if (min < 60) return `${min}m ago`;
71
+ const hr = Math.floor(min / 60);
72
+ if (hr < 24) return `${hr}h ago`;
73
+ const day = Math.floor(hr / 24);
74
+ return `${day}d ago`;
75
+ }
76
+
77
+ /**
78
+ * Compute the badge value from a scan object.
79
+ *
80
+ * Returns:
81
+ * {
82
+ * label: 'agentic-security',
83
+ * summary: 'critical 0 · high 2 · medium 5' | 'passing' | 'no scan',
84
+ * color: '#fe7d37',
85
+ * highest: 'high' | 'none' | 'unknown',
86
+ * ageStr: '4h ago' | null,
87
+ * counts: { critical, high, medium, low, info },
88
+ * total: 7,
89
+ * }
90
+ */
91
+ function summarizeForBadge(scan) {
92
+ if (!scan || !Array.isArray(scan.findings)) {
93
+ return {
94
+ label: 'agentic-security',
95
+ summary: 'no scan',
96
+ color: COLORS.info,
97
+ highest: 'unknown',
98
+ ageStr: null,
99
+ counts: { critical: 0, high: 0, medium: 0, low: 0, info: 0 },
100
+ total: 0,
101
+ };
102
+ }
103
+ const counts = { critical: 0, high: 0, medium: 0, low: 0, info: 0 };
104
+ for (const f of scan.findings) {
105
+ const s = f.severity || 'info';
106
+ if (counts[s] !== undefined) counts[s]++;
107
+ }
108
+ let highest = 'none';
109
+ for (const s of SEVERITIES) { if (counts[s] > 0) { highest = s; break; } }
110
+ const color = COLORS[highest] || COLORS.info;
111
+ const summary = highest === 'none'
112
+ ? 'passing'
113
+ : `crit ${counts.critical} · high ${counts.high} · med ${counts.medium}`;
114
+ const total = SEVERITIES.reduce((a, s) => a + counts[s], 0);
115
+ return {
116
+ label: 'agentic-security',
117
+ summary,
118
+ color,
119
+ highest,
120
+ ageStr: _ageString(scan.timestamp || scan.when || scan.lastScan),
121
+ counts,
122
+ total,
123
+ };
124
+ }
125
+
126
+ /**
127
+ * Compute the badge from .agentic-security/last-scan.json under `scanRoot`.
128
+ */
129
+ function badgeFromScanRoot(scanRoot) {
130
+ return summarizeForBadge(_readLastScan(scanRoot));
131
+ }
132
+
133
+ function _xmlEscape(s) {
134
+ return String(s).replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');
135
+ }
136
+
137
+ function _textWidth(s) {
138
+ // Rough character width — works fine for the small badge label range.
139
+ return s.length * 7 + 10;
140
+ }
141
+
142
+ /**
143
+ * Render an inline SVG matching shields.io's flat style. Self-contained
144
+ * (no external font references) so the badge works in any README.
145
+ */
146
+ function renderSvg(b, opts = {}) {
147
+ if (!b) b = summarizeForBadge(null);
148
+ const style = opts.style || 'flat';
149
+ const labelText = b.label;
150
+ const valueText = b.ageStr ? `${b.summary} · ${b.ageStr}` : b.summary;
151
+ const lblW = _textWidth(labelText);
152
+ const valW = _textWidth(valueText);
153
+ const totalW = lblW + valW;
154
+ const h = style === 'for-the-badge' ? 28 : 20;
155
+ const fontSize = style === 'for-the-badge' ? 12 : 11;
156
+ return `<svg xmlns="http://www.w3.org/2000/svg" width="${totalW}" height="${h}" role="img" aria-label="${_xmlEscape(labelText)}: ${_xmlEscape(valueText)}">
157
+ <title>${_xmlEscape(labelText)}: ${_xmlEscape(valueText)}</title>
158
+ <linearGradient id="s" x2="0" y2="100%">
159
+ <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
160
+ <stop offset="1" stop-opacity=".1"/>
161
+ </linearGradient>
162
+ <clipPath id="r"><rect width="${totalW}" height="${h}" rx="3" fill="#fff"/></clipPath>
163
+ <g clip-path="url(#r)">
164
+ <rect width="${lblW}" height="${h}" fill="${COLORS.label}"/>
165
+ <rect x="${lblW}" width="${valW}" height="${h}" fill="${b.color}"/>
166
+ <rect width="${totalW}" height="${h}" fill="url(#s)"/>
167
+ </g>
168
+ <g fill="#fff" text-anchor="middle" font-family="Verdana,Geneva,DejaVu Sans,sans-serif" font-size="${fontSize}">
169
+ <text aria-hidden="true" x="${lblW / 2}" y="${h - 6}" fill="#010101" fill-opacity=".3">${_xmlEscape(labelText)}</text>
170
+ <text x="${lblW / 2}" y="${h - 7}">${_xmlEscape(labelText)}</text>
171
+ <text aria-hidden="true" x="${lblW + valW / 2}" y="${h - 6}" fill="#010101" fill-opacity=".3">${_xmlEscape(valueText)}</text>
172
+ <text x="${lblW + valW / 2}" y="${h - 7}">${_xmlEscape(valueText)}</text>
173
+ </g>
174
+ </svg>`;
175
+ }
176
+
177
+ /**
178
+ * Public entry: produce the badge in the requested format.
179
+ *
180
+ * format: 'svg' (default) | 'json'
181
+ * style: 'flat' (default) | 'for-the-badge'
182
+ * scanRoot: directory containing .agentic-security/last-scan.json
183
+ * scan: pre-loaded scan object (skips disk read)
184
+ */
185
+ function renderBadge({ format = 'svg', style = 'flat', scanRoot, scan } = {}) {
186
+ const summary = summarizeForBadge(scan || _readLastScan(scanRoot));
187
+ if (format === 'json') {
188
+ return JSON.stringify({
189
+ schemaVersion: 1,
190
+ label: summary.label,
191
+ message: summary.summary,
192
+ color: summary.color,
193
+ highest: summary.highest,
194
+ ageStr: summary.ageStr,
195
+ counts: summary.counts,
196
+ total: summary.total,
197
+ });
198
+ }
199
+ return renderSvg(summary, { style });
200
+ }
201
+
202
+ const _internal = { COLORS, _ageString, _readLastScan };
203
+
204
+
205
+ /***/ }),
206
+
207
+ /***/ 8513:
208
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
209
+
210
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
211
+ /* harmony export */ leaderboardRowFor: () => (/* binding */ leaderboardRowFor)
212
+ /* harmony export */ });
213
+ /* unused harmony exports rankRows, _internal */
214
+ /* harmony import */ var node_fs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3024);
215
+ /* harmony import */ var node_path__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6760);
216
+ /* harmony import */ var _badge_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3117);
217
+ // Leaderboard backend (v0.72).
218
+ //
219
+ // Generates the data shape that powers the future public leaderboard at
220
+ // agentic-security.dev/leaderboard. The leaderboard ranks repos by their
221
+ // security posture under our scanner — F1-on-CVE-history when we can
222
+ // compute it, otherwise just last-scan severity counts.
223
+ //
224
+ // Public hosting of the site is deferred — we ship the data side now so
225
+ // the future site is a thin frontend over this JSON.
226
+ //
227
+ // One leaderboard row per repo:
228
+ //
229
+ // {
230
+ // repo: 'owner/name',
231
+ // score: { critical, high, medium, low, info, total },
232
+ // postureGrade: 'A' | 'B' | 'C' | 'D' | 'F',
233
+ // lastScanAge: '4h',
234
+ // topCwe: 'CWE-89',
235
+ // deltaTrend: 'improving' | 'flat' | 'regressing',
236
+ // badgeUrl: 'https://agentic-security.dev/badge?repo=…',
237
+ // }
238
+ //
239
+ // The grader is intentionally coarse — single letter — so the leaderboard
240
+ // stays scannable. Tie-break by lowest critical-count, then by recency.
241
+
242
+
243
+
244
+
245
+
246
+ // Grade thresholds. Critical findings dominate; high/medium contribute
247
+ // secondarily. These numbers are heuristic — calibrate against the
248
+ // public leaderboard corpus once data lands.
249
+ function _postureGrade(counts) {
250
+ if (!counts) return 'F';
251
+ const c = counts.critical || 0;
252
+ const h = counts.high || 0;
253
+ const m = counts.medium || 0;
254
+ if (c === 0 && h === 0 && m === 0) return 'A';
255
+ if (c === 0 && h === 0 && m <= 5) return 'B';
256
+ if (c === 0 && h <= 2) return 'C';
257
+ if (c <= 1 && h <= 5) return 'D';
258
+ return 'F';
259
+ }
260
+
261
+ function _ageString(ts) {
262
+ if (!ts) return null;
263
+ const ageMs = Date.now() - new Date(ts).getTime();
264
+ if (isNaN(ageMs) || ageMs < 0) return null;
265
+ const min = Math.floor(ageMs / 60_000);
266
+ if (min < 60) return `${min}m`;
267
+ const hr = Math.floor(min / 60);
268
+ if (hr < 24) return `${hr}h`;
269
+ const day = Math.floor(hr / 24);
270
+ return `${day}d`;
271
+ }
272
+
273
+ function _topCwe(scan) {
274
+ if (!scan || !Array.isArray(scan.findings)) return null;
275
+ const counts = new Map();
276
+ for (const f of scan.findings) {
277
+ if (!f.cwe) continue;
278
+ counts.set(f.cwe, (counts.get(f.cwe) || 0) + 1);
279
+ }
280
+ let topCwe = null, topN = 0;
281
+ for (const [cwe, n] of counts) {
282
+ if (n > topN) { topCwe = cwe; topN = n; }
283
+ }
284
+ return topCwe;
285
+ }
286
+
287
+ function _deltaTrend(history) {
288
+ // history: array of past scan summaries with `.timestamp` + `.severityCounts.critical`
289
+ if (!Array.isArray(history) || history.length < 2) return 'flat';
290
+ const recent = history.slice(-3);
291
+ const first = recent[0].severityCounts || {};
292
+ const last = recent[recent.length - 1].severityCounts || {};
293
+ const fScore = (first.critical || 0) * 4 + (first.high || 0);
294
+ const lScore = (last.critical || 0) * 4 + (last.high || 0);
295
+ if (lScore < fScore - 1) return 'improving';
296
+ if (lScore > fScore + 1) return 'regressing';
297
+ return 'flat';
298
+ }
299
+
300
+ /**
301
+ * Build a single leaderboard row for a repo. Reads the latest scan from
302
+ * `<scanRoot>/.agentic-security/last-scan.json` and (optionally) history
303
+ * from `<scanRoot>/.agentic-security/scan-history.jsonl`.
304
+ *
305
+ * `repo` is the GitHub slug ('owner/name'); used to drive the badge URL.
306
+ */
307
+ function leaderboardRowFor({ scanRoot, repo, badgeBase = 'https://agentic-security.dev/badge' } = {}) {
308
+ if (!repo) throw new Error('leaderboardRowFor: repo slug is required');
309
+ const lastScanPath = node_path__WEBPACK_IMPORTED_MODULE_1__.join(scanRoot || '.', '.agentic-security', 'last-scan.json');
310
+ let scan = null;
311
+ try { scan = JSON.parse(node_fs__WEBPACK_IMPORTED_MODULE_0__.readFileSync(lastScanPath, 'utf8')); } catch {}
312
+ const summary = (0,_badge_js__WEBPACK_IMPORTED_MODULE_2__/* .summarizeForBadge */ .iI)(scan);
313
+ const grade = _postureGrade(summary.counts);
314
+ const topCwe = _topCwe(scan);
315
+
316
+ // Optional scan history for the trend signal.
317
+ const historyPath = node_path__WEBPACK_IMPORTED_MODULE_1__.join(scanRoot || '.', '.agentic-security', 'scan-history.jsonl');
318
+ let history = [];
319
+ if (node_fs__WEBPACK_IMPORTED_MODULE_0__.existsSync(historyPath)) {
320
+ try {
321
+ history = node_fs__WEBPACK_IMPORTED_MODULE_0__.readFileSync(historyPath, 'utf8').split('\n')
322
+ .map(l => l.trim()).filter(Boolean)
323
+ .map(l => { try { return JSON.parse(l); } catch { return null; } })
324
+ .filter(Boolean);
325
+ } catch {}
326
+ }
327
+ const deltaTrend = _deltaTrend(history);
328
+
329
+ return {
330
+ repo,
331
+ score: { ...summary.counts, total: summary.total },
332
+ postureGrade: grade,
333
+ lastScanAge: _ageString(scan?.timestamp || scan?.when),
334
+ topCwe,
335
+ deltaTrend,
336
+ badgeUrl: `${badgeBase}?repo=${encodeURIComponent(repo)}`,
337
+ badgeMarkdown: `![agentic-security](${badgeBase}?repo=${encodeURIComponent(repo)})`,
338
+ };
339
+ }
340
+
341
+ /**
342
+ * Rank a list of rows for the leaderboard. Sort by:
343
+ * 1. lower critical count
344
+ * 2. lower high count
345
+ * 3. higher postureGrade (A > F)
346
+ * 4. fresher lastScanAge
347
+ *
348
+ * Returns the input rows annotated with `rank` (1-indexed).
349
+ */
350
+ function rankRows(rows) {
351
+ if (!Array.isArray(rows)) return [];
352
+ const gradeOrder = { A: 0, B: 1, C: 2, D: 3, F: 4 };
353
+ const sorted = [...rows].sort((a, b) => {
354
+ const ac = a.score?.critical || 0;
355
+ const bc = b.score?.critical || 0;
356
+ if (ac !== bc) return ac - bc;
357
+ const ah = a.score?.high || 0;
358
+ const bh = b.score?.high || 0;
359
+ if (ah !== bh) return ah - bh;
360
+ const ag = gradeOrder[a.postureGrade] ?? 5;
361
+ const bg = gradeOrder[b.postureGrade] ?? 5;
362
+ if (ag !== bg) return ag - bg;
363
+ return 0;
364
+ });
365
+ return sorted.map((r, i) => ({ ...r, rank: i + 1 }));
366
+ }
367
+
368
+ const _internal = { _postureGrade, _ageString, _topCwe, _deltaTrend };
369
+
370
+
371
+ /***/ })
372
+
373
+ };
@@ -0,0 +1,13 @@
1
+ export const id = 520;
2
+ export const ids = [520];
3
+ export const modules = {
4
+
5
+ /***/ 8520:
6
+ /***/ ((module) => {
7
+
8
+ module.exports = eval("require")("z3-solver");
9
+
10
+
11
+ /***/ })
12
+
13
+ };