@vibecheckai/cli 2.5.1

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 (415) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +532 -0
  3. package/dist/autopatch/verified-autopatch.d.ts +111 -0
  4. package/dist/autopatch/verified-autopatch.d.ts.map +1 -0
  5. package/dist/autopatch/verified-autopatch.js +503 -0
  6. package/dist/autopatch/verified-autopatch.js.map +1 -0
  7. package/dist/bundles/guardrail-core.js +25799 -0
  8. package/dist/bundles/guardrail-security.js +208687 -0
  9. package/dist/bundles/guardrail-ship.js +2318 -0
  10. package/dist/bundles/index.js +8 -0
  11. package/dist/commands/autopilot-decision.d.ts +24 -0
  12. package/dist/commands/autopilot-decision.d.ts.map +1 -0
  13. package/dist/commands/autopilot-decision.js +304 -0
  14. package/dist/commands/autopilot-decision.js.map +1 -0
  15. package/dist/commands/autopilot.d.ts +33 -0
  16. package/dist/commands/autopilot.d.ts.map +1 -0
  17. package/dist/commands/autopilot.js +1539 -0
  18. package/dist/commands/autopilot.js.map +1 -0
  19. package/dist/commands/baseline.d.ts +7 -0
  20. package/dist/commands/baseline.d.ts.map +1 -0
  21. package/dist/commands/baseline.js +79 -0
  22. package/dist/commands/baseline.js.map +1 -0
  23. package/dist/commands/cache.d.ts +13 -0
  24. package/dist/commands/cache.d.ts.map +1 -0
  25. package/dist/commands/cache.js +165 -0
  26. package/dist/commands/cache.js.map +1 -0
  27. package/dist/commands/checkpoint.d.ts +8 -0
  28. package/dist/commands/checkpoint.d.ts.map +1 -0
  29. package/dist/commands/checkpoint.js +35 -0
  30. package/dist/commands/checkpoint.js.map +1 -0
  31. package/dist/commands/context.d.ts +8 -0
  32. package/dist/commands/context.d.ts.map +1 -0
  33. package/dist/commands/context.js +340 -0
  34. package/dist/commands/context.js.map +1 -0
  35. package/dist/commands/debug.d.ts +78 -0
  36. package/dist/commands/debug.d.ts.map +1 -0
  37. package/dist/commands/debug.js +381 -0
  38. package/dist/commands/debug.js.map +1 -0
  39. package/dist/commands/doctor.d.ts +17 -0
  40. package/dist/commands/doctor.d.ts.map +1 -0
  41. package/dist/commands/doctor.js +226 -0
  42. package/dist/commands/doctor.js.map +1 -0
  43. package/dist/commands/evidence.d.ts +45 -0
  44. package/dist/commands/evidence.d.ts.map +1 -0
  45. package/dist/commands/evidence.js +197 -0
  46. package/dist/commands/evidence.js.map +1 -0
  47. package/dist/commands/explain.d.ts +8 -0
  48. package/dist/commands/explain.d.ts.map +1 -0
  49. package/dist/commands/explain.js +52 -0
  50. package/dist/commands/explain.js.map +1 -0
  51. package/dist/commands/fix-consolidated.d.ts +19 -0
  52. package/dist/commands/fix-consolidated.d.ts.map +1 -0
  53. package/dist/commands/fix-consolidated.js +165 -0
  54. package/dist/commands/fix-consolidated.js.map +1 -0
  55. package/dist/commands/index.d.ts +8 -0
  56. package/dist/commands/index.d.ts.map +1 -0
  57. package/dist/commands/index.js +15 -0
  58. package/dist/commands/index.js.map +1 -0
  59. package/dist/commands/init.d.ts +8 -0
  60. package/dist/commands/init.d.ts.map +1 -0
  61. package/dist/commands/init.js +125 -0
  62. package/dist/commands/init.js.map +1 -0
  63. package/dist/commands/launcher.d.ts +10 -0
  64. package/dist/commands/launcher.d.ts.map +1 -0
  65. package/dist/commands/launcher.js +174 -0
  66. package/dist/commands/launcher.js.map +1 -0
  67. package/dist/commands/on.d.ts +8 -0
  68. package/dist/commands/on.d.ts.map +1 -0
  69. package/dist/commands/on.js +123 -0
  70. package/dist/commands/on.js.map +1 -0
  71. package/dist/commands/preview.d.ts +54 -0
  72. package/dist/commands/preview.d.ts.map +1 -0
  73. package/dist/commands/preview.js +352 -0
  74. package/dist/commands/preview.js.map +1 -0
  75. package/dist/commands/quality/check.d.ts +31 -0
  76. package/dist/commands/quality/check.d.ts.map +1 -0
  77. package/dist/commands/quality/check.js +242 -0
  78. package/dist/commands/quality/check.js.map +1 -0
  79. package/dist/commands/quality/index.d.ts +8 -0
  80. package/dist/commands/quality/index.d.ts.map +1 -0
  81. package/dist/commands/quality/index.js +14 -0
  82. package/dist/commands/quality/index.js.map +1 -0
  83. package/dist/commands/quality/setup-quality.d.ts +23 -0
  84. package/dist/commands/quality/setup-quality.d.ts.map +1 -0
  85. package/dist/commands/quality/setup-quality.js +452 -0
  86. package/dist/commands/quality/setup-quality.js.map +1 -0
  87. package/dist/commands/quality/tidy.d.ts +41 -0
  88. package/dist/commands/quality/tidy.d.ts.map +1 -0
  89. package/dist/commands/quality/tidy.js +466 -0
  90. package/dist/commands/quality/tidy.js.map +1 -0
  91. package/dist/commands/quality/utils.d.ts +73 -0
  92. package/dist/commands/quality/utils.d.ts.map +1 -0
  93. package/dist/commands/quality/utils.js +158 -0
  94. package/dist/commands/quality/utils.js.map +1 -0
  95. package/dist/commands/replay.d.ts +8 -0
  96. package/dist/commands/replay.d.ts.map +1 -0
  97. package/dist/commands/replay.js +52 -0
  98. package/dist/commands/replay.js.map +1 -0
  99. package/dist/commands/scan-consolidated.d.ts +61 -0
  100. package/dist/commands/scan-consolidated.d.ts.map +1 -0
  101. package/dist/commands/scan-consolidated.js +243 -0
  102. package/dist/commands/scan-consolidated.js.map +1 -0
  103. package/dist/commands/scan-secrets.d.ts +47 -0
  104. package/dist/commands/scan-secrets.d.ts.map +1 -0
  105. package/dist/commands/scan-secrets.js +225 -0
  106. package/dist/commands/scan-secrets.js.map +1 -0
  107. package/dist/commands/scan-vulnerabilities-enhanced.d.ts +41 -0
  108. package/dist/commands/scan-vulnerabilities-enhanced.d.ts.map +1 -0
  109. package/dist/commands/scan-vulnerabilities-enhanced.js +368 -0
  110. package/dist/commands/scan-vulnerabilities-enhanced.js.map +1 -0
  111. package/dist/commands/scan-vulnerabilities-osv.d.ts +58 -0
  112. package/dist/commands/scan-vulnerabilities-osv.d.ts.map +1 -0
  113. package/dist/commands/scan-vulnerabilities-osv.js +716 -0
  114. package/dist/commands/scan-vulnerabilities-osv.js.map +1 -0
  115. package/dist/commands/scan-vulnerabilities.d.ts +32 -0
  116. package/dist/commands/scan-vulnerabilities.d.ts.map +1 -0
  117. package/dist/commands/scan-vulnerabilities.js +283 -0
  118. package/dist/commands/scan-vulnerabilities.js.map +1 -0
  119. package/dist/commands/secrets-allowlist.d.ts +7 -0
  120. package/dist/commands/secrets-allowlist.d.ts.map +1 -0
  121. package/dist/commands/secrets-allowlist.js +85 -0
  122. package/dist/commands/secrets-allowlist.js.map +1 -0
  123. package/dist/commands/ship-consolidated.d.ts +58 -0
  124. package/dist/commands/ship-consolidated.d.ts.map +1 -0
  125. package/dist/commands/ship-consolidated.js +515 -0
  126. package/dist/commands/ship-consolidated.js.map +1 -0
  127. package/dist/commands/stats.d.ts +8 -0
  128. package/dist/commands/stats.d.ts.map +1 -0
  129. package/dist/commands/stats.js +134 -0
  130. package/dist/commands/stats.js.map +1 -0
  131. package/dist/commands/upgrade.d.ts +8 -0
  132. package/dist/commands/upgrade.d.ts.map +1 -0
  133. package/dist/commands/upgrade.js +30 -0
  134. package/dist/commands/upgrade.js.map +1 -0
  135. package/dist/fix/analytics.d.ts +121 -0
  136. package/dist/fix/analytics.d.ts.map +1 -0
  137. package/dist/fix/analytics.js +289 -0
  138. package/dist/fix/analytics.js.map +1 -0
  139. package/dist/fix/applicator.d.ts +44 -0
  140. package/dist/fix/applicator.d.ts.map +1 -0
  141. package/dist/fix/applicator.js +144 -0
  142. package/dist/fix/applicator.js.map +1 -0
  143. package/dist/fix/audit.d.ts +61 -0
  144. package/dist/fix/audit.d.ts.map +1 -0
  145. package/dist/fix/audit.js +149 -0
  146. package/dist/fix/audit.js.map +1 -0
  147. package/dist/fix/backup.d.ts +38 -0
  148. package/dist/fix/backup.d.ts.map +1 -0
  149. package/dist/fix/backup.js +154 -0
  150. package/dist/fix/backup.js.map +1 -0
  151. package/dist/fix/config.d.ts +78 -0
  152. package/dist/fix/config.d.ts.map +1 -0
  153. package/dist/fix/config.js +200 -0
  154. package/dist/fix/config.js.map +1 -0
  155. package/dist/fix/engine.d.ts +55 -0
  156. package/dist/fix/engine.d.ts.map +1 -0
  157. package/dist/fix/engine.js +285 -0
  158. package/dist/fix/engine.js.map +1 -0
  159. package/dist/fix/impact.d.ts +74 -0
  160. package/dist/fix/impact.d.ts.map +1 -0
  161. package/dist/fix/impact.js +281 -0
  162. package/dist/fix/impact.js.map +1 -0
  163. package/dist/fix/index.d.ts +5 -0
  164. package/dist/fix/index.d.ts.map +1 -0
  165. package/dist/fix/index.js +12 -0
  166. package/dist/fix/index.js.map +1 -0
  167. package/dist/fix/interactive.d.ts +22 -0
  168. package/dist/fix/interactive.d.ts.map +1 -0
  169. package/dist/fix/interactive.js +172 -0
  170. package/dist/fix/interactive.js.map +1 -0
  171. package/dist/fix/learning.d.ts +109 -0
  172. package/dist/fix/learning.d.ts.map +1 -0
  173. package/dist/fix/learning.js +296 -0
  174. package/dist/fix/learning.js.map +1 -0
  175. package/dist/fix/metrics.d.ts +106 -0
  176. package/dist/fix/metrics.d.ts.map +1 -0
  177. package/dist/fix/metrics.js +138 -0
  178. package/dist/fix/metrics.js.map +1 -0
  179. package/dist/fix/parallel.d.ts +69 -0
  180. package/dist/fix/parallel.d.ts.map +1 -0
  181. package/dist/fix/parallel.js +203 -0
  182. package/dist/fix/parallel.js.map +1 -0
  183. package/dist/fix/report.d.ts +40 -0
  184. package/dist/fix/report.d.ts.map +1 -0
  185. package/dist/fix/report.js +212 -0
  186. package/dist/fix/report.js.map +1 -0
  187. package/dist/fix/strategy.d.ts +53 -0
  188. package/dist/fix/strategy.d.ts.map +1 -0
  189. package/dist/fix/strategy.js +143 -0
  190. package/dist/fix/strategy.js.map +1 -0
  191. package/dist/fix/templates.d.ts +58 -0
  192. package/dist/fix/templates.d.ts.map +1 -0
  193. package/dist/fix/templates.js +259 -0
  194. package/dist/fix/templates.js.map +1 -0
  195. package/dist/fix/testing.d.ts +68 -0
  196. package/dist/fix/testing.d.ts.map +1 -0
  197. package/dist/fix/testing.js +245 -0
  198. package/dist/fix/testing.js.map +1 -0
  199. package/dist/fix/validation.d.ts +71 -0
  200. package/dist/fix/validation.d.ts.map +1 -0
  201. package/dist/fix/validation.js +267 -0
  202. package/dist/fix/validation.js.map +1 -0
  203. package/dist/fix/visualization.d.ts +73 -0
  204. package/dist/fix/visualization.d.ts.map +1 -0
  205. package/dist/fix/visualization.js +243 -0
  206. package/dist/fix/visualization.js.map +1 -0
  207. package/dist/formatters/index.d.ts +6 -0
  208. package/dist/formatters/index.d.ts.map +1 -0
  209. package/dist/formatters/index.js +11 -0
  210. package/dist/formatters/index.js.map +1 -0
  211. package/dist/formatters/sarif-enhanced.d.ts +78 -0
  212. package/dist/formatters/sarif-enhanced.d.ts.map +1 -0
  213. package/dist/formatters/sarif-enhanced.js +144 -0
  214. package/dist/formatters/sarif-enhanced.js.map +1 -0
  215. package/dist/formatters/sarif-v2.d.ts +121 -0
  216. package/dist/formatters/sarif-v2.d.ts.map +1 -0
  217. package/dist/formatters/sarif-v2.js +356 -0
  218. package/dist/formatters/sarif-v2.js.map +1 -0
  219. package/dist/formatters/sarif.d.ts +72 -0
  220. package/dist/formatters/sarif.d.ts.map +1 -0
  221. package/dist/formatters/sarif.js +146 -0
  222. package/dist/formatters/sarif.js.map +1 -0
  223. package/dist/index.d.ts +61 -0
  224. package/dist/index.d.ts.map +1 -0
  225. package/dist/index.js +4455 -0
  226. package/dist/index.js.map +1 -0
  227. package/dist/init/ci-generator.d.ts +18 -0
  228. package/dist/init/ci-generator.d.ts.map +1 -0
  229. package/dist/init/ci-generator.js +317 -0
  230. package/dist/init/ci-generator.js.map +1 -0
  231. package/dist/init/detect-framework.d.ts +15 -0
  232. package/dist/init/detect-framework.d.ts.map +1 -0
  233. package/dist/init/detect-framework.js +301 -0
  234. package/dist/init/detect-framework.js.map +1 -0
  235. package/dist/init/hooks-installer.d.ts +22 -0
  236. package/dist/init/hooks-installer.d.ts.map +1 -0
  237. package/dist/init/hooks-installer.js +310 -0
  238. package/dist/init/hooks-installer.js.map +1 -0
  239. package/dist/init/index.d.ts +8 -0
  240. package/dist/init/index.d.ts.map +1 -0
  241. package/dist/init/index.js +22 -0
  242. package/dist/init/index.js.map +1 -0
  243. package/dist/init/templates.d.ts +401 -0
  244. package/dist/init/templates.d.ts.map +1 -0
  245. package/dist/init/templates.js +240 -0
  246. package/dist/init/templates.js.map +1 -0
  247. package/dist/mcp/server.d.ts +12 -0
  248. package/dist/mcp/server.d.ts.map +1 -0
  249. package/dist/mcp/server.js +42 -0
  250. package/dist/mcp/server.js.map +1 -0
  251. package/dist/mcp/telemetry.d.ts +40 -0
  252. package/dist/mcp/telemetry.d.ts.map +1 -0
  253. package/dist/mcp/telemetry.js +98 -0
  254. package/dist/mcp/telemetry.js.map +1 -0
  255. package/dist/reality/no-dead-buttons/button-sweep-generator.d.ts +32 -0
  256. package/dist/reality/no-dead-buttons/button-sweep-generator.d.ts.map +1 -0
  257. package/dist/reality/no-dead-buttons/button-sweep-generator.js +236 -0
  258. package/dist/reality/no-dead-buttons/button-sweep-generator.js.map +1 -0
  259. package/dist/reality/no-dead-buttons/index.d.ts +11 -0
  260. package/dist/reality/no-dead-buttons/index.d.ts.map +1 -0
  261. package/dist/reality/no-dead-buttons/index.js +18 -0
  262. package/dist/reality/no-dead-buttons/index.js.map +1 -0
  263. package/dist/reality/no-dead-buttons/static-scanner.d.ts +34 -0
  264. package/dist/reality/no-dead-buttons/static-scanner.d.ts.map +1 -0
  265. package/dist/reality/no-dead-buttons/static-scanner.js +230 -0
  266. package/dist/reality/no-dead-buttons/static-scanner.js.map +1 -0
  267. package/dist/reality/reality-graph.d.ts +192 -0
  268. package/dist/reality/reality-graph.d.ts.map +1 -0
  269. package/dist/reality/reality-graph.js +600 -0
  270. package/dist/reality/reality-graph.js.map +1 -0
  271. package/dist/reality/reality-runner.d.ts +89 -0
  272. package/dist/reality/reality-runner.d.ts.map +1 -0
  273. package/dist/reality/reality-runner.js +540 -0
  274. package/dist/reality/reality-runner.js.map +1 -0
  275. package/dist/reality/receipt-generator.d.ts +152 -0
  276. package/dist/reality/receipt-generator.d.ts.map +1 -0
  277. package/dist/reality/receipt-generator.js +495 -0
  278. package/dist/reality/receipt-generator.js.map +1 -0
  279. package/dist/reality/runtime-tracer.d.ts +75 -0
  280. package/dist/reality/runtime-tracer.d.ts.map +1 -0
  281. package/dist/reality/runtime-tracer.js +109 -0
  282. package/dist/reality/runtime-tracer.js.map +1 -0
  283. package/dist/runtime/auth-utils.d.ts +43 -0
  284. package/dist/runtime/auth-utils.d.ts.map +1 -0
  285. package/dist/runtime/auth-utils.js +130 -0
  286. package/dist/runtime/auth-utils.js.map +1 -0
  287. package/dist/runtime/cli-errors.d.ts +38 -0
  288. package/dist/runtime/cli-errors.d.ts.map +1 -0
  289. package/dist/runtime/cli-errors.js +354 -0
  290. package/dist/runtime/cli-errors.js.map +1 -0
  291. package/dist/runtime/client.d.ts +74 -0
  292. package/dist/runtime/client.d.ts.map +1 -0
  293. package/dist/runtime/client.js +222 -0
  294. package/dist/runtime/client.js.map +1 -0
  295. package/dist/runtime/creds.d.ts +48 -0
  296. package/dist/runtime/creds.d.ts.map +1 -0
  297. package/dist/runtime/creds.js +245 -0
  298. package/dist/runtime/creds.js.map +1 -0
  299. package/dist/runtime/exit-codes.d.ts +49 -0
  300. package/dist/runtime/exit-codes.d.ts.map +1 -0
  301. package/dist/runtime/exit-codes.js +93 -0
  302. package/dist/runtime/exit-codes.js.map +1 -0
  303. package/dist/runtime/index.d.ts +9 -0
  304. package/dist/runtime/index.d.ts.map +1 -0
  305. package/dist/runtime/index.js +25 -0
  306. package/dist/runtime/index.js.map +1 -0
  307. package/dist/runtime/json-output.d.ts +42 -0
  308. package/dist/runtime/json-output.d.ts.map +1 -0
  309. package/dist/runtime/json-output.js +59 -0
  310. package/dist/runtime/json-output.js.map +1 -0
  311. package/dist/runtime/owner-mode.d.ts +48 -0
  312. package/dist/runtime/owner-mode.d.ts.map +1 -0
  313. package/dist/runtime/owner-mode.js +284 -0
  314. package/dist/runtime/owner-mode.js.map +1 -0
  315. package/dist/runtime/semver.d.ts +37 -0
  316. package/dist/runtime/semver.d.ts.map +1 -0
  317. package/dist/runtime/semver.js +110 -0
  318. package/dist/runtime/semver.js.map +1 -0
  319. package/dist/scan/dead-ui-detector.d.ts +48 -0
  320. package/dist/scan/dead-ui-detector.d.ts.map +1 -0
  321. package/dist/scan/dead-ui-detector.js +170 -0
  322. package/dist/scan/dead-ui-detector.js.map +1 -0
  323. package/dist/scan/playwright-sweep.d.ts +40 -0
  324. package/dist/scan/playwright-sweep.d.ts.map +1 -0
  325. package/dist/scan/playwright-sweep.js +216 -0
  326. package/dist/scan/playwright-sweep.js.map +1 -0
  327. package/dist/scan/proof-bundle.d.ts +25 -0
  328. package/dist/scan/proof-bundle.d.ts.map +1 -0
  329. package/dist/scan/proof-bundle.js +203 -0
  330. package/dist/scan/proof-bundle.js.map +1 -0
  331. package/dist/scan/proof-graph.d.ts +59 -0
  332. package/dist/scan/proof-graph.d.ts.map +1 -0
  333. package/dist/scan/proof-graph.js +64 -0
  334. package/dist/scan/proof-graph.js.map +1 -0
  335. package/dist/scan/reality-sniff.d.ts +56 -0
  336. package/dist/scan/reality-sniff.d.ts.map +1 -0
  337. package/dist/scan/reality-sniff.js +200 -0
  338. package/dist/scan/reality-sniff.js.map +1 -0
  339. package/dist/scan/structural-verifier.d.ts +20 -0
  340. package/dist/scan/structural-verifier.d.ts.map +1 -0
  341. package/dist/scan/structural-verifier.js +112 -0
  342. package/dist/scan/structural-verifier.js.map +1 -0
  343. package/dist/scan/verification-engine.d.ts +47 -0
  344. package/dist/scan/verification-engine.d.ts.map +1 -0
  345. package/dist/scan/verification-engine.js +141 -0
  346. package/dist/scan/verification-engine.js.map +1 -0
  347. package/dist/scanner/baseline.d.ts +52 -0
  348. package/dist/scanner/baseline.d.ts.map +1 -0
  349. package/dist/scanner/baseline.js +85 -0
  350. package/dist/scanner/baseline.js.map +1 -0
  351. package/dist/scanner/incremental.d.ts +30 -0
  352. package/dist/scanner/incremental.d.ts.map +1 -0
  353. package/dist/scanner/incremental.js +82 -0
  354. package/dist/scanner/incremental.js.map +1 -0
  355. package/dist/scanner/index.d.ts +8 -0
  356. package/dist/scanner/index.d.ts.map +1 -0
  357. package/dist/scanner/index.js +15 -0
  358. package/dist/scanner/index.js.map +1 -0
  359. package/dist/scanner/parallel.d.ts +43 -0
  360. package/dist/scanner/parallel.d.ts.map +1 -0
  361. package/dist/scanner/parallel.js +99 -0
  362. package/dist/scanner/parallel.js.map +1 -0
  363. package/dist/scanner/placeholder-detector.d.ts +56 -0
  364. package/dist/scanner/placeholder-detector.d.ts.map +1 -0
  365. package/dist/scanner/placeholder-detector.js +220 -0
  366. package/dist/scanner/placeholder-detector.js.map +1 -0
  367. package/dist/scanner/route-detector.d.ts +100 -0
  368. package/dist/scanner/route-detector.d.ts.map +1 -0
  369. package/dist/scanner/route-detector.js +455 -0
  370. package/dist/scanner/route-detector.js.map +1 -0
  371. package/dist/scanner/scoring.d.ts +67 -0
  372. package/dist/scanner/scoring.d.ts.map +1 -0
  373. package/dist/scanner/scoring.js +284 -0
  374. package/dist/scanner/scoring.js.map +1 -0
  375. package/dist/ship-baseline.d.ts +56 -0
  376. package/dist/ship-baseline.d.ts.map +1 -0
  377. package/dist/ship-baseline.js +194 -0
  378. package/dist/ship-baseline.js.map +1 -0
  379. package/dist/ship-config.d.ts +91 -0
  380. package/dist/ship-config.d.ts.map +1 -0
  381. package/dist/ship-config.js +133 -0
  382. package/dist/ship-config.js.map +1 -0
  383. package/dist/ship-data-loader.d.ts +70 -0
  384. package/dist/ship-data-loader.d.ts.map +1 -0
  385. package/dist/ship-data-loader.js +301 -0
  386. package/dist/ship-data-loader.js.map +1 -0
  387. package/dist/standalone.d.ts +1 -0
  388. package/dist/standalone.d.ts.map +1 -0
  389. package/dist/standalone.js +1 -0
  390. package/dist/standalone.js.map +1 -0
  391. package/dist/truth-pack/index.d.ts +102 -0
  392. package/dist/truth-pack/index.d.ts.map +1 -0
  393. package/dist/truth-pack/index.js +694 -0
  394. package/dist/truth-pack/index.js.map +1 -0
  395. package/dist/ui/frame.d.ts +68 -0
  396. package/dist/ui/frame.d.ts.map +1 -0
  397. package/dist/ui/frame.js +165 -0
  398. package/dist/ui/frame.js.map +1 -0
  399. package/dist/ui/index.d.ts +5 -0
  400. package/dist/ui/index.d.ts.map +1 -0
  401. package/dist/ui/index.js +16 -0
  402. package/dist/ui/index.js.map +1 -0
  403. package/dist/ui.d.ts +36 -0
  404. package/dist/ui.d.ts.map +1 -0
  405. package/dist/ui.js +45 -0
  406. package/dist/ui.js.map +1 -0
  407. package/dist/utils/ai-helpers.d.ts +72 -0
  408. package/dist/utils/ai-helpers.d.ts.map +1 -0
  409. package/dist/utils/ai-helpers.js +339 -0
  410. package/dist/utils/ai-helpers.js.map +1 -0
  411. package/dist/utils/validation.d.ts +34 -0
  412. package/dist/utils/validation.d.ts.map +1 -0
  413. package/dist/utils/validation.js +160 -0
  414. package/dist/utils/validation.js.map +1 -0
  415. package/package.json +66 -0
@@ -0,0 +1,356 @@
1
+ "use strict";
2
+ /**
3
+ * SARIF v2.1.0 Output - Enterprise-grade implementation
4
+ * Compliant with GitHub Code Scanning and Azure DevOps
5
+ * https://docs.oasis-open.org/sarif/sarif/v2.1.0/sarif-v2.1.0.html
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.secretsToSarif = secretsToSarif;
9
+ exports.vulnerabilitiesToSarif = vulnerabilitiesToSarif;
10
+ exports.combinedToSarif = combinedToSarif;
11
+ const crypto_1 = require("crypto");
12
+ /**
13
+ * Convert severity to SARIF level
14
+ */
15
+ function severityToLevel(severity) {
16
+ switch (severity.toLowerCase()) {
17
+ case 'critical':
18
+ case 'high':
19
+ return 'error';
20
+ case 'medium':
21
+ return 'warning';
22
+ case 'low':
23
+ case 'info':
24
+ return 'note';
25
+ default:
26
+ return 'warning';
27
+ }
28
+ }
29
+ /**
30
+ * Generate stable fingerprint for a finding
31
+ */
32
+ function generateFingerprint(finding) {
33
+ const data = `${finding.type || finding.category}:${finding.file}:${finding.line}:${finding.title || finding.match}`;
34
+ return (0, crypto_1.createHash)('sha256').update(data).digest('hex').substring(0, 16);
35
+ }
36
+ /**
37
+ * Get package version
38
+ */
39
+ function getVersion() {
40
+ try {
41
+ const pkg = require('../../package.json');
42
+ return pkg.version || '1.0.0';
43
+ }
44
+ catch {
45
+ return '1.0.0';
46
+ }
47
+ }
48
+ /**
49
+ * Convert secrets scan results to SARIF v2.1.0
50
+ */
51
+ function secretsToSarif(results) {
52
+ const version = getVersion();
53
+ const ruleMap = new Map();
54
+ const ruleIndexMap = new Map();
55
+ // Build rules from unique finding types
56
+ for (const finding of results.findings || []) {
57
+ const ruleId = finding.type || 'secret-detected';
58
+ if (!ruleMap.has(ruleId)) {
59
+ const index = ruleMap.size;
60
+ ruleIndexMap.set(ruleId, index);
61
+ ruleMap.set(ruleId, {
62
+ id: ruleId,
63
+ name: ruleId.replace(/_/g, ' ').replace(/\b\w/g, (c) => c.toUpperCase()),
64
+ shortDescription: {
65
+ text: `Detected ${ruleId.replace(/_/g, ' ')}`,
66
+ },
67
+ fullDescription: {
68
+ text: finding.recommendation?.reason || `Potential ${ruleId} detected in source code`,
69
+ },
70
+ help: {
71
+ text: finding.recommendation?.remediation || 'Move secrets to environment variables or secure vault',
72
+ markdown: `## Remediation\n\n${finding.recommendation?.remediation || 'Move secrets to environment variables or secure vault'}\n\n[Learn more](https://guardrail.dev/docs/secrets)`,
73
+ },
74
+ helpUri: 'https://guardrail.dev/docs/secrets',
75
+ defaultConfiguration: {
76
+ level: severityToLevel(finding.risk || 'high'),
77
+ enabled: true,
78
+ },
79
+ properties: {
80
+ tags: ['security', 'secrets', finding.risk || 'high'],
81
+ precision: 'high',
82
+ },
83
+ });
84
+ }
85
+ }
86
+ const sarifResults = (results.findings || []).map((f) => {
87
+ const ruleId = f.type || 'secret-detected';
88
+ return {
89
+ ruleId,
90
+ ruleIndex: ruleIndexMap.get(ruleId),
91
+ level: severityToLevel(f.risk || 'high'),
92
+ message: {
93
+ text: `${f.type}: ${f.match}${f.isTest ? ' (in test file)' : ''}`,
94
+ },
95
+ locations: [{
96
+ physicalLocation: {
97
+ artifactLocation: {
98
+ uri: f.file.replace(/\\/g, '/'),
99
+ uriBaseId: '%SRCROOT%',
100
+ },
101
+ region: {
102
+ startLine: f.line,
103
+ startColumn: 1,
104
+ snippet: {
105
+ text: f.match,
106
+ },
107
+ },
108
+ },
109
+ }],
110
+ partialFingerprints: {
111
+ 'guardrail/v1': generateFingerprint(f),
112
+ },
113
+ fingerprints: {
114
+ 'guardrail/v1': `${f.type}:${f.file}:${f.line}`,
115
+ },
116
+ properties: {
117
+ confidence: f.confidence,
118
+ entropy: f.entropy,
119
+ isTest: f.isTest,
120
+ risk: f.risk,
121
+ },
122
+ fixes: f.recommendation?.remediation ? [{
123
+ description: {
124
+ text: f.recommendation.remediation,
125
+ },
126
+ artifactChanges: [{
127
+ artifactLocation: {
128
+ uri: f.file.replace(/\\/g, '/'),
129
+ uriBaseId: '%SRCROOT%',
130
+ },
131
+ replacements: [{
132
+ deletedRegion: {
133
+ startLine: f.line,
134
+ startColumn: 1,
135
+ },
136
+ insertedContent: {
137
+ text: '// TODO: Move to environment variable',
138
+ },
139
+ }],
140
+ }],
141
+ }] : undefined,
142
+ };
143
+ });
144
+ return {
145
+ $schema: 'https://raw.githubusercontent.com/oasis-tcs/sarif-spec/master/Schemata/sarif-schema-2.1.0.json',
146
+ version: '2.1.0',
147
+ runs: [{
148
+ tool: {
149
+ driver: {
150
+ name: 'Guardrail',
151
+ version,
152
+ semanticVersion: version,
153
+ informationUri: 'https://guardrail.dev',
154
+ organization: 'Guardrail Security',
155
+ rules: Array.from(ruleMap.values()),
156
+ },
157
+ },
158
+ results: sarifResults,
159
+ invocations: [{
160
+ executionSuccessful: true,
161
+ startTimeUtc: new Date().toISOString(),
162
+ endTimeUtc: new Date().toISOString(),
163
+ workingDirectory: {
164
+ uri: results.projectPath?.replace(/\\/g, '/') || '.',
165
+ },
166
+ exitCode: 0,
167
+ }],
168
+ properties: {
169
+ scanType: 'secrets',
170
+ filesScanned: results.filesScanned,
171
+ patterns: results.patterns,
172
+ },
173
+ }],
174
+ };
175
+ }
176
+ /**
177
+ * Convert vulnerability scan results to SARIF v2.1.0
178
+ */
179
+ function vulnerabilitiesToSarif(results) {
180
+ const version = getVersion();
181
+ const rules = [{
182
+ id: 'vulnerable-dependency',
183
+ name: 'Vulnerable Dependency',
184
+ shortDescription: {
185
+ text: 'Known vulnerability in dependency',
186
+ },
187
+ fullDescription: {
188
+ text: 'A dependency with a known security vulnerability was detected. Update to the fixed version to remediate.',
189
+ },
190
+ help: {
191
+ text: 'Update vulnerable dependencies to their fixed versions',
192
+ markdown: '## Remediation\n\nUpdate the vulnerable dependency to the version specified in the fix recommendation.\n\n[Learn more](https://guardrail.dev/docs/vulnerabilities)',
193
+ },
194
+ helpUri: 'https://guardrail.dev/docs/vulnerabilities',
195
+ defaultConfiguration: {
196
+ level: 'error',
197
+ enabled: true,
198
+ },
199
+ properties: {
200
+ tags: ['security', 'vulnerability', 'dependencies'],
201
+ precision: 'very-high',
202
+ },
203
+ }];
204
+ const sarifResults = (results.findings || []).map((f) => ({
205
+ ruleId: 'vulnerable-dependency',
206
+ ruleIndex: 0,
207
+ level: severityToLevel(f.severity),
208
+ message: {
209
+ text: `${f.cve}: ${f.title} in ${f.package}@${f.version}`,
210
+ markdown: `**${f.cve}**: ${f.title}\n\n**Package**: \`${f.package}@${f.version}\`\n**Fix**: Upgrade to \`${f.fixedIn}\``,
211
+ },
212
+ locations: [{
213
+ physicalLocation: {
214
+ artifactLocation: {
215
+ uri: 'package.json',
216
+ uriBaseId: '%SRCROOT%',
217
+ },
218
+ region: {
219
+ startLine: 1,
220
+ },
221
+ },
222
+ }],
223
+ partialFingerprints: {
224
+ 'guardrail/v1': generateFingerprint(f),
225
+ },
226
+ fingerprints: {
227
+ 'guardrail/v1': `${f.cve}:${f.package}:${f.version}`,
228
+ },
229
+ properties: {
230
+ cve: f.cve,
231
+ package: f.package,
232
+ version: f.version,
233
+ fixedIn: f.fixedIn,
234
+ severity: f.severity,
235
+ },
236
+ fixes: [{
237
+ description: {
238
+ text: `Upgrade ${f.package} to ${f.fixedIn}`,
239
+ },
240
+ artifactChanges: [{
241
+ artifactLocation: {
242
+ uri: 'package.json',
243
+ uriBaseId: '%SRCROOT%',
244
+ },
245
+ replacements: [{
246
+ deletedRegion: {
247
+ startLine: 1,
248
+ },
249
+ insertedContent: {
250
+ text: `"${f.package}": "${f.fixedIn}"`,
251
+ },
252
+ }],
253
+ }],
254
+ }],
255
+ }));
256
+ return {
257
+ $schema: 'https://raw.githubusercontent.com/oasis-tcs/sarif-spec/master/Schemata/sarif-schema-2.1.0.json',
258
+ version: '2.1.0',
259
+ runs: [{
260
+ tool: {
261
+ driver: {
262
+ name: 'Guardrail',
263
+ version,
264
+ semanticVersion: version,
265
+ informationUri: 'https://guardrail.dev',
266
+ organization: 'Guardrail Security',
267
+ rules,
268
+ },
269
+ },
270
+ results: sarifResults,
271
+ invocations: [{
272
+ executionSuccessful: true,
273
+ startTimeUtc: new Date().toISOString(),
274
+ endTimeUtc: new Date().toISOString(),
275
+ workingDirectory: {
276
+ uri: results.projectPath?.replace(/\\/g, '/') || '.',
277
+ },
278
+ exitCode: 0,
279
+ }],
280
+ properties: {
281
+ scanType: 'vulnerabilities',
282
+ packagesScanned: results.packagesScanned,
283
+ auditSource: results.auditSource,
284
+ },
285
+ }],
286
+ };
287
+ }
288
+ /**
289
+ * Convert combined scan results to SARIF v2.1.0
290
+ */
291
+ function combinedToSarif(results) {
292
+ const version = getVersion();
293
+ const allRules = [];
294
+ const allResults = [];
295
+ const ruleIndexMap = new Map();
296
+ // Add secrets rules and results
297
+ if (results.secrets) {
298
+ const secretsSarif = secretsToSarif(results.secrets);
299
+ const secretsRun = secretsSarif.runs[0];
300
+ for (const rule of secretsRun.tool.driver.rules || []) {
301
+ ruleIndexMap.set(rule.id, allRules.length);
302
+ allRules.push(rule);
303
+ }
304
+ for (const result of secretsRun.results) {
305
+ allResults.push({
306
+ ...result,
307
+ ruleIndex: ruleIndexMap.get(result.ruleId),
308
+ });
309
+ }
310
+ }
311
+ // Add vulnerability rules and results
312
+ if (results.vulnerabilities) {
313
+ const vulnSarif = vulnerabilitiesToSarif(results.vulnerabilities);
314
+ const vulnRun = vulnSarif.runs[0];
315
+ for (const rule of vulnRun.tool.driver.rules || []) {
316
+ if (!ruleIndexMap.has(rule.id)) {
317
+ ruleIndexMap.set(rule.id, allRules.length);
318
+ allRules.push(rule);
319
+ }
320
+ }
321
+ for (const result of vulnRun.results) {
322
+ allResults.push({
323
+ ...result,
324
+ ruleIndex: ruleIndexMap.get(result.ruleId),
325
+ });
326
+ }
327
+ }
328
+ return {
329
+ $schema: 'https://raw.githubusercontent.com/oasis-tcs/sarif-spec/master/Schemata/sarif-schema-2.1.0.json',
330
+ version: '2.1.0',
331
+ runs: [{
332
+ tool: {
333
+ driver: {
334
+ name: 'Guardrail',
335
+ version,
336
+ semanticVersion: version,
337
+ informationUri: 'https://guardrail.dev',
338
+ organization: 'Guardrail Security',
339
+ rules: allRules,
340
+ },
341
+ },
342
+ results: allResults,
343
+ invocations: [{
344
+ executionSuccessful: true,
345
+ startTimeUtc: new Date().toISOString(),
346
+ endTimeUtc: new Date().toISOString(),
347
+ exitCode: 0,
348
+ }],
349
+ properties: {
350
+ scanType: 'combined',
351
+ duration: results.duration,
352
+ },
353
+ }],
354
+ };
355
+ }
356
+ //# sourceMappingURL=sarif-v2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sarif-v2.js","sourceRoot":"","sources":["../../src/formatters/sarif-v2.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,72 @@
1
+ /**
2
+ * SARIF (Static Analysis Results Interchange Format) Output
3
+ * Standard format for GitHub/Azure DevOps security integration
4
+ * https://sarifweb.azurewebsites.net/
5
+ */
6
+ export interface SarifResult {
7
+ $schema: string;
8
+ version: string;
9
+ runs: SarifRun[];
10
+ }
11
+ export interface SarifRun {
12
+ tool: {
13
+ driver: {
14
+ name: string;
15
+ version: string;
16
+ informationUri: string;
17
+ rules: SarifRule[];
18
+ };
19
+ };
20
+ results: SarifFinding[];
21
+ invocations: SarifInvocation[];
22
+ }
23
+ export interface SarifRule {
24
+ id: string;
25
+ name: string;
26
+ shortDescription: {
27
+ text: string;
28
+ };
29
+ fullDescription?: {
30
+ text: string;
31
+ };
32
+ helpUri?: string;
33
+ defaultConfiguration: {
34
+ level: 'error' | 'warning' | 'note' | 'none';
35
+ };
36
+ }
37
+ export interface SarifFinding {
38
+ ruleId: string;
39
+ level: 'error' | 'warning' | 'note' | 'none';
40
+ message: {
41
+ text: string;
42
+ };
43
+ locations: SarifLocation[];
44
+ fingerprints?: Record<string, string>;
45
+ properties?: Record<string, any>;
46
+ }
47
+ export interface SarifLocation {
48
+ physicalLocation: {
49
+ artifactLocation: {
50
+ uri: string;
51
+ uriBaseId?: string;
52
+ };
53
+ region?: {
54
+ startLine: number;
55
+ startColumn?: number;
56
+ endLine?: number;
57
+ endColumn?: number;
58
+ };
59
+ };
60
+ }
61
+ export interface SarifInvocation {
62
+ executionSuccessful: boolean;
63
+ commandLine?: string;
64
+ startTimeUtc?: string;
65
+ endTimeUtc?: string;
66
+ workingDirectory?: {
67
+ uri: string;
68
+ };
69
+ }
70
+ export declare function toSarif(results: any): SarifResult;
71
+ export declare function toSarifVulnerabilities(results: any): SarifResult;
72
+ //# sourceMappingURL=sarif.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sarif.d.ts","sourceRoot":"","sources":["../../src/formatters/sarif.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,QAAQ,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE;QACJ,MAAM,EAAE;YACN,IAAI,EAAE,MAAM,CAAC;YACb,OAAO,EAAE,MAAM,CAAC;YAChB,cAAc,EAAE,MAAM,CAAC;YACvB,KAAK,EAAE,SAAS,EAAE,CAAC;SACpB,CAAC;KACH,CAAC;IACF,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,WAAW,EAAE,eAAe,EAAE,CAAC;CAChC;AAED,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IACnC,eAAe,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IACnC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,oBAAoB,EAAE;QACpB,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;KAC9C,CAAC;CACH;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;IAC7C,OAAO,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;IAC1B,SAAS,EAAE,aAAa,EAAE,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAClC;AAED,MAAM,WAAW,aAAa;IAC5B,gBAAgB,EAAE;QAChB,gBAAgB,EAAE;YAChB,GAAG,EAAE,MAAM,CAAC;YACZ,SAAS,CAAC,EAAE,MAAM,CAAC;SACpB,CAAC;QACF,MAAM,CAAC,EAAE;YACP,SAAS,EAAE,MAAM,CAAC;YAClB,WAAW,CAAC,EAAE,MAAM,CAAC;YACrB,OAAO,CAAC,EAAE,MAAM,CAAC;YACjB,SAAS,CAAC,EAAE,MAAM,CAAC;SACpB,CAAC;KACH,CAAC;CACH;AAED,MAAM,WAAW,eAAe;IAC9B,mBAAmB,EAAE,OAAO,CAAC;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;CACpC;AAoBD,wBAAgB,OAAO,CAAC,OAAO,EAAE,GAAG,GAAG,WAAW,CAmEjD;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,GAAG,GAAG,WAAW,CAwDhE"}
@@ -0,0 +1,146 @@
1
+ "use strict";
2
+ /**
3
+ * SARIF (Static Analysis Results Interchange Format) Output
4
+ * Standard format for GitHub/Azure DevOps security integration
5
+ * https://sarifweb.azurewebsites.net/
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.toSarif = toSarif;
9
+ exports.toSarifVulnerabilities = toSarifVulnerabilities;
10
+ function riskToLevel(risk) {
11
+ switch (risk) {
12
+ case 'high': return 'error';
13
+ case 'medium': return 'warning';
14
+ case 'low': return 'note';
15
+ default: return 'warning';
16
+ }
17
+ }
18
+ function getVersion() {
19
+ try {
20
+ const pkg = require('../../package.json');
21
+ return pkg.version || '1.0.0';
22
+ }
23
+ catch {
24
+ return '1.0.0';
25
+ }
26
+ }
27
+ function toSarif(results) {
28
+ const version = getVersion();
29
+ const ruleMap = new Map();
30
+ // Build rules from unique finding types
31
+ for (const finding of results.findings || []) {
32
+ if (!ruleMap.has(finding.type)) {
33
+ ruleMap.set(finding.type, {
34
+ id: finding.type,
35
+ name: finding.type.replace(/_/g, ' ').replace(/\b\w/g, (c) => c.toUpperCase()),
36
+ shortDescription: { text: `Detected ${finding.type.replace(/_/g, ' ')}` },
37
+ fullDescription: { text: finding.recommendation?.reason || `Potential ${finding.type} detected in source code` },
38
+ helpUri: 'https://guardrail.dev/docs/secrets',
39
+ defaultConfiguration: { level: riskToLevel(finding.risk) },
40
+ });
41
+ }
42
+ }
43
+ const sarifResults = (results.findings || []).map((f) => ({
44
+ ruleId: f.type,
45
+ level: riskToLevel(f.risk),
46
+ message: {
47
+ text: `${f.type}: ${f.match}${f.isTest ? ' (in test file)' : ''}`,
48
+ },
49
+ locations: [{
50
+ physicalLocation: {
51
+ artifactLocation: {
52
+ uri: f.file.replace(/\\/g, '/'),
53
+ uriBaseId: '%SRCROOT%',
54
+ },
55
+ region: {
56
+ startLine: f.line,
57
+ startColumn: 1,
58
+ },
59
+ },
60
+ }],
61
+ fingerprints: {
62
+ 'guardrail/v1': `${f.type}:${f.file}:${f.line}`,
63
+ },
64
+ properties: {
65
+ confidence: f.confidence,
66
+ entropy: f.entropy,
67
+ isTest: f.isTest,
68
+ remediation: f.recommendation?.remediation,
69
+ },
70
+ }));
71
+ return {
72
+ $schema: 'https://raw.githubusercontent.com/oasis-tcs/sarif-spec/master/Schemata/sarif-schema-2.1.0.json',
73
+ version: '2.1.0',
74
+ runs: [{
75
+ tool: {
76
+ driver: {
77
+ name: 'guardrail-cli',
78
+ version,
79
+ informationUri: 'https://guardrail.dev',
80
+ rules: Array.from(ruleMap.values()),
81
+ },
82
+ },
83
+ results: sarifResults,
84
+ invocations: [{
85
+ executionSuccessful: true,
86
+ startTimeUtc: new Date().toISOString(),
87
+ workingDirectory: { uri: results.projectPath?.replace(/\\/g, '/') || '.' },
88
+ }],
89
+ }],
90
+ };
91
+ }
92
+ function toSarifVulnerabilities(results) {
93
+ const version = getVersion();
94
+ const rules = [{
95
+ id: 'vulnerable-dependency',
96
+ name: 'Vulnerable Dependency',
97
+ shortDescription: { text: 'Known vulnerability in dependency' },
98
+ helpUri: 'https://guardrail.dev/docs/vulnerabilities',
99
+ defaultConfiguration: { level: 'error' },
100
+ }];
101
+ const sarifResults = (results.findings || []).map((f) => ({
102
+ ruleId: 'vulnerable-dependency',
103
+ level: riskToLevel(f.severity),
104
+ message: {
105
+ text: `${f.cve}: ${f.title} in ${f.package}@${f.version}. Fix: upgrade to ${f.fixedIn}`,
106
+ },
107
+ locations: [{
108
+ physicalLocation: {
109
+ artifactLocation: {
110
+ uri: 'package.json',
111
+ uriBaseId: '%SRCROOT%',
112
+ },
113
+ region: { startLine: 1 },
114
+ },
115
+ }],
116
+ fingerprints: {
117
+ 'guardrail/v1': `${f.cve}:${f.package}:${f.version}`,
118
+ },
119
+ properties: {
120
+ cve: f.cve,
121
+ package: f.package,
122
+ version: f.version,
123
+ fixedIn: f.fixedIn,
124
+ },
125
+ }));
126
+ return {
127
+ $schema: 'https://raw.githubusercontent.com/oasis-tcs/sarif-spec/master/Schemata/sarif-schema-2.1.0.json',
128
+ version: '2.1.0',
129
+ runs: [{
130
+ tool: {
131
+ driver: {
132
+ name: 'guardrail-cli',
133
+ version,
134
+ informationUri: 'https://guardrail.dev',
135
+ rules,
136
+ },
137
+ },
138
+ results: sarifResults,
139
+ invocations: [{
140
+ executionSuccessful: true,
141
+ startTimeUtc: new Date().toISOString(),
142
+ }],
143
+ }],
144
+ };
145
+ }
146
+ //# sourceMappingURL=sarif.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sarif.js","sourceRoot":"","sources":["../../src/formatters/sarif.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,61 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Guardrail CLI
4
+ *
5
+ * Command-line interface for local security scanning
6
+ */
7
+ declare const icons: {
8
+ scan: string;
9
+ secret: string;
10
+ compliance: string;
11
+ sbom: string;
12
+ auth: string;
13
+ fix: string;
14
+ ship: string;
15
+ reality: string;
16
+ autopilot: string;
17
+ smells: string;
18
+ success: string;
19
+ error: string;
20
+ warning: string;
21
+ info: string;
22
+ bullet: string;
23
+ dot: string;
24
+ refresh: string;
25
+ block: string;
26
+ halfBlock: string;
27
+ };
28
+ declare const styles: {
29
+ reset: string;
30
+ bold: string;
31
+ dim: string;
32
+ italic: string;
33
+ underline: string;
34
+ black: string;
35
+ red: string;
36
+ green: string;
37
+ yellow: string;
38
+ blue: string;
39
+ magenta: string;
40
+ cyan: string;
41
+ white: string;
42
+ brightRed: string;
43
+ brightGreen: string;
44
+ brightYellow: string;
45
+ brightBlue: string;
46
+ brightMagenta: string;
47
+ brightCyan: string;
48
+ brightWhite: string;
49
+ bgBlue: string;
50
+ bgMagenta: string;
51
+ bgCyan: string;
52
+ bullet: string;
53
+ };
54
+ export { printLogo, styles, icons };
55
+ export declare function promptSelect<T extends string>(message: string, choices: {
56
+ name: string;
57
+ value: T;
58
+ badge?: string;
59
+ }[]): Promise<T>;
60
+ declare function printLogo(): void;
61
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAEA;;;;GAIG;AAuHH,QAAA,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;CAoBV,CAAC;AAEF,QAAA,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;CAkCX,CAAC;AA2KF,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;AAGpC,wBAAsB,YAAY,CAAC,CAAC,SAAS,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,CAAC,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAyDvI;AAgHD,iBAAS,SAAS,SAEjB"}