@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 @@
1
+ {"version":3,"file":"taint-propagator.js","sourceRoot":"","sources":["../../../src/analysis/interprocedural/taint-propagator.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAgMH;;;GAGG;AACH,MAAM,OAAO,eAAe;IAClB,OAAO,CAAmC;IAC1C,iBAAiB,GAA8B,IAAI,GAAG,EAAE,CAAC;IACzD,OAAO,CAAqB;IAC5B,KAAK,CAAmB;IACxB,UAAU,CAAwB;IAE1C,YACE,OAA2B,EAC3B,KAAuB,EACvB,UAAiC,EACjC,UAAkC,EAAE;QAEpC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG;YACb,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,EAAE;YAChC,kBAAkB,EAAE,OAAO,CAAC,kBAAkB,IAAI,KAAK;YACvD,aAAa,EAAE,OAAO,CAAC,aAAa,IAAI,GAAG;YAC3C,aAAa,EAAE,OAAO,CAAC,aAAa,IAAI,EAAE;YAC1C,WAAW,EAAE,OAAO,CAAC,WAAW,IAAI,EAAE;YACtC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB,IAAI,EAAE;SACjD,CAAC;QAEF,2BAA2B;QAC3B,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAChE,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC1D,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC3E,CAAC;IAED;;OAEG;IACH,OAAO,CACL,SAAoB,EACpB,eAAgC,EAChC,gBAAoD;QAEpD,MAAM,QAAQ,GAAmB,EAAE,CAAC;QAEpC,2BAA2B;QAC3B,IAAI,CAAC,sBAAsB,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;QAEzD,uDAAuD;QACvD,KAAK,MAAM,cAAc,IAAI,eAAe,EAAE,CAAC;YAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CACpC,SAAS,EACT,cAAc,EACd,IAAI,GAAG,EAAU,EACjB,EAAE,EACF,GAAG,EACH,CAAC,CACF,CAAC;YAEF,2CAA2C;YAC3C,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;gBAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;gBACjE,IAAI,OAAO,IAAI,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;oBAChE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACzB,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACK,sBAAsB,CAC5B,SAAoB,EACpB,gBAAoD;QAEpD,KAAK,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;YAC7C,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YAC1F,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAED;;OAEG;IACK,oBAAoB,CAC1B,IAAmB,EACnB,UAAqB,EACrB,OAA8B;QAE9B,MAAM,OAAO,GAAiB;YAC5B,MAAM,EAAE,IAAI,CAAC,EAAE;YACf,sBAAsB,EAAE,EAAE;YAC1B,WAAW,EAAE,KAAK;YAClB,mBAAmB,EAAE,EAAE;YACvB,MAAM,EAAE,KAAK;YACb,QAAQ,EAAE,KAAK;SAChB,CAAC;QAEF,sCAAsC;QACtC,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAC5C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAC5C,CAAC;QACF,IAAI,aAAa,EAAE,CAAC;YAClB,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;YACxB,OAAO,CAAC,UAAU,GAAG,aAAa,CAAC,EAAE,CAAC;QACxC,CAAC;QAED,oCAAoC;QACpC,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC9B,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACpC,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM;oBAC5B,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;oBACnE,CAAC,CAAC,EAAE,CAAC;gBACP,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ;oBACjC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC;oBACzE,CAAC,CAAC,EAAE,CAAC;gBAEP,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBAClF,MAAM,eAAe,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBAEvF,IAAI,aAAa,IAAI,eAAe,EAAE,CAAC;oBACrC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;oBACtB,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC;oBACrC,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;QAED,yCAAyC;QACzC,MAAM,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAClD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,WAAW,CAAC,CACtE,CAAC;QACF,IAAI,gBAAgB,EAAE,CAAC;YACrB,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;YAC3B,OAAO,CAAC,mBAAmB,GAAG,gBAAgB,CAAC,QAAQ,CAAC;QAC1D,CAAC;QAED,oDAAoD;QACpD,IAAI,OAAO,EAAE,CAAC;YACZ,KAAK,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;gBAC7D,IAAI,OAAO,CAAC,WAAW,EAAE,SAAS,IAAI,UAAU,CAAC,SAAS,EAAE,CAAC;oBAC3D,OAAO,CAAC,sBAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAChD,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,iEAAiE;YACjE,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;OAEG;IACK,cAAc,CACpB,SAAoB,EACpB,eAA8B,EAC9B,OAAoB,EACpB,IAAqB,EACrB,UAAkB,EAClB,KAAa;QAEb,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC;QAED,MAAM,QAAQ,GAAG,GAAG,eAAe,CAAC,MAAM,IAAI,eAAe,CAAC,UAAU,EAAE,CAAC;QAC3E,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAEtB,MAAM,OAAO,GAAsB,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAEnE,iDAAiD;QACjD,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;YACpB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;QAED,0CAA0C;QAC1C,MAAM,aAAa,GAAG,SAAS,CAAC,aAAa,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QAEhF,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE,CAAC;YACjC,+CAA+C;YAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;YACjE,IAAI,QAAQ,KAAK,CAAC,CAAC;gBAAE,SAAS;YAE9B,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACtD,MAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAChE,IAAI,CAAC,UAAU,IAAI,CAAC,aAAa;gBAAE,SAAS;YAE5C,yCAAyC;YACzC,MAAM,aAAa,GAAkB;gBACnC,EAAE,EAAE,QAAQ,IAAI,CAAC,MAAM,EAAE;gBACzB,IAAI,EAAE,eAAe;gBACrB,EAAE,EAAE;oBACF,MAAM,EAAE,IAAI,CAAC,QAAQ;oBACrB,UAAU,EAAE,SAAS,QAAQ,EAAE;oBAC/B,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB;gBACD,QAAQ,EAAE,WAAW;gBACrB,QAAQ,EAAE,IAAI;gBACd,iBAAiB,EAAE,EAAE;gBACrB,UAAU,EAAE,UAAU,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;aAC1D,CAAC;YAEF,yBAAyB;YACzB,IAAI,aAAa,CAAC,WAAW,EAAE,CAAC;gBAC9B,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACxD,CAAC;YAED,MAAM,OAAO,GAAG,CAAC,GAAG,IAAI,EAAE,aAAa,CAAC,CAAC;YAEzC,sCAAsC;YACtC,IAAI,aAAa,CAAC,MAAM,EAAE,CAAC;gBACzB,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACxB,CAAC;YAED,yDAAyD;YACzD,IAAI,aAAa,CAAC,sBAAsB,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC5D,MAAM,cAAc,GAAkB;oBACpC,MAAM,EAAE,IAAI,CAAC,QAAQ;oBACrB,UAAU,EAAE,QAAQ;oBACpB,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,CAAC;gBAEF,MAAM,cAAc,GAAkB;oBACpC,EAAE,EAAE,QAAQ,OAAO,CAAC,MAAM,EAAE;oBAC5B,IAAI,EAAE,aAAa,CAAC,EAAE;oBACtB,EAAE,EAAE,cAAc;oBAClB,QAAQ,EAAE,QAAQ;oBAClB,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE;oBACrE,UAAU,EAAE,aAAa,CAAC,UAAU;iBACrC,CAAC;gBAEF,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CACxC,SAAS,EACT,cAAc,EACd,IAAI,GAAG,CAAC,OAAO,CAAC,EAChB,CAAC,GAAG,OAAO,EAAE,cAAc,CAAC,EAC5B,cAAc,CAAC,UAAU,EACzB,KAAK,GAAG,CAAC,CACV,CAAC;gBAEF,OAAO,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC;YAClC,CAAC;QACH,CAAC;QAED,oDAAoD;QACpD,IAAI,eAAe,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;YAC5C,MAAM,aAAa,GAAG,SAAS,CAAC,aAAa,CAAC,GAAG,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YAEhF,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE,CAAC;gBACjC,MAAM,cAAc,GAAkB;oBACpC,MAAM,EAAE,IAAI,CAAC,QAAQ;oBACrB,UAAU,EAAE,eAAe,IAAI,CAAC,IAAI,EAAE;oBACtC,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,CAAC;gBAEF,MAAM,cAAc,GAAkB;oBACpC,EAAE,EAAE,QAAQ,IAAI,CAAC,MAAM,EAAE;oBACzB,IAAI,EAAE,eAAe;oBACrB,EAAE,EAAE,cAAc;oBAClB,QAAQ,EAAE,aAAa;oBACvB,QAAQ,EAAE,IAAI;oBACd,iBAAiB,EAAE,EAAE;oBACrB,UAAU,EAAE,UAAU,GAAG,GAAG;iBAC7B,CAAC;gBAEF,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CACxC,SAAS,EACT,cAAc,EACd,IAAI,GAAG,CAAC,OAAO,CAAC,EAChB,CAAC,GAAG,IAAI,EAAE,cAAc,CAAC,EACzB,cAAc,CAAC,UAAU,EACzB,KAAK,GAAG,CAAC,CACV,CAAC;gBAEF,OAAO,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC;YAClC,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;OAEG;IACK,mBAAmB,CACzB,IAAmB,EACnB,eAA8B;QAE9B,yEAAyE;QACzE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC/C,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,eAAe,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC3D,OAAO,CAAC,CAAC;YACX,CAAC;QACH,CAAC;QACD,OAAO,CAAC,CAAC,CAAC;IACZ,CAAC;IAED;;OAEG;IACK,qBAAqB,CAC3B,QAAyB,EACzB,cAA6B;QAE7B,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC;QAEvC,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;QAE/D,IAAI,CAAC,OAAO,EAAE,MAAM;YAAE,OAAO,IAAI,CAAC;QAElC,iCAAiC;QACjC,MAAM,gBAAgB,GAAa,EAAE,CAAC;QACtC,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,gBAAgB,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACnD,CAAC;QAED,2DAA2D;QAC3D,MAAM,YAAY,GAAG,OAAO,CAAC,YAAa,CAAC;QAC3C,MAAM,oBAAoB,GAAG,IAAI,CAAC,yBAAyB,CAAC,gBAAgB,EAAE,YAAY,CAAC,CAAC;QAE5F,+BAA+B;QAC/B,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QAEhF,qCAAqC;QACrC,IAAI,oBAAoB,IAAI,UAAU,GAAG,GAAG;YAAE,OAAO,IAAI,CAAC;QAE1D,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;QAC5D,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,YAAY,CAAC,CAAC;QAEjE,OAAO;YACL,EAAE,EAAE,WAAW,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;YACtE,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,oBAAoB,EAAE,UAAU,CAAC;YAChF,KAAK,EAAE,aAAa,YAAY,gBAAgB;YAChD,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,QAAQ,EAAE,gBAAgB,CAAC;YAC/E,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;YAC1B,MAAM,EAAE;gBACN,EAAE,EAAE,OAAO,cAAc,CAAC,MAAM,EAAE;gBAClC,IAAI,EAAE,cAAc,CAAC,UAAU;gBAC/B,QAAQ,EAAE;oBACR,IAAI,EAAE,cAAc,CAAC,QAAQ;oBAC7B,IAAI,EAAE,cAAc,CAAC,IAAI;oBACzB,MAAM,EAAE,cAAc,CAAC,MAAM;iBAC9B;gBACD,IAAI,EAAE,YAAY;gBAClB,UAAU,EAAE,GAAG;aAChB;YACD,IAAI,EAAE;gBACJ,EAAE,EAAE,QAAQ,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE;gBAChC,IAAI,EAAE,IAAI,EAAE,MAAM,IAAI,SAAS;gBAC/B,QAAQ,EAAE;oBACR,IAAI,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ;oBAC1B,IAAI,EAAE,QAAQ,CAAC,EAAE,CAAC,IAAI;oBACtB,MAAM,EAAE,QAAQ,CAAC,EAAE,CAAC,MAAM;iBAC3B;gBACD,QAAQ,EAAE,YAAY;gBACtB,UAAU;aACX;YACD,QAAQ;YACR,gBAAgB;YAChB,oBAAoB;YACpB,UAAU;YACV,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC;SACpD,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,yBAAyB,CAC/B,iBAA2B,EAC3B,YAA+B;QAE/B,KAAK,MAAM,aAAa,IAAI,iBAAiB,EAAE,CAAC;YAC9C,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CACpC,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,IAAI,KAAK,aAAa;gBACxB,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,aAAa,CAAC,CACrC,CAAC;YACF,IAAI,SAAS,EAAE,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,SAAS,CAAC,YAAY,KAAK,UAAU,EAAE,CAAC;gBACxF,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACK,iBAAiB,CACvB,QAA2B,EAC3B,SAAkB,EAClB,UAAkB;QAElB,MAAM,YAAY,GAAsC;YACtD,WAAW,EAAE,CAAC;YACd,aAAa,EAAE,CAAC;YAChB,cAAc,EAAE,CAAC;YACjB,YAAY,EAAE,CAAC;YACf,WAAW,EAAE,CAAC;YACd,aAAa,EAAE,CAAC;YAChB,UAAU,EAAE,CAAC;YACb,MAAM,EAAE,CAAC;YACT,iBAAiB,EAAE,CAAC;YACpB,YAAY,EAAE,CAAC;YACf,aAAa,EAAE,CAAC;YAChB,cAAc,EAAE,CAAC;SAClB,CAAC;QAEF,IAAI,KAAK,GAAG,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,SAAS;YAAE,KAAK,IAAI,CAAC,CAAC;QAC1B,KAAK,GAAG,KAAK,GAAG,UAAU,CAAC;QAE3B,IAAI,KAAK,IAAI,GAAG;YAAE,OAAO,UAAU,CAAC;QACpC,IAAI,KAAK,IAAI,GAAG;YAAE,OAAO,MAAM,CAAC;QAChC,IAAI,KAAK,IAAI,GAAG;YAAE,OAAO,QAAQ,CAAC;QAClC,IAAI,KAAK,IAAI,GAAG;YAAE,OAAO,KAAK,CAAC;QAC/B,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,mBAAmB,CACzB,QAA2B,EAC3B,QAAyB,EACzB,UAAoB;QAEpB,MAAM,YAAY,GAAsC;YACtD,WAAW,EAAE,qEAAqE;YAClF,aAAa,EAAE,uEAAuE;YACtF,cAAc,EAAE,oDAAoD;YACpE,YAAY,EAAE,mEAAmE;YACjF,WAAW,EAAE,qEAAqE;YAClF,aAAa,EAAE,sDAAsD;YACrE,UAAU,EAAE,2DAA2D;YACvE,MAAM,EAAE,gEAAgE;YACxE,iBAAiB,EAAE,wDAAwD;YAC3E,YAAY,EAAE,2DAA2D;YACzE,aAAa,EAAE,6DAA6D;YAC5E,cAAc,EAAE,0DAA0D;SAC3E,CAAC;QAEF,IAAI,WAAW,GAAG,YAAY,CAAC,QAAQ,CAAC,IAAI,2CAA2C,CAAC;QAExF,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,WAAW,IAAI,mCAAmC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC5E,CAAC;QAED,WAAW,IAAI,uBAAuB,QAAQ,CAAC,MAAM,SAAS,CAAC;QAE/D,OAAO,WAAW,CAAC;IACrB,CAAC;IAED;;OAEG;IACK,mBAAmB,CAAC,QAA2B;QACrD,MAAM,YAAY,GAAsC;YACtD,WAAW,EAAE,kFAAkF;YAC/F,aAAa,EAAE,oDAAoD;YACnE,cAAc,EAAE,wFAAwF;YACxG,YAAY,EAAE,+FAA+F;YAC7G,WAAW,EAAE,iFAAiF;YAC9F,aAAa,EAAE,0FAA0F;YACzG,UAAU,EAAE,6DAA6D;YACzE,MAAM,EAAE,+EAA+E;YACvF,iBAAiB,EAAE,6EAA6E;YAChG,YAAY,EAAE,8DAA8D;YAC5E,aAAa,EAAE,8DAA8D;YAC7E,cAAc,EAAE,0EAA0E;SAC3F,CAAC;QAEF,OAAO,YAAY,CAAC,QAAQ,CAAC,IAAI,2CAA2C,CAAC;IAC/E,CAAC;IAED;;OAEG;IACK,mBAAmB,CAAC,QAAwB;QAClD,MAAM,IAAI,GAAG,IAAI,GAAG,EAAwB,CAAC;QAE7C,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,MAAM,GAAG,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YAC1I,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAE/B,IAAI,CAAC,QAAQ,IAAI,OAAO,CAAC,UAAU,GAAG,QAAQ,CAAC,UAAU,EAAE,CAAC;gBAC1D,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACnC,CAAC;IAED;;OAEG;IACK,mBAAmB,CACzB,MAAc,EACd,QAAgB,EAChB,OAAkB,EAClB,OAAgB;QAEhB,IAAI,MAAM,KAAK,QAAQ;YAAE,OAAO,IAAI,CAAC;QACrC,IAAI,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC;QAC3C,IAAI,OAAO,IAAI,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC;QAC7D,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACH,kBAAkB,CAAC,MAAc;QAC/B,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACH,kBAAkB;QAChB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAC/E,CAAC;IAED;;OAEG;IACH,gBAAgB;QACd,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAC7E,CAAC;IAED;;OAEG;IACH,qBAAqB;QACnB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IAClF,CAAC;CACF"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @fileoverview Command execution sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/command-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ import type { SanitizerDefinition } from './types.js';
7
+ /**
8
+ * Command injection sanitizers
9
+ * @trace REQ-SEC-001
10
+ */
11
+ export declare const COMMAND_SANITIZERS: readonly SanitizerDefinition[];
12
+ //# sourceMappingURL=command-sanitizers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-sanitizers.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/command-sanitizers.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD;;;GAGG;AACH,eAAO,MAAM,kBAAkB,EAAE,SAAS,mBAAmB,EAuHnD,CAAC"}
@@ -0,0 +1,123 @@
1
+ /**
2
+ * @fileoverview Command execution sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/command-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ /**
7
+ * Command injection sanitizers
8
+ * @trace REQ-SEC-001
9
+ */
10
+ export const COMMAND_SANITIZERS = [
11
+ // shell-quote package
12
+ {
13
+ id: 'SAN-CMD-001',
14
+ name: 'quote',
15
+ package: 'shell-quote',
16
+ protects: ['command-exec'],
17
+ completeness: 'complete',
18
+ returnsClean: true,
19
+ description: 'shell-quote quote function - escapes shell arguments',
20
+ enabled: true,
21
+ tags: ['command', 'shell', 'quote'],
22
+ },
23
+ {
24
+ id: 'SAN-CMD-002',
25
+ name: 'escape',
26
+ package: 'shell-quote',
27
+ protects: ['command-exec'],
28
+ completeness: 'complete',
29
+ returnsClean: true,
30
+ description: 'shell-quote escape function',
31
+ enabled: true,
32
+ tags: ['command', 'shell', 'escape'],
33
+ },
34
+ // shell-escape package
35
+ {
36
+ id: 'SAN-CMD-010',
37
+ name: 'shellEscape',
38
+ aliases: ['shell-escape'],
39
+ package: 'shell-escape',
40
+ protects: ['command-exec'],
41
+ completeness: 'complete',
42
+ returnsClean: true,
43
+ description: 'shell-escape package',
44
+ enabled: true,
45
+ tags: ['command', 'shell', 'escape'],
46
+ },
47
+ // any-shell-escape
48
+ {
49
+ id: 'SAN-CMD-020',
50
+ name: 'shellescape',
51
+ package: 'any-shell-escape',
52
+ protects: ['command-exec'],
53
+ completeness: 'complete',
54
+ returnsClean: true,
55
+ description: 'any-shell-escape package',
56
+ enabled: true,
57
+ tags: ['command', 'shell', 'escape'],
58
+ },
59
+ // Generic escape patterns
60
+ {
61
+ id: 'SAN-CMD-030',
62
+ name: 'escapeShell',
63
+ aliases: ['escapeShellArg', 'escapeShellCmd'],
64
+ protects: ['command-exec'],
65
+ completeness: 'complete',
66
+ returnsClean: true,
67
+ description: 'Generic shell escape function',
68
+ enabled: true,
69
+ tags: ['command', 'shell', 'escape'],
70
+ },
71
+ // Argument array (spawn-style - safer)
72
+ {
73
+ id: 'SAN-CMD-040',
74
+ name: 'spawn',
75
+ aliases: ['spawnSync'],
76
+ protects: ['command-exec'],
77
+ completeness: 'conditional',
78
+ returnsClean: false,
79
+ description: 'Using spawn with argument array instead of exec',
80
+ caveats: 'Only safe if shell option is false and args are separate',
81
+ enabled: true,
82
+ tags: ['command', 'spawn', 'array'],
83
+ },
84
+ // execFile (safer than exec)
85
+ {
86
+ id: 'SAN-CMD-050',
87
+ name: 'execFile',
88
+ aliases: ['execFileSync'],
89
+ protects: ['command-exec'],
90
+ completeness: 'conditional',
91
+ returnsClean: false,
92
+ description: 'Using execFile with argument array',
93
+ caveats: 'Only safe if file path is controlled and args are separate',
94
+ enabled: true,
95
+ tags: ['command', 'execFile', 'array'],
96
+ },
97
+ // Command whitelist pattern
98
+ {
99
+ id: 'SAN-CMD-060',
100
+ name: 'validateCommand',
101
+ aliases: ['allowedCommands', 'commandWhitelist'],
102
+ protects: ['command-exec'],
103
+ completeness: 'complete',
104
+ returnsClean: true,
105
+ description: 'Command whitelist validation',
106
+ enabled: true,
107
+ tags: ['command', 'whitelist', 'validate'],
108
+ },
109
+ // Execa options
110
+ {
111
+ id: 'SAN-CMD-070',
112
+ name: 'execa',
113
+ package: 'execa',
114
+ protects: ['command-exec'],
115
+ completeness: 'conditional',
116
+ returnsClean: false,
117
+ description: 'Execa with array arguments',
118
+ caveats: 'Only safe when using array form, not string command',
119
+ enabled: true,
120
+ tags: ['command', 'execa', 'array'],
121
+ },
122
+ ];
123
+ //# sourceMappingURL=command-sanitizers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-sanitizers.js","sourceRoot":"","sources":["../../../src/analysis/sanitizers/command-sanitizers.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH;;;GAGG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAmC;IAChE,sBAAsB;IACtB;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,OAAO;QACb,OAAO,EAAE,aAAa;QACtB,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,UAAU;QACxB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,sDAAsD;QACnE,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC;KACpC;IACD;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,aAAa;QACtB,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,UAAU;QACxB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,6BAA6B;QAC1C,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC;KACrC;IAED,uBAAuB;IACvB;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,aAAa;QACnB,OAAO,EAAE,CAAC,cAAc,CAAC;QACzB,OAAO,EAAE,cAAc;QACvB,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,UAAU;QACxB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,sBAAsB;QACnC,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC;KACrC;IAED,mBAAmB;IACnB;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,aAAa;QACnB,OAAO,EAAE,kBAAkB;QAC3B,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,UAAU;QACxB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,0BAA0B;QACvC,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC;KACrC;IAED,0BAA0B;IAC1B;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,aAAa;QACnB,OAAO,EAAE,CAAC,gBAAgB,EAAE,gBAAgB,CAAC;QAC7C,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,UAAU;QACxB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,+BAA+B;QAC5C,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC;KACrC;IAED,uCAAuC;IACvC;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,OAAO;QACb,OAAO,EAAE,CAAC,WAAW,CAAC;QACtB,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,aAAa;QAC3B,YAAY,EAAE,KAAK;QACnB,WAAW,EAAE,iDAAiD;QAC9D,OAAO,EAAE,0DAA0D;QACnE,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC;KACpC;IAED,6BAA6B;IAC7B;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,CAAC,cAAc,CAAC;QACzB,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,aAAa;QAC3B,YAAY,EAAE,KAAK;QACnB,WAAW,EAAE,oCAAoC;QACjD,OAAO,EAAE,4DAA4D;QACrE,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,CAAC;KACvC;IAED,4BAA4B;IAC5B;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,iBAAiB;QACvB,OAAO,EAAE,CAAC,iBAAiB,EAAE,kBAAkB,CAAC;QAChD,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,UAAU;QACxB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,8BAA8B;QAC3C,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,WAAW,EAAE,UAAU,CAAC;KAC3C;IAED,gBAAgB;IAChB;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,OAAO;QACb,OAAO,EAAE,OAAO;QAChB,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,YAAY,EAAE,aAAa;QAC3B,YAAY,EAAE,KAAK;QACnB,WAAW,EAAE,4BAA4B;QACzC,OAAO,EAAE,qDAAqD;QAC9D,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC;KACpC;CACO,CAAC"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @fileoverview HTML/XSS sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/html-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ import type { SanitizerDefinition } from './types.js';
7
+ /**
8
+ * HTML/XSS sanitizers
9
+ * @trace REQ-SEC-001
10
+ */
11
+ export declare const HTML_SANITIZERS: readonly SanitizerDefinition[];
12
+ //# sourceMappingURL=html-sanitizers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"html-sanitizers.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/html-sanitizers.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD;;;GAGG;AACH,eAAO,MAAM,eAAe,EAAE,SAAS,mBAAmB,EAqNhD,CAAC"}
@@ -0,0 +1,213 @@
1
+ /**
2
+ * @fileoverview HTML/XSS sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/html-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ /**
7
+ * HTML/XSS sanitizers
8
+ * @trace REQ-SEC-001
9
+ */
10
+ export const HTML_SANITIZERS = [
11
+ // Generic HTML escape
12
+ {
13
+ id: 'SAN-HTML-001',
14
+ name: 'escapeHtml',
15
+ aliases: ['escapeHTML', 'htmlEscape', 'escape'],
16
+ protects: ['html-output'],
17
+ completeness: 'complete',
18
+ returnsClean: true,
19
+ description: 'Generic HTML escape function',
20
+ enabled: true,
21
+ tags: ['html-output', 'html', 'escape'],
22
+ },
23
+ {
24
+ id: 'SAN-HTML-002',
25
+ name: 'encode',
26
+ aliases: ['htmlEncode', 'encodeHTML'],
27
+ protects: ['html-output'],
28
+ completeness: 'complete',
29
+ returnsClean: true,
30
+ description: 'HTML entity encoding',
31
+ enabled: true,
32
+ tags: ['html-output', 'html', 'encode'],
33
+ },
34
+ // html-entities package
35
+ {
36
+ id: 'SAN-HTML-010',
37
+ name: 'encode',
38
+ package: 'html-entities',
39
+ protects: ['html-output'],
40
+ completeness: 'complete',
41
+ returnsClean: true,
42
+ description: 'html-entities encode function',
43
+ enabled: true,
44
+ tags: ['html-output', 'html-entities', 'encode'],
45
+ },
46
+ {
47
+ id: 'SAN-HTML-011',
48
+ name: 'encodeHTML',
49
+ package: 'html-entities',
50
+ protects: ['html-output'],
51
+ completeness: 'complete',
52
+ returnsClean: true,
53
+ description: 'html-entities encodeHTML function',
54
+ enabled: true,
55
+ tags: ['html-output', 'html-entities', 'encode'],
56
+ },
57
+ // sanitize-html package
58
+ {
59
+ id: 'SAN-HTML-020',
60
+ name: 'sanitizeHtml',
61
+ aliases: ['sanitize'],
62
+ package: 'sanitize-html',
63
+ protects: ['html-output'],
64
+ completeness: 'complete',
65
+ returnsClean: true,
66
+ description: 'sanitize-html - removes dangerous HTML',
67
+ enabled: true,
68
+ tags: ['html-output', 'sanitize-html', 'sanitize'],
69
+ },
70
+ // DOMPurify
71
+ {
72
+ id: 'SAN-HTML-030',
73
+ name: 'sanitize',
74
+ package: 'dompurify',
75
+ protects: ['html-output'],
76
+ completeness: 'complete',
77
+ returnsClean: true,
78
+ description: 'DOMPurify.sanitize - DOM-based sanitization',
79
+ enabled: true,
80
+ tags: ['html-output', 'dompurify', 'sanitize'],
81
+ },
82
+ {
83
+ id: 'SAN-HTML-031',
84
+ name: 'sanitize',
85
+ package: 'isomorphic-dompurify',
86
+ protects: ['html-output'],
87
+ completeness: 'complete',
88
+ returnsClean: true,
89
+ description: 'isomorphic-dompurify - works on server and client',
90
+ enabled: true,
91
+ tags: ['html-output', 'dompurify', 'isomorphic'],
92
+ },
93
+ // xss package
94
+ {
95
+ id: 'SAN-HTML-040',
96
+ name: 'filterXSS',
97
+ aliases: ['html-output'],
98
+ package: 'html-output',
99
+ protects: ['html-output'],
100
+ completeness: 'complete',
101
+ returnsClean: true,
102
+ description: 'xss package - filters XSS attacks',
103
+ enabled: true,
104
+ tags: ['html-output', 'filter', 'xss-package'],
105
+ },
106
+ // he package
107
+ {
108
+ id: 'SAN-HTML-050',
109
+ name: 'encode',
110
+ package: 'he',
111
+ protects: ['html-output'],
112
+ completeness: 'complete',
113
+ returnsClean: true,
114
+ description: 'he.encode - HTML entity encoder',
115
+ enabled: true,
116
+ tags: ['html-output', 'he', 'encode'],
117
+ },
118
+ {
119
+ id: 'SAN-HTML-051',
120
+ name: 'escape',
121
+ package: 'he',
122
+ protects: ['html-output'],
123
+ completeness: 'complete',
124
+ returnsClean: true,
125
+ description: 'he.escape - HTML escape',
126
+ enabled: true,
127
+ tags: ['html-output', 'he', 'escape'],
128
+ },
129
+ // lodash escape
130
+ {
131
+ id: 'SAN-HTML-060',
132
+ name: 'escape',
133
+ aliases: ['_.escape'],
134
+ package: 'lodash',
135
+ protects: ['html-output'],
136
+ completeness: 'complete',
137
+ returnsClean: true,
138
+ description: 'Lodash escape function',
139
+ enabled: true,
140
+ tags: ['html-output', 'lodash', 'escape'],
141
+ },
142
+ // validator.js
143
+ {
144
+ id: 'SAN-HTML-070',
145
+ name: 'escape',
146
+ package: 'validator',
147
+ protects: ['html-output'],
148
+ completeness: 'complete',
149
+ returnsClean: true,
150
+ description: 'validator.js escape function',
151
+ enabled: true,
152
+ tags: ['html-output', 'validator', 'escape'],
153
+ },
154
+ // Text content (DOM safe alternative)
155
+ {
156
+ id: 'SAN-HTML-080',
157
+ name: 'textContent',
158
+ protects: ['html-output'],
159
+ completeness: 'complete',
160
+ returnsClean: true,
161
+ description: 'Using textContent instead of innerHTML',
162
+ enabled: true,
163
+ tags: ['html-output', 'dom', 'textContent'],
164
+ },
165
+ {
166
+ id: 'SAN-HTML-081',
167
+ name: 'innerText',
168
+ protects: ['html-output'],
169
+ completeness: 'complete',
170
+ returnsClean: true,
171
+ description: 'Using innerText instead of innerHTML',
172
+ enabled: true,
173
+ tags: ['html-output', 'dom', 'innerText'],
174
+ },
175
+ // jQuery text()
176
+ {
177
+ id: 'SAN-HTML-090',
178
+ name: 'text',
179
+ package: 'jquery',
180
+ protects: ['html-output'],
181
+ completeness: 'complete',
182
+ returnsClean: true,
183
+ description: 'jQuery text() instead of html()',
184
+ enabled: true,
185
+ tags: ['html-output', 'jquery', 'text'],
186
+ },
187
+ // Template engine auto-escape
188
+ {
189
+ id: 'SAN-HTML-100',
190
+ name: 'autoEscape',
191
+ namePattern: 'autoEscape|auto_escape',
192
+ protects: ['html-output'],
193
+ completeness: 'conditional',
194
+ returnsClean: true,
195
+ description: 'Template engine auto-escape feature',
196
+ caveats: 'Depends on template engine configuration',
197
+ enabled: true,
198
+ tags: ['html-output', 'template', 'auto-escape'],
199
+ },
200
+ // HTTP Header sanitization
201
+ {
202
+ id: 'SAN-HTML-110',
203
+ name: 'sanitizeHeader',
204
+ aliases: ['removeNewlines', 'stripNewlines'],
205
+ protects: ['html-output'],
206
+ completeness: 'complete',
207
+ returnsClean: true,
208
+ description: 'HTTP header sanitization - removes CRLF',
209
+ enabled: true,
210
+ tags: ['header', 'crlf', 'sanitize'],
211
+ },
212
+ ];
213
+ //# sourceMappingURL=html-sanitizers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"html-sanitizers.js","sourceRoot":"","sources":["../../../src/analysis/sanitizers/html-sanitizers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ /**
2
+ * @fileoverview Sanitizer definitions - Builtin sanitizers for taint analysis
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers
4
+ * @trace REQ-SEC-001 (EARS: テイント分析の高度化)
5
+ */
6
+ export * from './types.js';
7
+ export * from './sql-sanitizers.js';
8
+ export * from './html-sanitizers.js';
9
+ export * from './command-sanitizers.js';
10
+ export * from './path-sanitizers.js';
11
+ export * from './validation-sanitizers.js';
12
+ import type { SanitizerDefinition } from './types.js';
13
+ import type { TaintSinkCategory } from '../../types/taint.js';
14
+ /**
15
+ * All built-in sanitizers aggregated
16
+ * @trace REQ-SEC-001
17
+ */
18
+ export declare const ALL_BUILTIN_SANITIZERS: readonly SanitizerDefinition[];
19
+ /**
20
+ * Get sanitizers that protect against a specific sink category
21
+ */
22
+ export declare function getSanitizersForSink(sinkCategory: TaintSinkCategory): readonly SanitizerDefinition[];
23
+ /**
24
+ * Get sanitizers by package name
25
+ */
26
+ export declare function getSanitizersByPackage(packageName: string): readonly SanitizerDefinition[];
27
+ /**
28
+ * Check if a function name matches any known sanitizer
29
+ */
30
+ export declare function isSanitizer(functionName: string, sinkCategory?: TaintSinkCategory): SanitizerDefinition | undefined;
31
+ /**
32
+ * Get all sink categories that a sanitizer protects against
33
+ */
34
+ export declare function getProtectedCategories(sanitizerName: string): TaintSinkCategory[];
35
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAO3C,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACtD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAE9D;;;GAGG;AACH,eAAO,MAAM,sBAAsB,EAAE,SAAS,mBAAmB,EAMvD,CAAC;AAEX;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,YAAY,EAAE,iBAAiB,GAC9B,SAAS,mBAAmB,EAAE,CAIhC;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CACpC,WAAW,EAAE,MAAM,GAClB,SAAS,mBAAmB,EAAE,CAEhC;AAED;;GAEG;AACH,wBAAgB,WAAW,CACzB,YAAY,EAAE,MAAM,EACpB,YAAY,CAAC,EAAE,iBAAiB,GAC/B,mBAAmB,GAAG,SAAS,CAWjC;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CACpC,aAAa,EAAE,MAAM,GACpB,iBAAiB,EAAE,CAOrB"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * @fileoverview Sanitizer definitions - Builtin sanitizers for taint analysis
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers
4
+ * @trace REQ-SEC-001 (EARS: テイント分析の高度化)
5
+ */
6
+ export * from './types.js';
7
+ export * from './sql-sanitizers.js';
8
+ export * from './html-sanitizers.js';
9
+ export * from './command-sanitizers.js';
10
+ export * from './path-sanitizers.js';
11
+ export * from './validation-sanitizers.js';
12
+ import { SQL_SANITIZERS } from './sql-sanitizers.js';
13
+ import { HTML_SANITIZERS } from './html-sanitizers.js';
14
+ import { COMMAND_SANITIZERS } from './command-sanitizers.js';
15
+ import { PATH_SANITIZERS } from './path-sanitizers.js';
16
+ import { VALIDATION_SANITIZERS } from './validation-sanitizers.js';
17
+ /**
18
+ * All built-in sanitizers aggregated
19
+ * @trace REQ-SEC-001
20
+ */
21
+ export const ALL_BUILTIN_SANITIZERS = [
22
+ ...SQL_SANITIZERS,
23
+ ...HTML_SANITIZERS,
24
+ ...COMMAND_SANITIZERS,
25
+ ...PATH_SANITIZERS,
26
+ ...VALIDATION_SANITIZERS,
27
+ ];
28
+ /**
29
+ * Get sanitizers that protect against a specific sink category
30
+ */
31
+ export function getSanitizersForSink(sinkCategory) {
32
+ return ALL_BUILTIN_SANITIZERS.filter((s) => s.protects.includes(sinkCategory));
33
+ }
34
+ /**
35
+ * Get sanitizers by package name
36
+ */
37
+ export function getSanitizersByPackage(packageName) {
38
+ return ALL_BUILTIN_SANITIZERS.filter((s) => s.package === packageName);
39
+ }
40
+ /**
41
+ * Check if a function name matches any known sanitizer
42
+ */
43
+ export function isSanitizer(functionName, sinkCategory) {
44
+ const sanitizers = sinkCategory
45
+ ? getSanitizersForSink(sinkCategory)
46
+ : ALL_BUILTIN_SANITIZERS;
47
+ return sanitizers.find((s) => s.name === functionName ||
48
+ s.aliases?.includes(functionName) ||
49
+ (s.namePattern && new RegExp(s.namePattern).test(functionName)));
50
+ }
51
+ /**
52
+ * Get all sink categories that a sanitizer protects against
53
+ */
54
+ export function getProtectedCategories(sanitizerName) {
55
+ const sanitizer = ALL_BUILTIN_SANITIZERS.find((s) => s.name === sanitizerName ||
56
+ s.aliases?.includes(sanitizerName));
57
+ return sanitizer?.protects ?? [];
58
+ }
59
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/analysis/sanitizers/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAE3C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAInE;;;GAGG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAmC;IACpE,GAAG,cAAc;IACjB,GAAG,eAAe;IAClB,GAAG,kBAAkB;IACrB,GAAG,eAAe;IAClB,GAAG,qBAAqB;CAChB,CAAC;AAEX;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAClC,YAA+B;IAE/B,OAAO,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACzC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,CAClC,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,sBAAsB,CACpC,WAAmB;IAEnB,OAAO,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,WAAW,CAAC,CAAC;AACzE,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,WAAW,CACzB,YAAoB,EACpB,YAAgC;IAEhC,MAAM,UAAU,GAAG,YAAY;QAC7B,CAAC,CAAC,oBAAoB,CAAC,YAAY,CAAC;QACpC,CAAC,CAAC,sBAAsB,CAAC;IAE3B,OAAO,UAAU,CAAC,IAAI,CACpB,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,IAAI,KAAK,YAAY;QACvB,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,YAAY,CAAC;QACjC,CAAC,CAAC,CAAC,WAAW,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAClE,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,sBAAsB,CACpC,aAAqB;IAErB,MAAM,SAAS,GAAG,sBAAsB,CAAC,IAAI,CAC3C,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,IAAI,KAAK,aAAa;QACxB,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,aAAa,CAAC,CACrC,CAAC;IACF,OAAO,SAAS,EAAE,QAAQ,IAAI,EAAE,CAAC;AACnC,CAAC"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @fileoverview Path traversal sanitizer definitions
3
+ * @module @nahisaho/musubix-security/analysis/sanitizers/path-sanitizers
4
+ * @trace REQ-SEC-001
5
+ */
6
+ import type { SanitizerDefinition } from './types.js';
7
+ /**
8
+ * Path traversal sanitizers
9
+ * @trace REQ-SEC-001
10
+ */
11
+ export declare const PATH_SANITIZERS: readonly SanitizerDefinition[];
12
+ //# sourceMappingURL=path-sanitizers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"path-sanitizers.d.ts","sourceRoot":"","sources":["../../../src/analysis/sanitizers/path-sanitizers.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEtD;;;GAGG;AACH,eAAO,MAAM,eAAe,EAAE,SAAS,mBAAmB,EAmKhD,CAAC"}