@oculum/scanner 1.0.10 → 1.0.12

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 (520) hide show
  1. package/dist/ai-context/index.d.ts +6 -0
  2. package/dist/ai-context/index.d.ts.map +1 -0
  3. package/dist/ai-context/index.js +13 -0
  4. package/dist/ai-context/index.js.map +1 -0
  5. package/dist/ai-context/manager.d.ts +67 -0
  6. package/dist/ai-context/manager.d.ts.map +1 -0
  7. package/dist/ai-context/manager.js +104 -0
  8. package/dist/ai-context/manager.js.map +1 -0
  9. package/dist/baseline/diff.d.ts +32 -0
  10. package/dist/baseline/diff.d.ts.map +1 -0
  11. package/dist/baseline/diff.js +119 -0
  12. package/dist/baseline/diff.js.map +1 -0
  13. package/dist/baseline/index.d.ts +9 -0
  14. package/dist/baseline/index.d.ts.map +1 -0
  15. package/dist/baseline/index.js +19 -0
  16. package/dist/baseline/index.js.map +1 -0
  17. package/dist/baseline/manager.d.ts +67 -0
  18. package/dist/baseline/manager.d.ts.map +1 -0
  19. package/dist/baseline/manager.js +180 -0
  20. package/dist/baseline/manager.js.map +1 -0
  21. package/dist/baseline/types.d.ts +91 -0
  22. package/dist/baseline/types.d.ts.map +1 -0
  23. package/dist/baseline/types.js +12 -0
  24. package/dist/baseline/types.js.map +1 -0
  25. package/dist/category-filter.d.ts +125 -0
  26. package/dist/category-filter.d.ts.map +1 -0
  27. package/dist/category-filter.js +360 -0
  28. package/dist/category-filter.js.map +1 -0
  29. package/dist/filtering/context-adjustments.d.ts +23 -0
  30. package/dist/filtering/context-adjustments.d.ts.map +1 -0
  31. package/dist/filtering/context-adjustments.js +100 -0
  32. package/dist/filtering/context-adjustments.js.map +1 -0
  33. package/dist/filtering/index.d.ts +3 -0
  34. package/dist/filtering/index.d.ts.map +1 -0
  35. package/dist/filtering/index.js +8 -0
  36. package/dist/filtering/index.js.map +1 -0
  37. package/dist/filtering/pipeline.d.ts +48 -0
  38. package/dist/filtering/pipeline.d.ts.map +1 -0
  39. package/dist/filtering/pipeline.js +76 -0
  40. package/dist/filtering/pipeline.js.map +1 -0
  41. package/dist/formatters/ai-context.d.ts +23 -0
  42. package/dist/formatters/ai-context.d.ts.map +1 -0
  43. package/dist/formatters/ai-context.js +238 -0
  44. package/dist/formatters/ai-context.js.map +1 -0
  45. package/dist/formatters/cli-terminal.d.ts +38 -0
  46. package/dist/formatters/cli-terminal.d.ts.map +1 -1
  47. package/dist/formatters/cli-terminal.js +365 -42
  48. package/dist/formatters/cli-terminal.js.map +1 -1
  49. package/dist/formatters/github-comment.d.ts +2 -2
  50. package/dist/formatters/github-comment.d.ts.map +1 -1
  51. package/dist/formatters/github-comment.js +77 -13
  52. package/dist/formatters/github-comment.js.map +1 -1
  53. package/dist/formatters/ide/claude-code.d.ts +17 -0
  54. package/dist/formatters/ide/claude-code.d.ts.map +1 -0
  55. package/dist/formatters/ide/claude-code.js +94 -0
  56. package/dist/formatters/ide/claude-code.js.map +1 -0
  57. package/dist/formatters/ide/cursor.d.ts +13 -0
  58. package/dist/formatters/ide/cursor.d.ts.map +1 -0
  59. package/dist/formatters/ide/cursor.js +125 -0
  60. package/dist/formatters/ide/cursor.js.map +1 -0
  61. package/dist/formatters/ide/index.d.ts +62 -0
  62. package/dist/formatters/ide/index.d.ts.map +1 -0
  63. package/dist/formatters/ide/index.js +184 -0
  64. package/dist/formatters/ide/index.js.map +1 -0
  65. package/dist/formatters/ide/windsurf.d.ts +13 -0
  66. package/dist/formatters/ide/windsurf.d.ts.map +1 -0
  67. package/dist/formatters/ide/windsurf.js +117 -0
  68. package/dist/formatters/ide/windsurf.js.map +1 -0
  69. package/dist/formatters/index.d.ts +3 -1
  70. package/dist/formatters/index.d.ts.map +1 -1
  71. package/dist/formatters/index.js +20 -1
  72. package/dist/formatters/index.js.map +1 -1
  73. package/dist/index.d.ts +11 -0
  74. package/dist/index.d.ts.map +1 -1
  75. package/dist/index.js +423 -56
  76. package/dist/index.js.map +1 -1
  77. package/dist/layer1/comments.d.ts +4 -1
  78. package/dist/layer1/comments.d.ts.map +1 -1
  79. package/dist/layer1/comments.js +1 -1
  80. package/dist/layer1/comments.js.map +1 -1
  81. package/dist/layer1/config-audit.d.ts +4 -1
  82. package/dist/layer1/config-audit.d.ts.map +1 -1
  83. package/dist/layer1/config-audit.js +65 -14
  84. package/dist/layer1/config-audit.js.map +1 -1
  85. package/dist/layer1/config-mcp-audit.d.ts +23 -0
  86. package/dist/layer1/config-mcp-audit.d.ts.map +1 -0
  87. package/dist/layer1/config-mcp-audit.js +239 -0
  88. package/dist/layer1/config-mcp-audit.js.map +1 -0
  89. package/dist/layer1/entropy.d.ts +4 -1
  90. package/dist/layer1/entropy.d.ts.map +1 -1
  91. package/dist/layer1/entropy.js +212 -1
  92. package/dist/layer1/entropy.js.map +1 -1
  93. package/dist/layer1/file-flags.d.ts +4 -1
  94. package/dist/layer1/file-flags.d.ts.map +1 -1
  95. package/dist/layer1/file-flags.js +12 -5
  96. package/dist/layer1/file-flags.js.map +1 -1
  97. package/dist/layer1/index.d.ts +1 -0
  98. package/dist/layer1/index.d.ts.map +1 -1
  99. package/dist/layer1/index.js +22 -19
  100. package/dist/layer1/index.js.map +1 -1
  101. package/dist/layer1/patterns.d.ts +4 -1
  102. package/dist/layer1/patterns.d.ts.map +1 -1
  103. package/dist/layer1/patterns.js +34 -4
  104. package/dist/layer1/patterns.js.map +1 -1
  105. package/dist/layer1/urls.d.ts +4 -1
  106. package/dist/layer1/urls.d.ts.map +1 -1
  107. package/dist/layer1/urls.js +162 -14
  108. package/dist/layer1/urls.js.map +1 -1
  109. package/dist/layer1/weak-crypto.d.ts +4 -1
  110. package/dist/layer1/weak-crypto.d.ts.map +1 -1
  111. package/dist/layer1/weak-crypto.js +144 -7
  112. package/dist/layer1/weak-crypto.js.map +1 -1
  113. package/dist/layer2/ai-agent-tools.d.ts +4 -1
  114. package/dist/layer2/ai-agent-tools.d.ts.map +1 -1
  115. package/dist/layer2/ai-agent-tools.js +964 -2
  116. package/dist/layer2/ai-agent-tools.js.map +1 -1
  117. package/dist/layer2/ai-endpoint-protection.d.ts +2 -0
  118. package/dist/layer2/ai-endpoint-protection.d.ts.map +1 -1
  119. package/dist/layer2/ai-endpoint-protection.js +18 -4
  120. package/dist/layer2/ai-endpoint-protection.js.map +1 -1
  121. package/dist/layer2/ai-execution-sinks.d.ts +4 -1
  122. package/dist/layer2/ai-execution-sinks.d.ts.map +1 -1
  123. package/dist/layer2/ai-execution-sinks.js +688 -29
  124. package/dist/layer2/ai-execution-sinks.js.map +1 -1
  125. package/dist/layer2/ai-fingerprinting.d.ts +4 -1
  126. package/dist/layer2/ai-fingerprinting.d.ts.map +1 -1
  127. package/dist/layer2/ai-fingerprinting.js +28 -32
  128. package/dist/layer2/ai-fingerprinting.js.map +1 -1
  129. package/dist/layer2/ai-mcp-security.d.ts +20 -0
  130. package/dist/layer2/ai-mcp-security.d.ts.map +1 -0
  131. package/dist/layer2/ai-mcp-security.js +877 -0
  132. package/dist/layer2/ai-mcp-security.js.map +1 -0
  133. package/dist/layer2/ai-package-hallucination.d.ts +22 -0
  134. package/dist/layer2/ai-package-hallucination.d.ts.map +1 -0
  135. package/dist/layer2/ai-package-hallucination.js +828 -0
  136. package/dist/layer2/ai-package-hallucination.js.map +1 -0
  137. package/dist/layer2/ai-prompt-hygiene.d.ts +4 -1
  138. package/dist/layer2/ai-prompt-hygiene.d.ts.map +1 -1
  139. package/dist/layer2/ai-prompt-hygiene.js +817 -17
  140. package/dist/layer2/ai-prompt-hygiene.js.map +1 -1
  141. package/dist/layer2/ai-rag-safety.d.ts +4 -1
  142. package/dist/layer2/ai-rag-safety.d.ts.map +1 -1
  143. package/dist/layer2/ai-rag-safety.js +454 -3
  144. package/dist/layer2/ai-rag-safety.js.map +1 -1
  145. package/dist/layer2/ai-schema-validation.d.ts +4 -1
  146. package/dist/layer2/ai-schema-validation.d.ts.map +1 -1
  147. package/dist/layer2/ai-schema-validation.js +2 -2
  148. package/dist/layer2/ai-schema-validation.js.map +1 -1
  149. package/dist/layer2/auth-antipatterns.d.ts +2 -0
  150. package/dist/layer2/auth-antipatterns.d.ts.map +1 -1
  151. package/dist/layer2/auth-antipatterns.js +209 -20
  152. package/dist/layer2/auth-antipatterns.js.map +1 -1
  153. package/dist/layer2/byok-patterns.d.ts +4 -1
  154. package/dist/layer2/byok-patterns.d.ts.map +1 -1
  155. package/dist/layer2/byok-patterns.js +5 -2
  156. package/dist/layer2/byok-patterns.js.map +1 -1
  157. package/dist/layer2/dangerous-functions/child-process.d.ts +16 -0
  158. package/dist/layer2/dangerous-functions/child-process.d.ts.map +1 -0
  159. package/dist/layer2/dangerous-functions/child-process.js +74 -0
  160. package/dist/layer2/dangerous-functions/child-process.js.map +1 -0
  161. package/dist/layer2/dangerous-functions/dom-xss.d.ts +34 -0
  162. package/dist/layer2/dangerous-functions/dom-xss.d.ts.map +1 -0
  163. package/dist/layer2/dangerous-functions/dom-xss.js +230 -0
  164. package/dist/layer2/dangerous-functions/dom-xss.js.map +1 -0
  165. package/dist/layer2/dangerous-functions/index.d.ts +16 -0
  166. package/dist/layer2/dangerous-functions/index.d.ts.map +1 -0
  167. package/dist/layer2/dangerous-functions/index.js +1152 -0
  168. package/dist/layer2/dangerous-functions/index.js.map +1 -0
  169. package/dist/layer2/dangerous-functions/json-parse.d.ts +31 -0
  170. package/dist/layer2/dangerous-functions/json-parse.d.ts.map +1 -0
  171. package/dist/layer2/dangerous-functions/json-parse.js +319 -0
  172. package/dist/layer2/dangerous-functions/json-parse.js.map +1 -0
  173. package/dist/layer2/dangerous-functions/math-random.d.ts +111 -0
  174. package/dist/layer2/dangerous-functions/math-random.d.ts.map +1 -0
  175. package/dist/layer2/dangerous-functions/math-random.js +684 -0
  176. package/dist/layer2/dangerous-functions/math-random.js.map +1 -0
  177. package/dist/layer2/dangerous-functions/patterns.d.ts +21 -0
  178. package/dist/layer2/dangerous-functions/patterns.d.ts.map +1 -0
  179. package/dist/layer2/dangerous-functions/patterns.js +163 -0
  180. package/dist/layer2/dangerous-functions/patterns.js.map +1 -0
  181. package/dist/layer2/dangerous-functions/request-validation.d.ts +13 -0
  182. package/dist/layer2/dangerous-functions/request-validation.d.ts.map +1 -0
  183. package/dist/layer2/dangerous-functions/request-validation.js +119 -0
  184. package/dist/layer2/dangerous-functions/request-validation.js.map +1 -0
  185. package/dist/layer2/dangerous-functions/utils/control-flow.d.ts +24 -0
  186. package/dist/layer2/dangerous-functions/utils/control-flow.d.ts.map +1 -0
  187. package/dist/layer2/dangerous-functions/utils/control-flow.js +70 -0
  188. package/dist/layer2/dangerous-functions/utils/control-flow.js.map +1 -0
  189. package/dist/layer2/dangerous-functions/utils/helpers.d.ts +31 -0
  190. package/dist/layer2/dangerous-functions/utils/helpers.d.ts.map +1 -0
  191. package/dist/layer2/dangerous-functions/utils/helpers.js +147 -0
  192. package/dist/layer2/dangerous-functions/utils/helpers.js.map +1 -0
  193. package/dist/layer2/dangerous-functions/utils/index.d.ts +9 -0
  194. package/dist/layer2/dangerous-functions/utils/index.d.ts.map +1 -0
  195. package/dist/layer2/dangerous-functions/utils/index.js +23 -0
  196. package/dist/layer2/dangerous-functions/utils/index.js.map +1 -0
  197. package/dist/layer2/dangerous-functions/utils/schema-validation.d.ts +22 -0
  198. package/dist/layer2/dangerous-functions/utils/schema-validation.d.ts.map +1 -0
  199. package/dist/layer2/dangerous-functions/utils/schema-validation.js +102 -0
  200. package/dist/layer2/dangerous-functions/utils/schema-validation.js.map +1 -0
  201. package/dist/layer2/data-exposure.d.ts +4 -1
  202. package/dist/layer2/data-exposure.d.ts.map +1 -1
  203. package/dist/layer2/data-exposure.js +14 -38
  204. package/dist/layer2/data-exposure.js.map +1 -1
  205. package/dist/layer2/framework-checks.d.ts +4 -1
  206. package/dist/layer2/framework-checks.d.ts.map +1 -1
  207. package/dist/layer2/framework-checks.js +5 -2
  208. package/dist/layer2/framework-checks.js.map +1 -1
  209. package/dist/layer2/index.d.ts +12 -1
  210. package/dist/layer2/index.d.ts.map +1 -1
  211. package/dist/layer2/index.js +110 -45
  212. package/dist/layer2/index.js.map +1 -1
  213. package/dist/layer2/logic-gates.d.ts +4 -1
  214. package/dist/layer2/logic-gates.d.ts.map +1 -1
  215. package/dist/layer2/logic-gates.js +58 -20
  216. package/dist/layer2/logic-gates.js.map +1 -1
  217. package/dist/layer2/model-supply-chain.d.ts +23 -0
  218. package/dist/layer2/model-supply-chain.d.ts.map +1 -0
  219. package/dist/layer2/model-supply-chain.js +444 -0
  220. package/dist/layer2/model-supply-chain.js.map +1 -0
  221. package/dist/layer2/risky-imports.d.ts +4 -1
  222. package/dist/layer2/risky-imports.d.ts.map +1 -1
  223. package/dist/layer2/risky-imports.js +6 -2
  224. package/dist/layer2/risky-imports.js.map +1 -1
  225. package/dist/layer2/variables.d.ts +4 -1
  226. package/dist/layer2/variables.d.ts.map +1 -1
  227. package/dist/layer2/variables.js +6 -2
  228. package/dist/layer2/variables.js.map +1 -1
  229. package/dist/layer3/anthropic/auto-dismiss.d.ts +24 -0
  230. package/dist/layer3/anthropic/auto-dismiss.d.ts.map +1 -0
  231. package/dist/layer3/anthropic/auto-dismiss.js +199 -0
  232. package/dist/layer3/anthropic/auto-dismiss.js.map +1 -0
  233. package/dist/layer3/anthropic/clients.d.ts +44 -0
  234. package/dist/layer3/anthropic/clients.d.ts.map +1 -0
  235. package/dist/layer3/anthropic/clients.js +81 -0
  236. package/dist/layer3/anthropic/clients.js.map +1 -0
  237. package/dist/layer3/anthropic/index.d.ts +41 -0
  238. package/dist/layer3/anthropic/index.d.ts.map +1 -0
  239. package/dist/layer3/anthropic/index.js +141 -0
  240. package/dist/layer3/anthropic/index.js.map +1 -0
  241. package/dist/layer3/anthropic/prompts/index.d.ts +8 -0
  242. package/dist/layer3/anthropic/prompts/index.d.ts.map +1 -0
  243. package/dist/layer3/anthropic/prompts/index.js +14 -0
  244. package/dist/layer3/anthropic/prompts/index.js.map +1 -0
  245. package/dist/layer3/anthropic/prompts/semantic-analysis.d.ts +15 -0
  246. package/dist/layer3/anthropic/prompts/semantic-analysis.d.ts.map +1 -0
  247. package/dist/layer3/anthropic/prompts/semantic-analysis.js +169 -0
  248. package/dist/layer3/anthropic/prompts/semantic-analysis.js.map +1 -0
  249. package/dist/layer3/anthropic/prompts/validation.d.ts +12 -0
  250. package/dist/layer3/anthropic/prompts/validation.d.ts.map +1 -0
  251. package/dist/layer3/anthropic/prompts/validation.js +421 -0
  252. package/dist/layer3/anthropic/prompts/validation.js.map +1 -0
  253. package/dist/layer3/anthropic/providers/anthropic.d.ts +21 -0
  254. package/dist/layer3/anthropic/providers/anthropic.d.ts.map +1 -0
  255. package/dist/layer3/anthropic/providers/anthropic.js +266 -0
  256. package/dist/layer3/anthropic/providers/anthropic.js.map +1 -0
  257. package/dist/layer3/anthropic/providers/index.d.ts +8 -0
  258. package/dist/layer3/anthropic/providers/index.d.ts.map +1 -0
  259. package/dist/layer3/anthropic/providers/index.js +15 -0
  260. package/dist/layer3/anthropic/providers/index.js.map +1 -0
  261. package/dist/layer3/anthropic/providers/openai.d.ts +18 -0
  262. package/dist/layer3/anthropic/providers/openai.d.ts.map +1 -0
  263. package/dist/layer3/anthropic/providers/openai.js +340 -0
  264. package/dist/layer3/anthropic/providers/openai.js.map +1 -0
  265. package/dist/layer3/anthropic/request-builder.d.ts +20 -0
  266. package/dist/layer3/anthropic/request-builder.d.ts.map +1 -0
  267. package/dist/layer3/anthropic/request-builder.js +134 -0
  268. package/dist/layer3/anthropic/request-builder.js.map +1 -0
  269. package/dist/layer3/anthropic/types.d.ts +88 -0
  270. package/dist/layer3/anthropic/types.d.ts.map +1 -0
  271. package/dist/layer3/anthropic/types.js +38 -0
  272. package/dist/layer3/anthropic/types.js.map +1 -0
  273. package/dist/layer3/anthropic/utils/index.d.ts +9 -0
  274. package/dist/layer3/anthropic/utils/index.d.ts.map +1 -0
  275. package/dist/layer3/anthropic/utils/index.js +24 -0
  276. package/dist/layer3/anthropic/utils/index.js.map +1 -0
  277. package/dist/layer3/anthropic/utils/path-helpers.d.ts +21 -0
  278. package/dist/layer3/anthropic/utils/path-helpers.d.ts.map +1 -0
  279. package/dist/layer3/anthropic/utils/path-helpers.js +69 -0
  280. package/dist/layer3/anthropic/utils/path-helpers.js.map +1 -0
  281. package/dist/layer3/anthropic/utils/response-parser.d.ts +40 -0
  282. package/dist/layer3/anthropic/utils/response-parser.d.ts.map +1 -0
  283. package/dist/layer3/anthropic/utils/response-parser.js +285 -0
  284. package/dist/layer3/anthropic/utils/response-parser.js.map +1 -0
  285. package/dist/layer3/anthropic/utils/retry.d.ts +15 -0
  286. package/dist/layer3/anthropic/utils/retry.d.ts.map +1 -0
  287. package/dist/layer3/anthropic/utils/retry.js +62 -0
  288. package/dist/layer3/anthropic/utils/retry.js.map +1 -0
  289. package/dist/layer3/index.d.ts +1 -0
  290. package/dist/layer3/index.d.ts.map +1 -1
  291. package/dist/layer3/index.js +16 -6
  292. package/dist/layer3/index.js.map +1 -1
  293. package/dist/layer3/osv-check.d.ts +75 -0
  294. package/dist/layer3/osv-check.d.ts.map +1 -0
  295. package/dist/layer3/osv-check.js +308 -0
  296. package/dist/layer3/osv-check.js.map +1 -0
  297. package/dist/modes/incremental.js +1 -1
  298. package/dist/rules/framework-fixes.d.ts +48 -0
  299. package/dist/rules/framework-fixes.d.ts.map +1 -0
  300. package/dist/rules/framework-fixes.js +439 -0
  301. package/dist/rules/framework-fixes.js.map +1 -0
  302. package/dist/rules/index.d.ts +8 -0
  303. package/dist/rules/index.d.ts.map +1 -0
  304. package/dist/rules/index.js +18 -0
  305. package/dist/rules/index.js.map +1 -0
  306. package/dist/rules/metadata.d.ts +43 -0
  307. package/dist/rules/metadata.d.ts.map +1 -0
  308. package/dist/rules/metadata.js +734 -0
  309. package/dist/rules/metadata.js.map +1 -0
  310. package/dist/suppression/config-loader.d.ts +74 -0
  311. package/dist/suppression/config-loader.d.ts.map +1 -0
  312. package/dist/suppression/config-loader.js +424 -0
  313. package/dist/suppression/config-loader.js.map +1 -0
  314. package/dist/suppression/hash.d.ts +48 -0
  315. package/dist/suppression/hash.d.ts.map +1 -0
  316. package/dist/suppression/hash.js +88 -0
  317. package/dist/suppression/hash.js.map +1 -0
  318. package/dist/suppression/index.d.ts +11 -0
  319. package/dist/suppression/index.d.ts.map +1 -0
  320. package/dist/suppression/index.js +39 -0
  321. package/dist/suppression/index.js.map +1 -0
  322. package/dist/suppression/inline-parser.d.ts +39 -0
  323. package/dist/suppression/inline-parser.d.ts.map +1 -0
  324. package/dist/suppression/inline-parser.js +218 -0
  325. package/dist/suppression/inline-parser.js.map +1 -0
  326. package/dist/suppression/manager.d.ts +94 -0
  327. package/dist/suppression/manager.d.ts.map +1 -0
  328. package/dist/suppression/manager.js +292 -0
  329. package/dist/suppression/manager.js.map +1 -0
  330. package/dist/suppression/types.d.ts +151 -0
  331. package/dist/suppression/types.d.ts.map +1 -0
  332. package/dist/suppression/types.js +28 -0
  333. package/dist/suppression/types.js.map +1 -0
  334. package/dist/tiers.d.ts +3 -3
  335. package/dist/tiers.d.ts.map +1 -1
  336. package/dist/tiers.js +34 -7
  337. package/dist/tiers.js.map +1 -1
  338. package/dist/types.d.ts +140 -9
  339. package/dist/types.d.ts.map +1 -1
  340. package/dist/types.js +34 -0
  341. package/dist/types.js.map +1 -1
  342. package/dist/utils/code-analysis.d.ts +39 -0
  343. package/dist/utils/code-analysis.d.ts.map +1 -0
  344. package/dist/utils/code-analysis.js +159 -0
  345. package/dist/utils/code-analysis.js.map +1 -0
  346. package/dist/utils/comment-analyzer.d.ts +38 -0
  347. package/dist/utils/comment-analyzer.d.ts.map +1 -0
  348. package/dist/utils/comment-analyzer.js +218 -0
  349. package/dist/utils/comment-analyzer.js.map +1 -0
  350. package/dist/utils/context-helpers.d.ts +112 -1
  351. package/dist/utils/context-helpers.d.ts.map +1 -1
  352. package/dist/utils/context-helpers.js +364 -11
  353. package/dist/utils/context-helpers.js.map +1 -1
  354. package/dist/utils/environment-context.d.ts +76 -0
  355. package/dist/utils/environment-context.d.ts.map +1 -0
  356. package/dist/utils/environment-context.js +271 -0
  357. package/dist/utils/environment-context.js.map +1 -0
  358. package/dist/utils/intent-detector.d.ts +66 -0
  359. package/dist/utils/intent-detector.d.ts.map +1 -0
  360. package/dist/utils/intent-detector.js +282 -0
  361. package/dist/utils/intent-detector.js.map +1 -0
  362. package/dist/utils/parsed-file.d.ts +51 -0
  363. package/dist/utils/parsed-file.d.ts.map +1 -0
  364. package/dist/utils/parsed-file.js +95 -0
  365. package/dist/utils/parsed-file.js.map +1 -0
  366. package/dist/utils/route-hierarchy.d.ts +50 -0
  367. package/dist/utils/route-hierarchy.d.ts.map +1 -0
  368. package/dist/utils/route-hierarchy.js +226 -0
  369. package/dist/utils/route-hierarchy.js.map +1 -0
  370. package/dist/utils/schema-semantics.d.ts +45 -0
  371. package/dist/utils/schema-semantics.d.ts.map +1 -0
  372. package/dist/utils/schema-semantics.js +193 -0
  373. package/dist/utils/schema-semantics.js.map +1 -0
  374. package/package.json +4 -2
  375. package/src/__tests__/benchmark/fixtures/layer1/mcp-config-audit.json +31 -0
  376. package/src/__tests__/benchmark/fixtures/layer2/ai-execution-sinks.ts +1489 -82
  377. package/src/__tests__/benchmark/fixtures/layer2/ai-mcp-security.ts +495 -0
  378. package/src/__tests__/benchmark/fixtures/layer2/ai-package-hallucination.ts +255 -0
  379. package/src/__tests__/benchmark/fixtures/layer2/ai-prompt-hygiene.ts +300 -1
  380. package/src/__tests__/benchmark/fixtures/layer2/ai-rag-safety.ts +139 -0
  381. package/src/__tests__/benchmark/fixtures/layer2/byok-patterns.ts +7 -0
  382. package/src/__tests__/benchmark/fixtures/layer2/data-exposure.ts +63 -0
  383. package/src/__tests__/benchmark/fixtures/layer2/excessive-agency.ts +221 -0
  384. package/src/__tests__/benchmark/fixtures/layer2/index.ts +30 -0
  385. package/src/__tests__/benchmark/fixtures/layer2/model-supply-chain.ts +204 -0
  386. package/src/__tests__/benchmark/fixtures/layer2/phase1-enhancements.ts +157 -0
  387. package/src/__tests__/benchmark/fixtures/layer2/phase5-excessive-agency.ts +580 -0
  388. package/src/__tests__/benchmark/fixtures/layer2/sprint6-ai-enhancements.ts +515 -0
  389. package/src/__tests__/benchmark/run-depth-validation.ts +9 -9
  390. package/src/__tests__/category-filter.test.ts +478 -0
  391. package/src/__tests__/regression/known-false-positives.test.ts +490 -0
  392. package/src/__tests__/snapshots/__snapshots__/anthropic-validation-refactor.test.ts.snap +762 -0
  393. package/src/__tests__/snapshots/__snapshots__/dangerous-functions-refactor.test.ts.snap +503 -0
  394. package/src/__tests__/snapshots/__snapshots__/scan-depth.test.ts.snap +0 -9
  395. package/src/__tests__/snapshots/anthropic-validation-refactor.test.ts +321 -0
  396. package/src/__tests__/snapshots/dangerous-functions-refactor.test.ts +439 -0
  397. package/src/__tests__/validation/run-validation.ts +7 -7
  398. package/src/ai-context/__tests__/manager.test.ts +193 -0
  399. package/src/ai-context/index.ts +15 -0
  400. package/src/ai-context/manager.ts +145 -0
  401. package/src/baseline/__tests__/diff.test.ts +261 -0
  402. package/src/baseline/__tests__/manager.test.ts +225 -0
  403. package/src/baseline/diff.ts +135 -0
  404. package/src/baseline/index.ts +29 -0
  405. package/src/baseline/manager.ts +230 -0
  406. package/src/baseline/types.ts +97 -0
  407. package/src/category-filter.ts +400 -0
  408. package/src/filtering/__tests__/pipeline.test.ts +134 -0
  409. package/src/filtering/context-adjustments.ts +111 -0
  410. package/src/filtering/index.ts +10 -0
  411. package/src/filtering/pipeline.ts +130 -0
  412. package/src/formatters/__tests__/ai-context.test.ts +254 -0
  413. package/src/formatters/ai-context.ts +302 -0
  414. package/src/formatters/cli-terminal.ts +444 -41
  415. package/src/formatters/github-comment.ts +82 -14
  416. package/src/formatters/ide/__tests__/ide.test.ts +319 -0
  417. package/src/formatters/ide/claude-code.ts +110 -0
  418. package/src/formatters/ide/cursor.ts +147 -0
  419. package/src/formatters/ide/index.ts +216 -0
  420. package/src/formatters/ide/windsurf.ts +135 -0
  421. package/src/formatters/index.ts +28 -0
  422. package/src/index.ts +506 -45
  423. package/src/layer1/comments.ts +3 -1
  424. package/src/layer1/config-audit.ts +74 -14
  425. package/src/layer1/config-mcp-audit.ts +278 -0
  426. package/src/layer1/entropy.ts +234 -1
  427. package/src/layer1/file-flags.ts +17 -6
  428. package/src/layer1/index.ts +29 -23
  429. package/src/layer1/patterns.ts +42 -4
  430. package/src/layer1/urls.ts +188 -14
  431. package/src/layer1/weak-crypto.ts +168 -16
  432. package/src/layer2/ai-agent-tools.ts +1043 -2
  433. package/src/layer2/ai-endpoint-protection.ts +19 -4
  434. package/src/layer2/ai-execution-sinks.ts +755 -29
  435. package/src/layer2/ai-fingerprinting.ts +33 -33
  436. package/src/layer2/ai-mcp-security.ts +933 -0
  437. package/src/layer2/ai-package-hallucination.ts +940 -0
  438. package/src/layer2/ai-prompt-hygiene.ts +898 -17
  439. package/src/layer2/ai-rag-safety.ts +467 -5
  440. package/src/layer2/ai-schema-validation.ts +4 -2
  441. package/src/layer2/auth-antipatterns.ts +235 -20
  442. package/src/layer2/byok-patterns.ts +9 -3
  443. package/src/layer2/dangerous-functions/child-process.ts +98 -0
  444. package/src/layer2/dangerous-functions/dom-xss.ts +292 -0
  445. package/src/layer2/dangerous-functions/index.ts +1533 -0
  446. package/src/layer2/dangerous-functions/json-parse.ts +385 -0
  447. package/src/layer2/dangerous-functions/math-random.ts +789 -0
  448. package/src/layer2/dangerous-functions/patterns.ts +176 -0
  449. package/src/layer2/dangerous-functions/request-validation.ts +145 -0
  450. package/src/layer2/dangerous-functions/utils/control-flow.ts +35 -0
  451. package/src/layer2/dangerous-functions/utils/helpers.ts +170 -0
  452. package/src/layer2/dangerous-functions/utils/index.ts +25 -0
  453. package/src/layer2/dangerous-functions/utils/schema-validation.ts +106 -0
  454. package/src/layer2/data-exposure.ts +18 -39
  455. package/src/layer2/framework-checks.ts +9 -2
  456. package/src/layer2/index.ts +124 -43
  457. package/src/layer2/logic-gates.ts +64 -22
  458. package/src/layer2/model-supply-chain.ts +531 -0
  459. package/src/layer2/risky-imports.ts +9 -2
  460. package/src/layer2/variables.ts +9 -2
  461. package/src/layer3/__tests__/osv-check.test.ts +384 -0
  462. package/src/layer3/anthropic/auto-dismiss.ts +223 -0
  463. package/src/layer3/anthropic/clients.ts +84 -0
  464. package/src/layer3/anthropic/index.ts +170 -0
  465. package/src/layer3/anthropic/prompts/index.ts +14 -0
  466. package/src/layer3/anthropic/prompts/semantic-analysis.ts +173 -0
  467. package/src/layer3/anthropic/prompts/validation.ts +419 -0
  468. package/src/layer3/anthropic/providers/anthropic.ts +310 -0
  469. package/src/layer3/anthropic/providers/index.ts +8 -0
  470. package/src/layer3/anthropic/providers/openai.ts +384 -0
  471. package/src/layer3/anthropic/request-builder.ts +150 -0
  472. package/src/layer3/anthropic/types.ts +148 -0
  473. package/src/layer3/anthropic/utils/index.ts +26 -0
  474. package/src/layer3/anthropic/utils/path-helpers.ts +68 -0
  475. package/src/layer3/anthropic/utils/response-parser.ts +322 -0
  476. package/src/layer3/anthropic/utils/retry.ts +75 -0
  477. package/src/layer3/index.ts +18 -5
  478. package/src/layer3/osv-check.ts +420 -0
  479. package/src/modes/incremental.ts +1 -1
  480. package/src/rules/__tests__/framework-fixes.test.ts +689 -0
  481. package/src/rules/__tests__/metadata.test.ts +218 -0
  482. package/src/rules/framework-fixes.ts +470 -0
  483. package/src/rules/index.ts +21 -0
  484. package/src/rules/metadata.ts +831 -0
  485. package/src/suppression/__tests__/config-loader.test.ts +382 -0
  486. package/src/suppression/__tests__/hash.test.ts +166 -0
  487. package/src/suppression/__tests__/inline-parser.test.ts +212 -0
  488. package/src/suppression/__tests__/manager.test.ts +415 -0
  489. package/src/suppression/config-loader.ts +462 -0
  490. package/src/suppression/hash.ts +95 -0
  491. package/src/suppression/index.ts +51 -0
  492. package/src/suppression/inline-parser.ts +273 -0
  493. package/src/suppression/manager.ts +379 -0
  494. package/src/suppression/types.ts +174 -0
  495. package/src/tiers.ts +45 -9
  496. package/src/types.ts +212 -8
  497. package/src/utils/__tests__/code-analysis.test.ts +165 -0
  498. package/src/utils/__tests__/parsed-file.test.ts +124 -0
  499. package/src/utils/code-analysis.ts +179 -0
  500. package/src/utils/comment-analyzer.ts +249 -0
  501. package/src/utils/context-helpers.ts +421 -11
  502. package/src/utils/environment-context.ts +304 -0
  503. package/src/utils/intent-detector.ts +318 -0
  504. package/src/utils/parsed-file.ts +103 -0
  505. package/src/utils/route-hierarchy.ts +250 -0
  506. package/src/utils/schema-semantics.ts +233 -0
  507. package/dist/layer2/dangerous-functions.d.ts +0 -7
  508. package/dist/layer2/dangerous-functions.d.ts.map +0 -1
  509. package/dist/layer2/dangerous-functions.js +0 -1701
  510. package/dist/layer2/dangerous-functions.js.map +0 -1
  511. package/dist/layer3/anthropic.d.ts +0 -87
  512. package/dist/layer3/anthropic.d.ts.map +0 -1
  513. package/dist/layer3/anthropic.js +0 -1948
  514. package/dist/layer3/anthropic.js.map +0 -1
  515. package/dist/layer3/openai.d.ts +0 -25
  516. package/dist/layer3/openai.d.ts.map +0 -1
  517. package/dist/layer3/openai.js +0 -238
  518. package/dist/layer3/openai.js.map +0 -1
  519. package/src/layer2/dangerous-functions.ts +0 -1940
  520. package/src/layer3/anthropic.ts +0 -2257
@@ -0,0 +1,135 @@
1
+ /**
2
+ * Baseline Diff Computation
3
+ * Computes the difference between current findings and a baseline
4
+ */
5
+
6
+ import type { Vulnerability, SeverityCounts, VulnerabilitySeverity } from '../types'
7
+ import type { BaselineData, BaselineFinding, DiffResult } from './types'
8
+ import { computeFindingHash } from '../suppression/hash'
9
+
10
+ /**
11
+ * Compute severity counts from baseline findings
12
+ */
13
+ function computeBaselineSeverityCounts(findings: BaselineFinding[]): SeverityCounts {
14
+ const counts: SeverityCounts = { critical: 0, high: 0, medium: 0, low: 0, info: 0 }
15
+
16
+ for (const finding of findings) {
17
+ const severity = finding.severity as VulnerabilitySeverity
18
+ if (severity in counts) {
19
+ counts[severity]++
20
+ }
21
+ }
22
+
23
+ return counts
24
+ }
25
+
26
+ /**
27
+ * Compute severity counts from vulnerabilities
28
+ */
29
+ function computeVulnerabilitySeverityCounts(vulnerabilities: Vulnerability[]): SeverityCounts {
30
+ const counts: SeverityCounts = { critical: 0, high: 0, medium: 0, low: 0, info: 0 }
31
+
32
+ for (const vuln of vulnerabilities) {
33
+ if (vuln.severity in counts) {
34
+ counts[vuln.severity]++
35
+ }
36
+ }
37
+
38
+ return counts
39
+ }
40
+
41
+ /**
42
+ * Compute the diff between current scan findings and a baseline
43
+ *
44
+ * Uses finding hashes for comparison, which are computed from:
45
+ * - Normalized file path
46
+ * - Normalized line content
47
+ * - Category
48
+ *
49
+ * This means findings are considered the same even if:
50
+ * - Line numbers changed (code moved)
51
+ * - Minor whitespace changes occurred
52
+ *
53
+ * @param currentFindings - Vulnerabilities from the current scan
54
+ * @param baseline - The baseline to compare against
55
+ * @returns DiffResult with new, fixed, and existing findings
56
+ */
57
+ export function computeDiff(
58
+ currentFindings: Vulnerability[],
59
+ baseline: BaselineData
60
+ ): DiffResult {
61
+ // Build hash set from baseline for O(1) lookup
62
+ const baselineHashes = new Set(baseline.findings.map(f => f.hash))
63
+
64
+ // Build hash map from current findings
65
+ const currentHashMap = new Map<string, Vulnerability>()
66
+ for (const finding of currentFindings) {
67
+ const hash = computeFindingHash(finding)
68
+ currentHashMap.set(hash, finding)
69
+ }
70
+
71
+ // Compute new findings (in current, not in baseline)
72
+ const newFindings: Vulnerability[] = []
73
+ for (const finding of currentFindings) {
74
+ const hash = computeFindingHash(finding)
75
+ if (!baselineHashes.has(hash)) {
76
+ newFindings.push(finding)
77
+ }
78
+ }
79
+
80
+ // Compute fixed findings (in baseline, not in current)
81
+ const fixedFindings: BaselineFinding[] = []
82
+ for (const baselineFinding of baseline.findings) {
83
+ if (!currentHashMap.has(baselineFinding.hash)) {
84
+ fixedFindings.push(baselineFinding)
85
+ }
86
+ }
87
+
88
+ // Compute existing findings (in both)
89
+ const existingFindings: Vulnerability[] = []
90
+ for (const finding of currentFindings) {
91
+ const hash = computeFindingHash(finding)
92
+ if (baselineHashes.has(hash)) {
93
+ existingFindings.push(finding)
94
+ }
95
+ }
96
+
97
+ return {
98
+ new: newFindings,
99
+ fixed: fixedFindings,
100
+ existing: existingFindings,
101
+ stats: {
102
+ newCount: newFindings.length,
103
+ fixedCount: fixedFindings.length,
104
+ existingCount: existingFindings.length,
105
+ newBySeverity: computeVulnerabilitySeverityCounts(newFindings),
106
+ fixedBySeverity: computeBaselineSeverityCounts(fixedFindings),
107
+ },
108
+ }
109
+ }
110
+
111
+ /**
112
+ * Check if a diff has any new blocking issues (critical or high severity)
113
+ */
114
+ export function hasNewBlockingIssues(diff: DiffResult): boolean {
115
+ return diff.stats.newBySeverity.critical > 0 || diff.stats.newBySeverity.high > 0
116
+ }
117
+
118
+ /**
119
+ * Format a summary string for the diff
120
+ */
121
+ export function formatDiffSummary(diff: DiffResult): string {
122
+ const parts: string[] = []
123
+
124
+ if (diff.stats.newCount > 0) {
125
+ parts.push(`${diff.stats.newCount} new`)
126
+ }
127
+ if (diff.stats.fixedCount > 0) {
128
+ parts.push(`${diff.stats.fixedCount} fixed`)
129
+ }
130
+ if (diff.stats.existingCount > 0) {
131
+ parts.push(`${diff.stats.existingCount} existing`)
132
+ }
133
+
134
+ return parts.join(', ')
135
+ }
@@ -0,0 +1,29 @@
1
+ /**
2
+ * Baseline Module
3
+ * Provides baseline/diff mode functionality for tracking security improvements
4
+ */
5
+
6
+ // Types
7
+ export type {
8
+ BaselineFinding,
9
+ BaselineData,
10
+ DiffResult,
11
+ BaselineDiff,
12
+ } from './types'
13
+ export { BASELINE_FILE_PATH, OCULUM_DIR } from './types'
14
+
15
+ // Manager
16
+ export {
17
+ BaselineManager,
18
+ type BaselineManagerOptions,
19
+ type LoadBaselineResult,
20
+ type SaveBaselineResult,
21
+ type ClearBaselineResult,
22
+ } from './manager'
23
+
24
+ // Diff computation
25
+ export {
26
+ computeDiff,
27
+ hasNewBlockingIssues,
28
+ formatDiffSummary,
29
+ } from './diff'
@@ -0,0 +1,230 @@
1
+ /**
2
+ * Baseline Manager
3
+ * Handles loading, saving, and clearing baseline files
4
+ */
5
+
6
+ import { existsSync, readFileSync, writeFileSync, mkdirSync, unlinkSync } from 'fs'
7
+ import { join, dirname } from 'path'
8
+ import { execFileSync } from 'child_process'
9
+ import type { ScanResult, ScanDepth, Vulnerability } from '../types'
10
+ import type { BaselineData, BaselineFinding } from './types'
11
+ import { BASELINE_FILE_PATH, OCULUM_DIR } from './types'
12
+ import { computeFindingHash } from '../suppression/hash'
13
+
14
+ export interface BaselineManagerOptions {
15
+ /** Project root path */
16
+ projectPath: string
17
+ }
18
+
19
+ export interface LoadBaselineResult {
20
+ /** Whether a baseline was found */
21
+ found: boolean
22
+ /** The baseline data (if found) */
23
+ baseline?: BaselineData
24
+ /** Error message (if failed to load) */
25
+ error?: string
26
+ }
27
+
28
+ export interface SaveBaselineResult {
29
+ /** Whether the save was successful */
30
+ success: boolean
31
+ /** Path where baseline was saved */
32
+ path: string
33
+ /** Error message (if failed) */
34
+ error?: string
35
+ }
36
+
37
+ export interface ClearBaselineResult {
38
+ /** Whether the clear was successful */
39
+ success: boolean
40
+ /** Whether a baseline existed before clearing */
41
+ existed: boolean
42
+ /** Error message (if failed) */
43
+ error?: string
44
+ }
45
+
46
+ /**
47
+ * Get current git commit SHA (short form)
48
+ */
49
+ function getGitCommit(projectPath: string): string | undefined {
50
+ try {
51
+ const result = execFileSync('git', ['rev-parse', '--short', 'HEAD'], {
52
+ cwd: projectPath,
53
+ stdio: ['ignore', 'pipe', 'ignore'],
54
+ })
55
+ return result.toString().trim()
56
+ } catch {
57
+ return undefined
58
+ }
59
+ }
60
+
61
+ /**
62
+ * Get current git branch name
63
+ */
64
+ function getGitBranch(projectPath: string): string | undefined {
65
+ try {
66
+ const result = execFileSync('git', ['rev-parse', '--abbrev-ref', 'HEAD'], {
67
+ cwd: projectPath,
68
+ stdio: ['ignore', 'pipe', 'ignore'],
69
+ })
70
+ return result.toString().trim()
71
+ } catch {
72
+ return undefined
73
+ }
74
+ }
75
+
76
+ /**
77
+ * Convert a Vulnerability to a BaselineFinding
78
+ */
79
+ function toBaselineFinding(vuln: Vulnerability): BaselineFinding {
80
+ return {
81
+ hash: computeFindingHash(vuln),
82
+ filePath: vuln.filePath,
83
+ lineNumber: vuln.lineNumber,
84
+ category: vuln.category,
85
+ severity: vuln.severity,
86
+ title: vuln.title,
87
+ }
88
+ }
89
+
90
+ /**
91
+ * Manages baseline files for diff mode
92
+ */
93
+ export class BaselineManager {
94
+ private projectPath: string
95
+ private baselinePath: string
96
+
97
+ constructor(options: BaselineManagerOptions | string) {
98
+ // Support both old string arg and new options object
99
+ if (typeof options === 'string') {
100
+ this.projectPath = options
101
+ } else {
102
+ this.projectPath = options.projectPath
103
+ }
104
+ this.baselinePath = join(this.projectPath, BASELINE_FILE_PATH)
105
+ }
106
+
107
+ /**
108
+ * Get the full path to the baseline file
109
+ */
110
+ getBaselinePath(): string {
111
+ return this.baselinePath
112
+ }
113
+
114
+ /**
115
+ * Load baseline from .oculum/baseline.json
116
+ */
117
+ loadBaseline(): LoadBaselineResult {
118
+ if (!existsSync(this.baselinePath)) {
119
+ return { found: false }
120
+ }
121
+
122
+ try {
123
+ const content = readFileSync(this.baselinePath, 'utf-8')
124
+ const baseline = JSON.parse(content) as BaselineData
125
+
126
+ // Basic validation
127
+ if (baseline.version !== 1) {
128
+ return {
129
+ found: false,
130
+ error: `Unsupported baseline version: ${baseline.version}. Expected version 1.`,
131
+ }
132
+ }
133
+
134
+ if (!Array.isArray(baseline.findings)) {
135
+ return {
136
+ found: false,
137
+ error: 'Invalid baseline: missing findings array',
138
+ }
139
+ }
140
+
141
+ return { found: true, baseline }
142
+ } catch (err) {
143
+ return {
144
+ found: false,
145
+ error: `Failed to parse baseline: ${err instanceof Error ? err.message : 'Unknown error'}`,
146
+ }
147
+ }
148
+ }
149
+
150
+ /**
151
+ * Save current scan result as baseline
152
+ */
153
+ saveBaseline(
154
+ scanResult: ScanResult,
155
+ options?: { commit?: string; branch?: string; scanDepth?: ScanDepth }
156
+ ): SaveBaselineResult {
157
+ try {
158
+ // Ensure .oculum directory exists
159
+ const oculumDir = join(this.projectPath, OCULUM_DIR)
160
+ if (!existsSync(oculumDir)) {
161
+ mkdirSync(oculumDir, { recursive: true })
162
+ }
163
+
164
+ // Get git info if not provided
165
+ const commit = options?.commit ?? getGitCommit(this.projectPath)
166
+ const branch = options?.branch ?? getGitBranch(this.projectPath)
167
+
168
+ // Convert vulnerabilities to baseline findings
169
+ const findings = scanResult.vulnerabilities.map(toBaselineFinding)
170
+
171
+ // Build baseline data
172
+ const baseline: BaselineData = {
173
+ version: 1,
174
+ createdAt: new Date().toISOString(),
175
+ commit,
176
+ branch,
177
+ scanDepth: options?.scanDepth,
178
+ findings,
179
+ stats: {
180
+ total: findings.length,
181
+ critical: scanResult.severityCounts.critical,
182
+ high: scanResult.severityCounts.high,
183
+ medium: scanResult.severityCounts.medium,
184
+ low: scanResult.severityCounts.low,
185
+ info: scanResult.severityCounts.info,
186
+ },
187
+ }
188
+
189
+ // Write to file
190
+ writeFileSync(this.baselinePath, JSON.stringify(baseline, null, 2))
191
+
192
+ return { success: true, path: this.baselinePath }
193
+ } catch (err) {
194
+ return {
195
+ success: false,
196
+ path: this.baselinePath,
197
+ error: `Failed to save baseline: ${err instanceof Error ? err.message : 'Unknown error'}`,
198
+ }
199
+ }
200
+ }
201
+
202
+ /**
203
+ * Clear (delete) the baseline file
204
+ */
205
+ clearBaseline(): ClearBaselineResult {
206
+ const existed = existsSync(this.baselinePath)
207
+
208
+ if (!existed) {
209
+ return { success: true, existed: false }
210
+ }
211
+
212
+ try {
213
+ unlinkSync(this.baselinePath)
214
+ return { success: true, existed: true }
215
+ } catch (err) {
216
+ return {
217
+ success: false,
218
+ existed: true,
219
+ error: `Failed to clear baseline: ${err instanceof Error ? err.message : 'Unknown error'}`,
220
+ }
221
+ }
222
+ }
223
+
224
+ /**
225
+ * Check if a baseline exists
226
+ */
227
+ hasBaseline(): boolean {
228
+ return existsSync(this.baselinePath)
229
+ }
230
+ }
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Baseline Types
3
+ * Types for baseline/diff mode functionality
4
+ */
5
+
6
+ import type { VulnerabilityCategory, VulnerabilitySeverity, SeverityCounts, ScanDepth } from '../types'
7
+
8
+ /**
9
+ * A finding stored in the baseline
10
+ * Contains enough information to identify and display the finding
11
+ */
12
+ export interface BaselineFinding {
13
+ /** Finding hash (from computeFindingHash) */
14
+ hash: string
15
+ /** File path relative to project root */
16
+ filePath: string
17
+ /** Line number in the file */
18
+ lineNumber: number
19
+ /** Vulnerability category */
20
+ category: VulnerabilityCategory
21
+ /** Severity level */
22
+ severity: VulnerabilitySeverity
23
+ /** Finding title */
24
+ title: string
25
+ }
26
+
27
+ /**
28
+ * Baseline data stored in .oculum/baseline.json
29
+ */
30
+ export interface BaselineData {
31
+ /** Schema version for forward compatibility */
32
+ version: 1
33
+ /** ISO 8601 timestamp when baseline was created */
34
+ createdAt: string
35
+ /** Git commit SHA when baseline was created (optional) */
36
+ commit?: string
37
+ /** Git branch name when baseline was created (optional) */
38
+ branch?: string
39
+ /** Scan depth used when creating baseline */
40
+ scanDepth?: ScanDepth
41
+ /** List of findings in the baseline */
42
+ findings: BaselineFinding[]
43
+ /** Summary statistics */
44
+ stats: {
45
+ total: number
46
+ critical: number
47
+ high: number
48
+ medium: number
49
+ low: number
50
+ info: number
51
+ }
52
+ }
53
+
54
+ /**
55
+ * Result of comparing current findings against baseline
56
+ */
57
+ export interface DiffResult {
58
+ /** Findings in current scan but NOT in baseline (new issues) */
59
+ new: import('../types').Vulnerability[]
60
+ /** Findings in baseline but NOT in current scan (fixed issues) */
61
+ fixed: BaselineFinding[]
62
+ /** Findings in both current scan AND baseline (existing issues) */
63
+ existing: import('../types').Vulnerability[]
64
+ /** Summary statistics */
65
+ stats: {
66
+ newCount: number
67
+ fixedCount: number
68
+ existingCount: number
69
+ newBySeverity: SeverityCounts
70
+ fixedBySeverity: SeverityCounts
71
+ }
72
+ }
73
+
74
+ /**
75
+ * Baseline diff metadata attached to ScanResult
76
+ * Only present when --new flag is used
77
+ */
78
+ export interface BaselineDiff {
79
+ /** When the baseline was created */
80
+ baselineCreatedAt: string
81
+ /** Git commit of the baseline (if available) */
82
+ baselineCommit?: string
83
+ /** Number of new findings (not in baseline) */
84
+ newCount: number
85
+ /** Number of fixed findings (in baseline, not in current) */
86
+ fixedCount: number
87
+ /** Number of existing findings (in both) */
88
+ existingCount: number
89
+ /** Details of fixed findings for display */
90
+ fixedFindings: BaselineFinding[]
91
+ }
92
+
93
+ /** Default baseline file path relative to project root */
94
+ export const BASELINE_FILE_PATH = '.oculum/baseline.json'
95
+
96
+ /** Directory for oculum files */
97
+ export const OCULUM_DIR = '.oculum'