@nahisaho/musubix-security 2.0.0 → 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.
- package/dist/analysis/enhanced-taint-analyzer.d.ts +120 -0
- package/dist/analysis/enhanced-taint-analyzer.d.ts.map +1 -0
- package/dist/analysis/enhanced-taint-analyzer.js +450 -0
- package/dist/analysis/enhanced-taint-analyzer.js.map +1 -0
- package/dist/analysis/index.d.ts +1 -0
- package/dist/analysis/index.d.ts.map +1 -1
- package/dist/analysis/index.js +1 -0
- package/dist/analysis/index.js.map +1 -1
- package/dist/analysis/interprocedural/call-graph-builder.d.ts +192 -0
- package/dist/analysis/interprocedural/call-graph-builder.d.ts.map +1 -0
- package/dist/analysis/interprocedural/call-graph-builder.js +510 -0
- package/dist/analysis/interprocedural/call-graph-builder.js.map +1 -0
- package/dist/analysis/interprocedural/dfg-adapter.d.ts +166 -0
- package/dist/analysis/interprocedural/dfg-adapter.d.ts.map +1 -0
- package/dist/analysis/interprocedural/dfg-adapter.js +455 -0
- package/dist/analysis/interprocedural/dfg-adapter.js.map +1 -0
- package/dist/analysis/interprocedural/index.d.ts +9 -0
- package/dist/analysis/interprocedural/index.d.ts.map +1 -0
- package/dist/analysis/interprocedural/index.js +9 -0
- package/dist/analysis/interprocedural/index.js.map +1 -0
- package/dist/analysis/interprocedural/taint-propagator.d.ts +250 -0
- package/dist/analysis/interprocedural/taint-propagator.d.ts.map +1 -0
- package/dist/analysis/interprocedural/taint-propagator.js +435 -0
- package/dist/analysis/interprocedural/taint-propagator.js.map +1 -0
- package/dist/analysis/sanitizers/command-sanitizers.d.ts +12 -0
- package/dist/analysis/sanitizers/command-sanitizers.d.ts.map +1 -0
- package/dist/analysis/sanitizers/command-sanitizers.js +123 -0
- package/dist/analysis/sanitizers/command-sanitizers.js.map +1 -0
- package/dist/analysis/sanitizers/html-sanitizers.d.ts +12 -0
- package/dist/analysis/sanitizers/html-sanitizers.d.ts.map +1 -0
- package/dist/analysis/sanitizers/html-sanitizers.js +213 -0
- package/dist/analysis/sanitizers/html-sanitizers.js.map +1 -0
- package/dist/analysis/sanitizers/index.d.ts +35 -0
- package/dist/analysis/sanitizers/index.d.ts.map +1 -0
- package/dist/analysis/sanitizers/index.js +59 -0
- package/dist/analysis/sanitizers/index.js.map +1 -0
- package/dist/analysis/sanitizers/path-sanitizers.d.ts +12 -0
- package/dist/analysis/sanitizers/path-sanitizers.d.ts.map +1 -0
- package/dist/analysis/sanitizers/path-sanitizers.js +163 -0
- package/dist/analysis/sanitizers/path-sanitizers.js.map +1 -0
- package/dist/analysis/sanitizers/sql-sanitizers.d.ts +12 -0
- package/dist/analysis/sanitizers/sql-sanitizers.d.ts.map +1 -0
- package/dist/analysis/sanitizers/sql-sanitizers.js +216 -0
- package/dist/analysis/sanitizers/sql-sanitizers.js.map +1 -0
- package/dist/analysis/sanitizers/types.d.ts +78 -0
- package/dist/analysis/sanitizers/types.d.ts.map +1 -0
- package/dist/analysis/sanitizers/types.js +7 -0
- package/dist/analysis/sanitizers/types.js.map +1 -0
- package/dist/analysis/sanitizers/validation-sanitizers.d.ts +12 -0
- package/dist/analysis/sanitizers/validation-sanitizers.d.ts.map +1 -0
- package/dist/analysis/sanitizers/validation-sanitizers.js +268 -0
- package/dist/analysis/sanitizers/validation-sanitizers.js.map +1 -0
- package/dist/analysis/sinks/code-eval.d.ts +12 -0
- package/dist/analysis/sinks/code-eval.d.ts.map +1 -0
- package/dist/analysis/sinks/code-eval.js +231 -0
- package/dist/analysis/sinks/code-eval.js.map +1 -0
- package/dist/analysis/sinks/command-exec.d.ts +12 -0
- package/dist/analysis/sinks/command-exec.d.ts.map +1 -0
- package/dist/analysis/sinks/command-exec.js +187 -0
- package/dist/analysis/sinks/command-exec.js.map +1 -0
- package/dist/analysis/sinks/file-operations.d.ts +12 -0
- package/dist/analysis/sinks/file-operations.d.ts.map +1 -0
- package/dist/analysis/sinks/file-operations.js +239 -0
- package/dist/analysis/sinks/file-operations.js.map +1 -0
- package/dist/analysis/sinks/html-output.d.ts +12 -0
- package/dist/analysis/sinks/html-output.d.ts.map +1 -0
- package/dist/analysis/sinks/html-output.js +256 -0
- package/dist/analysis/sinks/html-output.js.map +1 -0
- package/dist/analysis/sinks/index.d.ts +30 -0
- package/dist/analysis/sinks/index.d.ts.map +1 -0
- package/dist/analysis/sinks/index.js +46 -0
- package/dist/analysis/sinks/index.js.map +1 -0
- package/dist/analysis/sinks/sql-query.d.ts +12 -0
- package/dist/analysis/sinks/sql-query.d.ts.map +1 -0
- package/dist/analysis/sinks/sql-query.js +209 -0
- package/dist/analysis/sinks/sql-query.js.map +1 -0
- package/dist/analysis/sinks/types.d.ts +97 -0
- package/dist/analysis/sinks/types.d.ts.map +1 -0
- package/dist/analysis/sinks/types.js +7 -0
- package/dist/analysis/sinks/types.js.map +1 -0
- package/dist/analysis/sources/database.d.ts +12 -0
- package/dist/analysis/sources/database.d.ts.map +1 -0
- package/dist/analysis/sources/database.js +211 -0
- package/dist/analysis/sources/database.js.map +1 -0
- package/dist/analysis/sources/environment.d.ts +12 -0
- package/dist/analysis/sources/environment.d.ts.map +1 -0
- package/dist/analysis/sources/environment.js +158 -0
- package/dist/analysis/sources/environment.js.map +1 -0
- package/dist/analysis/sources/file-system.d.ts +12 -0
- package/dist/analysis/sources/file-system.d.ts.map +1 -0
- package/dist/analysis/sources/file-system.js +180 -0
- package/dist/analysis/sources/file-system.js.map +1 -0
- package/dist/analysis/sources/http-request.d.ts +12 -0
- package/dist/analysis/sources/http-request.d.ts.map +1 -0
- package/dist/analysis/sources/http-request.js +179 -0
- package/dist/analysis/sources/http-request.js.map +1 -0
- package/dist/analysis/sources/index.d.ts +26 -0
- package/dist/analysis/sources/index.d.ts.map +1 -0
- package/dist/analysis/sources/index.js +40 -0
- package/dist/analysis/sources/index.js.map +1 -0
- package/dist/analysis/sources/types.d.ts +93 -0
- package/dist/analysis/sources/types.d.ts.map +1 -0
- package/dist/analysis/sources/types.js +7 -0
- package/dist/analysis/sources/types.js.map +1 -0
- package/dist/analysis/sources/user-input.d.ts +12 -0
- package/dist/analysis/sources/user-input.d.ts.map +1 -0
- package/dist/analysis/sources/user-input.js +261 -0
- package/dist/analysis/sources/user-input.js.map +1 -0
- package/dist/cve/cpe-matcher.d.ts +183 -0
- package/dist/cve/cpe-matcher.d.ts.map +1 -0
- package/dist/cve/cpe-matcher.js +396 -0
- package/dist/cve/cpe-matcher.js.map +1 -0
- package/dist/cve/cve-cache.d.ts +225 -0
- package/dist/cve/cve-cache.d.ts.map +1 -0
- package/dist/cve/cve-cache.js +452 -0
- package/dist/cve/cve-cache.js.map +1 -0
- package/dist/cve/cve-cache.test.d.ts +6 -0
- package/dist/cve/cve-cache.test.d.ts.map +1 -0
- package/dist/cve/cve-cache.test.js +363 -0
- package/dist/cve/cve-cache.test.js.map +1 -0
- package/dist/cve/dependency-parser.d.ts +204 -0
- package/dist/cve/dependency-parser.d.ts.map +1 -0
- package/dist/cve/dependency-parser.js +338 -0
- package/dist/cve/dependency-parser.js.map +1 -0
- package/dist/cve/index.d.ts +20 -0
- package/dist/cve/index.d.ts.map +1 -0
- package/dist/cve/index.js +13 -0
- package/dist/cve/index.js.map +1 -0
- package/dist/cve/nvd-client.d.ts +137 -0
- package/dist/cve/nvd-client.d.ts.map +1 -0
- package/dist/cve/nvd-client.js +333 -0
- package/dist/cve/nvd-client.js.map +1 -0
- package/dist/cve/rate-limiter.d.ts +194 -0
- package/dist/cve/rate-limiter.d.ts.map +1 -0
- package/dist/cve/rate-limiter.js +276 -0
- package/dist/cve/rate-limiter.js.map +1 -0
- package/dist/cve/report-generator.d.ts +145 -0
- package/dist/cve/report-generator.d.ts.map +1 -0
- package/dist/cve/report-generator.js +377 -0
- package/dist/cve/report-generator.js.map +1 -0
- package/dist/cve/report-generator.test.d.ts +6 -0
- package/dist/cve/report-generator.test.d.ts.map +1 -0
- package/dist/cve/report-generator.test.js +275 -0
- package/dist/cve/report-generator.test.js.map +1 -0
- package/dist/cve/vulnerability-scanner.d.ts +198 -0
- package/dist/cve/vulnerability-scanner.d.ts.map +1 -0
- package/dist/cve/vulnerability-scanner.js +311 -0
- package/dist/cve/vulnerability-scanner.js.map +1 -0
- package/dist/cve/vulnerability-scanner.test.d.ts +6 -0
- package/dist/cve/vulnerability-scanner.test.d.ts.map +1 -0
- package/dist/cve/vulnerability-scanner.test.js +329 -0
- package/dist/cve/vulnerability-scanner.test.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -1
- package/dist/rules/config/config-parser.d.ts +119 -0
- package/dist/rules/config/config-parser.d.ts.map +1 -0
- package/dist/rules/config/config-parser.js +376 -0
- package/dist/rules/config/config-parser.js.map +1 -0
- package/dist/rules/config/index.d.ts +8 -0
- package/dist/rules/config/index.d.ts.map +1 -0
- package/dist/rules/config/index.js +8 -0
- package/dist/rules/config/index.js.map +1 -0
- package/dist/rules/config/profiles.d.ts +85 -0
- package/dist/rules/config/profiles.d.ts.map +1 -0
- package/dist/rules/config/profiles.js +226 -0
- package/dist/rules/config/profiles.js.map +1 -0
- package/dist/rules/cwe/cwe-119-buffer-overflow.d.ts +9 -0
- package/dist/rules/cwe/cwe-119-buffer-overflow.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-119-buffer-overflow.js +54 -0
- package/dist/rules/cwe/cwe-119-buffer-overflow.js.map +1 -0
- package/dist/rules/cwe/cwe-125-oob-read.d.ts +20 -0
- package/dist/rules/cwe/cwe-125-oob-read.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-125-oob-read.js +247 -0
- package/dist/rules/cwe/cwe-125-oob-read.js.map +1 -0
- package/dist/rules/cwe/cwe-190-integer-overflow.d.ts +9 -0
- package/dist/rules/cwe/cwe-190-integer-overflow.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-190-integer-overflow.js +55 -0
- package/dist/rules/cwe/cwe-190-integer-overflow.js.map +1 -0
- package/dist/rules/cwe/cwe-20-input-validation.d.ts +21 -0
- package/dist/rules/cwe/cwe-20-input-validation.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-20-input-validation.js +342 -0
- package/dist/rules/cwe/cwe-20-input-validation.js.map +1 -0
- package/dist/rules/cwe/cwe-22-path-traversal.d.ts +20 -0
- package/dist/rules/cwe/cwe-22-path-traversal.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-22-path-traversal.js +306 -0
- package/dist/rules/cwe/cwe-22-path-traversal.js.map +1 -0
- package/dist/rules/cwe/cwe-269-improper-privilege.d.ts +9 -0
- package/dist/rules/cwe/cwe-269-improper-privilege.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-269-improper-privilege.js +58 -0
- package/dist/rules/cwe/cwe-269-improper-privilege.js.map +1 -0
- package/dist/rules/cwe/cwe-276-default-permissions.d.ts +9 -0
- package/dist/rules/cwe/cwe-276-default-permissions.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-276-default-permissions.js +54 -0
- package/dist/rules/cwe/cwe-276-default-permissions.js.map +1 -0
- package/dist/rules/cwe/cwe-287-improper-auth.d.ts +9 -0
- package/dist/rules/cwe/cwe-287-improper-auth.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-287-improper-auth.js +57 -0
- package/dist/rules/cwe/cwe-287-improper-auth.js.map +1 -0
- package/dist/rules/cwe/cwe-306-missing-auth-critical.d.ts +9 -0
- package/dist/rules/cwe/cwe-306-missing-auth-critical.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-306-missing-auth-critical.js +53 -0
- package/dist/rules/cwe/cwe-306-missing-auth-critical.js.map +1 -0
- package/dist/rules/cwe/cwe-352-csrf.d.ts +9 -0
- package/dist/rules/cwe/cwe-352-csrf.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-352-csrf.js +51 -0
- package/dist/rules/cwe/cwe-352-csrf.js.map +1 -0
- package/dist/rules/cwe/cwe-362-race-condition.d.ts +9 -0
- package/dist/rules/cwe/cwe-362-race-condition.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-362-race-condition.js +55 -0
- package/dist/rules/cwe/cwe-362-race-condition.js.map +1 -0
- package/dist/rules/cwe/cwe-416-use-after-free.d.ts +23 -0
- package/dist/rules/cwe/cwe-416-use-after-free.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-416-use-after-free.js +402 -0
- package/dist/rules/cwe/cwe-416-use-after-free.js.map +1 -0
- package/dist/rules/cwe/cwe-434-file-upload.d.ts +9 -0
- package/dist/rules/cwe/cwe-434-file-upload.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-434-file-upload.js +55 -0
- package/dist/rules/cwe/cwe-434-file-upload.js.map +1 -0
- package/dist/rules/cwe/cwe-476-null-deref.d.ts +9 -0
- package/dist/rules/cwe/cwe-476-null-deref.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-476-null-deref.js +55 -0
- package/dist/rules/cwe/cwe-476-null-deref.js.map +1 -0
- package/dist/rules/cwe/cwe-502-deserialization.d.ts +9 -0
- package/dist/rules/cwe/cwe-502-deserialization.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-502-deserialization.js +57 -0
- package/dist/rules/cwe/cwe-502-deserialization.js.map +1 -0
- package/dist/rules/cwe/cwe-77-command-injection.d.ts +9 -0
- package/dist/rules/cwe/cwe-77-command-injection.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-77-command-injection.js +55 -0
- package/dist/rules/cwe/cwe-77-command-injection.js.map +1 -0
- package/dist/rules/cwe/cwe-78-command-injection.d.ts +20 -0
- package/dist/rules/cwe/cwe-78-command-injection.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-78-command-injection.js +259 -0
- package/dist/rules/cwe/cwe-78-command-injection.js.map +1 -0
- package/dist/rules/cwe/cwe-787-oob-write.d.ts +21 -0
- package/dist/rules/cwe/cwe-787-oob-write.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-787-oob-write.js +321 -0
- package/dist/rules/cwe/cwe-787-oob-write.js.map +1 -0
- package/dist/rules/cwe/cwe-79-xss.d.ts +22 -0
- package/dist/rules/cwe/cwe-79-xss.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-79-xss.js +386 -0
- package/dist/rules/cwe/cwe-79-xss.js.map +1 -0
- package/dist/rules/cwe/cwe-798-hardcoded-credentials.d.ts +9 -0
- package/dist/rules/cwe/cwe-798-hardcoded-credentials.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-798-hardcoded-credentials.js +58 -0
- package/dist/rules/cwe/cwe-798-hardcoded-credentials.js.map +1 -0
- package/dist/rules/cwe/cwe-862-missing-auth.d.ts +9 -0
- package/dist/rules/cwe/cwe-862-missing-auth.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-862-missing-auth.js +55 -0
- package/dist/rules/cwe/cwe-862-missing-auth.js.map +1 -0
- package/dist/rules/cwe/cwe-863-incorrect-auth.d.ts +9 -0
- package/dist/rules/cwe/cwe-863-incorrect-auth.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-863-incorrect-auth.js +58 -0
- package/dist/rules/cwe/cwe-863-incorrect-auth.js.map +1 -0
- package/dist/rules/cwe/cwe-89-sql-injection.d.ts +21 -0
- package/dist/rules/cwe/cwe-89-sql-injection.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-89-sql-injection.js +456 -0
- package/dist/rules/cwe/cwe-89-sql-injection.js.map +1 -0
- package/dist/rules/cwe/cwe-918-ssrf.d.ts +9 -0
- package/dist/rules/cwe/cwe-918-ssrf.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-918-ssrf.js +59 -0
- package/dist/rules/cwe/cwe-918-ssrf.js.map +1 -0
- package/dist/rules/cwe/cwe-94-code-injection.d.ts +9 -0
- package/dist/rules/cwe/cwe-94-code-injection.d.ts.map +1 -0
- package/dist/rules/cwe/cwe-94-code-injection.js +59 -0
- package/dist/rules/cwe/cwe-94-code-injection.js.map +1 -0
- package/dist/rules/cwe/index.d.ts +43 -0
- package/dist/rules/cwe/index.d.ts.map +1 -0
- package/dist/rules/cwe/index.js +99 -0
- package/dist/rules/cwe/index.js.map +1 -0
- package/dist/rules/engine/index.d.ts +10 -0
- package/dist/rules/engine/index.d.ts.map +1 -0
- package/dist/rules/engine/index.js +9 -0
- package/dist/rules/engine/index.js.map +1 -0
- package/dist/rules/engine/rule-context.d.ts +99 -0
- package/dist/rules/engine/rule-context.d.ts.map +1 -0
- package/dist/rules/engine/rule-context.js +175 -0
- package/dist/rules/engine/rule-context.js.map +1 -0
- package/dist/rules/engine/rule-engine.d.ts +132 -0
- package/dist/rules/engine/rule-engine.d.ts.map +1 -0
- package/dist/rules/engine/rule-engine.js +379 -0
- package/dist/rules/engine/rule-engine.js.map +1 -0
- package/dist/rules/engine/rule-registry.d.ts +133 -0
- package/dist/rules/engine/rule-registry.d.ts.map +1 -0
- package/dist/rules/engine/rule-registry.js +281 -0
- package/dist/rules/engine/rule-registry.js.map +1 -0
- package/dist/rules/index.d.ts +14 -0
- package/dist/rules/index.d.ts.map +1 -0
- package/dist/rules/index.js +16 -0
- package/dist/rules/index.js.map +1 -0
- package/dist/rules/owasp/a01-broken-access-control.d.ts +19 -0
- package/dist/rules/owasp/a01-broken-access-control.d.ts.map +1 -0
- package/dist/rules/owasp/a01-broken-access-control.js +295 -0
- package/dist/rules/owasp/a01-broken-access-control.js.map +1 -0
- package/dist/rules/owasp/a02-cryptographic-failures.d.ts +19 -0
- package/dist/rules/owasp/a02-cryptographic-failures.d.ts.map +1 -0
- package/dist/rules/owasp/a02-cryptographic-failures.js +327 -0
- package/dist/rules/owasp/a02-cryptographic-failures.js.map +1 -0
- package/dist/rules/owasp/a03-injection.d.ts +21 -0
- package/dist/rules/owasp/a03-injection.d.ts.map +1 -0
- package/dist/rules/owasp/a03-injection.js +342 -0
- package/dist/rules/owasp/a03-injection.js.map +1 -0
- package/dist/rules/owasp/a04-insecure-design.d.ts +19 -0
- package/dist/rules/owasp/a04-insecure-design.d.ts.map +1 -0
- package/dist/rules/owasp/a04-insecure-design.js +403 -0
- package/dist/rules/owasp/a04-insecure-design.js.map +1 -0
- package/dist/rules/owasp/a05-security-misconfiguration.d.ts +19 -0
- package/dist/rules/owasp/a05-security-misconfiguration.d.ts.map +1 -0
- package/dist/rules/owasp/a05-security-misconfiguration.js +371 -0
- package/dist/rules/owasp/a05-security-misconfiguration.js.map +1 -0
- package/dist/rules/owasp/a06-vulnerable-components.d.ts +18 -0
- package/dist/rules/owasp/a06-vulnerable-components.d.ts.map +1 -0
- package/dist/rules/owasp/a06-vulnerable-components.js +243 -0
- package/dist/rules/owasp/a06-vulnerable-components.js.map +1 -0
- package/dist/rules/owasp/a07-auth-failures.d.ts +19 -0
- package/dist/rules/owasp/a07-auth-failures.d.ts.map +1 -0
- package/dist/rules/owasp/a07-auth-failures.js +300 -0
- package/dist/rules/owasp/a07-auth-failures.js.map +1 -0
- package/dist/rules/owasp/a08-integrity-failures.d.ts +18 -0
- package/dist/rules/owasp/a08-integrity-failures.d.ts.map +1 -0
- package/dist/rules/owasp/a08-integrity-failures.js +306 -0
- package/dist/rules/owasp/a08-integrity-failures.js.map +1 -0
- package/dist/rules/owasp/a09-logging-failures.d.ts +18 -0
- package/dist/rules/owasp/a09-logging-failures.d.ts.map +1 -0
- package/dist/rules/owasp/a09-logging-failures.js +339 -0
- package/dist/rules/owasp/a09-logging-failures.js.map +1 -0
- package/dist/rules/owasp/a10-ssrf.d.ts +18 -0
- package/dist/rules/owasp/a10-ssrf.d.ts.map +1 -0
- package/dist/rules/owasp/a10-ssrf.js +349 -0
- package/dist/rules/owasp/a10-ssrf.js.map +1 -0
- package/dist/rules/owasp/index.d.ts +20 -0
- package/dist/rules/owasp/index.d.ts.map +1 -0
- package/dist/rules/owasp/index.js +53 -0
- package/dist/rules/owasp/index.js.map +1 -0
- package/dist/rules/types.d.ts +277 -0
- package/dist/rules/types.d.ts.map +1 -0
- package/dist/rules/types.js +34 -0
- package/dist/rules/types.js.map +1 -0
- package/dist/tests/integration/epic-integration.test.d.ts +7 -0
- package/dist/tests/integration/epic-integration.test.d.ts.map +1 -0
- package/dist/tests/integration/epic-integration.test.js +390 -0
- package/dist/tests/integration/epic-integration.test.js.map +1 -0
- package/dist/tests/rules/cwe/cwe-top25-1-13.test.d.ts +2 -0
- package/dist/tests/rules/cwe/cwe-top25-1-13.test.d.ts.map +1 -0
- package/dist/tests/rules/cwe/cwe-top25-1-13.test.js +154 -0
- package/dist/tests/rules/cwe/cwe-top25-1-13.test.js.map +1 -0
- package/dist/tests/rules/cwe/cwe-top25-14-25.test.d.ts +2 -0
- package/dist/tests/rules/cwe/cwe-top25-14-25.test.d.ts.map +1 -0
- package/dist/tests/rules/cwe/cwe-top25-14-25.test.js +121 -0
- package/dist/tests/rules/cwe/cwe-top25-14-25.test.js.map +1 -0
- package/dist/types/cve.d.ts +278 -0
- package/dist/types/cve.d.ts.map +1 -0
- package/dist/types/cve.js +7 -0
- package/dist/types/cve.js.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/rule.d.ts +245 -0
- package/dist/types/rule.d.ts.map +1 -0
- package/dist/types/rule.js +7 -0
- package/dist/types/rule.js.map +1 -0
- package/package.json +4 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"taint-propagator.js","sourceRoot":"","sources":["../../../src/analysis/interprocedural/taint-propagator.ts"],"names":[],"mappings":"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"}
|
|
@@ -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":"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"}
|
|
@@ -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"}
|