@nahisaho/musubix-security 2.0.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (363) hide show
  1. package/dist/analysis/enhanced-taint-analyzer.d.ts +120 -0
  2. package/dist/analysis/enhanced-taint-analyzer.d.ts.map +1 -0
  3. package/dist/analysis/enhanced-taint-analyzer.js +450 -0
  4. package/dist/analysis/enhanced-taint-analyzer.js.map +1 -0
  5. package/dist/analysis/index.d.ts +1 -0
  6. package/dist/analysis/index.d.ts.map +1 -1
  7. package/dist/analysis/index.js +1 -0
  8. package/dist/analysis/index.js.map +1 -1
  9. package/dist/analysis/interprocedural/call-graph-builder.d.ts +192 -0
  10. package/dist/analysis/interprocedural/call-graph-builder.d.ts.map +1 -0
  11. package/dist/analysis/interprocedural/call-graph-builder.js +510 -0
  12. package/dist/analysis/interprocedural/call-graph-builder.js.map +1 -0
  13. package/dist/analysis/interprocedural/dfg-adapter.d.ts +166 -0
  14. package/dist/analysis/interprocedural/dfg-adapter.d.ts.map +1 -0
  15. package/dist/analysis/interprocedural/dfg-adapter.js +455 -0
  16. package/dist/analysis/interprocedural/dfg-adapter.js.map +1 -0
  17. package/dist/analysis/interprocedural/index.d.ts +9 -0
  18. package/dist/analysis/interprocedural/index.d.ts.map +1 -0
  19. package/dist/analysis/interprocedural/index.js +9 -0
  20. package/dist/analysis/interprocedural/index.js.map +1 -0
  21. package/dist/analysis/interprocedural/taint-propagator.d.ts +250 -0
  22. package/dist/analysis/interprocedural/taint-propagator.d.ts.map +1 -0
  23. package/dist/analysis/interprocedural/taint-propagator.js +435 -0
  24. package/dist/analysis/interprocedural/taint-propagator.js.map +1 -0
  25. package/dist/analysis/sanitizers/command-sanitizers.d.ts +12 -0
  26. package/dist/analysis/sanitizers/command-sanitizers.d.ts.map +1 -0
  27. package/dist/analysis/sanitizers/command-sanitizers.js +123 -0
  28. package/dist/analysis/sanitizers/command-sanitizers.js.map +1 -0
  29. package/dist/analysis/sanitizers/html-sanitizers.d.ts +12 -0
  30. package/dist/analysis/sanitizers/html-sanitizers.d.ts.map +1 -0
  31. package/dist/analysis/sanitizers/html-sanitizers.js +213 -0
  32. package/dist/analysis/sanitizers/html-sanitizers.js.map +1 -0
  33. package/dist/analysis/sanitizers/index.d.ts +35 -0
  34. package/dist/analysis/sanitizers/index.d.ts.map +1 -0
  35. package/dist/analysis/sanitizers/index.js +59 -0
  36. package/dist/analysis/sanitizers/index.js.map +1 -0
  37. package/dist/analysis/sanitizers/path-sanitizers.d.ts +12 -0
  38. package/dist/analysis/sanitizers/path-sanitizers.d.ts.map +1 -0
  39. package/dist/analysis/sanitizers/path-sanitizers.js +163 -0
  40. package/dist/analysis/sanitizers/path-sanitizers.js.map +1 -0
  41. package/dist/analysis/sanitizers/sql-sanitizers.d.ts +12 -0
  42. package/dist/analysis/sanitizers/sql-sanitizers.d.ts.map +1 -0
  43. package/dist/analysis/sanitizers/sql-sanitizers.js +216 -0
  44. package/dist/analysis/sanitizers/sql-sanitizers.js.map +1 -0
  45. package/dist/analysis/sanitizers/types.d.ts +78 -0
  46. package/dist/analysis/sanitizers/types.d.ts.map +1 -0
  47. package/dist/analysis/sanitizers/types.js +7 -0
  48. package/dist/analysis/sanitizers/types.js.map +1 -0
  49. package/dist/analysis/sanitizers/validation-sanitizers.d.ts +12 -0
  50. package/dist/analysis/sanitizers/validation-sanitizers.d.ts.map +1 -0
  51. package/dist/analysis/sanitizers/validation-sanitizers.js +268 -0
  52. package/dist/analysis/sanitizers/validation-sanitizers.js.map +1 -0
  53. package/dist/analysis/sinks/code-eval.d.ts +12 -0
  54. package/dist/analysis/sinks/code-eval.d.ts.map +1 -0
  55. package/dist/analysis/sinks/code-eval.js +231 -0
  56. package/dist/analysis/sinks/code-eval.js.map +1 -0
  57. package/dist/analysis/sinks/command-exec.d.ts +12 -0
  58. package/dist/analysis/sinks/command-exec.d.ts.map +1 -0
  59. package/dist/analysis/sinks/command-exec.js +187 -0
  60. package/dist/analysis/sinks/command-exec.js.map +1 -0
  61. package/dist/analysis/sinks/file-operations.d.ts +12 -0
  62. package/dist/analysis/sinks/file-operations.d.ts.map +1 -0
  63. package/dist/analysis/sinks/file-operations.js +239 -0
  64. package/dist/analysis/sinks/file-operations.js.map +1 -0
  65. package/dist/analysis/sinks/html-output.d.ts +12 -0
  66. package/dist/analysis/sinks/html-output.d.ts.map +1 -0
  67. package/dist/analysis/sinks/html-output.js +256 -0
  68. package/dist/analysis/sinks/html-output.js.map +1 -0
  69. package/dist/analysis/sinks/index.d.ts +30 -0
  70. package/dist/analysis/sinks/index.d.ts.map +1 -0
  71. package/dist/analysis/sinks/index.js +46 -0
  72. package/dist/analysis/sinks/index.js.map +1 -0
  73. package/dist/analysis/sinks/sql-query.d.ts +12 -0
  74. package/dist/analysis/sinks/sql-query.d.ts.map +1 -0
  75. package/dist/analysis/sinks/sql-query.js +209 -0
  76. package/dist/analysis/sinks/sql-query.js.map +1 -0
  77. package/dist/analysis/sinks/types.d.ts +97 -0
  78. package/dist/analysis/sinks/types.d.ts.map +1 -0
  79. package/dist/analysis/sinks/types.js +7 -0
  80. package/dist/analysis/sinks/types.js.map +1 -0
  81. package/dist/analysis/sources/database.d.ts +12 -0
  82. package/dist/analysis/sources/database.d.ts.map +1 -0
  83. package/dist/analysis/sources/database.js +211 -0
  84. package/dist/analysis/sources/database.js.map +1 -0
  85. package/dist/analysis/sources/environment.d.ts +12 -0
  86. package/dist/analysis/sources/environment.d.ts.map +1 -0
  87. package/dist/analysis/sources/environment.js +158 -0
  88. package/dist/analysis/sources/environment.js.map +1 -0
  89. package/dist/analysis/sources/file-system.d.ts +12 -0
  90. package/dist/analysis/sources/file-system.d.ts.map +1 -0
  91. package/dist/analysis/sources/file-system.js +180 -0
  92. package/dist/analysis/sources/file-system.js.map +1 -0
  93. package/dist/analysis/sources/http-request.d.ts +12 -0
  94. package/dist/analysis/sources/http-request.d.ts.map +1 -0
  95. package/dist/analysis/sources/http-request.js +179 -0
  96. package/dist/analysis/sources/http-request.js.map +1 -0
  97. package/dist/analysis/sources/index.d.ts +26 -0
  98. package/dist/analysis/sources/index.d.ts.map +1 -0
  99. package/dist/analysis/sources/index.js +40 -0
  100. package/dist/analysis/sources/index.js.map +1 -0
  101. package/dist/analysis/sources/types.d.ts +93 -0
  102. package/dist/analysis/sources/types.d.ts.map +1 -0
  103. package/dist/analysis/sources/types.js +7 -0
  104. package/dist/analysis/sources/types.js.map +1 -0
  105. package/dist/analysis/sources/user-input.d.ts +12 -0
  106. package/dist/analysis/sources/user-input.d.ts.map +1 -0
  107. package/dist/analysis/sources/user-input.js +261 -0
  108. package/dist/analysis/sources/user-input.js.map +1 -0
  109. package/dist/cve/cpe-matcher.d.ts +183 -0
  110. package/dist/cve/cpe-matcher.d.ts.map +1 -0
  111. package/dist/cve/cpe-matcher.js +396 -0
  112. package/dist/cve/cpe-matcher.js.map +1 -0
  113. package/dist/cve/cve-cache.d.ts +225 -0
  114. package/dist/cve/cve-cache.d.ts.map +1 -0
  115. package/dist/cve/cve-cache.js +452 -0
  116. package/dist/cve/cve-cache.js.map +1 -0
  117. package/dist/cve/cve-cache.test.d.ts +6 -0
  118. package/dist/cve/cve-cache.test.d.ts.map +1 -0
  119. package/dist/cve/cve-cache.test.js +363 -0
  120. package/dist/cve/cve-cache.test.js.map +1 -0
  121. package/dist/cve/dependency-parser.d.ts +204 -0
  122. package/dist/cve/dependency-parser.d.ts.map +1 -0
  123. package/dist/cve/dependency-parser.js +338 -0
  124. package/dist/cve/dependency-parser.js.map +1 -0
  125. package/dist/cve/index.d.ts +20 -0
  126. package/dist/cve/index.d.ts.map +1 -0
  127. package/dist/cve/index.js +13 -0
  128. package/dist/cve/index.js.map +1 -0
  129. package/dist/cve/nvd-client.d.ts +137 -0
  130. package/dist/cve/nvd-client.d.ts.map +1 -0
  131. package/dist/cve/nvd-client.js +333 -0
  132. package/dist/cve/nvd-client.js.map +1 -0
  133. package/dist/cve/rate-limiter.d.ts +194 -0
  134. package/dist/cve/rate-limiter.d.ts.map +1 -0
  135. package/dist/cve/rate-limiter.js +276 -0
  136. package/dist/cve/rate-limiter.js.map +1 -0
  137. package/dist/cve/report-generator.d.ts +145 -0
  138. package/dist/cve/report-generator.d.ts.map +1 -0
  139. package/dist/cve/report-generator.js +377 -0
  140. package/dist/cve/report-generator.js.map +1 -0
  141. package/dist/cve/report-generator.test.d.ts +6 -0
  142. package/dist/cve/report-generator.test.d.ts.map +1 -0
  143. package/dist/cve/report-generator.test.js +275 -0
  144. package/dist/cve/report-generator.test.js.map +1 -0
  145. package/dist/cve/vulnerability-scanner.d.ts +198 -0
  146. package/dist/cve/vulnerability-scanner.d.ts.map +1 -0
  147. package/dist/cve/vulnerability-scanner.js +311 -0
  148. package/dist/cve/vulnerability-scanner.js.map +1 -0
  149. package/dist/cve/vulnerability-scanner.test.d.ts +6 -0
  150. package/dist/cve/vulnerability-scanner.test.d.ts.map +1 -0
  151. package/dist/cve/vulnerability-scanner.test.js +329 -0
  152. package/dist/cve/vulnerability-scanner.test.js.map +1 -0
  153. package/dist/index.d.ts +1 -0
  154. package/dist/index.d.ts.map +1 -1
  155. package/dist/index.js +4 -0
  156. package/dist/index.js.map +1 -1
  157. package/dist/rules/config/config-parser.d.ts +119 -0
  158. package/dist/rules/config/config-parser.d.ts.map +1 -0
  159. package/dist/rules/config/config-parser.js +376 -0
  160. package/dist/rules/config/config-parser.js.map +1 -0
  161. package/dist/rules/config/index.d.ts +8 -0
  162. package/dist/rules/config/index.d.ts.map +1 -0
  163. package/dist/rules/config/index.js +8 -0
  164. package/dist/rules/config/index.js.map +1 -0
  165. package/dist/rules/config/profiles.d.ts +85 -0
  166. package/dist/rules/config/profiles.d.ts.map +1 -0
  167. package/dist/rules/config/profiles.js +226 -0
  168. package/dist/rules/config/profiles.js.map +1 -0
  169. package/dist/rules/cwe/cwe-119-buffer-overflow.d.ts +9 -0
  170. package/dist/rules/cwe/cwe-119-buffer-overflow.d.ts.map +1 -0
  171. package/dist/rules/cwe/cwe-119-buffer-overflow.js +54 -0
  172. package/dist/rules/cwe/cwe-119-buffer-overflow.js.map +1 -0
  173. package/dist/rules/cwe/cwe-125-oob-read.d.ts +20 -0
  174. package/dist/rules/cwe/cwe-125-oob-read.d.ts.map +1 -0
  175. package/dist/rules/cwe/cwe-125-oob-read.js +247 -0
  176. package/dist/rules/cwe/cwe-125-oob-read.js.map +1 -0
  177. package/dist/rules/cwe/cwe-190-integer-overflow.d.ts +9 -0
  178. package/dist/rules/cwe/cwe-190-integer-overflow.d.ts.map +1 -0
  179. package/dist/rules/cwe/cwe-190-integer-overflow.js +55 -0
  180. package/dist/rules/cwe/cwe-190-integer-overflow.js.map +1 -0
  181. package/dist/rules/cwe/cwe-20-input-validation.d.ts +21 -0
  182. package/dist/rules/cwe/cwe-20-input-validation.d.ts.map +1 -0
  183. package/dist/rules/cwe/cwe-20-input-validation.js +342 -0
  184. package/dist/rules/cwe/cwe-20-input-validation.js.map +1 -0
  185. package/dist/rules/cwe/cwe-22-path-traversal.d.ts +20 -0
  186. package/dist/rules/cwe/cwe-22-path-traversal.d.ts.map +1 -0
  187. package/dist/rules/cwe/cwe-22-path-traversal.js +306 -0
  188. package/dist/rules/cwe/cwe-22-path-traversal.js.map +1 -0
  189. package/dist/rules/cwe/cwe-269-improper-privilege.d.ts +9 -0
  190. package/dist/rules/cwe/cwe-269-improper-privilege.d.ts.map +1 -0
  191. package/dist/rules/cwe/cwe-269-improper-privilege.js +58 -0
  192. package/dist/rules/cwe/cwe-269-improper-privilege.js.map +1 -0
  193. package/dist/rules/cwe/cwe-276-default-permissions.d.ts +9 -0
  194. package/dist/rules/cwe/cwe-276-default-permissions.d.ts.map +1 -0
  195. package/dist/rules/cwe/cwe-276-default-permissions.js +54 -0
  196. package/dist/rules/cwe/cwe-276-default-permissions.js.map +1 -0
  197. package/dist/rules/cwe/cwe-287-improper-auth.d.ts +9 -0
  198. package/dist/rules/cwe/cwe-287-improper-auth.d.ts.map +1 -0
  199. package/dist/rules/cwe/cwe-287-improper-auth.js +57 -0
  200. package/dist/rules/cwe/cwe-287-improper-auth.js.map +1 -0
  201. package/dist/rules/cwe/cwe-306-missing-auth-critical.d.ts +9 -0
  202. package/dist/rules/cwe/cwe-306-missing-auth-critical.d.ts.map +1 -0
  203. package/dist/rules/cwe/cwe-306-missing-auth-critical.js +53 -0
  204. package/dist/rules/cwe/cwe-306-missing-auth-critical.js.map +1 -0
  205. package/dist/rules/cwe/cwe-352-csrf.d.ts +9 -0
  206. package/dist/rules/cwe/cwe-352-csrf.d.ts.map +1 -0
  207. package/dist/rules/cwe/cwe-352-csrf.js +51 -0
  208. package/dist/rules/cwe/cwe-352-csrf.js.map +1 -0
  209. package/dist/rules/cwe/cwe-362-race-condition.d.ts +9 -0
  210. package/dist/rules/cwe/cwe-362-race-condition.d.ts.map +1 -0
  211. package/dist/rules/cwe/cwe-362-race-condition.js +55 -0
  212. package/dist/rules/cwe/cwe-362-race-condition.js.map +1 -0
  213. package/dist/rules/cwe/cwe-416-use-after-free.d.ts +23 -0
  214. package/dist/rules/cwe/cwe-416-use-after-free.d.ts.map +1 -0
  215. package/dist/rules/cwe/cwe-416-use-after-free.js +402 -0
  216. package/dist/rules/cwe/cwe-416-use-after-free.js.map +1 -0
  217. package/dist/rules/cwe/cwe-434-file-upload.d.ts +9 -0
  218. package/dist/rules/cwe/cwe-434-file-upload.d.ts.map +1 -0
  219. package/dist/rules/cwe/cwe-434-file-upload.js +55 -0
  220. package/dist/rules/cwe/cwe-434-file-upload.js.map +1 -0
  221. package/dist/rules/cwe/cwe-476-null-deref.d.ts +9 -0
  222. package/dist/rules/cwe/cwe-476-null-deref.d.ts.map +1 -0
  223. package/dist/rules/cwe/cwe-476-null-deref.js +55 -0
  224. package/dist/rules/cwe/cwe-476-null-deref.js.map +1 -0
  225. package/dist/rules/cwe/cwe-502-deserialization.d.ts +9 -0
  226. package/dist/rules/cwe/cwe-502-deserialization.d.ts.map +1 -0
  227. package/dist/rules/cwe/cwe-502-deserialization.js +57 -0
  228. package/dist/rules/cwe/cwe-502-deserialization.js.map +1 -0
  229. package/dist/rules/cwe/cwe-77-command-injection.d.ts +9 -0
  230. package/dist/rules/cwe/cwe-77-command-injection.d.ts.map +1 -0
  231. package/dist/rules/cwe/cwe-77-command-injection.js +55 -0
  232. package/dist/rules/cwe/cwe-77-command-injection.js.map +1 -0
  233. package/dist/rules/cwe/cwe-78-command-injection.d.ts +20 -0
  234. package/dist/rules/cwe/cwe-78-command-injection.d.ts.map +1 -0
  235. package/dist/rules/cwe/cwe-78-command-injection.js +259 -0
  236. package/dist/rules/cwe/cwe-78-command-injection.js.map +1 -0
  237. package/dist/rules/cwe/cwe-787-oob-write.d.ts +21 -0
  238. package/dist/rules/cwe/cwe-787-oob-write.d.ts.map +1 -0
  239. package/dist/rules/cwe/cwe-787-oob-write.js +321 -0
  240. package/dist/rules/cwe/cwe-787-oob-write.js.map +1 -0
  241. package/dist/rules/cwe/cwe-79-xss.d.ts +22 -0
  242. package/dist/rules/cwe/cwe-79-xss.d.ts.map +1 -0
  243. package/dist/rules/cwe/cwe-79-xss.js +386 -0
  244. package/dist/rules/cwe/cwe-79-xss.js.map +1 -0
  245. package/dist/rules/cwe/cwe-798-hardcoded-credentials.d.ts +9 -0
  246. package/dist/rules/cwe/cwe-798-hardcoded-credentials.d.ts.map +1 -0
  247. package/dist/rules/cwe/cwe-798-hardcoded-credentials.js +58 -0
  248. package/dist/rules/cwe/cwe-798-hardcoded-credentials.js.map +1 -0
  249. package/dist/rules/cwe/cwe-862-missing-auth.d.ts +9 -0
  250. package/dist/rules/cwe/cwe-862-missing-auth.d.ts.map +1 -0
  251. package/dist/rules/cwe/cwe-862-missing-auth.js +55 -0
  252. package/dist/rules/cwe/cwe-862-missing-auth.js.map +1 -0
  253. package/dist/rules/cwe/cwe-863-incorrect-auth.d.ts +9 -0
  254. package/dist/rules/cwe/cwe-863-incorrect-auth.d.ts.map +1 -0
  255. package/dist/rules/cwe/cwe-863-incorrect-auth.js +58 -0
  256. package/dist/rules/cwe/cwe-863-incorrect-auth.js.map +1 -0
  257. package/dist/rules/cwe/cwe-89-sql-injection.d.ts +21 -0
  258. package/dist/rules/cwe/cwe-89-sql-injection.d.ts.map +1 -0
  259. package/dist/rules/cwe/cwe-89-sql-injection.js +456 -0
  260. package/dist/rules/cwe/cwe-89-sql-injection.js.map +1 -0
  261. package/dist/rules/cwe/cwe-918-ssrf.d.ts +9 -0
  262. package/dist/rules/cwe/cwe-918-ssrf.d.ts.map +1 -0
  263. package/dist/rules/cwe/cwe-918-ssrf.js +59 -0
  264. package/dist/rules/cwe/cwe-918-ssrf.js.map +1 -0
  265. package/dist/rules/cwe/cwe-94-code-injection.d.ts +9 -0
  266. package/dist/rules/cwe/cwe-94-code-injection.d.ts.map +1 -0
  267. package/dist/rules/cwe/cwe-94-code-injection.js +59 -0
  268. package/dist/rules/cwe/cwe-94-code-injection.js.map +1 -0
  269. package/dist/rules/cwe/index.d.ts +43 -0
  270. package/dist/rules/cwe/index.d.ts.map +1 -0
  271. package/dist/rules/cwe/index.js +99 -0
  272. package/dist/rules/cwe/index.js.map +1 -0
  273. package/dist/rules/engine/index.d.ts +10 -0
  274. package/dist/rules/engine/index.d.ts.map +1 -0
  275. package/dist/rules/engine/index.js +9 -0
  276. package/dist/rules/engine/index.js.map +1 -0
  277. package/dist/rules/engine/rule-context.d.ts +99 -0
  278. package/dist/rules/engine/rule-context.d.ts.map +1 -0
  279. package/dist/rules/engine/rule-context.js +175 -0
  280. package/dist/rules/engine/rule-context.js.map +1 -0
  281. package/dist/rules/engine/rule-engine.d.ts +132 -0
  282. package/dist/rules/engine/rule-engine.d.ts.map +1 -0
  283. package/dist/rules/engine/rule-engine.js +379 -0
  284. package/dist/rules/engine/rule-engine.js.map +1 -0
  285. package/dist/rules/engine/rule-registry.d.ts +133 -0
  286. package/dist/rules/engine/rule-registry.d.ts.map +1 -0
  287. package/dist/rules/engine/rule-registry.js +281 -0
  288. package/dist/rules/engine/rule-registry.js.map +1 -0
  289. package/dist/rules/index.d.ts +14 -0
  290. package/dist/rules/index.d.ts.map +1 -0
  291. package/dist/rules/index.js +16 -0
  292. package/dist/rules/index.js.map +1 -0
  293. package/dist/rules/owasp/a01-broken-access-control.d.ts +19 -0
  294. package/dist/rules/owasp/a01-broken-access-control.d.ts.map +1 -0
  295. package/dist/rules/owasp/a01-broken-access-control.js +295 -0
  296. package/dist/rules/owasp/a01-broken-access-control.js.map +1 -0
  297. package/dist/rules/owasp/a02-cryptographic-failures.d.ts +19 -0
  298. package/dist/rules/owasp/a02-cryptographic-failures.d.ts.map +1 -0
  299. package/dist/rules/owasp/a02-cryptographic-failures.js +327 -0
  300. package/dist/rules/owasp/a02-cryptographic-failures.js.map +1 -0
  301. package/dist/rules/owasp/a03-injection.d.ts +21 -0
  302. package/dist/rules/owasp/a03-injection.d.ts.map +1 -0
  303. package/dist/rules/owasp/a03-injection.js +342 -0
  304. package/dist/rules/owasp/a03-injection.js.map +1 -0
  305. package/dist/rules/owasp/a04-insecure-design.d.ts +19 -0
  306. package/dist/rules/owasp/a04-insecure-design.d.ts.map +1 -0
  307. package/dist/rules/owasp/a04-insecure-design.js +403 -0
  308. package/dist/rules/owasp/a04-insecure-design.js.map +1 -0
  309. package/dist/rules/owasp/a05-security-misconfiguration.d.ts +19 -0
  310. package/dist/rules/owasp/a05-security-misconfiguration.d.ts.map +1 -0
  311. package/dist/rules/owasp/a05-security-misconfiguration.js +371 -0
  312. package/dist/rules/owasp/a05-security-misconfiguration.js.map +1 -0
  313. package/dist/rules/owasp/a06-vulnerable-components.d.ts +18 -0
  314. package/dist/rules/owasp/a06-vulnerable-components.d.ts.map +1 -0
  315. package/dist/rules/owasp/a06-vulnerable-components.js +243 -0
  316. package/dist/rules/owasp/a06-vulnerable-components.js.map +1 -0
  317. package/dist/rules/owasp/a07-auth-failures.d.ts +19 -0
  318. package/dist/rules/owasp/a07-auth-failures.d.ts.map +1 -0
  319. package/dist/rules/owasp/a07-auth-failures.js +300 -0
  320. package/dist/rules/owasp/a07-auth-failures.js.map +1 -0
  321. package/dist/rules/owasp/a08-integrity-failures.d.ts +18 -0
  322. package/dist/rules/owasp/a08-integrity-failures.d.ts.map +1 -0
  323. package/dist/rules/owasp/a08-integrity-failures.js +306 -0
  324. package/dist/rules/owasp/a08-integrity-failures.js.map +1 -0
  325. package/dist/rules/owasp/a09-logging-failures.d.ts +18 -0
  326. package/dist/rules/owasp/a09-logging-failures.d.ts.map +1 -0
  327. package/dist/rules/owasp/a09-logging-failures.js +339 -0
  328. package/dist/rules/owasp/a09-logging-failures.js.map +1 -0
  329. package/dist/rules/owasp/a10-ssrf.d.ts +18 -0
  330. package/dist/rules/owasp/a10-ssrf.d.ts.map +1 -0
  331. package/dist/rules/owasp/a10-ssrf.js +349 -0
  332. package/dist/rules/owasp/a10-ssrf.js.map +1 -0
  333. package/dist/rules/owasp/index.d.ts +20 -0
  334. package/dist/rules/owasp/index.d.ts.map +1 -0
  335. package/dist/rules/owasp/index.js +53 -0
  336. package/dist/rules/owasp/index.js.map +1 -0
  337. package/dist/rules/types.d.ts +277 -0
  338. package/dist/rules/types.d.ts.map +1 -0
  339. package/dist/rules/types.js +34 -0
  340. package/dist/rules/types.js.map +1 -0
  341. package/dist/tests/integration/epic-integration.test.d.ts +7 -0
  342. package/dist/tests/integration/epic-integration.test.d.ts.map +1 -0
  343. package/dist/tests/integration/epic-integration.test.js +390 -0
  344. package/dist/tests/integration/epic-integration.test.js.map +1 -0
  345. package/dist/tests/rules/cwe/cwe-top25-1-13.test.d.ts +2 -0
  346. package/dist/tests/rules/cwe/cwe-top25-1-13.test.d.ts.map +1 -0
  347. package/dist/tests/rules/cwe/cwe-top25-1-13.test.js +154 -0
  348. package/dist/tests/rules/cwe/cwe-top25-1-13.test.js.map +1 -0
  349. package/dist/tests/rules/cwe/cwe-top25-14-25.test.d.ts +2 -0
  350. package/dist/tests/rules/cwe/cwe-top25-14-25.test.d.ts.map +1 -0
  351. package/dist/tests/rules/cwe/cwe-top25-14-25.test.js +121 -0
  352. package/dist/tests/rules/cwe/cwe-top25-14-25.test.js.map +1 -0
  353. package/dist/types/cve.d.ts +278 -0
  354. package/dist/types/cve.d.ts.map +1 -0
  355. package/dist/types/cve.js +7 -0
  356. package/dist/types/cve.js.map +1 -0
  357. package/dist/types/index.d.ts +2 -0
  358. package/dist/types/index.d.ts.map +1 -1
  359. package/dist/types/rule.d.ts +245 -0
  360. package/dist/types/rule.d.ts.map +1 -0
  361. package/dist/types/rule.js +7 -0
  362. package/dist/types/rule.js.map +1 -0
  363. package/package.json +1 -1
@@ -0,0 +1,163 @@
1
+ /**
2
+ * @fileoverview Path traversal sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/path-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ /**
7
+ * Path traversal sanitizers
8
+ * @trace REQ-SEC-001
9
+ */
10
+ export const PATH_SANITIZERS = [
11
+ // path.basename - removes directory components
12
+ {
13
+ id: 'SAN-PATH-001',
14
+ name: 'basename',
15
+ package: 'path',
16
+ protects: ['file-read', 'file-write'],
17
+ completeness: 'partial',
18
+ returnsClean: true,
19
+ description: 'path.basename - removes directory components',
20
+ caveats: 'Only removes directory path, does not prevent all traversal',
21
+ enabled: true,
22
+ tags: ['path', 'basename', 'traversal'],
23
+ },
24
+ // path.normalize
25
+ {
26
+ id: 'SAN-PATH-010',
27
+ name: 'normalize',
28
+ package: 'path',
29
+ protects: ['file-read', 'file-write'],
30
+ completeness: 'partial',
31
+ returnsClean: true,
32
+ description: 'path.normalize - resolves . and .. segments',
33
+ caveats: 'Resolves .. but does not prevent traversal outside base',
34
+ enabled: true,
35
+ tags: ['path', 'normalize', 'traversal'],
36
+ },
37
+ // path.resolve
38
+ {
39
+ id: 'SAN-PATH-020',
40
+ name: 'resolve',
41
+ package: 'path',
42
+ protects: ['file-read', 'file-write'],
43
+ completeness: 'partial',
44
+ returnsClean: true,
45
+ description: 'path.resolve - resolves to absolute path',
46
+ caveats: 'Creates absolute path but does not prevent traversal',
47
+ enabled: true,
48
+ tags: ['path', 'resolve', 'traversal'],
49
+ },
50
+ // Custom path validation
51
+ {
52
+ id: 'SAN-PATH-030',
53
+ name: 'validatePath',
54
+ aliases: ['isValidPath', 'checkPath', 'sanitizePath'],
55
+ protects: ['file-read', 'file-write'],
56
+ completeness: 'complete',
57
+ returnsClean: true,
58
+ description: 'Custom path validation function',
59
+ enabled: true,
60
+ tags: ['path', 'validate', 'traversal'],
61
+ },
62
+ // startsWith check pattern
63
+ {
64
+ id: 'SAN-PATH-040',
65
+ name: 'startsWith',
66
+ protects: ['file-read', 'file-write'],
67
+ completeness: 'conditional',
68
+ returnsClean: false,
69
+ description: 'Path prefix check with startsWith',
70
+ caveats: 'Must be combined with resolve/normalize to be effective',
71
+ enabled: true,
72
+ tags: ['path', 'startsWith', 'check'],
73
+ },
74
+ // within base directory check
75
+ {
76
+ id: 'SAN-PATH-050',
77
+ name: 'isWithinBase',
78
+ aliases: ['isInsideDirectory', 'isSubPath', 'isInside'],
79
+ protects: ['file-read', 'file-write'],
80
+ completeness: 'complete',
81
+ returnsClean: true,
82
+ description: 'Check if path is within allowed base directory',
83
+ enabled: true,
84
+ tags: ['path', 'base', 'check'],
85
+ },
86
+ // realpath
87
+ {
88
+ id: 'SAN-PATH-060',
89
+ name: 'realpath',
90
+ aliases: ['realpathSync'],
91
+ package: 'fs',
92
+ protects: ['file-read', 'file-write'],
93
+ completeness: 'partial',
94
+ returnsClean: true,
95
+ description: 'fs.realpath - resolves symlinks',
96
+ caveats: 'Resolves symlinks but should be combined with base check',
97
+ enabled: true,
98
+ tags: ['path', 'realpath', 'symlink'],
99
+ },
100
+ // path-is-inside package
101
+ {
102
+ id: 'SAN-PATH-070',
103
+ name: 'pathIsInside',
104
+ package: 'path-is-inside',
105
+ protects: ['file-read', 'file-write'],
106
+ completeness: 'complete',
107
+ returnsClean: true,
108
+ description: 'path-is-inside package',
109
+ enabled: true,
110
+ tags: ['path', 'inside', 'check'],
111
+ },
112
+ // sanitize-filename package
113
+ {
114
+ id: 'SAN-PATH-080',
115
+ name: 'sanitize',
116
+ aliases: ['sanitizeFilename'],
117
+ package: 'sanitize-filename',
118
+ protects: ['file-read', 'file-write'],
119
+ completeness: 'complete',
120
+ returnsClean: true,
121
+ description: 'sanitize-filename - removes dangerous characters',
122
+ enabled: true,
123
+ tags: ['path', 'filename', 'sanitize'],
124
+ },
125
+ // filenamify package
126
+ {
127
+ id: 'SAN-PATH-090',
128
+ name: 'filenamify',
129
+ package: 'filenamify',
130
+ protects: ['file-read', 'file-write'],
131
+ completeness: 'complete',
132
+ returnsClean: true,
133
+ description: 'filenamify - converts string to safe filename',
134
+ enabled: true,
135
+ tags: ['path', 'filename', 'sanitize'],
136
+ },
137
+ // Extension validation
138
+ {
139
+ id: 'SAN-PATH-100',
140
+ name: 'validateExtension',
141
+ aliases: ['checkExtension', 'allowedExtensions'],
142
+ protects: ['file-read', 'file-write'],
143
+ completeness: 'partial',
144
+ returnsClean: true,
145
+ description: 'File extension whitelist validation',
146
+ caveats: 'Only validates extension, not path traversal',
147
+ enabled: true,
148
+ tags: ['path', 'extension', 'validate'],
149
+ },
150
+ // Zip Slip protection
151
+ {
152
+ id: 'SAN-PATH-110',
153
+ name: 'checkZipSlip',
154
+ aliases: ['validateZipEntry', 'preventZipSlip'],
155
+ protects: ['file-write'],
156
+ completeness: 'complete',
157
+ returnsClean: true,
158
+ description: 'Zip Slip vulnerability protection',
159
+ enabled: true,
160
+ tags: ['path', 'zip', 'slip'],
161
+ },
162
+ ];
163
+ //# sourceMappingURL=path-sanitizers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"path-sanitizers.js","sourceRoot":"","sources":["../../../src/analysis/sanitizers/path-sanitizers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @fileoverview SQL sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/sql-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ import type { SanitizerDefinition } from './types.js';
7
+ /**
8
+ * SQL injection sanitizers
9
+ * @trace REQ-SEC-001
10
+ */
11
+ export declare const SQL_SANITIZERS: readonly SanitizerDefinition[];
12
+ //# sourceMappingURL=sql-sanitizers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql-sanitizers.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/sql-sanitizers.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,SAAS,mBAAmB,EAqN/C,CAAC"}
@@ -0,0 +1,216 @@
1
+ /**
2
+ * @fileoverview SQL sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/sql-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ /**
7
+ * SQL injection sanitizers
8
+ * @trace REQ-SEC-001
9
+ */
10
+ export const SQL_SANITIZERS = [
11
+ // MySQL escape
12
+ {
13
+ id: 'SAN-SQL-001',
14
+ name: 'escape',
15
+ package: 'mysql',
16
+ protects: ['sql-query'],
17
+ completeness: 'complete',
18
+ returnsClean: true,
19
+ description: 'MySQL escape function - escapes special characters',
20
+ enabled: true,
21
+ tags: ['sql', 'mysql', 'escape'],
22
+ },
23
+ {
24
+ id: 'SAN-SQL-002',
25
+ name: 'escape',
26
+ package: 'mysql2',
27
+ protects: ['sql-query'],
28
+ completeness: 'complete',
29
+ returnsClean: true,
30
+ description: 'MySQL2 escape function',
31
+ enabled: true,
32
+ tags: ['sql', 'mysql2', 'escape'],
33
+ },
34
+ {
35
+ id: 'SAN-SQL-003',
36
+ name: 'escapeId',
37
+ aliases: ['escapeIdentifier'],
38
+ package: 'mysql',
39
+ protects: ['sql-query'],
40
+ completeness: 'complete',
41
+ returnsClean: true,
42
+ description: 'MySQL identifier escape (for column/table names)',
43
+ enabled: true,
44
+ tags: ['sql', 'mysql', 'escape', 'identifier'],
45
+ },
46
+ {
47
+ id: 'SAN-SQL-004',
48
+ name: 'format',
49
+ package: 'mysql',
50
+ protects: ['sql-query'],
51
+ completeness: 'complete',
52
+ returnsClean: true,
53
+ description: 'MySQL format function - parameterized queries',
54
+ enabled: true,
55
+ tags: ['sql', 'mysql', 'format', 'parameterized'],
56
+ },
57
+ // PostgreSQL escape
58
+ {
59
+ id: 'SAN-SQL-010',
60
+ name: 'escapeLiteral',
61
+ package: 'pg',
62
+ protects: ['sql-query'],
63
+ completeness: 'complete',
64
+ returnsClean: true,
65
+ description: 'PostgreSQL literal escape',
66
+ enabled: true,
67
+ tags: ['sql', 'postgresql', 'escape'],
68
+ },
69
+ {
70
+ id: 'SAN-SQL-011',
71
+ name: 'escapeIdentifier',
72
+ package: 'pg',
73
+ protects: ['sql-query'],
74
+ completeness: 'complete',
75
+ returnsClean: true,
76
+ description: 'PostgreSQL identifier escape',
77
+ enabled: true,
78
+ tags: ['sql', 'postgresql', 'escape', 'identifier'],
79
+ },
80
+ // Parameterized queries (generic)
81
+ {
82
+ id: 'SAN-SQL-020',
83
+ name: 'parameterize',
84
+ protects: ['sql-query', 'nosql-query'],
85
+ completeness: 'complete',
86
+ returnsClean: true,
87
+ description: 'Generic parameterized query pattern',
88
+ enabled: true,
89
+ tags: ['sql', 'parameterized', 'generic'],
90
+ },
91
+ {
92
+ id: 'SAN-SQL-021',
93
+ name: 'prepare',
94
+ aliases: ['prepareStatement', 'prepared'],
95
+ protects: ['sql-query'],
96
+ completeness: 'complete',
97
+ returnsClean: true,
98
+ description: 'Prepared statement pattern',
99
+ enabled: true,
100
+ tags: ['sql', 'prepared', 'statement'],
101
+ },
102
+ {
103
+ id: 'SAN-SQL-022',
104
+ name: 'bind',
105
+ aliases: ['binding', 'bindings'],
106
+ protects: ['sql-query'],
107
+ completeness: 'complete',
108
+ returnsClean: true,
109
+ description: 'Parameter binding pattern',
110
+ enabled: true,
111
+ tags: ['sql', 'bind', 'parameterized'],
112
+ },
113
+ // Knex.js
114
+ {
115
+ id: 'SAN-SQL-030',
116
+ name: 'raw',
117
+ namePattern: '^knex\\.raw\\(.*\\?',
118
+ package: 'knex',
119
+ protects: ['sql-query'],
120
+ completeness: 'conditional',
121
+ returnsClean: true,
122
+ description: 'Knex raw with placeholders - safe if placeholders used',
123
+ caveats: 'Only safe when using ? placeholders for values',
124
+ enabled: true,
125
+ tags: ['sql', 'knex', 'raw'],
126
+ },
127
+ // Prisma
128
+ {
129
+ id: 'SAN-SQL-040',
130
+ name: 'sql',
131
+ aliases: ['Prisma.sql'],
132
+ package: '@prisma/client',
133
+ protects: ['sql-query'],
134
+ completeness: 'complete',
135
+ returnsClean: true,
136
+ description: 'Prisma.sql template literal - safe parameterization',
137
+ enabled: true,
138
+ tags: ['sql', 'prisma', 'template'],
139
+ },
140
+ // Sequelize
141
+ {
142
+ id: 'SAN-SQL-050',
143
+ name: 'literal',
144
+ aliases: ['Sequelize.literal'],
145
+ package: 'sequelize',
146
+ protects: ['sql-query'],
147
+ completeness: 'partial',
148
+ returnsClean: true,
149
+ description: 'Sequelize literal - should be used carefully',
150
+ caveats: 'Does not escape, only marks as literal',
151
+ enabled: true,
152
+ tags: ['sql', 'sequelize', 'literal'],
153
+ },
154
+ {
155
+ id: 'SAN-SQL-051',
156
+ name: 'escape',
157
+ package: 'sequelize',
158
+ protects: ['sql-query'],
159
+ completeness: 'complete',
160
+ returnsClean: true,
161
+ description: 'Sequelize escape function',
162
+ enabled: true,
163
+ tags: ['sql', 'sequelize', 'escape'],
164
+ },
165
+ // SQLite
166
+ {
167
+ id: 'SAN-SQL-060',
168
+ name: 'pluck',
169
+ package: 'better-sqlite3',
170
+ protects: ['sql-query'],
171
+ completeness: 'complete',
172
+ returnsClean: true,
173
+ description: 'better-sqlite3 pluck - uses prepared statements',
174
+ enabled: true,
175
+ tags: ['sql', 'sqlite', 'prepared'],
176
+ },
177
+ // Generic SQL escape
178
+ {
179
+ id: 'SAN-SQL-070',
180
+ name: 'sqlstring',
181
+ aliases: ['SqlString.escape'],
182
+ package: 'sqlstring',
183
+ protects: ['sql-query'],
184
+ completeness: 'complete',
185
+ returnsClean: true,
186
+ description: 'sqlstring escape function',
187
+ enabled: true,
188
+ tags: ['sql', 'escape', 'generic'],
189
+ },
190
+ // MongoDB sanitization
191
+ {
192
+ id: 'SAN-SQL-080',
193
+ name: 'sanitize',
194
+ aliases: ['mongo-sanitize'],
195
+ package: 'mongo-sanitize',
196
+ protects: ['nosql-query'],
197
+ completeness: 'complete',
198
+ returnsClean: true,
199
+ description: 'MongoDB query sanitization',
200
+ enabled: true,
201
+ tags: ['nosql', 'mongodb', 'sanitize'],
202
+ },
203
+ {
204
+ id: 'SAN-SQL-081',
205
+ name: 'ObjectId',
206
+ aliases: ['mongoose.Types.ObjectId'],
207
+ package: 'mongodb',
208
+ protects: ['nosql-query'],
209
+ completeness: 'complete',
210
+ returnsClean: true,
211
+ description: 'MongoDB ObjectId validation',
212
+ enabled: true,
213
+ tags: ['nosql', 'mongodb', 'objectid'],
214
+ },
215
+ ];
216
+ //# sourceMappingURL=sql-sanitizers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql-sanitizers.js","sourceRoot":"","sources":["../../../src/analysis/sanitizers/sql-sanitizers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,78 @@
1
+ /**
2
+ * @fileoverview Sanitizer type definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/types
4
+ * @trace REQ-SEC-001
5
+ */
6
+ import type { TaintSinkCategory } from '../../types/taint.js';
7
+ /**
8
+ * Sanitizer completeness level
9
+ */
10
+ export type SanitizerCompleteness = 'complete' | 'partial' | 'conditional';
11
+ /**
12
+ * Sanitizer definition for taint analysis
13
+ * @trace REQ-SEC-001
14
+ */
15
+ export interface SanitizerDefinition {
16
+ /** Unique sanitizer ID */
17
+ id: string;
18
+ /** Function/method name */
19
+ name: string;
20
+ /** Alternative names for this sanitizer */
21
+ aliases?: string[];
22
+ /** Regex pattern for matching function names */
23
+ namePattern?: string;
24
+ /** Package/module containing the sanitizer */
25
+ package?: string;
26
+ /** Sink categories this sanitizer protects against */
27
+ protects: TaintSinkCategory[];
28
+ /** Whether sanitization is complete, partial, or conditional */
29
+ completeness: SanitizerCompleteness;
30
+ /** Argument index that gets sanitized (for transform functions) */
31
+ sanitizedArg?: number;
32
+ /** Whether the sanitizer returns sanitized data */
33
+ returnsClean: boolean;
34
+ /** Description of the sanitizer */
35
+ description: string;
36
+ /** Caveats or limitations */
37
+ caveats?: string;
38
+ /** Whether this sanitizer is enabled by default */
39
+ enabled: boolean;
40
+ /** Tags for filtering */
41
+ tags: string[];
42
+ }
43
+ /**
44
+ * Sanitizer match result
45
+ */
46
+ export interface SanitizerMatchResult {
47
+ /** Definition that matched */
48
+ definition: SanitizerDefinition;
49
+ /** Function name that matched */
50
+ functionName: string;
51
+ /** Whether sanitization is complete */
52
+ isComplete: boolean;
53
+ /** Any caveats to consider */
54
+ caveats?: string;
55
+ }
56
+ /**
57
+ * Sanitizer detector interface
58
+ */
59
+ export interface ISanitizerDetector {
60
+ /** Check if an expression is sanitized for a given sink category */
61
+ isSanitized(expression: string, sinkCategory: TaintSinkCategory): SanitizerMatchResult | undefined;
62
+ /** Register custom sanitizer definition */
63
+ registerSanitizer(definition: SanitizerDefinition): void;
64
+ /** Get all registered sanitizers */
65
+ getSanitizers(): readonly SanitizerDefinition[];
66
+ }
67
+ /**
68
+ * Sanitizer detector options
69
+ */
70
+ export interface SanitizerDetectorOptions {
71
+ /** Custom sanitizers to add */
72
+ customSanitizers?: SanitizerDefinition[];
73
+ /** Packages to include */
74
+ packages?: string[];
75
+ /** Whether to include partial sanitizers */
76
+ includePartial?: boolean;
77
+ }
78
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAE9D;;GAEG;AACH,MAAM,MAAM,qBAAqB,GAAG,UAAU,GAAG,SAAS,GAAG,aAAa,CAAC;AAE3E;;;GAGG;AACH,MAAM,WAAW,mBAAmB;IAClC,0BAA0B;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,2CAA2C;IAC3C,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,gDAAgD;IAChD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,8CAA8C;IAC9C,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,sDAAsD;IACtD,QAAQ,EAAE,iBAAiB,EAAE,CAAC;IAC9B,gEAAgE;IAChE,YAAY,EAAE,qBAAqB,CAAC;IACpC,mEAAmE;IACnE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,mDAAmD;IACnD,YAAY,EAAE,OAAO,CAAC;IACtB,mCAAmC;IACnC,WAAW,EAAE,MAAM,CAAC;IACpB,6BAA6B;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,mDAAmD;IACnD,OAAO,EAAE,OAAO,CAAC;IACjB,yBAAyB;IACzB,IAAI,EAAE,MAAM,EAAE,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,8BAA8B;IAC9B,UAAU,EAAE,mBAAmB,CAAC;IAChC,iCAAiC;IACjC,YAAY,EAAE,MAAM,CAAC;IACrB,uCAAuC;IACvC,UAAU,EAAE,OAAO,CAAC;IACpB,8BAA8B;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,oEAAoE;IACpE,WAAW,CACT,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,iBAAiB,GAC9B,oBAAoB,GAAG,SAAS,CAAC;IAEpC,2CAA2C;IAC3C,iBAAiB,CAAC,UAAU,EAAE,mBAAmB,GAAG,IAAI,CAAC;IAEzD,oCAAoC;IACpC,aAAa,IAAI,SAAS,mBAAmB,EAAE,CAAC;CACjD;AAED;;GAEG;AACH,MAAM,WAAW,wBAAwB;IACvC,+BAA+B;IAC/B,gBAAgB,CAAC,EAAE,mBAAmB,EAAE,CAAC;IACzC,0BAA0B;IAC1B,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,4CAA4C;IAC5C,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * @fileoverview Sanitizer type definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/types
4
+ * @trace REQ-SEC-001
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/analysis/sanitizers/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @fileoverview Input validation sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/validation-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ import type { SanitizerDefinition } from './types.js';
7
+ /**
8
+ * Input validation sanitizers
9
+ * @trace REQ-SEC-001
10
+ */
11
+ export declare const VALIDATION_SANITIZERS: readonly SanitizerDefinition[];
12
+ //# sourceMappingURL=validation-sanitizers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation-sanitizers.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/validation-sanitizers.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD;;;GAGG;AACH,eAAO,MAAM,qBAAqB,EAAE,SAAS,mBAAmB,EAoRtD,CAAC"}