@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,170 @@
1
+ "use strict";
2
+ /**
3
+ * No Dead UI Static Gate
4
+ *
5
+ * Fast pre-test gate that blocks obvious deadness:
6
+ * - href="#"
7
+ * - noop onClick={() => {}}
8
+ * - "coming soon" UI in prod surfaces
9
+ * - disabled buttons without reason text
10
+ * - raw fetch("/api/...") in components
11
+ */
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.DeadUIDetector = void 0;
14
+ const fs_1 = require("fs");
15
+ const path_1 = require("path");
16
+ // Dead link patterns
17
+ const DEAD_LINK_PATTERNS = [
18
+ /href=["']#["']/g,
19
+ /href=["']javascript:void\(0\)["']/g,
20
+ /href=["']#!["']/g,
21
+ /href=["']\/#["']/g,
22
+ ];
23
+ // Noop handler patterns
24
+ const NOOP_HANDLER_PATTERNS = [
25
+ /onClick\s*=\s*{\s*\(\)\s*=>\s*\{\s*\}\s*\}/g,
26
+ /onClick\s*=\s*{\s*\(\)\s*=>\s*\{\s*return\s*;?\s*\}\s*\}/g,
27
+ /onClick\s*=\s*{\s*\(\)\s*=>\s*undefined\s*}/g,
28
+ /onClick\s*=\s*{\s*\(\)\s*=>\s*null\s*}/g,
29
+ /onClick\s*=\s*{\s*\(\)\s*=>\s*void\s*0\s*}/g,
30
+ ];
31
+ // Coming soon patterns
32
+ const COMING_SOON_PATTERNS = [
33
+ /coming\s+soon/gi,
34
+ /coming\s+later/gi,
35
+ /not\s+available/gi,
36
+ /under\s+construction/gi,
37
+ /work\s+in\s+progress/gi,
38
+ /wip/gi,
39
+ ];
40
+ // Disabled button without reason
41
+ const DISABLED_NO_REASON_PATTERNS = [
42
+ /disabled\s*(?!.*(?:reason|tooltip|title|aria-label|aria-describedby))/gi,
43
+ ];
44
+ // Raw fetch in components
45
+ const RAW_FETCH_PATTERNS = [
46
+ /fetch\s*\(\s*["']\/api\//g,
47
+ /fetch\s*\(\s*`\/api\//g,
48
+ /axios\s*\.\s*(get|post|put|delete)\s*\(\s*["']\/api\//g,
49
+ ];
50
+ class DeadUIDetector {
51
+ constructor() {
52
+ this.findings = [];
53
+ this.findingCounter = 1;
54
+ }
55
+ /**
56
+ * Scan for dead UI issues
57
+ */
58
+ async scan(projectPath, options = {}) {
59
+ this.findings = [];
60
+ this.findingCounter = 1;
61
+ const exclude = options.exclude || ['node_modules', '.git', 'dist', 'build', '.next'];
62
+ const includeTests = options.includeTests || false;
63
+ // Scan UI files
64
+ await this.scanDirectory(projectPath, exclude, includeTests);
65
+ // Calculate summary
66
+ const summary = {
67
+ total: this.findings.length,
68
+ critical: this.findings.filter(f => f.severity === 'critical').length,
69
+ high: this.findings.filter(f => f.severity === 'high').length,
70
+ medium: this.findings.filter(f => f.severity === 'medium').length,
71
+ low: this.findings.filter(f => f.severity === 'low').length,
72
+ };
73
+ return {
74
+ findings: this.findings,
75
+ summary,
76
+ };
77
+ }
78
+ async scanDirectory(dir, exclude, includeTests) {
79
+ const entries = (0, fs_1.readdirSync)(dir);
80
+ for (const entry of entries) {
81
+ const fullPath = (0, path_1.join)(dir, entry);
82
+ const stat = (0, fs_1.statSync)(fullPath);
83
+ // Skip excluded directories
84
+ if (stat.isDirectory()) {
85
+ if (exclude.some(e => entry.includes(e)))
86
+ continue;
87
+ if (!includeTests && (entry.includes('test') || entry.includes('spec')))
88
+ continue;
89
+ await this.scanDirectory(fullPath, exclude, includeTests);
90
+ continue;
91
+ }
92
+ // Only scan UI files
93
+ const ext = (0, path_1.extname)(entry);
94
+ if (!['.tsx', '.jsx', '.ts', '.js', '.vue', '.svelte'].includes(ext)) {
95
+ continue;
96
+ }
97
+ await this.scanFile(fullPath);
98
+ }
99
+ }
100
+ async scanFile(filePath) {
101
+ try {
102
+ const content = (0, fs_1.readFileSync)(filePath, 'utf-8');
103
+ const lines = content.split('\n');
104
+ // Check each line for patterns
105
+ lines.forEach((line, index) => {
106
+ const lineNum = index + 1;
107
+ // Dead link detection
108
+ this.checkPatterns(line, lineNum, filePath, DEAD_LINK_PATTERNS, 'dead_link', 'high', 'Dead link detected (href="#")');
109
+ // Noop handler detection
110
+ this.checkPatterns(line, lineNum, filePath, NOOP_HANDLER_PATTERNS, 'noop_handler', 'high', 'No-op click handler detected');
111
+ // Coming soon detection (only in non-test files)
112
+ if (!filePath.includes('test') && !filePath.includes('spec')) {
113
+ this.checkPatterns(line, lineNum, filePath, COMING_SOON_PATTERNS, 'coming_soon', 'medium', 'Coming soon UI in production code');
114
+ }
115
+ // Disabled button without reason
116
+ if (line.includes('disabled') && !this.hasReasonText(line)) {
117
+ this.addFinding({
118
+ id: `GR-UI-${String(this.findingCounter++).padStart(3, '0')}`,
119
+ type: 'disabled_no_reason',
120
+ file: filePath,
121
+ line: lineNum,
122
+ severity: 'medium',
123
+ issue: 'Disabled button without reason text',
124
+ suggestion: 'Add tooltip, aria-label, or reason text explaining why button is disabled',
125
+ });
126
+ }
127
+ // Raw fetch detection
128
+ this.checkPatterns(line, lineNum, filePath, RAW_FETCH_PATTERNS, 'raw_fetch', 'low', 'Raw API fetch in component (consider using action registry)');
129
+ });
130
+ }
131
+ catch (error) {
132
+ // Ignore files we can't read
133
+ }
134
+ }
135
+ checkPatterns(line, lineNum, filePath, patterns, type, severity, issue) {
136
+ for (const pattern of patterns) {
137
+ const matches = line.matchAll(new RegExp(pattern.source, pattern.flags));
138
+ for (const match of matches) {
139
+ this.addFinding({
140
+ id: `GR-UI-${String(this.findingCounter++).padStart(3, '0')}`,
141
+ type,
142
+ file: filePath,
143
+ line: lineNum,
144
+ severity,
145
+ issue,
146
+ suggestion: this.getSuggestion(type),
147
+ });
148
+ }
149
+ }
150
+ }
151
+ hasReasonText(line) {
152
+ // Check if line has reason text (tooltip, aria-label, etc.)
153
+ return /(tooltip|aria-label|aria-describedby|title|reason|why|disabled.*because)/i.test(line);
154
+ }
155
+ addFinding(finding) {
156
+ this.findings.push(finding);
157
+ }
158
+ getSuggestion(type) {
159
+ const suggestions = {
160
+ dead_link: 'Replace with actual route or remove if not needed',
161
+ noop_handler: 'Implement actual handler or remove onClick',
162
+ coming_soon: 'Remove or implement the feature',
163
+ disabled_no_reason: 'Add tooltip, aria-label, or reason text',
164
+ raw_fetch: 'Use action registry or typed API client',
165
+ };
166
+ return suggestions[type] || 'Review and fix';
167
+ }
168
+ }
169
+ exports.DeadUIDetector = DeadUIDetector;
170
+ //# sourceMappingURL=dead-ui-detector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dead-ui-detector.js","sourceRoot":"","sources":["../../src/scan/dead-ui-detector.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * Playwright Button Sweep
3
+ *
4
+ * The cheat code:
5
+ * - Click every data-action-id on key pages
6
+ * - Fail on console errors/unhandled rejections
7
+ * - Fail on unexpected 4xx/5xx
8
+ * - Save traces/screenshots on failure
9
+ */
10
+ export interface PlaywrightSweepResult {
11
+ ran: boolean;
12
+ passed: boolean;
13
+ failures: Array<{
14
+ test: string;
15
+ error: string;
16
+ trace?: string;
17
+ screenshot?: string;
18
+ }>;
19
+ traces: string[];
20
+ summary: {
21
+ totalActions: number;
22
+ passed: number;
23
+ failed: number;
24
+ errors: number;
25
+ };
26
+ }
27
+ export interface PlaywrightConfig {
28
+ baseUrl: string;
29
+ pages: string[];
30
+ actionSelectors: string[];
31
+ timeout?: number;
32
+ }
33
+ export declare class PlaywrightSweep {
34
+ /**
35
+ * Run button sweep on application
36
+ */
37
+ sweep(config: PlaywrightConfig, artifactsDir: string): Promise<PlaywrightSweepResult>;
38
+ private isPlaywrightAvailable;
39
+ }
40
+ //# sourceMappingURL=playwright-sweep.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"playwright-sweep.d.ts","sourceRoot":"","sources":["../../src/scan/playwright-sweep.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAKH,MAAM,WAAW,qBAAqB;IACpC,GAAG,EAAE,OAAO,CAAC;IACb,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,KAAK,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC,CAAC;IACH,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,OAAO,EAAE;QACP,YAAY,EAAE,MAAM,CAAC;QACrB,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;KAChB,CAAC;CACH;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,qBAAa,eAAe;IAC1B;;OAEG;IACG,KAAK,CACT,MAAM,EAAE,gBAAgB,EACxB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,qBAAqB,CAAC;IA2KjC,OAAO,CAAC,qBAAqB;CAQ9B"}
@@ -0,0 +1,216 @@
1
+ "use strict";
2
+ /**
3
+ * Playwright Button Sweep
4
+ *
5
+ * The cheat code:
6
+ * - Click every data-action-id on key pages
7
+ * - Fail on console errors/unhandled rejections
8
+ * - Fail on unexpected 4xx/5xx
9
+ * - Save traces/screenshots on failure
10
+ */
11
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
12
+ if (k2 === undefined) k2 = k;
13
+ var desc = Object.getOwnPropertyDescriptor(m, k);
14
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
15
+ desc = { enumerable: true, get: function() { return m[k]; } };
16
+ }
17
+ Object.defineProperty(o, k2, desc);
18
+ }) : (function(o, m, k, k2) {
19
+ if (k2 === undefined) k2 = k;
20
+ o[k2] = m[k];
21
+ }));
22
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
23
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
24
+ }) : function(o, v) {
25
+ o["default"] = v;
26
+ });
27
+ var __importStar = (this && this.__importStar) || (function () {
28
+ var ownKeys = function(o) {
29
+ ownKeys = Object.getOwnPropertyNames || function (o) {
30
+ var ar = [];
31
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
32
+ return ar;
33
+ };
34
+ return ownKeys(o);
35
+ };
36
+ return function (mod) {
37
+ if (mod && mod.__esModule) return mod;
38
+ var result = {};
39
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
40
+ __setModuleDefault(result, mod);
41
+ return result;
42
+ };
43
+ })();
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.PlaywrightSweep = void 0;
46
+ const fs_1 = require("fs");
47
+ const path_1 = require("path");
48
+ class PlaywrightSweep {
49
+ /**
50
+ * Run button sweep on application
51
+ */
52
+ async sweep(config, artifactsDir) {
53
+ // Check if Playwright is available
54
+ if (!this.isPlaywrightAvailable()) {
55
+ return {
56
+ ran: false,
57
+ passed: true,
58
+ failures: [],
59
+ traces: [],
60
+ summary: {
61
+ totalActions: 0,
62
+ passed: 0,
63
+ failed: 0,
64
+ errors: 0,
65
+ },
66
+ };
67
+ }
68
+ // Ensure artifacts directory exists
69
+ if (!(0, fs_1.existsSync)(artifactsDir)) {
70
+ (0, fs_1.mkdirSync)(artifactsDir, { recursive: true });
71
+ }
72
+ const failures = [];
73
+ const traces = [];
74
+ let totalActions = 0;
75
+ let passed = 0;
76
+ let failed = 0;
77
+ let errors = 0;
78
+ try {
79
+ // Import Playwright dynamically
80
+ const { chromium } = await Promise.resolve().then(() => __importStar(require('playwright')));
81
+ const browser = await chromium.launch({ headless: true });
82
+ const context = await browser.newContext();
83
+ // Enable console and network monitoring
84
+ const consoleErrors = [];
85
+ const networkErrors = [];
86
+ context.on('console', (msg) => {
87
+ if (msg.type() === 'error') {
88
+ consoleErrors.push(msg.text());
89
+ }
90
+ });
91
+ context.on('response', (response) => {
92
+ const status = response.status();
93
+ if (status >= 400) {
94
+ networkErrors.push({
95
+ url: response.url(),
96
+ status,
97
+ });
98
+ }
99
+ });
100
+ // Test each page
101
+ for (const pagePath of config.pages) {
102
+ const page = await context.newPage();
103
+ const fullUrl = `${config.baseUrl}${pagePath}`;
104
+ try {
105
+ await page.goto(fullUrl, { waitUntil: 'networkidle', timeout: config.timeout || 30000 });
106
+ // Find all action elements
107
+ const actionElements = await page.$$(config.actionSelectors.join(', '));
108
+ for (const element of actionElements) {
109
+ totalActions++;
110
+ try {
111
+ // Get action ID for identification
112
+ const actionId = await element.getAttribute('data-action-id') ||
113
+ await element.getAttribute('id') ||
114
+ await element.textContent() ||
115
+ 'unknown';
116
+ // Click the element
117
+ await element.click({ timeout: 5000 });
118
+ // Wait a bit for any async operations
119
+ await page.waitForTimeout(1000);
120
+ // Check for console errors
121
+ if (consoleErrors.length > 0) {
122
+ failed++;
123
+ const error = consoleErrors.join('; ');
124
+ failures.push({
125
+ test: `Click action: ${actionId} on ${pagePath}`,
126
+ error: `Console errors: ${error}`,
127
+ });
128
+ consoleErrors.length = 0; // Clear after reporting
129
+ }
130
+ // Check for network errors
131
+ if (networkErrors.length > 0) {
132
+ failed++;
133
+ const error = networkErrors.map(e => `${e.url}: ${e.status}`).join('; ');
134
+ failures.push({
135
+ test: `Click action: ${actionId} on ${pagePath}`,
136
+ error: `Network errors: ${error}`,
137
+ });
138
+ networkErrors.length = 0; // Clear after reporting
139
+ }
140
+ if (consoleErrors.length === 0 && networkErrors.length === 0) {
141
+ passed++;
142
+ }
143
+ }
144
+ catch (error) {
145
+ failed++;
146
+ const tracePath = (0, path_1.join)(artifactsDir, `trace-${Date.now()}.zip`);
147
+ const screenshotPath = (0, path_1.join)(artifactsDir, `screenshot-${Date.now()}.png`);
148
+ // Save trace and screenshot
149
+ await context.tracing.stop({ path: tracePath });
150
+ await page.screenshot({ path: screenshotPath, fullPage: true });
151
+ traces.push(tracePath);
152
+ failures.push({
153
+ test: `Click action on ${pagePath}`,
154
+ error: error.message || String(error),
155
+ trace: tracePath,
156
+ screenshot: screenshotPath,
157
+ });
158
+ }
159
+ }
160
+ }
161
+ catch (error) {
162
+ errors++;
163
+ failures.push({
164
+ test: `Navigate to ${pagePath}`,
165
+ error: error.message || String(error),
166
+ });
167
+ }
168
+ finally {
169
+ await page.close();
170
+ }
171
+ }
172
+ await browser.close();
173
+ }
174
+ catch (error) {
175
+ // Playwright not available or other error
176
+ return {
177
+ ran: false,
178
+ passed: true,
179
+ failures: [{
180
+ test: 'Playwright setup',
181
+ error: error.message || 'Playwright not available',
182
+ }],
183
+ traces: [],
184
+ summary: {
185
+ totalActions: 0,
186
+ passed: 0,
187
+ failed: 0,
188
+ errors: 1,
189
+ },
190
+ };
191
+ }
192
+ return {
193
+ ran: true,
194
+ passed: failures.length === 0,
195
+ failures,
196
+ traces,
197
+ summary: {
198
+ totalActions,
199
+ passed,
200
+ failed,
201
+ errors,
202
+ },
203
+ };
204
+ }
205
+ isPlaywrightAvailable() {
206
+ try {
207
+ require.resolve('playwright');
208
+ return true;
209
+ }
210
+ catch {
211
+ return false;
212
+ }
213
+ }
214
+ }
215
+ exports.PlaywrightSweep = PlaywrightSweep;
216
+ //# sourceMappingURL=playwright-sweep.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"playwright-sweep.js","sourceRoot":"","sources":["../../src/scan/playwright-sweep.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Proof Bundle Generator
3
+ *
4
+ * Creates zip file with traces/HAR/screenshots/log excerpts
5
+ */
6
+ export interface ProofBundle {
7
+ path: string;
8
+ includes: string[];
9
+ metadata: {
10
+ scanId: string;
11
+ timestamp: string;
12
+ verdict: 'PASS' | 'FAIL' | 'WARN';
13
+ findings: number;
14
+ };
15
+ }
16
+ export declare class ProofBundleGenerator {
17
+ /**
18
+ * Create proof bundle zip file
19
+ */
20
+ createBundle(artifactsDir: string, scanResult: any, proofGraph: any, deadUI: any, playwright: any): Promise<ProofBundle | null>;
21
+ private getArchiver;
22
+ private createZipWithArchiver;
23
+ private createBundleManifest;
24
+ }
25
+ //# sourceMappingURL=proof-bundle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proof-bundle.d.ts","sourceRoot":"","sources":["../../src/scan/proof-bundle.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAMH,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,EAAE;QACR,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;QAClC,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;CACH;AAED,qBAAa,oBAAoB;IAC/B;;OAEG;IACG,YAAY,CAChB,YAAY,EAAE,MAAM,EACpB,UAAU,EAAE,GAAG,EACf,UAAU,EAAE,GAAG,EACf,MAAM,EAAE,GAAG,EACX,UAAU,EAAE,GAAG,GACd,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;YA8HhB,WAAW;YAQX,qBAAqB;YAqBrB,oBAAoB;CAiBnC"}