@oculum/scanner 1.0.11 → 1.0.13
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/ai-context/index.d.ts +6 -0
- package/dist/ai-context/index.d.ts.map +1 -0
- package/dist/ai-context/index.js +13 -0
- package/dist/ai-context/index.js.map +1 -0
- package/dist/ai-context/manager.d.ts +67 -0
- package/dist/ai-context/manager.d.ts.map +1 -0
- package/dist/ai-context/manager.js +104 -0
- package/dist/ai-context/manager.js.map +1 -0
- package/dist/category-filter.d.ts +125 -0
- package/dist/category-filter.d.ts.map +1 -0
- package/dist/category-filter.js +360 -0
- package/dist/category-filter.js.map +1 -0
- package/dist/detect/ai-code/agent-tools.d.ts +22 -0
- package/dist/detect/ai-code/agent-tools.d.ts.map +1 -0
- package/dist/detect/ai-code/agent-tools.js +1509 -0
- package/dist/detect/ai-code/agent-tools.js.map +1 -0
- package/dist/detect/ai-code/byok-patterns.d.ts +15 -0
- package/dist/detect/ai-code/byok-patterns.d.ts.map +1 -0
- package/dist/detect/ai-code/byok-patterns.js +313 -0
- package/dist/detect/ai-code/byok-patterns.js.map +1 -0
- package/dist/detect/ai-code/endpoint-protection.d.ts +38 -0
- package/dist/detect/ai-code/endpoint-protection.d.ts.map +1 -0
- package/dist/detect/ai-code/endpoint-protection.js +349 -0
- package/dist/detect/ai-code/endpoint-protection.js.map +1 -0
- package/dist/detect/ai-code/execution-sinks.d.ts +21 -0
- package/dist/detect/ai-code/execution-sinks.d.ts.map +1 -0
- package/dist/detect/ai-code/execution-sinks.js +1158 -0
- package/dist/detect/ai-code/execution-sinks.js.map +1 -0
- package/dist/detect/ai-code/fingerprinting.d.ts +10 -0
- package/dist/detect/ai-code/fingerprinting.d.ts.map +1 -0
- package/dist/detect/ai-code/fingerprinting.js +665 -0
- package/dist/detect/ai-code/fingerprinting.js.map +1 -0
- package/dist/detect/ai-code/index.d.ts +12 -0
- package/dist/detect/ai-code/index.d.ts.map +1 -0
- package/dist/detect/ai-code/index.js +26 -0
- package/dist/detect/ai-code/index.js.map +1 -0
- package/dist/detect/ai-code/mcp-security.d.ts +20 -0
- package/dist/detect/ai-code/mcp-security.d.ts.map +1 -0
- package/dist/detect/ai-code/mcp-security.js +880 -0
- package/dist/detect/ai-code/mcp-security.js.map +1 -0
- package/dist/detect/ai-code/model-supply-chain.d.ts +23 -0
- package/dist/detect/ai-code/model-supply-chain.d.ts.map +1 -0
- package/dist/detect/ai-code/model-supply-chain.js +447 -0
- package/dist/detect/ai-code/model-supply-chain.js.map +1 -0
- package/dist/detect/ai-code/package-hallucination.d.ts +22 -0
- package/dist/detect/ai-code/package-hallucination.d.ts.map +1 -0
- package/dist/detect/ai-code/package-hallucination.js +841 -0
- package/dist/detect/ai-code/package-hallucination.js.map +1 -0
- package/dist/detect/ai-code/prompt-hygiene.d.ts +22 -0
- package/dist/detect/ai-code/prompt-hygiene.d.ts.map +1 -0
- package/dist/detect/ai-code/prompt-hygiene.js +1177 -0
- package/dist/detect/ai-code/prompt-hygiene.js.map +1 -0
- package/dist/detect/ai-code/rag-safety.d.ts +24 -0
- package/dist/detect/ai-code/rag-safety.d.ts.map +1 -0
- package/dist/detect/ai-code/rag-safety.js +913 -0
- package/dist/detect/ai-code/rag-safety.js.map +1 -0
- package/dist/detect/ai-code/schema-validation.d.ts +28 -0
- package/dist/detect/ai-code/schema-validation.d.ts.map +1 -0
- package/dist/detect/ai-code/schema-validation.js +378 -0
- package/dist/detect/ai-code/schema-validation.js.map +1 -0
- package/dist/detect/config/agent-skill-injection.d.ts +27 -0
- package/dist/detect/config/agent-skill-injection.d.ts.map +1 -0
- package/dist/detect/config/agent-skill-injection.js +472 -0
- package/dist/detect/config/agent-skill-injection.js.map +1 -0
- package/dist/detect/config/comments.d.ts +11 -0
- package/dist/detect/config/comments.d.ts.map +1 -0
- package/dist/detect/config/comments.js +206 -0
- package/dist/detect/config/comments.js.map +1 -0
- package/dist/detect/config/file-flags.d.ts +10 -0
- package/dist/detect/config/file-flags.d.ts.map +1 -0
- package/dist/detect/config/file-flags.js +124 -0
- package/dist/detect/config/file-flags.js.map +1 -0
- package/dist/detect/config/index.d.ts +7 -0
- package/dist/detect/config/index.d.ts.map +1 -0
- package/dist/detect/config/index.js +17 -0
- package/dist/detect/config/index.js.map +1 -0
- package/dist/detect/config/osv-check.d.ts +75 -0
- package/dist/detect/config/osv-check.d.ts.map +1 -0
- package/dist/detect/config/osv-check.js +309 -0
- package/dist/detect/config/osv-check.js.map +1 -0
- package/dist/detect/config/package-check.d.ts +63 -0
- package/dist/detect/config/package-check.d.ts.map +1 -0
- package/dist/detect/config/package-check.js +509 -0
- package/dist/detect/config/package-check.js.map +1 -0
- package/dist/detect/config/urls.d.ts +11 -0
- package/dist/detect/config/urls.d.ts.map +1 -0
- package/dist/detect/config/urls.js +450 -0
- package/dist/detect/config/urls.js.map +1 -0
- package/dist/detect/index.d.ts +37 -0
- package/dist/detect/index.d.ts.map +1 -0
- package/dist/detect/index.js +77 -0
- package/dist/detect/index.js.map +1 -0
- package/dist/detect/secrets/config-audit.d.ts +11 -0
- package/dist/detect/secrets/config-audit.d.ts.map +1 -0
- package/dist/detect/secrets/config-audit.js +315 -0
- package/dist/detect/secrets/config-audit.js.map +1 -0
- package/dist/detect/secrets/config-mcp-audit.d.ts +23 -0
- package/dist/detect/secrets/config-mcp-audit.d.ts.map +1 -0
- package/dist/detect/secrets/config-mcp-audit.js +243 -0
- package/dist/detect/secrets/config-mcp-audit.js.map +1 -0
- package/dist/detect/secrets/entropy.d.ts +11 -0
- package/dist/detect/secrets/entropy.d.ts.map +1 -0
- package/dist/detect/secrets/entropy.js +751 -0
- package/dist/detect/secrets/entropy.js.map +1 -0
- package/dist/detect/secrets/index.d.ts +36 -0
- package/dist/detect/secrets/index.d.ts.map +1 -0
- package/dist/detect/secrets/index.js +174 -0
- package/dist/detect/secrets/index.js.map +1 -0
- package/dist/detect/secrets/patterns.d.ts +11 -0
- package/dist/detect/secrets/patterns.d.ts.map +1 -0
- package/dist/detect/secrets/patterns.js +518 -0
- package/dist/detect/secrets/patterns.js.map +1 -0
- package/dist/detect/secrets/weak-crypto.d.ts +10 -0
- package/dist/detect/secrets/weak-crypto.d.ts.map +1 -0
- package/dist/detect/secrets/weak-crypto.js +432 -0
- package/dist/detect/secrets/weak-crypto.js.map +1 -0
- package/dist/detect/structural/auth-patterns.d.ts +22 -0
- package/dist/detect/structural/auth-patterns.d.ts.map +1 -0
- package/dist/detect/structural/auth-patterns.js +533 -0
- package/dist/detect/structural/auth-patterns.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/child-process.d.ts +16 -0
- package/dist/detect/structural/dangerous-functions/child-process.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/child-process.js +74 -0
- package/dist/detect/structural/dangerous-functions/child-process.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/dom-xss.d.ts +34 -0
- package/dist/detect/structural/dangerous-functions/dom-xss.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/dom-xss.js +230 -0
- package/dist/detect/structural/dangerous-functions/dom-xss.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/index.d.ts +16 -0
- package/dist/detect/structural/dangerous-functions/index.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/index.js +1193 -0
- package/dist/detect/structural/dangerous-functions/index.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/json-parse.d.ts +31 -0
- package/dist/detect/structural/dangerous-functions/json-parse.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/json-parse.js +326 -0
- package/dist/detect/structural/dangerous-functions/json-parse.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/math-random.d.ts +111 -0
- package/dist/detect/structural/dangerous-functions/math-random.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/math-random.js +684 -0
- package/dist/detect/structural/dangerous-functions/math-random.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/patterns.d.ts +21 -0
- package/dist/detect/structural/dangerous-functions/patterns.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/patterns.js +163 -0
- package/dist/detect/structural/dangerous-functions/patterns.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/request-validation.d.ts +13 -0
- package/dist/detect/structural/dangerous-functions/request-validation.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/request-validation.js +126 -0
- package/dist/detect/structural/dangerous-functions/request-validation.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/control-flow.d.ts +24 -0
- package/dist/detect/structural/dangerous-functions/utils/control-flow.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/control-flow.js +70 -0
- package/dist/detect/structural/dangerous-functions/utils/control-flow.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/helpers.d.ts +31 -0
- package/dist/detect/structural/dangerous-functions/utils/helpers.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/helpers.js +147 -0
- package/dist/detect/structural/dangerous-functions/utils/helpers.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/index.d.ts +9 -0
- package/dist/detect/structural/dangerous-functions/utils/index.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/index.js +23 -0
- package/dist/detect/structural/dangerous-functions/utils/index.js.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/schema-validation.d.ts +22 -0
- package/dist/detect/structural/dangerous-functions/utils/schema-validation.d.ts.map +1 -0
- package/dist/detect/structural/dangerous-functions/utils/schema-validation.js +102 -0
- package/dist/detect/structural/dangerous-functions/utils/schema-validation.js.map +1 -0
- package/dist/detect/structural/data-exposure.d.ts +19 -0
- package/dist/detect/structural/data-exposure.d.ts.map +1 -0
- package/dist/detect/structural/data-exposure.js +262 -0
- package/dist/detect/structural/data-exposure.js.map +1 -0
- package/dist/detect/structural/framework-checks.d.ts +10 -0
- package/dist/detect/structural/framework-checks.d.ts.map +1 -0
- package/dist/detect/structural/framework-checks.js +389 -0
- package/dist/detect/structural/framework-checks.js.map +1 -0
- package/dist/detect/structural/index.d.ts +71 -0
- package/dist/detect/structural/index.d.ts.map +1 -0
- package/dist/detect/structural/index.js +510 -0
- package/dist/detect/structural/index.js.map +1 -0
- package/dist/detect/structural/log-injection.d.ts +18 -0
- package/dist/detect/structural/log-injection.d.ts.map +1 -0
- package/dist/detect/structural/log-injection.js +217 -0
- package/dist/detect/structural/log-injection.js.map +1 -0
- package/dist/detect/structural/logic-gates.d.ts +10 -0
- package/dist/detect/structural/logic-gates.d.ts.map +1 -0
- package/dist/detect/structural/logic-gates.js +227 -0
- package/dist/detect/structural/logic-gates.js.map +1 -0
- package/dist/detect/structural/risky-imports.d.ts +10 -0
- package/dist/detect/structural/risky-imports.d.ts.map +1 -0
- package/dist/detect/structural/risky-imports.js +168 -0
- package/dist/detect/structural/risky-imports.js.map +1 -0
- package/dist/detect/structural/security-headers.d.ts +18 -0
- package/dist/detect/structural/security-headers.d.ts.map +1 -0
- package/dist/detect/structural/security-headers.js +196 -0
- package/dist/detect/structural/security-headers.js.map +1 -0
- package/dist/detect/structural/ssrf-detection.d.ts +18 -0
- package/dist/detect/structural/ssrf-detection.d.ts.map +1 -0
- package/dist/detect/structural/ssrf-detection.js +263 -0
- package/dist/detect/structural/ssrf-detection.js.map +1 -0
- package/dist/detect/structural/variables.d.ts +11 -0
- package/dist/detect/structural/variables.d.ts.map +1 -0
- package/dist/detect/structural/variables.js +159 -0
- package/dist/detect/structural/variables.js.map +1 -0
- package/dist/detect/structural/xxe-detection.d.ts +18 -0
- package/dist/detect/structural/xxe-detection.d.ts.map +1 -0
- package/dist/detect/structural/xxe-detection.js +245 -0
- package/dist/detect/structural/xxe-detection.js.map +1 -0
- package/dist/filtering/context-adjustments.d.ts +23 -0
- package/dist/filtering/context-adjustments.d.ts.map +1 -0
- package/dist/filtering/context-adjustments.js +100 -0
- package/dist/filtering/context-adjustments.js.map +1 -0
- package/dist/filtering/index.d.ts +3 -0
- package/dist/filtering/index.d.ts.map +1 -0
- package/dist/filtering/index.js +8 -0
- package/dist/filtering/index.js.map +1 -0
- package/dist/filtering/pipeline.d.ts +48 -0
- package/dist/filtering/pipeline.d.ts.map +1 -0
- package/dist/filtering/pipeline.js +76 -0
- package/dist/filtering/pipeline.js.map +1 -0
- package/dist/formatters/ai-context.d.ts +23 -0
- package/dist/formatters/ai-context.d.ts.map +1 -0
- package/dist/formatters/ai-context.js +238 -0
- package/dist/formatters/ai-context.js.map +1 -0
- package/dist/formatters/github-comment.d.ts +1 -1
- package/dist/formatters/github-comment.d.ts.map +1 -1
- package/dist/formatters/github-comment.js +2 -2
- package/dist/formatters/github-comment.js.map +1 -1
- package/dist/formatters/ide/claude-code.d.ts +17 -0
- package/dist/formatters/ide/claude-code.d.ts.map +1 -0
- package/dist/formatters/ide/claude-code.js +94 -0
- package/dist/formatters/ide/claude-code.js.map +1 -0
- package/dist/formatters/ide/cursor.d.ts +13 -0
- package/dist/formatters/ide/cursor.d.ts.map +1 -0
- package/dist/formatters/ide/cursor.js +125 -0
- package/dist/formatters/ide/cursor.js.map +1 -0
- package/dist/formatters/ide/index.d.ts +62 -0
- package/dist/formatters/ide/index.d.ts.map +1 -0
- package/dist/formatters/ide/index.js +184 -0
- package/dist/formatters/ide/index.js.map +1 -0
- package/dist/formatters/ide/windsurf.d.ts +13 -0
- package/dist/formatters/ide/windsurf.d.ts.map +1 -0
- package/dist/formatters/ide/windsurf.js +117 -0
- package/dist/formatters/ide/windsurf.js.map +1 -0
- package/dist/formatters/index.d.ts +2 -0
- package/dist/formatters/index.d.ts.map +1 -1
- package/dist/formatters/index.js +17 -1
- package/dist/formatters/index.js.map +1 -1
- package/dist/index.d.ts +17 -60
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +67 -824
- package/dist/index.js.map +1 -1
- package/dist/layer1/comments.d.ts +4 -1
- package/dist/layer1/comments.d.ts.map +1 -1
- package/dist/layer1/comments.js +1 -1
- package/dist/layer1/comments.js.map +1 -1
- package/dist/layer1/config-audit.d.ts +4 -1
- package/dist/layer1/config-audit.d.ts.map +1 -1
- package/dist/layer1/config-audit.js +45 -11
- package/dist/layer1/config-audit.js.map +1 -1
- package/dist/layer1/config-mcp-audit.d.ts +4 -1
- package/dist/layer1/config-mcp-audit.d.ts.map +1 -1
- package/dist/layer1/config-mcp-audit.js +2 -2
- package/dist/layer1/config-mcp-audit.js.map +1 -1
- package/dist/layer1/entropy.d.ts +4 -1
- package/dist/layer1/entropy.d.ts.map +1 -1
- package/dist/layer1/entropy.js +212 -1
- package/dist/layer1/entropy.js.map +1 -1
- package/dist/layer1/file-flags.d.ts +4 -1
- package/dist/layer1/file-flags.d.ts.map +1 -1
- package/dist/layer1/file-flags.js +12 -5
- package/dist/layer1/file-flags.js.map +1 -1
- package/dist/layer1/index.d.ts.map +1 -1
- package/dist/layer1/index.js +14 -19
- package/dist/layer1/index.js.map +1 -1
- package/dist/layer1/patterns.d.ts +4 -1
- package/dist/layer1/patterns.d.ts.map +1 -1
- package/dist/layer1/patterns.js +34 -4
- package/dist/layer1/patterns.js.map +1 -1
- package/dist/layer1/urls.d.ts +4 -1
- package/dist/layer1/urls.d.ts.map +1 -1
- package/dist/layer1/urls.js +162 -14
- package/dist/layer1/urls.js.map +1 -1
- package/dist/layer1/weak-crypto.d.ts +4 -1
- package/dist/layer1/weak-crypto.d.ts.map +1 -1
- package/dist/layer1/weak-crypto.js +144 -7
- package/dist/layer1/weak-crypto.js.map +1 -1
- package/dist/layer2/ai-agent-tools.d.ts +4 -1
- package/dist/layer2/ai-agent-tools.d.ts.map +1 -1
- package/dist/layer2/ai-agent-tools.js +661 -2
- package/dist/layer2/ai-agent-tools.js.map +1 -1
- package/dist/layer2/ai-endpoint-protection.d.ts +2 -0
- package/dist/layer2/ai-endpoint-protection.d.ts.map +1 -1
- package/dist/layer2/ai-endpoint-protection.js +1 -1
- package/dist/layer2/ai-endpoint-protection.js.map +1 -1
- package/dist/layer2/ai-execution-sinks.d.ts +4 -1
- package/dist/layer2/ai-execution-sinks.d.ts.map +1 -1
- package/dist/layer2/ai-execution-sinks.js +252 -43
- package/dist/layer2/ai-execution-sinks.js.map +1 -1
- package/dist/layer2/ai-fingerprinting.d.ts +4 -1
- package/dist/layer2/ai-fingerprinting.d.ts.map +1 -1
- package/dist/layer2/ai-fingerprinting.js +25 -32
- package/dist/layer2/ai-fingerprinting.js.map +1 -1
- package/dist/layer2/ai-mcp-security.d.ts +4 -1
- package/dist/layer2/ai-mcp-security.d.ts.map +1 -1
- package/dist/layer2/ai-mcp-security.js +200 -2
- package/dist/layer2/ai-mcp-security.js.map +1 -1
- package/dist/layer2/ai-package-hallucination.d.ts +4 -1
- package/dist/layer2/ai-package-hallucination.d.ts.map +1 -1
- package/dist/layer2/ai-package-hallucination.js +136 -4
- package/dist/layer2/ai-package-hallucination.js.map +1 -1
- package/dist/layer2/ai-prompt-hygiene.d.ts +4 -1
- package/dist/layer2/ai-prompt-hygiene.d.ts.map +1 -1
- package/dist/layer2/ai-prompt-hygiene.js +342 -28
- package/dist/layer2/ai-prompt-hygiene.js.map +1 -1
- package/dist/layer2/ai-rag-safety.d.ts +4 -1
- package/dist/layer2/ai-rag-safety.d.ts.map +1 -1
- package/dist/layer2/ai-rag-safety.js +82 -2
- package/dist/layer2/ai-rag-safety.js.map +1 -1
- package/dist/layer2/ai-schema-validation.d.ts +4 -1
- package/dist/layer2/ai-schema-validation.d.ts.map +1 -1
- package/dist/layer2/ai-schema-validation.js +2 -2
- package/dist/layer2/ai-schema-validation.js.map +1 -1
- package/dist/layer2/auth-antipatterns.d.ts +2 -0
- package/dist/layer2/auth-antipatterns.d.ts.map +1 -1
- package/dist/layer2/auth-antipatterns.js +205 -20
- package/dist/layer2/auth-antipatterns.js.map +1 -1
- package/dist/layer2/byok-patterns.d.ts +4 -1
- package/dist/layer2/byok-patterns.d.ts.map +1 -1
- package/dist/layer2/byok-patterns.js +2 -2
- package/dist/layer2/byok-patterns.js.map +1 -1
- package/dist/layer2/dangerous-functions/dom-xss.d.ts +9 -4
- package/dist/layer2/dangerous-functions/dom-xss.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/dom-xss.js +73 -22
- package/dist/layer2/dangerous-functions/dom-xss.js.map +1 -1
- package/dist/layer2/dangerous-functions/index.d.ts +4 -1
- package/dist/layer2/dangerous-functions/index.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/index.js +551 -20
- package/dist/layer2/dangerous-functions/index.js.map +1 -1
- package/dist/layer2/dangerous-functions/math-random.d.ts +54 -4
- package/dist/layer2/dangerous-functions/math-random.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/math-random.js +241 -16
- package/dist/layer2/dangerous-functions/math-random.js.map +1 -1
- package/dist/layer2/dangerous-functions/patterns.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/patterns.js +3 -1
- package/dist/layer2/dangerous-functions/patterns.js.map +1 -1
- package/dist/layer2/dangerous-functions/utils/control-flow.d.ts +3 -2
- package/dist/layer2/dangerous-functions/utils/control-flow.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/utils/control-flow.js +41 -120
- package/dist/layer2/dangerous-functions/utils/control-flow.js.map +1 -1
- package/dist/layer2/dangerous-functions/utils/helpers.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/utils/helpers.js +26 -3
- package/dist/layer2/dangerous-functions/utils/helpers.js.map +1 -1
- package/dist/layer2/dangerous-functions/utils/schema-validation.d.ts.map +1 -1
- package/dist/layer2/dangerous-functions/utils/schema-validation.js +14 -1
- package/dist/layer2/dangerous-functions/utils/schema-validation.js.map +1 -1
- package/dist/layer2/data-exposure.d.ts +4 -1
- package/dist/layer2/data-exposure.d.ts.map +1 -1
- package/dist/layer2/data-exposure.js +11 -38
- package/dist/layer2/data-exposure.js.map +1 -1
- package/dist/layer2/framework-checks.d.ts +4 -1
- package/dist/layer2/framework-checks.d.ts.map +1 -1
- package/dist/layer2/framework-checks.js +3 -10
- package/dist/layer2/framework-checks.js.map +1 -1
- package/dist/layer2/index.d.ts +13 -1
- package/dist/layer2/index.d.ts.map +1 -1
- package/dist/layer2/index.js +107 -52
- package/dist/layer2/index.js.map +1 -1
- package/dist/layer2/log-injection.d.ts +18 -0
- package/dist/layer2/log-injection.d.ts.map +1 -0
- package/dist/layer2/log-injection.js +214 -0
- package/dist/layer2/log-injection.js.map +1 -0
- package/dist/layer2/logic-gates.d.ts +4 -1
- package/dist/layer2/logic-gates.d.ts.map +1 -1
- package/dist/layer2/logic-gates.js +54 -20
- package/dist/layer2/logic-gates.js.map +1 -1
- package/dist/layer2/model-supply-chain.d.ts +4 -1
- package/dist/layer2/model-supply-chain.d.ts.map +1 -1
- package/dist/layer2/model-supply-chain.js +72 -4
- package/dist/layer2/model-supply-chain.js.map +1 -1
- package/dist/layer2/risky-imports.d.ts +4 -1
- package/dist/layer2/risky-imports.d.ts.map +1 -1
- package/dist/layer2/risky-imports.js +2 -2
- package/dist/layer2/risky-imports.js.map +1 -1
- package/dist/layer2/security-headers.d.ts +18 -0
- package/dist/layer2/security-headers.d.ts.map +1 -0
- package/dist/layer2/security-headers.js +187 -0
- package/dist/layer2/security-headers.js.map +1 -0
- package/dist/layer2/ssrf-detection.d.ts +18 -0
- package/dist/layer2/ssrf-detection.d.ts.map +1 -0
- package/dist/layer2/ssrf-detection.js +252 -0
- package/dist/layer2/ssrf-detection.js.map +1 -0
- package/dist/layer2/variables.d.ts +4 -1
- package/dist/layer2/variables.d.ts.map +1 -1
- package/dist/layer2/variables.js +2 -2
- package/dist/layer2/variables.js.map +1 -1
- package/dist/layer2/xxe-detection.d.ts +18 -0
- package/dist/layer2/xxe-detection.d.ts.map +1 -0
- package/dist/layer2/xxe-detection.js +242 -0
- package/dist/layer2/xxe-detection.js.map +1 -0
- package/dist/layer3/anthropic/auto-dismiss.d.ts.map +1 -1
- package/dist/layer3/anthropic/auto-dismiss.js +11 -0
- package/dist/layer3/anthropic/auto-dismiss.js.map +1 -1
- package/dist/layer3/anthropic/prompts/index.d.ts +1 -1
- package/dist/layer3/anthropic/prompts/index.d.ts.map +1 -1
- package/dist/layer3/anthropic/prompts/index.js +3 -1
- package/dist/layer3/anthropic/prompts/index.js.map +1 -1
- package/dist/layer3/anthropic/prompts/modules/ai-patterns.d.ts +19 -0
- package/dist/layer3/anthropic/prompts/modules/ai-patterns.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/ai-patterns.js +156 -0
- package/dist/layer3/anthropic/prompts/modules/ai-patterns.js.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/auth-access.d.ts +9 -0
- package/dist/layer3/anthropic/prompts/modules/auth-access.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/auth-access.js +25 -0
- package/dist/layer3/anthropic/prompts/modules/auth-access.js.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/common.d.ts +11 -0
- package/dist/layer3/anthropic/prompts/modules/common.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/common.js +152 -0
- package/dist/layer3/anthropic/prompts/modules/common.js.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/index.d.ts +54 -0
- package/dist/layer3/anthropic/prompts/modules/index.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/index.js +185 -0
- package/dist/layer3/anthropic/prompts/modules/index.js.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/owasp-classic.d.ts +8 -0
- package/dist/layer3/anthropic/prompts/modules/owasp-classic.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/owasp-classic.js +84 -0
- package/dist/layer3/anthropic/prompts/modules/owasp-classic.js.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/secrets-crypto.d.ts +8 -0
- package/dist/layer3/anthropic/prompts/modules/secrets-crypto.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/secrets-crypto.js +68 -0
- package/dist/layer3/anthropic/prompts/modules/secrets-crypto.js.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/xss-prompt.d.ts +8 -0
- package/dist/layer3/anthropic/prompts/modules/xss-prompt.d.ts.map +1 -0
- package/dist/layer3/anthropic/prompts/modules/xss-prompt.js +22 -0
- package/dist/layer3/anthropic/prompts/modules/xss-prompt.js.map +1 -0
- package/dist/layer3/anthropic/prompts/validation.d.ts +9 -3
- package/dist/layer3/anthropic/prompts/validation.d.ts.map +1 -1
- package/dist/layer3/anthropic/prompts/validation.js +14 -410
- package/dist/layer3/anthropic/prompts/validation.js.map +1 -1
- package/dist/layer3/anthropic/providers/anthropic.d.ts.map +1 -1
- package/dist/layer3/anthropic/providers/anthropic.js +6 -3
- package/dist/layer3/anthropic/providers/anthropic.js.map +1 -1
- package/dist/layer3/anthropic/providers/openai.d.ts.map +1 -1
- package/dist/layer3/anthropic/providers/openai.js +6 -3
- package/dist/layer3/anthropic/providers/openai.js.map +1 -1
- package/dist/layer3/anthropic/request-builder.d.ts +11 -4
- package/dist/layer3/anthropic/request-builder.d.ts.map +1 -1
- package/dist/layer3/anthropic/request-builder.js +32 -16
- package/dist/layer3/anthropic/request-builder.js.map +1 -1
- package/dist/layer3/anthropic/utils/context-extractor.d.ts +55 -0
- package/dist/layer3/anthropic/utils/context-extractor.d.ts.map +1 -0
- package/dist/layer3/anthropic/utils/context-extractor.js +161 -0
- package/dist/layer3/anthropic/utils/context-extractor.js.map +1 -0
- package/dist/layer3/anthropic/utils/index.d.ts +2 -0
- package/dist/layer3/anthropic/utils/index.d.ts.map +1 -1
- package/dist/layer3/anthropic/utils/index.js +4 -1
- package/dist/layer3/anthropic/utils/index.js.map +1 -1
- package/dist/model/auth-helper-detector.d.ts +56 -0
- package/dist/model/auth-helper-detector.d.ts.map +1 -0
- package/dist/model/auth-helper-detector.js +360 -0
- package/dist/model/auth-helper-detector.js.map +1 -0
- package/dist/model/cross-file-taint.d.ts +40 -0
- package/dist/model/cross-file-taint.d.ts.map +1 -0
- package/dist/model/cross-file-taint.js +290 -0
- package/dist/model/cross-file-taint.js.map +1 -0
- package/dist/model/framework-models/django.d.ts +9 -0
- package/dist/model/framework-models/django.d.ts.map +1 -0
- package/dist/model/framework-models/django.js +82 -0
- package/dist/model/framework-models/django.js.map +1 -0
- package/dist/model/framework-models/express.d.ts +9 -0
- package/dist/model/framework-models/express.d.ts.map +1 -0
- package/dist/model/framework-models/express.js +52 -0
- package/dist/model/framework-models/express.js.map +1 -0
- package/dist/model/framework-models/index.d.ts +20 -0
- package/dist/model/framework-models/index.d.ts.map +1 -0
- package/dist/model/framework-models/index.js +102 -0
- package/dist/model/framework-models/index.js.map +1 -0
- package/dist/model/framework-models/nextjs.d.ts +9 -0
- package/dist/model/framework-models/nextjs.d.ts.map +1 -0
- package/dist/model/framework-models/nextjs.js +71 -0
- package/dist/model/framework-models/nextjs.js.map +1 -0
- package/dist/model/framework-models/prisma.d.ts +10 -0
- package/dist/model/framework-models/prisma.d.ts.map +1 -0
- package/dist/model/framework-models/prisma.js +54 -0
- package/dist/model/framework-models/prisma.js.map +1 -0
- package/dist/model/framework-models/react.d.ts +9 -0
- package/dist/model/framework-models/react.d.ts.map +1 -0
- package/dist/model/framework-models/react.js +67 -0
- package/dist/model/framework-models/react.js.map +1 -0
- package/dist/model/framework-models/sequelize.d.ts +9 -0
- package/dist/model/framework-models/sequelize.d.ts.map +1 -0
- package/dist/model/framework-models/sequelize.js +62 -0
- package/dist/model/framework-models/sequelize.js.map +1 -0
- package/dist/model/framework-models/types.d.ts +43 -0
- package/dist/model/framework-models/types.d.ts.map +1 -0
- package/dist/model/framework-models/types.js +10 -0
- package/dist/model/framework-models/types.js.map +1 -0
- package/dist/model/function-classifier.d.ts +32 -0
- package/dist/model/function-classifier.d.ts.map +1 -0
- package/dist/model/function-classifier.js +143 -0
- package/dist/model/function-classifier.js.map +1 -0
- package/dist/model/import-resolver.d.ts +45 -0
- package/dist/model/import-resolver.d.ts.map +1 -0
- package/dist/model/import-resolver.js +410 -0
- package/dist/model/import-resolver.js.map +1 -0
- package/dist/model/imported-auth-detector.d.ts +38 -0
- package/dist/model/imported-auth-detector.d.ts.map +1 -0
- package/dist/model/imported-auth-detector.js +199 -0
- package/dist/model/imported-auth-detector.js.map +1 -0
- package/dist/model/index.d.ts +63 -0
- package/dist/model/index.d.ts.map +1 -0
- package/dist/model/index.js +272 -0
- package/dist/model/index.js.map +1 -0
- package/dist/model/middleware-detector.d.ts +55 -0
- package/dist/model/middleware-detector.d.ts.map +1 -0
- package/dist/model/middleware-detector.js +382 -0
- package/dist/model/middleware-detector.js.map +1 -0
- package/dist/model/module-graph.d.ts +46 -0
- package/dist/model/module-graph.d.ts.map +1 -0
- package/dist/model/module-graph.js +187 -0
- package/dist/model/module-graph.js.map +1 -0
- package/dist/model/oauth-flow-detector.d.ts +41 -0
- package/dist/model/oauth-flow-detector.d.ts.map +1 -0
- package/dist/model/oauth-flow-detector.js +202 -0
- package/dist/model/oauth-flow-detector.js.map +1 -0
- package/dist/model/project-context.d.ts +119 -0
- package/dist/model/project-context.d.ts.map +1 -0
- package/dist/model/project-context.js +534 -0
- package/dist/model/project-context.js.map +1 -0
- package/dist/model/route-auth-resolver.d.ts +27 -0
- package/dist/model/route-auth-resolver.d.ts.map +1 -0
- package/dist/model/route-auth-resolver.js +182 -0
- package/dist/model/route-auth-resolver.js.map +1 -0
- package/dist/model/route-discovery/express.d.ts +25 -0
- package/dist/model/route-discovery/express.d.ts.map +1 -0
- package/dist/model/route-discovery/express.js +225 -0
- package/dist/model/route-discovery/express.js.map +1 -0
- package/dist/model/route-discovery/index.d.ts +21 -0
- package/dist/model/route-discovery/index.d.ts.map +1 -0
- package/dist/model/route-discovery/index.js +67 -0
- package/dist/model/route-discovery/index.js.map +1 -0
- package/dist/model/route-discovery/nextjs.d.ts +16 -0
- package/dist/model/route-discovery/nextjs.d.ts.map +1 -0
- package/dist/model/route-discovery/nextjs.js +179 -0
- package/dist/model/route-discovery/nextjs.js.map +1 -0
- package/dist/model/route-discovery/python.d.ts +16 -0
- package/dist/model/route-discovery/python.d.ts.map +1 -0
- package/dist/model/route-discovery/python.js +181 -0
- package/dist/model/route-discovery/python.js.map +1 -0
- package/dist/model/route-discovery/types.d.ts +36 -0
- package/dist/model/route-discovery/types.d.ts.map +1 -0
- package/dist/model/route-discovery/types.js +16 -0
- package/dist/model/route-discovery/types.js.map +1 -0
- package/dist/model/route-discovery/utils.d.ts +18 -0
- package/dist/model/route-discovery/utils.d.ts.map +1 -0
- package/dist/model/route-discovery/utils.js +55 -0
- package/dist/model/route-discovery/utils.js.map +1 -0
- package/dist/model/route-hierarchy.d.ts +50 -0
- package/dist/model/route-hierarchy.d.ts.map +1 -0
- package/dist/model/route-hierarchy.js +226 -0
- package/dist/model/route-hierarchy.js.map +1 -0
- package/dist/model/sanitiser-detection.d.ts +27 -0
- package/dist/model/sanitiser-detection.d.ts.map +1 -0
- package/dist/model/sanitiser-detection.js +224 -0
- package/dist/model/sanitiser-detection.js.map +1 -0
- package/dist/model/sink-matcher.d.ts +17 -0
- package/dist/model/sink-matcher.d.ts.map +1 -0
- package/dist/model/sink-matcher.js +141 -0
- package/dist/model/sink-matcher.js.map +1 -0
- package/dist/model/sink-patterns.d.ts +19 -0
- package/dist/model/sink-patterns.d.ts.map +1 -0
- package/dist/model/sink-patterns.js +88 -0
- package/dist/model/sink-patterns.js.map +1 -0
- package/dist/model/source-discovery.d.ts +15 -0
- package/dist/model/source-discovery.d.ts.map +1 -0
- package/dist/model/source-discovery.js +170 -0
- package/dist/model/source-discovery.js.map +1 -0
- package/dist/model/taint-tracker.d.ts +21 -0
- package/dist/model/taint-tracker.d.ts.map +1 -0
- package/dist/model/taint-tracker.js +281 -0
- package/dist/model/taint-tracker.js.map +1 -0
- package/dist/model/taint-types.d.ts +74 -0
- package/dist/model/taint-types.d.ts.map +1 -0
- package/dist/model/taint-types.js +9 -0
- package/dist/model/taint-types.js.map +1 -0
- package/dist/model/trpc-analyzer.d.ts +78 -0
- package/dist/model/trpc-analyzer.d.ts.map +1 -0
- package/dist/model/trpc-analyzer.js +297 -0
- package/dist/model/trpc-analyzer.js.map +1 -0
- package/dist/modes/incremental.js +1 -1
- package/dist/parse/file-classifier.d.ts +228 -0
- package/dist/parse/file-classifier.d.ts.map +1 -0
- package/dist/parse/file-classifier.js +933 -0
- package/dist/parse/file-classifier.js.map +1 -0
- package/dist/parse/path-exclusions.d.ts +55 -0
- package/dist/parse/path-exclusions.d.ts.map +1 -0
- package/dist/parse/path-exclusions.js +224 -0
- package/dist/parse/path-exclusions.js.map +1 -0
- package/dist/pipeline/config.d.ts +39 -0
- package/dist/pipeline/config.d.ts.map +1 -0
- package/dist/pipeline/config.js +46 -0
- package/dist/pipeline/config.js.map +1 -0
- package/dist/pipeline/index.d.ts +34 -0
- package/dist/pipeline/index.d.ts.map +1 -0
- package/dist/pipeline/index.js +377 -0
- package/dist/pipeline/index.js.map +1 -0
- package/dist/pipeline/modes/incremental.d.ts +66 -0
- package/dist/pipeline/modes/incremental.d.ts.map +1 -0
- package/dist/pipeline/modes/incremental.js +200 -0
- package/dist/pipeline/modes/incremental.js.map +1 -0
- package/dist/postprocess/aggregation.d.ts +14 -0
- package/dist/postprocess/aggregation.d.ts.map +1 -0
- package/dist/postprocess/aggregation.js +63 -0
- package/dist/postprocess/aggregation.js.map +1 -0
- package/dist/postprocess/contradictions.d.ts +18 -0
- package/dist/postprocess/contradictions.d.ts.map +1 -0
- package/dist/postprocess/contradictions.js +99 -0
- package/dist/postprocess/contradictions.js.map +1 -0
- package/dist/postprocess/dedup.d.ts +13 -0
- package/dist/postprocess/dedup.d.ts.map +1 -0
- package/dist/postprocess/dedup.js +58 -0
- package/dist/postprocess/dedup.js.map +1 -0
- package/dist/postprocess/filtering/context-adjustments.d.ts +23 -0
- package/dist/postprocess/filtering/context-adjustments.d.ts.map +1 -0
- package/dist/postprocess/filtering/context-adjustments.js +100 -0
- package/dist/postprocess/filtering/context-adjustments.js.map +1 -0
- package/dist/postprocess/filtering/index.d.ts +3 -0
- package/dist/postprocess/filtering/index.d.ts.map +1 -0
- package/dist/postprocess/filtering/index.js +8 -0
- package/dist/postprocess/filtering/index.js.map +1 -0
- package/dist/postprocess/filtering/pipeline.d.ts +48 -0
- package/dist/postprocess/filtering/pipeline.d.ts.map +1 -0
- package/dist/postprocess/filtering/pipeline.js +76 -0
- package/dist/postprocess/filtering/pipeline.js.map +1 -0
- package/dist/postprocess/index.d.ts +41 -0
- package/dist/postprocess/index.d.ts.map +1 -0
- package/dist/postprocess/index.js +85 -0
- package/dist/postprocess/index.js.map +1 -0
- package/dist/postprocess/suppression/config-loader.d.ts +74 -0
- package/dist/postprocess/suppression/config-loader.d.ts.map +1 -0
- package/dist/postprocess/suppression/config-loader.js +424 -0
- package/dist/postprocess/suppression/config-loader.js.map +1 -0
- package/dist/postprocess/suppression/hash.d.ts +48 -0
- package/dist/postprocess/suppression/hash.d.ts.map +1 -0
- package/dist/postprocess/suppression/hash.js +88 -0
- package/dist/postprocess/suppression/hash.js.map +1 -0
- package/dist/postprocess/suppression/index.d.ts +11 -0
- package/dist/postprocess/suppression/index.d.ts.map +1 -0
- package/dist/postprocess/suppression/index.js +39 -0
- package/dist/postprocess/suppression/index.js.map +1 -0
- package/dist/postprocess/suppression/inline-parser.d.ts +39 -0
- package/dist/postprocess/suppression/inline-parser.d.ts.map +1 -0
- package/dist/postprocess/suppression/inline-parser.js +218 -0
- package/dist/postprocess/suppression/inline-parser.js.map +1 -0
- package/dist/postprocess/suppression/manager.d.ts +94 -0
- package/dist/postprocess/suppression/manager.d.ts.map +1 -0
- package/dist/postprocess/suppression/manager.js +292 -0
- package/dist/postprocess/suppression/manager.js.map +1 -0
- package/dist/postprocess/suppression/types.d.ts +151 -0
- package/dist/postprocess/suppression/types.d.ts.map +1 -0
- package/dist/postprocess/suppression/types.js +28 -0
- package/dist/postprocess/suppression/types.js.map +1 -0
- package/dist/postprocess/validation-cap.d.ts +17 -0
- package/dist/postprocess/validation-cap.d.ts.map +1 -0
- package/dist/postprocess/validation-cap.js +64 -0
- package/dist/postprocess/validation-cap.js.map +1 -0
- package/dist/report/build-result.d.ts +33 -0
- package/dist/report/build-result.d.ts.map +1 -0
- package/dist/report/build-result.js +59 -0
- package/dist/report/build-result.js.map +1 -0
- package/dist/report/enrichment.d.ts +19 -0
- package/dist/report/enrichment.d.ts.map +1 -0
- package/dist/report/enrichment.js +44 -0
- package/dist/report/enrichment.js.map +1 -0
- package/dist/report/formatters/ai-context.d.ts +23 -0
- package/dist/report/formatters/ai-context.d.ts.map +1 -0
- package/dist/report/formatters/ai-context.js +238 -0
- package/dist/report/formatters/ai-context.js.map +1 -0
- package/dist/report/formatters/cli-terminal.d.ts +65 -0
- package/dist/report/formatters/cli-terminal.d.ts.map +1 -0
- package/dist/report/formatters/cli-terminal.js +735 -0
- package/dist/report/formatters/cli-terminal.js.map +1 -0
- package/dist/report/formatters/github-comment.d.ts +41 -0
- package/dist/report/formatters/github-comment.d.ts.map +1 -0
- package/dist/report/formatters/github-comment.js +370 -0
- package/dist/report/formatters/github-comment.js.map +1 -0
- package/dist/report/formatters/grouping.d.ts +52 -0
- package/dist/report/formatters/grouping.d.ts.map +1 -0
- package/dist/report/formatters/grouping.js +152 -0
- package/dist/report/formatters/grouping.js.map +1 -0
- package/dist/report/formatters/ide/claude-code.d.ts +17 -0
- package/dist/report/formatters/ide/claude-code.d.ts.map +1 -0
- package/dist/report/formatters/ide/claude-code.js +94 -0
- package/dist/report/formatters/ide/claude-code.js.map +1 -0
- package/dist/report/formatters/ide/cursor.d.ts +13 -0
- package/dist/report/formatters/ide/cursor.d.ts.map +1 -0
- package/dist/report/formatters/ide/cursor.js +125 -0
- package/dist/report/formatters/ide/cursor.js.map +1 -0
- package/dist/report/formatters/ide/index.d.ts +62 -0
- package/dist/report/formatters/ide/index.d.ts.map +1 -0
- package/dist/report/formatters/ide/index.js +184 -0
- package/dist/report/formatters/ide/index.js.map +1 -0
- package/dist/report/formatters/ide/windsurf.d.ts +13 -0
- package/dist/report/formatters/ide/windsurf.d.ts.map +1 -0
- package/dist/report/formatters/ide/windsurf.js +117 -0
- package/dist/report/formatters/ide/windsurf.js.map +1 -0
- package/dist/report/formatters/index.d.ts +11 -0
- package/dist/report/formatters/index.d.ts.map +1 -0
- package/dist/report/formatters/index.js +54 -0
- package/dist/report/formatters/index.js.map +1 -0
- package/dist/report/formatters/vscode-diagnostic.d.ts +103 -0
- package/dist/report/formatters/vscode-diagnostic.d.ts.map +1 -0
- package/dist/report/formatters/vscode-diagnostic.js +151 -0
- package/dist/report/formatters/vscode-diagnostic.js.map +1 -0
- package/dist/report/summary.d.ts +27 -0
- package/dist/report/summary.d.ts.map +1 -0
- package/dist/report/summary.js +57 -0
- package/dist/report/summary.js.map +1 -0
- package/dist/rules/metadata.d.ts.map +1 -1
- package/dist/rules/metadata.js +66 -0
- package/dist/rules/metadata.js.map +1 -1
- package/dist/score/adjustments.d.ts +22 -0
- package/dist/score/adjustments.d.ts.map +1 -0
- package/dist/score/adjustments.js +373 -0
- package/dist/score/adjustments.js.map +1 -0
- package/dist/score/auto-dismiss.d.ts +28 -0
- package/dist/score/auto-dismiss.d.ts.map +1 -0
- package/dist/score/auto-dismiss.js +200 -0
- package/dist/score/auto-dismiss.js.map +1 -0
- package/dist/score/confidence.d.ts +19 -0
- package/dist/score/confidence.d.ts.map +1 -0
- package/dist/score/confidence.js +52 -0
- package/dist/score/confidence.js.map +1 -0
- package/dist/score/index.d.ts +61 -0
- package/dist/score/index.d.ts.map +1 -0
- package/dist/score/index.js +250 -0
- package/dist/score/index.js.map +1 -0
- package/dist/score/types.d.ts +160 -0
- package/dist/score/types.d.ts.map +1 -0
- package/dist/score/types.js +14 -0
- package/dist/score/types.js.map +1 -0
- package/dist/shared/ai-context/index.d.ts +6 -0
- package/dist/shared/ai-context/index.d.ts.map +1 -0
- package/dist/shared/ai-context/index.js +13 -0
- package/dist/shared/ai-context/index.js.map +1 -0
- package/dist/shared/ai-context/manager.d.ts +67 -0
- package/dist/shared/ai-context/manager.d.ts.map +1 -0
- package/dist/shared/ai-context/manager.js +104 -0
- package/dist/shared/ai-context/manager.js.map +1 -0
- package/dist/shared/baseline/diff.d.ts +32 -0
- package/dist/shared/baseline/diff.d.ts.map +1 -0
- package/dist/shared/baseline/diff.js +119 -0
- package/dist/shared/baseline/diff.js.map +1 -0
- package/dist/shared/baseline/index.d.ts +9 -0
- package/dist/shared/baseline/index.d.ts.map +1 -0
- package/dist/shared/baseline/index.js +19 -0
- package/dist/shared/baseline/index.js.map +1 -0
- package/dist/shared/baseline/manager.d.ts +67 -0
- package/dist/shared/baseline/manager.d.ts.map +1 -0
- package/dist/shared/baseline/manager.js +180 -0
- package/dist/shared/baseline/manager.js.map +1 -0
- package/dist/shared/baseline/types.d.ts +91 -0
- package/dist/shared/baseline/types.d.ts.map +1 -0
- package/dist/shared/baseline/types.js +12 -0
- package/dist/shared/baseline/types.js.map +1 -0
- package/dist/shared/category-filter.d.ts +125 -0
- package/dist/shared/category-filter.d.ts.map +1 -0
- package/dist/shared/category-filter.js +360 -0
- package/dist/shared/category-filter.js.map +1 -0
- package/dist/shared/code-analysis.d.ts +39 -0
- package/dist/shared/code-analysis.d.ts.map +1 -0
- package/dist/shared/code-analysis.js +159 -0
- package/dist/shared/code-analysis.js.map +1 -0
- package/dist/shared/comment-analyzer.d.ts +38 -0
- package/dist/shared/comment-analyzer.d.ts.map +1 -0
- package/dist/shared/comment-analyzer.js +218 -0
- package/dist/shared/comment-analyzer.js.map +1 -0
- package/dist/shared/diff-detector.d.ts +53 -0
- package/dist/shared/diff-detector.d.ts.map +1 -0
- package/dist/shared/diff-detector.js +104 -0
- package/dist/shared/diff-detector.js.map +1 -0
- package/dist/shared/diff-parser.d.ts +80 -0
- package/dist/shared/diff-parser.d.ts.map +1 -0
- package/dist/shared/diff-parser.js +202 -0
- package/dist/shared/diff-parser.js.map +1 -0
- package/dist/shared/environment-context.d.ts +76 -0
- package/dist/shared/environment-context.d.ts.map +1 -0
- package/dist/shared/environment-context.js +271 -0
- package/dist/shared/environment-context.js.map +1 -0
- package/dist/shared/intent-detector.d.ts +66 -0
- package/dist/shared/intent-detector.d.ts.map +1 -0
- package/dist/shared/intent-detector.js +282 -0
- package/dist/shared/intent-detector.js.map +1 -0
- package/dist/shared/parsed-file.d.ts +51 -0
- package/dist/shared/parsed-file.d.ts.map +1 -0
- package/dist/shared/parsed-file.js +95 -0
- package/dist/shared/parsed-file.js.map +1 -0
- package/dist/shared/registry-clients.d.ts +93 -0
- package/dist/shared/registry-clients.d.ts.map +1 -0
- package/dist/shared/registry-clients.js +273 -0
- package/dist/shared/registry-clients.js.map +1 -0
- package/dist/shared/rules/framework-fixes.d.ts +48 -0
- package/dist/shared/rules/framework-fixes.d.ts.map +1 -0
- package/dist/shared/rules/framework-fixes.js +439 -0
- package/dist/shared/rules/framework-fixes.js.map +1 -0
- package/dist/shared/rules/index.d.ts +8 -0
- package/dist/shared/rules/index.d.ts.map +1 -0
- package/dist/shared/rules/index.js +18 -0
- package/dist/shared/rules/index.js.map +1 -0
- package/dist/shared/rules/metadata.d.ts +43 -0
- package/dist/shared/rules/metadata.d.ts.map +1 -0
- package/dist/shared/rules/metadata.js +819 -0
- package/dist/shared/rules/metadata.js.map +1 -0
- package/dist/shared/schema-semantics.d.ts +45 -0
- package/dist/shared/schema-semantics.d.ts.map +1 -0
- package/dist/shared/schema-semantics.js +193 -0
- package/dist/shared/schema-semantics.js.map +1 -0
- package/dist/shared/types.d.ts +337 -0
- package/dist/shared/types.d.ts.map +1 -0
- package/dist/shared/types.js +126 -0
- package/dist/shared/types.js.map +1 -0
- package/dist/tiers.d.ts +4 -4
- package/dist/tiers.d.ts.map +1 -1
- package/dist/tiers.js +17 -7
- package/dist/tiers.js.map +1 -1
- package/dist/types.d.ts +79 -9
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +34 -0
- package/dist/types.js.map +1 -1
- package/dist/utils/code-analysis.d.ts +39 -0
- package/dist/utils/code-analysis.d.ts.map +1 -0
- package/dist/utils/code-analysis.js +159 -0
- package/dist/utils/code-analysis.js.map +1 -0
- package/dist/utils/comment-analyzer.d.ts +38 -0
- package/dist/utils/comment-analyzer.d.ts.map +1 -0
- package/dist/utils/comment-analyzer.js +218 -0
- package/dist/utils/comment-analyzer.js.map +1 -0
- package/dist/utils/context-helpers.d.ts +108 -1
- package/dist/utils/context-helpers.d.ts.map +1 -1
- package/dist/utils/context-helpers.js +351 -2
- package/dist/utils/context-helpers.js.map +1 -1
- package/dist/utils/environment-context.d.ts +76 -0
- package/dist/utils/environment-context.d.ts.map +1 -0
- package/dist/utils/environment-context.js +271 -0
- package/dist/utils/environment-context.js.map +1 -0
- package/dist/utils/intent-detector.d.ts +66 -0
- package/dist/utils/intent-detector.d.ts.map +1 -0
- package/dist/utils/intent-detector.js +282 -0
- package/dist/utils/intent-detector.js.map +1 -0
- package/dist/utils/parsed-file.d.ts +51 -0
- package/dist/utils/parsed-file.d.ts.map +1 -0
- package/dist/utils/parsed-file.js +95 -0
- package/dist/utils/parsed-file.js.map +1 -0
- package/dist/utils/route-hierarchy.d.ts +50 -0
- package/dist/utils/route-hierarchy.d.ts.map +1 -0
- package/dist/utils/route-hierarchy.js +226 -0
- package/dist/utils/route-hierarchy.js.map +1 -0
- package/dist/utils/schema-semantics.d.ts +45 -0
- package/dist/utils/schema-semantics.d.ts.map +1 -0
- package/dist/utils/schema-semantics.js +193 -0
- package/dist/utils/schema-semantics.js.map +1 -0
- package/dist/validate/clients.d.ts +44 -0
- package/dist/validate/clients.d.ts.map +1 -0
- package/dist/validate/clients.js +81 -0
- package/dist/validate/clients.js.map +1 -0
- package/dist/validate/index.d.ts +41 -0
- package/dist/validate/index.d.ts.map +1 -0
- package/dist/validate/index.js +141 -0
- package/dist/validate/index.js.map +1 -0
- package/dist/validate/prompts/index.d.ts +8 -0
- package/dist/validate/prompts/index.d.ts.map +1 -0
- package/dist/validate/prompts/index.js +16 -0
- package/dist/validate/prompts/index.js.map +1 -0
- package/dist/validate/prompts/modules/ai-patterns.d.ts +19 -0
- package/dist/validate/prompts/modules/ai-patterns.d.ts.map +1 -0
- package/dist/validate/prompts/modules/ai-patterns.js +156 -0
- package/dist/validate/prompts/modules/ai-patterns.js.map +1 -0
- package/dist/validate/prompts/modules/auth-access.d.ts +9 -0
- package/dist/validate/prompts/modules/auth-access.d.ts.map +1 -0
- package/dist/validate/prompts/modules/auth-access.js +25 -0
- package/dist/validate/prompts/modules/auth-access.js.map +1 -0
- package/dist/validate/prompts/modules/common.d.ts +11 -0
- package/dist/validate/prompts/modules/common.d.ts.map +1 -0
- package/dist/validate/prompts/modules/common.js +186 -0
- package/dist/validate/prompts/modules/common.js.map +1 -0
- package/dist/validate/prompts/modules/index.d.ts +54 -0
- package/dist/validate/prompts/modules/index.d.ts.map +1 -0
- package/dist/validate/prompts/modules/index.js +186 -0
- package/dist/validate/prompts/modules/index.js.map +1 -0
- package/dist/validate/prompts/modules/owasp-classic.d.ts +8 -0
- package/dist/validate/prompts/modules/owasp-classic.d.ts.map +1 -0
- package/dist/validate/prompts/modules/owasp-classic.js +84 -0
- package/dist/validate/prompts/modules/owasp-classic.js.map +1 -0
- package/dist/validate/prompts/modules/secrets-crypto.d.ts +8 -0
- package/dist/validate/prompts/modules/secrets-crypto.d.ts.map +1 -0
- package/dist/validate/prompts/modules/secrets-crypto.js +68 -0
- package/dist/validate/prompts/modules/secrets-crypto.js.map +1 -0
- package/dist/validate/prompts/modules/xss-prompt.d.ts +8 -0
- package/dist/validate/prompts/modules/xss-prompt.d.ts.map +1 -0
- package/dist/validate/prompts/modules/xss-prompt.js +22 -0
- package/dist/validate/prompts/modules/xss-prompt.js.map +1 -0
- package/dist/validate/prompts/semantic-analysis.d.ts +15 -0
- package/dist/validate/prompts/semantic-analysis.d.ts.map +1 -0
- package/dist/validate/prompts/semantic-analysis.js +169 -0
- package/dist/validate/prompts/semantic-analysis.js.map +1 -0
- package/dist/validate/prompts/validation.d.ts +18 -0
- package/dist/validate/prompts/validation.d.ts.map +1 -0
- package/dist/validate/prompts/validation.js +25 -0
- package/dist/validate/prompts/validation.js.map +1 -0
- package/dist/validate/providers/anthropic.d.ts +17 -0
- package/dist/validate/providers/anthropic.d.ts.map +1 -0
- package/dist/validate/providers/anthropic.js +260 -0
- package/dist/validate/providers/anthropic.js.map +1 -0
- package/dist/validate/providers/index.d.ts +8 -0
- package/dist/validate/providers/index.d.ts.map +1 -0
- package/dist/validate/providers/index.js +13 -0
- package/dist/validate/providers/index.js.map +1 -0
- package/dist/validate/providers/openai.d.ts +14 -0
- package/dist/validate/providers/openai.d.ts.map +1 -0
- package/dist/validate/providers/openai.js +336 -0
- package/dist/validate/providers/openai.js.map +1 -0
- package/dist/validate/request-builder.d.ts +61 -0
- package/dist/validate/request-builder.d.ts.map +1 -0
- package/dist/validate/request-builder.js +346 -0
- package/dist/validate/request-builder.js.map +1 -0
- package/dist/validate/types.d.ts +88 -0
- package/dist/validate/types.d.ts.map +1 -0
- package/dist/validate/types.js +38 -0
- package/dist/validate/types.js.map +1 -0
- package/dist/validate/utils/context-extractor.d.ts +55 -0
- package/dist/validate/utils/context-extractor.d.ts.map +1 -0
- package/dist/validate/utils/context-extractor.js +161 -0
- package/dist/validate/utils/context-extractor.js.map +1 -0
- package/dist/validate/utils/index.d.ts +11 -0
- package/dist/validate/utils/index.d.ts.map +1 -0
- package/dist/validate/utils/index.js +27 -0
- package/dist/validate/utils/index.js.map +1 -0
- package/dist/validate/utils/path-helpers.d.ts +21 -0
- package/dist/validate/utils/path-helpers.d.ts.map +1 -0
- package/dist/validate/utils/path-helpers.js +69 -0
- package/dist/validate/utils/path-helpers.js.map +1 -0
- package/dist/validate/utils/response-parser.d.ts +40 -0
- package/dist/validate/utils/response-parser.d.ts.map +1 -0
- package/dist/validate/utils/response-parser.js +286 -0
- package/dist/validate/utils/response-parser.js.map +1 -0
- package/dist/validate/utils/retry.d.ts +15 -0
- package/dist/validate/utils/retry.d.ts.map +1 -0
- package/dist/validate/utils/retry.js +62 -0
- package/dist/validate/utils/retry.js.map +1 -0
- package/package.json +8 -7
- package/src/__tests__/benchmark/fixtures/layer1/agent-skill-injection.ts +204 -0
- package/src/__tests__/benchmark/fixtures/layer1/index.ts +3 -0
- package/src/__tests__/benchmark/fixtures/layer2/index.ts +27 -0
- package/src/__tests__/benchmark/fixtures/layer2/log-injection.ts +147 -0
- package/src/__tests__/benchmark/fixtures/layer2/phase5-excessive-agency.ts +580 -0
- package/src/__tests__/benchmark/fixtures/layer2/security-headers.ts +197 -0
- package/src/__tests__/benchmark/fixtures/layer2/sprint6-ai-enhancements.ts +515 -0
- package/src/__tests__/benchmark/fixtures/layer2/ssrf-detection.ts +210 -0
- package/src/__tests__/benchmark/fixtures/layer2/xxe-detection.ts +195 -0
- package/src/__tests__/benchmark/run-depth-validation.ts +12 -12
- package/src/__tests__/benchmark/run-real-world-test.ts +4 -4
- package/src/__tests__/benchmark/types.ts +1 -1
- package/src/__tests__/benchmark/utils/test-runner.ts +3 -3
- package/src/__tests__/category-filter.test.ts +478 -0
- package/src/__tests__/context-engine/cross-file-taint.test.ts +284 -0
- package/src/__tests__/context-engine/framework-models.test.ts +457 -0
- package/src/__tests__/context-engine/function-classifier.test.ts +146 -0
- package/src/__tests__/context-engine/import-resolver.test.ts +328 -0
- package/src/__tests__/context-engine/integration.test.ts +320 -0
- package/src/__tests__/context-engine/module-graph.test.ts +159 -0
- package/src/__tests__/context-engine/route-discovery/auth-resolver.test.ts +353 -0
- package/src/__tests__/context-engine/route-discovery/express.test.ts +150 -0
- package/src/__tests__/context-engine/route-discovery/nextjs.test.ts +138 -0
- package/src/__tests__/context-engine/route-discovery/python.test.ts +95 -0
- package/src/__tests__/context-engine/sanitiser-detection.test.ts +187 -0
- package/src/__tests__/context-engine/sink-matcher.test.ts +251 -0
- package/src/__tests__/context-engine/source-discovery.test.ts +186 -0
- package/src/__tests__/context-engine/taint-tracker.test.ts +182 -0
- package/src/__tests__/regression/agent-skill-benign.test.ts +174 -0
- package/src/__tests__/regression/known-false-positives.test.ts +801 -3
- package/src/__tests__/score/adjustments.test.ts +385 -0
- package/src/__tests__/score/confidence.test.ts +283 -0
- package/src/__tests__/score/framework-scoring.test.ts +275 -0
- package/src/__tests__/score/route-scoring.test.ts +156 -0
- package/src/__tests__/score/scoring-integration.test.ts +165 -0
- package/src/__tests__/score/taint-adjustments.test.ts +244 -0
- package/src/__tests__/snapshots/__snapshots__/anthropic-validation-refactor.test.ts.snap +50 -58
- package/src/__tests__/snapshots/__snapshots__/dangerous-functions-refactor.test.ts.snap +52 -0
- package/src/__tests__/snapshots/__snapshots__/scan-depth.test.ts.snap +3 -12
- package/src/__tests__/snapshots/anthropic-validation-refactor.test.ts +3 -3
- package/src/__tests__/snapshots/dangerous-functions-refactor.test.ts +1 -1
- package/src/__tests__/snapshots/scan-depth.test.ts +3 -3
- package/src/__tests__/validate/route-annotations.test.ts +138 -0
- package/src/__tests__/validation/analyze-results.ts +1 -1
- package/src/__tests__/validation/extract-for-triage.ts +1 -1
- package/src/__tests__/validation/fp-deep-analysis.ts +1 -1
- package/src/__tests__/validation/run-validation.ts +7 -7
- package/src/{layer2/ai-agent-tools.ts → detect/ai-code/agent-tools.ts} +729 -4
- package/src/{layer2 → detect/ai-code}/byok-patterns.ts +20 -6
- package/src/{layer2/ai-endpoint-protection.ts → detect/ai-code/endpoint-protection.ts} +10 -4
- package/src/{layer2/ai-execution-sinks.ts → detect/ai-code/execution-sinks.ts} +272 -46
- package/src/{layer2/ai-fingerprinting.ts → detect/ai-code/fingerprinting.ts} +46 -34
- package/src/detect/ai-code/index.ts +11 -0
- package/src/{layer2/ai-mcp-security.ts → detect/ai-code/mcp-security.ts} +212 -5
- package/src/{layer2 → detect/ai-code}/model-supply-chain.ts +85 -6
- package/src/{layer2/ai-package-hallucination.ts → detect/ai-code/package-hallucination.ts} +170 -6
- package/src/{layer2/ai-prompt-hygiene.ts → detect/ai-code/prompt-hygiene.ts} +393 -28
- package/src/{layer2/ai-rag-safety.ts → detect/ai-code/rag-safety.ts} +91 -4
- package/src/{layer2/ai-schema-validation.ts → detect/ai-code/schema-validation.ts} +10 -4
- package/src/detect/config/agent-skill-injection.ts +551 -0
- package/src/{layer1 → detect/config}/comments.ts +8 -2
- package/src/{layer1 → detect/config}/file-flags.ts +23 -6
- package/src/detect/config/index.ts +6 -0
- package/src/{layer3 → detect/config}/osv-check.ts +3 -2
- package/src/{layer3 → detect/config}/package-check.ts +3 -2
- package/src/{layer1 → detect/config}/urls.ts +196 -15
- package/src/detect/index.ts +131 -0
- package/src/{layer1 → detect/secrets}/config-audit.ts +56 -12
- package/src/{layer1 → detect/secrets}/config-mcp-audit.ts +11 -4
- package/src/{layer1 → detect/secrets}/entropy.ts +256 -11
- package/src/{layer1 → detect/secrets}/index.ts +43 -46
- package/src/{layer1 → detect/secrets}/patterns.ts +51 -6
- package/src/{layer1 → detect/secrets}/weak-crypto.ts +174 -17
- package/src/{layer2/auth-antipatterns.ts → detect/structural/auth-patterns.ts} +249 -27
- package/src/{layer2 → detect/structural}/dangerous-functions/dom-xss.ts +94 -22
- package/src/{layer2 → detect/structural}/dangerous-functions/index.ts +672 -65
- package/src/{layer2 → detect/structural}/dangerous-functions/json-parse.ts +10 -2
- package/src/{layer2 → detect/structural}/dangerous-functions/math-random.ts +269 -17
- package/src/{layer2 → detect/structural}/dangerous-functions/patterns.ts +4 -2
- package/src/{layer2 → detect/structural}/dangerous-functions/request-validation.ts +10 -2
- package/src/detect/structural/dangerous-functions/utils/control-flow.ts +35 -0
- package/src/{layer2 → detect/structural}/dangerous-functions/utils/schema-validation.ts +16 -1
- package/src/{layer2 → detect/structural}/data-exposure.ts +23 -40
- package/src/{layer2 → detect/structural}/framework-checks.ts +13 -12
- package/src/{layer2 → detect/structural}/index.ts +144 -122
- package/src/detect/structural/log-injection.ts +254 -0
- package/src/{layer2 → detect/structural}/logic-gates.ts +69 -24
- package/src/{layer2 → detect/structural}/risky-imports.ts +10 -4
- package/src/detect/structural/security-headers.ts +231 -0
- package/src/detect/structural/ssrf-detection.ts +300 -0
- package/src/{layer2 → detect/structural}/variables.ts +10 -4
- package/src/detect/structural/xxe-detection.ts +295 -0
- package/src/index.ts +64 -1038
- package/src/{utils → model}/auth-helper-detector.ts +1 -1
- package/src/model/cross-file-taint.ts +374 -0
- package/src/model/framework-models/django.ts +82 -0
- package/src/model/framework-models/express.ts +54 -0
- package/src/model/framework-models/index.ts +116 -0
- package/src/model/framework-models/nextjs.ts +69 -0
- package/src/model/framework-models/prisma.ts +57 -0
- package/src/model/framework-models/react.ts +63 -0
- package/src/model/framework-models/sequelize.ts +63 -0
- package/src/model/framework-models/types.ts +46 -0
- package/src/model/function-classifier.ts +184 -0
- package/src/model/import-resolver.ts +453 -0
- package/src/{utils → model}/imported-auth-detector.ts +21 -85
- package/src/model/index.ts +353 -0
- package/src/{utils → model}/middleware-detector.ts +156 -17
- package/src/model/module-graph.ts +254 -0
- package/src/{utils → model}/oauth-flow-detector.ts +1 -1
- package/src/{utils/project-context-builder.ts → model/project-context.ts} +1 -1
- package/src/model/route-auth-resolver.ts +216 -0
- package/src/model/route-discovery/express.ts +251 -0
- package/src/model/route-discovery/index.ts +83 -0
- package/src/model/route-discovery/nextjs.ts +216 -0
- package/src/model/route-discovery/python.ts +214 -0
- package/src/model/route-discovery/types.ts +48 -0
- package/src/model/route-discovery/utils.ts +54 -0
- package/src/model/route-hierarchy.ts +250 -0
- package/src/model/sanitiser-detection.ts +268 -0
- package/src/model/sink-matcher.ts +178 -0
- package/src/model/sink-patterns.ts +109 -0
- package/src/model/source-discovery.ts +209 -0
- package/src/model/taint-tracker.ts +333 -0
- package/src/model/taint-types.ts +149 -0
- package/src/{utils → model}/trpc-analyzer.ts +1 -1
- package/src/{utils/context-helpers.ts → parse/file-classifier.ts} +462 -2
- package/src/{utils → parse}/path-exclusions.ts +1 -1
- package/src/pipeline/config.ts +81 -0
- package/src/pipeline/index.ts +437 -0
- package/src/{modes → pipeline/modes}/incremental.ts +6 -6
- package/src/postprocess/aggregation.ts +74 -0
- package/src/postprocess/contradictions.ts +128 -0
- package/src/postprocess/dedup.ts +62 -0
- package/src/postprocess/filtering/__tests__/pipeline.test.ts +134 -0
- package/src/postprocess/filtering/context-adjustments.ts +111 -0
- package/src/postprocess/filtering/index.ts +10 -0
- package/src/postprocess/filtering/pipeline.ts +130 -0
- package/src/postprocess/index.ts +118 -0
- package/src/{suppression → postprocess/suppression}/config-loader.ts +1 -1
- package/src/{suppression → postprocess/suppression}/hash.ts +1 -1
- package/src/{suppression → postprocess/suppression}/inline-parser.ts +1 -1
- package/src/{suppression → postprocess/suppression}/manager.ts +1 -1
- package/src/{suppression → postprocess/suppression}/types.ts +2 -2
- package/src/postprocess/validation-cap.ts +66 -0
- package/src/report/build-result.ts +94 -0
- package/src/report/enrichment.ts +52 -0
- package/src/report/formatters/__tests__/ai-context.test.ts +254 -0
- package/src/report/formatters/ai-context.ts +302 -0
- package/src/{formatters → report/formatters}/cli-terminal.ts +11 -11
- package/src/{formatters → report/formatters}/github-comment.ts +4 -4
- package/src/{formatters → report/formatters}/grouping.ts +8 -8
- package/src/report/formatters/ide/__tests__/ide.test.ts +319 -0
- package/src/report/formatters/ide/claude-code.ts +110 -0
- package/src/report/formatters/ide/cursor.ts +147 -0
- package/src/report/formatters/ide/index.ts +216 -0
- package/src/report/formatters/ide/windsurf.ts +135 -0
- package/src/{formatters → report/formatters}/index.ts +24 -0
- package/src/{formatters → report/formatters}/vscode-diagnostic.ts +1 -1
- package/src/report/summary.ts +70 -0
- package/src/score/adjustments.ts +387 -0
- package/src/{layer3/anthropic → score}/auto-dismiss.ts +26 -14
- package/src/score/confidence.ts +66 -0
- package/src/score/index.ts +316 -0
- package/src/score/types.ts +187 -0
- package/src/shared/__tests__/code-analysis.test.ts +165 -0
- package/src/shared/__tests__/parsed-file.test.ts +124 -0
- package/src/shared/ai-context/__tests__/manager.test.ts +193 -0
- package/src/shared/ai-context/index.ts +15 -0
- package/src/shared/ai-context/manager.ts +145 -0
- package/src/{baseline → shared/baseline}/__tests__/diff.test.ts +2 -2
- package/src/{baseline → shared/baseline}/__tests__/manager.test.ts +2 -2
- package/src/{baseline → shared/baseline}/diff.ts +1 -1
- package/src/{baseline → shared/baseline}/manager.ts +1 -1
- package/src/shared/category-filter.ts +400 -0
- package/src/{layer2/dangerous-functions/utils/control-flow.ts → shared/code-analysis.ts} +56 -39
- package/src/shared/comment-analyzer.ts +249 -0
- package/src/shared/environment-context.ts +304 -0
- package/src/shared/intent-detector.ts +318 -0
- package/src/shared/parsed-file.ts +103 -0
- package/src/{rules → shared/rules}/__tests__/metadata.test.ts +7 -0
- package/src/{rules → shared/rules}/framework-fixes.ts +1 -1
- package/src/{rules → shared/rules}/metadata.ts +94 -0
- package/src/shared/schema-semantics.ts +233 -0
- package/src/{types.ts → shared/types.ts} +142 -11
- package/src/tiers.ts +27 -10
- package/src/validate/__tests__/context-extractor.test.ts +191 -0
- package/src/validate/__tests__/prompt-assembly.test.ts +233 -0
- package/src/validate/__tests__/request-builder.test.ts +347 -0
- package/src/{layer3/anthropic → validate}/index.ts +8 -7
- package/src/{layer3/anthropic → validate}/prompts/index.ts +2 -0
- package/src/validate/prompts/modules/ai-patterns.ts +153 -0
- package/src/validate/prompts/modules/auth-access.ts +22 -0
- package/src/validate/prompts/modules/common.ts +183 -0
- package/src/validate/prompts/modules/index.ts +204 -0
- package/src/validate/prompts/modules/owasp-classic.ts +81 -0
- package/src/validate/prompts/modules/secrets-crypto.ts +65 -0
- package/src/validate/prompts/modules/xss-prompt.ts +19 -0
- package/src/validate/prompts/validation.ts +20 -0
- package/src/{layer3/anthropic → validate}/providers/anthropic.ts +28 -27
- package/src/validate/providers/index.ts +8 -0
- package/src/{layer3/anthropic → validate}/providers/openai.ts +30 -25
- package/src/validate/request-builder.ts +448 -0
- package/src/{layer3/anthropic → validate}/types.ts +1 -1
- package/src/validate/utils/context-extractor.ts +220 -0
- package/src/{layer3/anthropic → validate}/utils/index.ts +10 -0
- package/src/{layer3/anthropic → validate}/utils/response-parser.ts +2 -1
- package/src/layer3/anthropic/prompts/validation.ts +0 -419
- package/src/layer3/anthropic/providers/index.ts +0 -8
- package/src/layer3/anthropic/request-builder.ts +0 -150
- package/src/layer3/index.ts +0 -168
- /package/src/{layer3 → detect/config}/__tests__/osv-check.test.ts +0 -0
- /package/src/{layer2 → detect/structural}/__tests__/math-random-enhanced.test.ts +0 -0
- /package/src/{layer2 → detect/structural}/dangerous-functions/child-process.ts +0 -0
- /package/src/{layer2 → detect/structural}/dangerous-functions/utils/helpers.ts +0 -0
- /package/src/{layer2 → detect/structural}/dangerous-functions/utils/index.ts +0 -0
- /package/src/{suppression → postprocess/suppression}/__tests__/config-loader.test.ts +0 -0
- /package/src/{suppression → postprocess/suppression}/__tests__/hash.test.ts +0 -0
- /package/src/{suppression → postprocess/suppression}/__tests__/inline-parser.test.ts +0 -0
- /package/src/{suppression → postprocess/suppression}/__tests__/manager.test.ts +0 -0
- /package/src/{suppression → postprocess/suppression}/index.ts +0 -0
- /package/src/{baseline → shared/baseline}/index.ts +0 -0
- /package/src/{baseline → shared/baseline}/types.ts +0 -0
- /package/src/{utils → shared}/diff-detector.ts +0 -0
- /package/src/{utils → shared}/diff-parser.ts +0 -0
- /package/src/{utils → shared}/registry-clients.ts +0 -0
- /package/src/{rules → shared/rules}/__tests__/framework-fixes.test.ts +0 -0
- /package/src/{rules → shared/rules}/index.ts +0 -0
- /package/src/{layer3/anthropic → validate}/clients.ts +0 -0
- /package/src/{layer3/anthropic → validate}/prompts/semantic-analysis.ts +0 -0
- /package/src/{layer3/anthropic → validate}/utils/path-helpers.ts +0 -0
- /package/src/{layer3/anthropic → validate}/utils/retry.ts +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,12 +4,40 @@
|
|
|
4
4
|
* Context-aware detection of Math.random() usage with intelligent severity
|
|
5
5
|
* classification based on usage context, variable names, and function intent.
|
|
6
6
|
*/
|
|
7
|
+
import type { ParsedFile } from '../../utils/parsed-file';
|
|
8
|
+
/**
|
|
9
|
+
* Check if Math.random() is used in a jitter/backoff/retry context
|
|
10
|
+
* These are legitimate uses of Math.random() for network resilience,
|
|
11
|
+
* not security-sensitive randomness.
|
|
12
|
+
*
|
|
13
|
+
* Examples:
|
|
14
|
+
* const delay = baseDelay + Math.random() * jitter
|
|
15
|
+
* setTimeout(retry, delay * Math.random())
|
|
16
|
+
* await sleep(backoff * (1 + Math.random() * 0.1))
|
|
17
|
+
*
|
|
18
|
+
* @param content - Full file content
|
|
19
|
+
* @param lineNumber - The 0-indexed line number where Math.random() was found
|
|
20
|
+
*/
|
|
21
|
+
export declare function isJitterOrBackoffContext(content: string, lineNumber: number, lines?: string[]): boolean;
|
|
22
|
+
/**
|
|
23
|
+
* Check if Math.random() is used in a React key prop context
|
|
24
|
+
* This is a common pattern to force re-renders, not a security issue.
|
|
25
|
+
*
|
|
26
|
+
* Examples:
|
|
27
|
+
* key={Math.random()}
|
|
28
|
+
* key={`prefix-${Math.random()}`}
|
|
29
|
+
* key={Math.random().toString()}
|
|
30
|
+
*
|
|
31
|
+
* @param lineContent - The line of code to check
|
|
32
|
+
* @param filePath - The file path (only check JSX/TSX files)
|
|
33
|
+
*/
|
|
34
|
+
export declare function isReactKeyPattern(lineContent: string, filePath: string): boolean;
|
|
7
35
|
/**
|
|
8
36
|
* Check if Math.random() is used for cosmetic/UI purposes (not security)
|
|
9
37
|
* Cosmetic uses: CSS values, animations, UI variations, demo data
|
|
10
38
|
* Security uses: tokens, IDs, cryptographic operations, session management
|
|
11
39
|
*/
|
|
12
|
-
export declare function isCosmeticMathRandom(lineContent: string, content: string, lineNumber: number): boolean;
|
|
40
|
+
export declare function isCosmeticMathRandom(lineContent: string, content: string, lineNumber: number, lines?: string[]): boolean;
|
|
13
41
|
/**
|
|
14
42
|
* Classify function intent based on function name
|
|
15
43
|
* Used to determine if Math.random() usage is legitimate
|
|
@@ -46,16 +74,38 @@ export declare function classifyVariableNameRisk(varName: string | null): 'high'
|
|
|
46
74
|
* Analyze surrounding code context for security signals
|
|
47
75
|
* Returns context type and description for severity classification
|
|
48
76
|
*/
|
|
49
|
-
export declare function analyzeMathRandomContext(content: string, filePath: string, lineNumber: number): {
|
|
77
|
+
export declare function analyzeMathRandomContext(content: string, filePath: string, lineNumber: number, lines?: string[]): {
|
|
50
78
|
inSecurityContext: boolean;
|
|
51
79
|
inTestContext: boolean;
|
|
52
80
|
inUIContext: boolean;
|
|
53
81
|
inBusinessLogicContext: boolean;
|
|
54
82
|
contextDescription: string;
|
|
55
83
|
};
|
|
84
|
+
/**
|
|
85
|
+
* Check if file is an animation/motion component based on file name
|
|
86
|
+
* Files with animation-related names typically use Math.random for visual effects
|
|
87
|
+
*/
|
|
88
|
+
export declare function isAnimationFile(filePath: string): boolean;
|
|
89
|
+
/**
|
|
90
|
+
* Check if Math.random() is used for animation/motion coordinates
|
|
91
|
+
* Common in animation libraries like framer-motion, react-spring, Three.js, etc.
|
|
92
|
+
*/
|
|
93
|
+
export declare function isAnimationCoordinateUsage(lineContent: string, context: string): boolean;
|
|
94
|
+
/**
|
|
95
|
+
* Check if Math.random() is used in a template placeholder generator context
|
|
96
|
+
* Template systems often use random generators for placeholder values
|
|
97
|
+
*
|
|
98
|
+
* Examples:
|
|
99
|
+
* const templates = { random: () => Math.random().toString() }
|
|
100
|
+
* random_hex: () => Math.random().toString(16)
|
|
101
|
+
* {{random}} placeholder generation
|
|
102
|
+
*/
|
|
103
|
+
export declare function isTemplatePlaceholderGenerator(line: string, content: string, lineNumber: number, lines?: string[]): boolean;
|
|
56
104
|
/**
|
|
57
105
|
* Check if Math.random() should be skipped entirely
|
|
58
|
-
* Returns true for seed files, test fixtures, captcha/puzzle, uuid, and pure cosmetic uses
|
|
106
|
+
* Returns true for seed files, test fixtures, captcha/puzzle, uuid, React keys, jitter/backoff, and pure cosmetic uses
|
|
59
107
|
*/
|
|
60
|
-
export declare function shouldSkipMathRandom(content: string, filePath: string, lineNumber: number
|
|
108
|
+
export declare function shouldSkipMathRandom(content: string, filePath: string, lineNumber: number, options?: {
|
|
109
|
+
parsed?: ParsedFile;
|
|
110
|
+
}): boolean;
|
|
61
111
|
//# sourceMappingURL=math-random.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"math-random.d.ts","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/math-random.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"math-random.d.ts","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/math-random.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAOH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAGzD;;;;;;;;;;;;GAYG;AACH,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EAAE,GACf,OAAO,CA8BT;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAehF;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAClC,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EAAE,GACf,OAAO,CA8FT;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CACpC,YAAY,EAAE,MAAM,GAAG,IAAI,GAC1B,MAAM,GAAG,SAAS,GAAG,MAAM,GAAG,UAAU,GAAG,SAAS,CA+CtD;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,WAAW,EAAE,MAAM,GAAG;IAC3D,WAAW,EAAE,OAAO,CAAA;IACpB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;IACnB,WAAW,EAAE,OAAO,CAAA;IACpB,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAA;IAC/B,MAAM,EAAE,aAAa,GAAG,aAAa,GAAG,YAAY,GAAG,SAAS,CAAA;CACjE,CA0EA;AAED;;;;;;GAMG;AACH,wBAAgB,6BAA6B,CAC3C,WAAW,EAAE,MAAM,GAClB,MAAM,GAAG,IAAI,CAgBf;AAED;;;;;;GAMG;AACH,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,MAAM,GAAG,IAAI,GACrB,MAAM,GAAG,QAAQ,GAAG,KAAK,CAmG3B;AAED;;;GAGG;AACH,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EAAE,GACf;IACD,iBAAiB,EAAE,OAAO,CAAA;IAC1B,aAAa,EAAE,OAAO,CAAA;IACtB,WAAW,EAAE,OAAO,CAAA;IACpB,sBAAsB,EAAE,OAAO,CAAA;IAC/B,kBAAkB,EAAE,MAAM,CAAA;CAC3B,CAsEA;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAczD;AAED;;;GAGG;AACH,wBAAgB,0BAA0B,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAuDxF;AAED;;;;;;;;GAQG;AACH,wBAAgB,8BAA8B,CAC5C,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,EAClB,KAAK,CAAC,EAAE,MAAM,EAAE,GACf,OAAO,CAiBT;AAED;;;GAGG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,UAAU,CAAA;CAAE,GAChC,OAAO,CAqGT"}
|
|
@@ -6,22 +6,96 @@
|
|
|
6
6
|
* classification based on usage context, variable names, and function intent.
|
|
7
7
|
*/
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.isJitterOrBackoffContext = isJitterOrBackoffContext;
|
|
10
|
+
exports.isReactKeyPattern = isReactKeyPattern;
|
|
9
11
|
exports.isCosmeticMathRandom = isCosmeticMathRandom;
|
|
10
12
|
exports.classifyFunctionIntent = classifyFunctionIntent;
|
|
11
13
|
exports.analyzeToStringPattern = analyzeToStringPattern;
|
|
12
14
|
exports.extractMathRandomVariableName = extractMathRandomVariableName;
|
|
13
15
|
exports.classifyVariableNameRisk = classifyVariableNameRisk;
|
|
14
16
|
exports.analyzeMathRandomContext = analyzeMathRandomContext;
|
|
17
|
+
exports.isAnimationFile = isAnimationFile;
|
|
18
|
+
exports.isAnimationCoordinateUsage = isAnimationCoordinateUsage;
|
|
19
|
+
exports.isTemplatePlaceholderGenerator = isTemplatePlaceholderGenerator;
|
|
15
20
|
exports.shouldSkipMathRandom = shouldSkipMathRandom;
|
|
16
21
|
const context_helpers_1 = require("../../utils/context-helpers");
|
|
17
22
|
const control_flow_1 = require("./utils/control-flow");
|
|
23
|
+
/**
|
|
24
|
+
* Check if Math.random() is used in a jitter/backoff/retry context
|
|
25
|
+
* These are legitimate uses of Math.random() for network resilience,
|
|
26
|
+
* not security-sensitive randomness.
|
|
27
|
+
*
|
|
28
|
+
* Examples:
|
|
29
|
+
* const delay = baseDelay + Math.random() * jitter
|
|
30
|
+
* setTimeout(retry, delay * Math.random())
|
|
31
|
+
* await sleep(backoff * (1 + Math.random() * 0.1))
|
|
32
|
+
*
|
|
33
|
+
* @param content - Full file content
|
|
34
|
+
* @param lineNumber - The 0-indexed line number where Math.random() was found
|
|
35
|
+
*/
|
|
36
|
+
function isJitterOrBackoffContext(content, lineNumber, lines) {
|
|
37
|
+
const _lines = lines ?? content.split('\n');
|
|
38
|
+
const start = Math.max(0, lineNumber - 10);
|
|
39
|
+
const end = Math.min(_lines.length, lineNumber + 5);
|
|
40
|
+
const context = _lines.slice(start, end).join('\n');
|
|
41
|
+
// Patterns indicating jitter/backoff/retry context
|
|
42
|
+
const jitterPatterns = [
|
|
43
|
+
// Direct keyword matches
|
|
44
|
+
/\b(jitter|backoff|retry|retries|exponential)\b/i,
|
|
45
|
+
// Delay/timeout with random
|
|
46
|
+
/setTimeout.*Math\.random/i,
|
|
47
|
+
/setInterval.*Math\.random/i,
|
|
48
|
+
/sleep.*Math\.random/i,
|
|
49
|
+
/await.*delay.*Math\.random/i,
|
|
50
|
+
// Common backoff patterns
|
|
51
|
+
/\* Math\.random\(\).*delay/i,
|
|
52
|
+
/delay\s*\*\s*Math\.random/i,
|
|
53
|
+
/Math\.random\(\)\s*\*\s*\d+.*delay/i,
|
|
54
|
+
// Retry-related function names
|
|
55
|
+
/function\s+(retry|withRetry|backoff|withBackoff|exponentialBackoff)/i,
|
|
56
|
+
// Common retry library patterns
|
|
57
|
+
/retryPolicy|retryConfig|retryOptions|maxRetries|retryCount/i,
|
|
58
|
+
// Network resilience patterns
|
|
59
|
+
/\b(throttle|debounce|rateLimit)\b.*Math\.random/i,
|
|
60
|
+
// Sampling/probability for non-security uses
|
|
61
|
+
/sampleRate|samplingRate|probability\s*[<>]=?\s*Math\.random/i,
|
|
62
|
+
];
|
|
63
|
+
return jitterPatterns.some(p => p.test(context));
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Check if Math.random() is used in a React key prop context
|
|
67
|
+
* This is a common pattern to force re-renders, not a security issue.
|
|
68
|
+
*
|
|
69
|
+
* Examples:
|
|
70
|
+
* key={Math.random()}
|
|
71
|
+
* key={`prefix-${Math.random()}`}
|
|
72
|
+
* key={Math.random().toString()}
|
|
73
|
+
*
|
|
74
|
+
* @param lineContent - The line of code to check
|
|
75
|
+
* @param filePath - The file path (only check JSX/TSX files)
|
|
76
|
+
*/
|
|
77
|
+
function isReactKeyPattern(lineContent, filePath) {
|
|
78
|
+
// Only check in JSX/TSX files
|
|
79
|
+
if (!/\.[jt]sx$/.test(filePath)) {
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
// Pattern: key={...Math.random()...}
|
|
83
|
+
// Matches:
|
|
84
|
+
// key={Math.random()}
|
|
85
|
+
// key={`foo-${Math.random()}`}
|
|
86
|
+
// key={Math.random().toString()}
|
|
87
|
+
// key={`${Math.random()}-bar`}
|
|
88
|
+
// key={something + Math.random()}
|
|
89
|
+
const keyPattern = /key\s*=\s*\{[^}]*Math\.random\(\)/;
|
|
90
|
+
return keyPattern.test(lineContent);
|
|
91
|
+
}
|
|
18
92
|
/**
|
|
19
93
|
* Check if Math.random() is used for cosmetic/UI purposes (not security)
|
|
20
94
|
* Cosmetic uses: CSS values, animations, UI variations, demo data
|
|
21
95
|
* Security uses: tokens, IDs, cryptographic operations, session management
|
|
22
96
|
*/
|
|
23
|
-
function isCosmeticMathRandom(lineContent, content, lineNumber) {
|
|
24
|
-
const
|
|
97
|
+
function isCosmeticMathRandom(lineContent, content, lineNumber, lines) {
|
|
98
|
+
const _lines = lines ?? content.split('\n');
|
|
25
99
|
// Check the line itself for cosmetic indicators
|
|
26
100
|
const cosmeticLinePatterns = [
|
|
27
101
|
// CSS/style values
|
|
@@ -57,8 +131,8 @@ function isCosmeticMathRandom(lineContent, content, lineNumber) {
|
|
|
57
131
|
}
|
|
58
132
|
// Check surrounding context (5 lines before and after)
|
|
59
133
|
const contextStart = Math.max(0, lineNumber - 5);
|
|
60
|
-
const contextEnd = Math.min(
|
|
61
|
-
const context =
|
|
134
|
+
const contextEnd = Math.min(_lines.length, lineNumber + 5);
|
|
135
|
+
const context = _lines.slice(contextStart, contextEnd).join('\n');
|
|
62
136
|
// Context indicators of cosmetic use
|
|
63
137
|
const cosmeticContextPatterns = [
|
|
64
138
|
// UI component files - REMOVED, let severity classification handle these
|
|
@@ -348,11 +422,11 @@ function classifyVariableNameRisk(varName) {
|
|
|
348
422
|
* Analyze surrounding code context for security signals
|
|
349
423
|
* Returns context type and description for severity classification
|
|
350
424
|
*/
|
|
351
|
-
function analyzeMathRandomContext(content, filePath, lineNumber) {
|
|
352
|
-
const
|
|
425
|
+
function analyzeMathRandomContext(content, filePath, lineNumber, lines) {
|
|
426
|
+
const _lines = lines ?? content.split('\n');
|
|
353
427
|
const start = Math.max(0, lineNumber - 10);
|
|
354
|
-
const end = Math.min(
|
|
355
|
-
const context =
|
|
428
|
+
const end = Math.min(_lines.length, lineNumber + 5);
|
|
429
|
+
const context = _lines.slice(start, end).join('\n');
|
|
356
430
|
// Security context indicators (functions, imports, comments)
|
|
357
431
|
const securityPatterns = [
|
|
358
432
|
/\b(generate|create)(Token|Secret|Key|Password|Nonce|Salt|Session|Signature)/i,
|
|
@@ -373,8 +447,8 @@ function analyzeMathRandomContext(content, filePath, lineNumber) {
|
|
|
373
447
|
const inTestContext = testFilePatterns.test(filePath) ||
|
|
374
448
|
testContextPatterns.some(p => p.test(context));
|
|
375
449
|
// UI/cosmetic context (reuse existing logic)
|
|
376
|
-
const lineContent =
|
|
377
|
-
const inUIContext = isCosmeticMathRandom(lineContent, content, lineNumber);
|
|
450
|
+
const lineContent = _lines[lineNumber];
|
|
451
|
+
const inUIContext = isCosmeticMathRandom(lineContent, content, lineNumber, _lines);
|
|
378
452
|
// Business logic context (non-security ID generation)
|
|
379
453
|
// Note: UUID/CAPTCHA patterns excluded - handled by functionIntent classification
|
|
380
454
|
const businessLogicPatterns = [
|
|
@@ -382,6 +456,14 @@ function analyzeMathRandomContext(content, filePath, lineNumber) {
|
|
|
382
456
|
/\b(reference|tracking|confirmation)Number\b/i,
|
|
383
457
|
/\b(backoff|retry|jitter|delay|timeout|latency)\b/i,
|
|
384
458
|
/\b(sample|sampling|probability|chance|rollout|experiment|abtest|cohort|bucket|variant)\b/i,
|
|
459
|
+
// Load balancing and selection patterns
|
|
460
|
+
/mode\s*===?\s*['"]random['"]/i, // mode === 'random'
|
|
461
|
+
/\.\w*index\s*%/i, // round-robin patterns
|
|
462
|
+
/keys?\[.*Math\.random/i, // keys[Math.floor(Math.random() * keys.length)]
|
|
463
|
+
/\[\s*Math\.floor\s*\(\s*Math\.random/i, // array[Math.floor(Math.random()...)]
|
|
464
|
+
/shuffle/i, // shuffle functions
|
|
465
|
+
/pickRandom/i, // pickRandom helpers
|
|
466
|
+
/randomElement/i, // randomElement helpers
|
|
385
467
|
];
|
|
386
468
|
const inBusinessLogicContext = businessLogicPatterns.some(p => p.test(context)) && !inSecurityContext;
|
|
387
469
|
// Determine context description
|
|
@@ -406,23 +488,145 @@ function analyzeMathRandomContext(content, filePath, lineNumber) {
|
|
|
406
488
|
contextDescription,
|
|
407
489
|
};
|
|
408
490
|
}
|
|
491
|
+
/**
|
|
492
|
+
* Check if file is an animation/motion component based on file name
|
|
493
|
+
* Files with animation-related names typically use Math.random for visual effects
|
|
494
|
+
*/
|
|
495
|
+
function isAnimationFile(filePath) {
|
|
496
|
+
const animationPatterns = [
|
|
497
|
+
/animated[-_]/i, // animated-document-scanner.tsx
|
|
498
|
+
/[-_]animation/i, // document-animation.tsx
|
|
499
|
+
/motion[-_]/i, // motion-component.tsx
|
|
500
|
+
/[-_]motion/i, // scroll-motion.tsx
|
|
501
|
+
/particles?[-_]/i, // particles-background.tsx
|
|
502
|
+
/confetti/i, // confetti.tsx
|
|
503
|
+
/[-_]effect/i, // hover-effect.tsx
|
|
504
|
+
/transition[-_]/i, // transition-wrapper.tsx
|
|
505
|
+
/visual[-_]/i, // visual-effects.tsx
|
|
506
|
+
/canvas[-_]/i, // canvas-animation.tsx
|
|
507
|
+
];
|
|
508
|
+
return animationPatterns.some(p => p.test(filePath));
|
|
509
|
+
}
|
|
510
|
+
/**
|
|
511
|
+
* Check if Math.random() is used for animation/motion coordinates
|
|
512
|
+
* Common in animation libraries like framer-motion, react-spring, Three.js, etc.
|
|
513
|
+
*/
|
|
514
|
+
function isAnimationCoordinateUsage(lineContent, context) {
|
|
515
|
+
// Object property assignments for coordinates
|
|
516
|
+
const coordinatePatterns = [
|
|
517
|
+
/\bx:\s*Math\.random/i, // x: Math.random()
|
|
518
|
+
/\by:\s*Math\.random/i, // y: Math.random()
|
|
519
|
+
/\bz:\s*Math\.random/i, // z: Math.random()
|
|
520
|
+
/\bleft:\s*.*Math\.random/i, // left: Math.random()
|
|
521
|
+
/\btop:\s*.*Math\.random/i, // top: Math.random()
|
|
522
|
+
/\bright:\s*.*Math\.random/i, // right: Math.random()
|
|
523
|
+
/\bbottom:\s*.*Math\.random/i, // bottom: Math.random()
|
|
524
|
+
/\brotation:\s*.*Math\.random/i, // rotation: Math.random()
|
|
525
|
+
/\brotateX:\s*.*Math\.random/i, // rotateX: Math.random()
|
|
526
|
+
/\brotateY:\s*.*Math\.random/i, // rotateY: Math.random()
|
|
527
|
+
/\brotateZ:\s*.*Math\.random/i, // rotateZ: Math.random()
|
|
528
|
+
/\bscaleX?:\s*.*Math\.random/i, // scale/scaleX: Math.random()
|
|
529
|
+
/\bscaleY:\s*.*Math\.random/i, // scaleY: Math.random()
|
|
530
|
+
/\bopacity:\s*.*Math\.random/i, // opacity: Math.random()
|
|
531
|
+
/\bduration:\s*.*Math\.random/i, // duration: Math.random()
|
|
532
|
+
/\bdelay:\s*.*Math\.random/i, // delay: Math.random()
|
|
533
|
+
// 3D/Three.js specific patterns
|
|
534
|
+
/\boffset\s*=.*Math\.random/i, // offset = Math.random()
|
|
535
|
+
/useMemo\s*\(\s*\(\s*\)\s*=>\s*Math\.random/i, // useMemo(() => Math.random(), [])
|
|
536
|
+
/\bphase\s*[:=].*Math\.random/i, // phase: Math.random() or phase = Math.random()
|
|
537
|
+
/\bspeed\s*[:=].*Math\.random/i, // speed: Math.random()
|
|
538
|
+
/\bangle\s*[:=].*Math\.random/i, // angle: Math.random()
|
|
539
|
+
];
|
|
540
|
+
if (coordinatePatterns.some(p => p.test(lineContent))) {
|
|
541
|
+
return true;
|
|
542
|
+
}
|
|
543
|
+
// Motion/animation library context patterns
|
|
544
|
+
const motionLibraryPatterns = [
|
|
545
|
+
/framer-motion/i,
|
|
546
|
+
/react-spring/i,
|
|
547
|
+
/react-motion/i,
|
|
548
|
+
/gsap/i,
|
|
549
|
+
/animejs/i,
|
|
550
|
+
/popmotion/i,
|
|
551
|
+
/motion\.div/i,
|
|
552
|
+
/useSpring/i,
|
|
553
|
+
/useAnimation/i,
|
|
554
|
+
/animate\s*\(/i,
|
|
555
|
+
/keyframes/i,
|
|
556
|
+
// Three.js and React Three Fiber patterns
|
|
557
|
+
/three/i,
|
|
558
|
+
/useFrame/i,
|
|
559
|
+
/@react-three/i,
|
|
560
|
+
/Canvas/i, // React Three Fiber Canvas
|
|
561
|
+
/mesh/i, // Three.js mesh
|
|
562
|
+
/geometry/i, // Three.js geometry
|
|
563
|
+
/material/i, // Three.js material
|
|
564
|
+
];
|
|
565
|
+
return motionLibraryPatterns.some(p => p.test(context));
|
|
566
|
+
}
|
|
567
|
+
/**
|
|
568
|
+
* Check if Math.random() is used in a template placeholder generator context
|
|
569
|
+
* Template systems often use random generators for placeholder values
|
|
570
|
+
*
|
|
571
|
+
* Examples:
|
|
572
|
+
* const templates = { random: () => Math.random().toString() }
|
|
573
|
+
* random_hex: () => Math.random().toString(16)
|
|
574
|
+
* {{random}} placeholder generation
|
|
575
|
+
*/
|
|
576
|
+
function isTemplatePlaceholderGenerator(line, content, lineNumber, lines) {
|
|
577
|
+
const _lines = lines ?? content.split('\n');
|
|
578
|
+
const contextStart = Math.max(0, lineNumber - 10);
|
|
579
|
+
const contextEnd = Math.min(_lines.length, lineNumber + 5);
|
|
580
|
+
const context = _lines.slice(contextStart, contextEnd).join('\n');
|
|
581
|
+
const templatePatterns = [
|
|
582
|
+
/\{\{random\w*\}\}/i, // {{random}}, {{random_hex}}, etc.
|
|
583
|
+
/random:\s*\(\s*\)\s*=>\s*Math\.random/i, // random: () => Math.random()
|
|
584
|
+
/random_\w+:\s*\(\s*\)\s*=>/i, // random_int: () => ...
|
|
585
|
+
/placeholder.*random/i, // placeholder context
|
|
586
|
+
/templates?\s*[=:]\s*\{/i, // templates = { or template: {
|
|
587
|
+
/generatePlaceholder/i, // generatePlaceholder function
|
|
588
|
+
/placeholder\s*[:=]/i, // placeholder: or placeholder =
|
|
589
|
+
];
|
|
590
|
+
return templatePatterns.some(p => p.test(context) || p.test(line));
|
|
591
|
+
}
|
|
409
592
|
/**
|
|
410
593
|
* Check if Math.random() should be skipped entirely
|
|
411
|
-
* Returns true for seed files, test fixtures, captcha/puzzle, uuid, and pure cosmetic uses
|
|
594
|
+
* Returns true for seed files, test fixtures, captcha/puzzle, uuid, React keys, jitter/backoff, and pure cosmetic uses
|
|
412
595
|
*/
|
|
413
|
-
function shouldSkipMathRandom(content, filePath, lineNumber) {
|
|
596
|
+
function shouldSkipMathRandom(content, filePath, lineNumber, options) {
|
|
414
597
|
// Seed/data generation files - skip entirely
|
|
415
598
|
if ((0, context_helpers_1.isSeedOrDataGenFile)(filePath)) {
|
|
416
599
|
return true;
|
|
417
600
|
}
|
|
601
|
+
// Animation/motion component files - skip entirely
|
|
602
|
+
// These use Math.random for visual effects, not security
|
|
603
|
+
if (isAnimationFile(filePath)) {
|
|
604
|
+
return true;
|
|
605
|
+
}
|
|
418
606
|
// Educational/intentional vulnerability files - skip entirely
|
|
419
607
|
// These include OWASP Juice Shop, intentionally-vulnerable examples, etc.
|
|
420
608
|
if ((0, context_helpers_1.isEducationalVulnerabilityFile)(filePath)) {
|
|
421
609
|
return true;
|
|
422
610
|
}
|
|
611
|
+
// Check for React key pattern - this is a common pattern to force re-renders
|
|
612
|
+
// It's not a security issue, just a way to reset component state
|
|
613
|
+
const lines = options?.parsed?.lines ?? content.split('\n');
|
|
614
|
+
const lineContent = lines[lineNumber] || '';
|
|
615
|
+
if (isReactKeyPattern(lineContent, filePath)) {
|
|
616
|
+
return true;
|
|
617
|
+
}
|
|
618
|
+
// Template placeholder generators - skip entirely
|
|
619
|
+
// These generate placeholder values for templates, not security tokens
|
|
620
|
+
if (isTemplatePlaceholderGenerator(lineContent, content, lineNumber, lines)) {
|
|
621
|
+
return true;
|
|
622
|
+
}
|
|
623
|
+
// Jitter/backoff/retry patterns - legitimate non-security use of randomness
|
|
624
|
+
// Used for network resilience, rate limiting, exponential backoff, etc.
|
|
625
|
+
if (isJitterOrBackoffContext(content, lineNumber, lines)) {
|
|
626
|
+
return true;
|
|
627
|
+
}
|
|
423
628
|
// Test files with test fixture patterns
|
|
424
629
|
if ((0, context_helpers_1.isTestOrMockFile)(filePath)) {
|
|
425
|
-
const lines = content.split('\n');
|
|
426
630
|
const line = lines[lineNumber];
|
|
427
631
|
// If in a test file and generating test data, skip
|
|
428
632
|
if (/\b(mock|fake|fixture|test)Data/i.test(line) ||
|
|
@@ -431,9 +635,7 @@ function shouldSkipMathRandom(content, filePath, lineNumber) {
|
|
|
431
635
|
}
|
|
432
636
|
}
|
|
433
637
|
// Pure cosmetic usage (CSS values, animations)
|
|
434
|
-
|
|
435
|
-
const lineContent = lines[lineNumber] || '';
|
|
436
|
-
if (isCosmeticMathRandom(lineContent, content, lineNumber)) {
|
|
638
|
+
if (isCosmeticMathRandom(lineContent, content, lineNumber, lines)) {
|
|
437
639
|
// Additional check: if this is for animation/style, truly skip
|
|
438
640
|
const pureStylePatterns = [
|
|
439
641
|
/\.style\./,
|
|
@@ -447,6 +649,14 @@ function shouldSkipMathRandom(content, filePath, lineNumber) {
|
|
|
447
649
|
return true;
|
|
448
650
|
}
|
|
449
651
|
}
|
|
652
|
+
// Animation coordinate usage (x, y, rotation, etc.)
|
|
653
|
+
// Get surrounding context for animation library detection
|
|
654
|
+
const contextStart = Math.max(0, lineNumber - 15);
|
|
655
|
+
const contextEnd = Math.min(lines.length, lineNumber + 5);
|
|
656
|
+
const animContext = lines.slice(contextStart, contextEnd).join('\n');
|
|
657
|
+
if (isAnimationCoordinateUsage(lineContent, animContext)) {
|
|
658
|
+
return true;
|
|
659
|
+
}
|
|
450
660
|
// Check function context for demo/seed/captcha/uuid functions
|
|
451
661
|
const functionName = (0, control_flow_1.extractFunctionContext)(content, lineNumber);
|
|
452
662
|
const functionIntent = classifyFunctionIntent(functionName);
|
|
@@ -454,6 +664,21 @@ function shouldSkipMathRandom(content, filePath, lineNumber) {
|
|
|
454
664
|
if (functionIntent === 'demo' || functionIntent === 'captcha' || functionIntent === 'uuid') {
|
|
455
665
|
return true;
|
|
456
666
|
}
|
|
667
|
+
// Check for fallback pattern: crypto.randomUUID?.() ?? Math.random()
|
|
668
|
+
// When a secure primary method is used with Math.random as fallback,
|
|
669
|
+
// the code is safe (Math.random only runs in environments without crypto API)
|
|
670
|
+
const prevLines = lines.slice(Math.max(0, lineNumber - 2), lineNumber + 1).join(' ');
|
|
671
|
+
const multiLineFallbackPatterns = [
|
|
672
|
+
/crypto\??\.?\s*randomUUID\??\.?\s*\(\s*\)\s*\?\?/i, // crypto.randomUUID() ??
|
|
673
|
+
/globalThis\.crypto\??\.?\s*randomUUID\??\.?\s*\(/i, // globalThis.crypto?.randomUUID?.()
|
|
674
|
+
/window\.crypto\??\.?\s*randomUUID\??\.?\s*\(/i, // window.crypto?.randomUUID?.()
|
|
675
|
+
/\?\.\s*randomUUID\??\.?\s*\(\s*\)\s*\?\?/i, // ?.randomUUID?.() ??
|
|
676
|
+
/crypto\??\.?\s*getRandomValues\s*\(/i, // crypto.getRandomValues()
|
|
677
|
+
/randomUUID\??\.?\s*\(\s*\)\s*\?\?/i, // randomUUID?.() ?? (generic)
|
|
678
|
+
];
|
|
679
|
+
if (multiLineFallbackPatterns.some(p => p.test(prevLines))) {
|
|
680
|
+
return true; // Skip - Math.random is only a fallback for missing crypto API
|
|
681
|
+
}
|
|
457
682
|
return false;
|
|
458
683
|
}
|
|
459
684
|
//# sourceMappingURL=math-random.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"math-random.js","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/math-random.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"math-random.js","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/math-random.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;AAuBH,4DAkCC;AAcD,8CAeC;AAOD,oDAmGC;AAMD,wDAiDC;AAMD,wDAgFC;AASD,sEAkBC;AASD,4DAqGC;AAMD,4DAiFC;AAMD,0CAcC;AAMD,gEAuDC;AAWD,wEAsBC;AAMD,oDA0GC;AA7wBD,iEAIoC;AAEpC,uDAA6D;AAE7D;;;;;;;;;;;;GAYG;AACH,SAAgB,wBAAwB,CACtC,OAAe,EACf,UAAkB,EAClB,KAAgB;IAEhB,MAAM,MAAM,GAAG,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,EAAE,CAAC,CAAA;IAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,GAAG,CAAC,CAAC,CAAA;IACnD,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAEnD,mDAAmD;IACnD,MAAM,cAAc,GAAG;QACrB,yBAAyB;QACzB,iDAAiD;QACjD,4BAA4B;QAC5B,2BAA2B;QAC3B,4BAA4B;QAC5B,sBAAsB;QACtB,6BAA6B;QAC7B,0BAA0B;QAC1B,6BAA6B;QAC7B,4BAA4B;QAC5B,qCAAqC;QACrC,+BAA+B;QAC/B,sEAAsE;QACtE,gCAAgC;QAChC,6DAA6D;QAC7D,8BAA8B;QAC9B,kDAAkD;QAClD,6CAA6C;QAC7C,8DAA8D;KAC/D,CAAA;IAED,OAAO,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;AAClD,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,iBAAiB,CAAC,WAAmB,EAAE,QAAgB;IACrE,8BAA8B;IAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QAChC,OAAO,KAAK,CAAA;IACd,CAAC;IAED,qCAAqC;IACrC,WAAW;IACX,wBAAwB;IACxB,iCAAiC;IACjC,mCAAmC;IACnC,iCAAiC;IACjC,oCAAoC;IACpC,MAAM,UAAU,GAAG,mCAAmC,CAAA;IACtD,OAAO,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;AACrC,CAAC;AAED;;;;GAIG;AACH,SAAgB,oBAAoB,CAClC,WAAmB,EACnB,OAAe,EACf,UAAkB,EAClB,KAAgB;IAEhB,MAAM,MAAM,GAAG,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IAE3C,gDAAgD;IAChD,MAAM,oBAAoB,GAAG;QAC3B,mBAAmB;QACnB,yCAAyC,EAAE,gCAAgC;QAC3E,mCAAmC,EAAE,2BAA2B;QAChE,iDAAiD,EAAE,iBAAiB;QACpE,8BAA8B,EAAE,mBAAmB;QACnD,+BAA+B,EAAE,gCAAgC;QACjE,gCAAgC,EAAE,iCAAiC;QACnE,kCAAkC,EAAE,yBAAyB;QAC7D,oCAAoC,EAAE,4BAA4B;QAClE,yBAAyB,EAAE,8BAA8B;QACzD,4BAA4B,EAAE,iCAAiC;QAC/D,wBAAwB,EAAE,2BAA2B;QACrD,yBAAyB;QACzB,wBAAwB,EAAE,gCAAgC;QAC1D,sBAAsB,EAAE,gCAAgC;QACxD,wBAAwB,EAAE,oCAAoC;QAC9D,wBAAwB,EAAE,mCAAmC;QAC7D,kCAAkC;QAClC,uCAAuC,EAAE,2CAA2C;QACpF,6BAA6B,EAAE,sCAAsC;QACrE,wBAAwB;QACxB,4CAA4C,EAAE,kCAAkC;QAChF,4CAA4C,EAAE,oCAAoC;QAClF,2CAA2C,EAAE,8BAA8B;QAC3E,4EAA4E;QAC5E,8EAA8E;QAC9E,yCAAyC;KAC1C,CAAA;IAED,IAAI,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;QACxD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,uDAAuD;IACvD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,CAAC,CAAC,CAAA;IAChD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,GAAG,CAAC,CAAC,CAAA;IAC1D,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAEjE,qCAAqC;IACrC,MAAM,uBAAuB,GAAG;QAC9B,yEAAyE;QACzE,oCAAoC;QACpC,sDAAsD;QACtD,kEAAkE;QAClE,oBAAoB;QACpB,yDAAyD;QACzD,gEAAgE;QAChE,mBAAmB;QACnB,2BAA2B;QAC3B,4BAA4B;QAC5B,sBAAsB;QACtB,yBAAyB;QACzB,sBAAsB;QACtB,kDAAkD;QAClD,iFAAiF;QACjF,+FAA+F;KAChG,CAAA;IAED,IAAI,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;QACvD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,+DAA+D;IAC/D,MAAM,gBAAgB,GAAG;QACvB,qDAAqD;QACrD,uCAAuC;QACvC,2BAA2B;QAC3B,0BAA0B,EAAE,+CAA+C;KAC5E,CAAA;IAED,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;QACvE,OAAO,KAAK,CAAA,CAAC,4CAA4C;IAC3D,CAAC;IAED,kFAAkF;IAClF,sFAAsF;IACtF,MAAM,8BAA8B,GAClC,kCAAkC,CAAC,IAAI,CAAC,WAAW,CAAC;QACpD,CAAC,8BAA8B,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;IAEnD,MAAM,8BAA8B,GAClC,kCAAkC,CAAC,IAAI,CAAC,WAAW,CAAC;QACpD,CAAC,8BAA8B,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;IAEnD,IAAI,8BAA8B,IAAI,8BAA8B,EAAE,CAAC;QACrE,OAAO,KAAK,CAAA,CAAC,oEAAoE;IACnF,CAAC;IAED,OAAO,KAAK,CAAA,CAAC,iCAAiC;AAChD,CAAC;AAED;;;GAGG;AACH,SAAgB,sBAAsB,CACpC,YAA2B;IAE3B,IAAI,CAAC,YAAY;QAAE,OAAO,SAAS,CAAA;IAEnC,MAAM,KAAK,GAAG,YAAY,CAAC,WAAW,EAAE,CAAA;IAExC,oDAAoD;IACpD,uEAAuE;IACvE,MAAM,YAAY,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAA;IACvF,iEAAiE;IACjE,MAAM,oBAAoB,GAAG,sDAAsD,CAAA;IACnF,IACE,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACzC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAChC,CAAC;QACD,OAAO,MAAM,CAAA;IACf,CAAC;IAED,sDAAsD;IACtD,MAAM,eAAe,GAAG,CAAC,SAAS,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAA;IAC5D,iEAAiE;IACjE,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAAE,OAAO,SAAS,CAAA;IAClE,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;QAAE,OAAO,SAAS,CAAA;IAE5E,yBAAyB;IACzB,MAAM,YAAY,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAA;IAChE,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAAE,OAAO,MAAM,CAAA;IAE5D,+EAA+E;IAC/E,MAAM,gBAAgB,GAAG;QACvB,OAAO;QACP,QAAQ;QACR,KAAK;QACL,UAAU;QACV,YAAY;QACZ,WAAW;KACZ,CAAA;IACD,0DAA0D;IAC1D,MAAM,uBAAuB,GAC3B,wEAAwE,CAAA;IAC1E,IACE,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC7C,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,EACnC,CAAC;QACD,OAAO,UAAU,CAAA;IACnB,CAAC;IAED,OAAO,SAAS,CAAA;AAClB,CAAC;AAED;;;GAGG;AACH,SAAgB,sBAAsB,CAAC,WAAmB;IAOxD,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAA;IAC7E,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAA;IAE7E,IAAI,CAAC,eAAe,IAAI,CAAC,eAAe,EAAE,CAAC;QACzC,OAAO;YACL,WAAW,EAAE,KAAK;YAClB,IAAI,EAAE,IAAI;YACV,WAAW,EAAE,KAAK;YAClB,gBAAgB,EAAE,IAAI;YACtB,MAAM,EAAE,SAAS;SAClB,CAAA;IACH,CAAC;IAED,MAAM,IAAI,GAAG,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAA;IAEtC,+BAA+B;IAC/B,MAAM,cAAc,GAAG,WAAW,CAAC,KAAK,CACtC,oCAAoC,CACrC,CAAA;IACD,MAAM,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAA;IACtE,MAAM,WAAW,GAAG,WAAW,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAA;IAExE,MAAM,UAAU,GAAG,cAAc,IAAI,UAAU,IAAI,WAAW,CAAA;IAE9D,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,IAAI;YACJ,WAAW,EAAE,KAAK;YAClB,gBAAgB,EAAE,IAAI;YACtB,MAAM,EAAE,YAAY;SACrB,CAAA;IACH,CAAC;IAED,8BAA8B;IAC9B,MAAM,KAAK,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA;IACrC,MAAM,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IAE1D,uFAAuF;IACvF,mEAAmE;IACnE,6DAA6D;IAC7D,yCAAyC;IACzC,MAAM,mBAAmB,GAAG,EAAE,CAAA;IAC9B,MAAM,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,mBAAmB,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IAEpF,4BAA4B;IAC5B,oDAAoD;IACpD,oDAAoD;IACpD,IAAI,MAAM,IAAI,MAAM,IAAI,CAAC,EAAE,CAAC;QAC1B,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,IAAI;YACJ,WAAW,EAAE,IAAI;YACjB,gBAAgB,EAAE,MAAM;YACxB,MAAM,EAAE,aAAa;SACtB,CAAA;IACH,CAAC;SAAM,IAAI,MAAM,IAAI,MAAM,IAAI,EAAE,EAAE,CAAC;QAClC,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,IAAI;YACJ,WAAW,EAAE,IAAI;YACjB,gBAAgB,EAAE,MAAM;YACxB,MAAM,EAAE,aAAa;SACtB,CAAA;IACH,CAAC;SAAM,CAAC;QACN,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,IAAI;YACJ,WAAW,EAAE,IAAI;YACjB,gBAAgB,EAAE,MAAM;YACxB,MAAM,EAAE,aAAa;SACtB,CAAA;IACH,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,6BAA6B,CAC3C,WAAmB;IAEnB,8CAA8C;IAC9C,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,CACvC,6CAA6C,CAC9C,CAAA;IACD,IAAI,eAAe;QAAE,OAAO,eAAe,CAAC,CAAC,CAAC,CAAA;IAE9C,mCAAmC;IACnC,MAAM,aAAa,GAAG,WAAW,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAA;IACtE,IAAI,aAAa;QAAE,OAAO,aAAa,CAAC,CAAC,CAAC,CAAA;IAE1C,kEAAkE;IAClE,MAAM,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAA;IAChE,IAAI,UAAU;QAAE,OAAO,UAAU,CAAC,CAAC,CAAC,CAAA;IAEpC,OAAO,IAAI,CAAA,CAAC,yBAAyB;AACvC,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,wBAAwB,CACtC,OAAsB;IAEtB,IAAI,CAAC,OAAO;QAAE,OAAO,QAAQ,CAAA,CAAC,+BAA+B;IAE7D,MAAM,KAAK,GAAG,OAAO,CAAC,WAAW,EAAE,CAAA;IAEnC,+CAA+C;IAC/C,+EAA+E;IAC/E,mDAAmD;IACnD,MAAM,gBAAgB,GAAG;QACvB,OAAO;QACP,QAAQ;QACR,UAAU;QACV,YAAY;QACZ,WAAW;QACX,MAAM;QACN,OAAO;QACP,SAAS;QACT,MAAM;QACN,MAAM;QACN,QAAQ;QACR,WAAW;QACX,YAAY;QACZ,eAAe;QACf,aAAa;QACb,cAAc;QACd,KAAK;QACL,QAAQ;QACR,OAAO;QACP,WAAW;KACZ,CAAA;IACD,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAClD,OAAO,MAAM,CAAA;IACf,CAAC;IAED,0CAA0C;IAC1C,MAAM,eAAe,GAAG;QACtB,uBAAuB;QACvB,IAAI;QACJ,KAAK;QACL,MAAM;QACN,UAAU;QACV,OAAO;QACP,SAAS;QACT,UAAU;QACV,MAAM;QACN,SAAS;QACT,MAAM;QACN,aAAa;QACb,SAAS;QACT,WAAW;QACX,UAAU;QACV,cAAc;QACd,iBAAiB;QACjB,MAAM;QACN,MAAM;QACN,MAAM;QACN,QAAQ;QACR,SAAS;QACT,SAAS;QACT,QAAQ;QACR,MAAM;QACN,WAAW;QACX,WAAW;QACX,OAAO;QACP,4EAA4E;QAC5E,KAAK;QACL,OAAO;QACP,cAAc;QACd,SAAS;QACT,WAAW;QACX,QAAQ;QACR,OAAO;QACP,QAAQ;QACR,OAAO;QACP,QAAQ;QACR,OAAO;QACP,+DAA+D;QAC/D,QAAQ;QACR,OAAO;QACP,SAAS;QACT,OAAO;QACP,SAAS;QACT,SAAS;QACT,QAAQ;QACR,UAAU;QACV,aAAa;QACb,QAAQ;QACR,SAAS;QACT,YAAY;QACZ,QAAQ;QACR,QAAQ;QACR,QAAQ;QACR,SAAS;KACV,CAAA;IACD,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACjD,OAAO,KAAK,CAAA;IACd,CAAC;IAED,OAAO,QAAQ,CAAA,CAAC,iCAAiC;AACnD,CAAC;AAED;;;GAGG;AACH,SAAgB,wBAAwB,CACtC,OAAe,EACf,QAAgB,EAChB,UAAkB,EAClB,KAAgB;IAQhB,MAAM,MAAM,GAAG,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,EAAE,CAAC,CAAA;IAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,GAAG,CAAC,CAAC,CAAA;IACnD,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAEnD,6DAA6D;IAC7D,MAAM,gBAAgB,GAAG;QACvB,8EAA8E;QAC9E,8CAA8C;QAC9C,gDAAgD;QAChD,uDAAuD;QACvD,8DAA8D;QAC9D,8CAA8C;KAC/C,CAAA;IACD,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;IAErE,eAAe;IACf,MAAM,gBAAgB,GAAG,kCAAkC,CAAA;IAC3D,MAAM,mBAAmB,GAAG;QAC1B,4DAA4D;QAC5D,gDAAgD;QAChD,yBAAyB;KAC1B,CAAA;IACD,MAAM,aAAa,GACjB,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;IAEhD,6CAA6C;IAC7C,MAAM,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAA;IACtC,MAAM,WAAW,GAAG,oBAAoB,CAAC,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,CAAA;IAElF,sDAAsD;IACtD,kFAAkF;IAClF,MAAM,qBAAqB,GAAG;QAC5B,8DAA8D;QAC9D,8CAA8C;QAC9C,mDAAmD;QACnD,2FAA2F;QAC3F,wCAAwC;QACxC,+BAA+B,EAAM,oBAAoB;QACzD,iBAAiB,EAAqB,uBAAuB;QAC7D,wBAAwB,EAAc,gDAAgD;QACtF,uCAAuC,EAAG,sCAAsC;QAChF,UAAU,EAA4B,oBAAoB;QAC1D,aAAa,EAAyB,qBAAqB;QAC3D,gBAAgB,EAAsB,wBAAwB;KAC/D,CAAA;IACD,MAAM,sBAAsB,GAC1B,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAA;IAExE,gCAAgC;IAChC,IAAI,kBAAkB,GAAG,iBAAiB,CAAA;IAC1C,IAAI,iBAAiB,EAAE,CAAC;QACtB,kBAAkB,GAAG,6BAA6B,CAAA;IACpD,CAAC;SAAM,IAAI,aAAa,EAAE,CAAC;QACzB,kBAAkB,GAAG,2BAA2B,CAAA;IAClD,CAAC;SAAM,IAAI,WAAW,EAAE,CAAC;QACvB,kBAAkB,GAAG,mBAAmB,CAAA;IAC1C,CAAC;SAAM,IAAI,sBAAsB,EAAE,CAAC;QAClC,kBAAkB,GAAG,oBAAoB,CAAA;IAC3C,CAAC;IAED,OAAO;QACL,iBAAiB;QACjB,aAAa;QACb,WAAW;QACX,sBAAsB;QACtB,kBAAkB;KACnB,CAAA;AACH,CAAC;AAED;;;GAGG;AACH,SAAgB,eAAe,CAAC,QAAgB;IAC9C,MAAM,iBAAiB,GAAG;QACxB,eAAe,EAAY,gCAAgC;QAC3D,gBAAgB,EAAW,yBAAyB;QACpD,aAAa,EAAc,uBAAuB;QAClD,aAAa,EAAc,oBAAoB;QAC/C,iBAAiB,EAAU,2BAA2B;QACtD,WAAW,EAAgB,eAAe;QAC1C,aAAa,EAAc,mBAAmB;QAC9C,iBAAiB,EAAU,yBAAyB;QACpD,aAAa,EAAc,qBAAqB;QAChD,aAAa,EAAc,uBAAuB;KACnD,CAAA;IACD,OAAO,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAA;AACtD,CAAC;AAED;;;GAGG;AACH,SAAgB,0BAA0B,CAAC,WAAmB,EAAE,OAAe;IAC7E,8CAA8C;IAC9C,MAAM,kBAAkB,GAAG;QACzB,sBAAsB,EAAY,mBAAmB;QACrD,sBAAsB,EAAY,mBAAmB;QACrD,sBAAsB,EAAY,mBAAmB;QACrD,2BAA2B,EAAO,sBAAsB;QACxD,0BAA0B,EAAQ,qBAAqB;QACvD,4BAA4B,EAAM,uBAAuB;QACzD,6BAA6B,EAAK,wBAAwB;QAC1D,+BAA+B,EAAG,0BAA0B;QAC5D,8BAA8B,EAAI,yBAAyB;QAC3D,8BAA8B,EAAI,yBAAyB;QAC3D,8BAA8B,EAAI,yBAAyB;QAC3D,8BAA8B,EAAI,8BAA8B;QAChE,6BAA6B,EAAK,wBAAwB;QAC1D,8BAA8B,EAAI,yBAAyB;QAC3D,+BAA+B,EAAG,0BAA0B;QAC5D,4BAA4B,EAAM,uBAAuB;QACzD,gCAAgC;QAChC,6BAA6B,EAAK,yBAAyB;QAC3D,6CAA6C,EAAG,mCAAmC;QACnF,+BAA+B,EAAG,gDAAgD;QAClF,+BAA+B,EAAG,uBAAuB;QACzD,+BAA+B,EAAG,uBAAuB;KAC1D,CAAA;IAED,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;QACtD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,4CAA4C;IAC5C,MAAM,qBAAqB,GAAG;QAC5B,gBAAgB;QAChB,eAAe;QACf,eAAe;QACf,OAAO;QACP,UAAU;QACV,YAAY;QACZ,cAAc;QACd,YAAY;QACZ,eAAe;QACf,eAAe;QACf,YAAY;QACZ,0CAA0C;QAC1C,QAAQ;QACR,WAAW;QACX,eAAe;QACf,SAAS,EAAO,2BAA2B;QAC3C,OAAO,EAAS,gBAAgB;QAChC,WAAW,EAAK,oBAAoB;QACpC,WAAW,EAAK,oBAAoB;KACrC,CAAA;IAED,OAAO,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;AACzD,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,8BAA8B,CAC5C,IAAY,EACZ,OAAe,EACf,UAAkB,EAClB,KAAgB;IAEhB,MAAM,MAAM,GAAG,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IAC3C,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,EAAE,CAAC,CAAA;IACjD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,GAAG,CAAC,CAAC,CAAA;IAC1D,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAEjE,MAAM,gBAAgB,GAAG;QACvB,oBAAoB,EAAsB,mCAAmC;QAC7E,wCAAwC,EAAE,8BAA8B;QACxE,6BAA6B,EAAa,wBAAwB;QAClE,sBAAsB,EAAqB,sBAAsB;QACjE,yBAAyB,EAAiB,+BAA+B;QACzE,sBAAsB,EAAqB,+BAA+B;QAC1E,qBAAqB,EAAsB,gCAAgC;KAC5E,CAAA;IAED,OAAO,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;AACpE,CAAC;AAED;;;GAGG;AACH,SAAgB,oBAAoB,CAClC,OAAe,EACf,QAAgB,EAChB,UAAkB,EAClB,OAAiC;IAEjC,6CAA6C;IAC7C,IAAI,IAAA,qCAAmB,EAAC,QAAQ,CAAC,EAAE,CAAC;QAClC,OAAO,IAAI,CAAA;IACb,CAAC;IAED,mDAAmD;IACnD,yDAAyD;IACzD,IAAI,eAAe,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAA;IACb,CAAC;IAED,8DAA8D;IAC9D,0EAA0E;IAC1E,IAAI,IAAA,gDAA8B,EAAC,QAAQ,CAAC,EAAE,CAAC;QAC7C,OAAO,IAAI,CAAA;IACb,CAAC;IAED,6EAA6E;IAC7E,iEAAiE;IACjE,MAAM,KAAK,GAAG,OAAO,EAAE,MAAM,EAAE,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IAC3D,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE,CAAA;IAC3C,IAAI,iBAAiB,CAAC,WAAW,EAAE,QAAQ,CAAC,EAAE,CAAC;QAC7C,OAAO,IAAI,CAAA;IACb,CAAC;IAED,kDAAkD;IAClD,uEAAuE;IACvE,IAAI,8BAA8B,CAAC,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC;QAC5E,OAAO,IAAI,CAAA;IACb,CAAC;IAED,4EAA4E;IAC5E,wEAAwE;IACxE,IAAI,wBAAwB,CAAC,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC;QACzD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,wCAAwC;IACxC,IAAI,IAAA,kCAAgB,EAAC,QAAQ,CAAC,EAAE,CAAC;QAC/B,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,CAAC,CAAA;QAC9B,mDAAmD;QACnD,IACE,iCAAiC,CAAC,IAAI,CAAC,IAAI,CAAC;YAC5C,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,EACtC,CAAC;YACD,OAAO,IAAI,CAAA;QACb,CAAC;IACH,CAAC;IAED,+CAA+C;IAC/C,IAAI,oBAAoB,CAAC,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC;QAClE,+DAA+D;QAC/D,MAAM,iBAAiB,GAAG;YACxB,WAAW;YACX,YAAY;YACZ,YAAY;YACZ,UAAU;YACV,QAAQ;YACR,QAAQ;SACT,CAAA;QACD,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;YACrD,OAAO,IAAI,CAAA;QACb,CAAC;IACH,CAAC;IAED,oDAAoD;IACpD,0DAA0D;IAC1D,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,EAAE,CAAC,CAAA;IACjD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,UAAU,GAAG,CAAC,CAAC,CAAA;IACzD,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACpE,IAAI,0BAA0B,CAAC,WAAW,EAAE,WAAW,CAAC,EAAE,CAAC;QACzD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,8DAA8D;IAC9D,MAAM,YAAY,GAAG,IAAA,qCAAsB,EAAC,OAAO,EAAE,UAAU,CAAC,CAAA;IAChE,MAAM,cAAc,GAAG,sBAAsB,CAAC,YAAY,CAAC,CAAA;IAE3D,8EAA8E;IAC9E,IAAI,cAAc,KAAK,MAAM,IAAI,cAAc,KAAK,SAAS,IAAI,cAAc,KAAK,MAAM,EAAE,CAAC;QAC3F,OAAO,IAAI,CAAA;IACb,CAAC;IAED,qEAAqE;IACrE,qEAAqE;IACrE,8EAA8E;IAC9E,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACpF,MAAM,yBAAyB,GAAG;QAChC,mDAAmD,EAAU,yBAAyB;QACtF,mDAAmD,EAAU,oCAAoC;QACjG,+CAA+C,EAAc,gCAAgC;QAC7F,2CAA2C,EAAkB,sBAAsB;QACnF,sCAAsC,EAAwB,2BAA2B;QACzF,oCAAoC,EAA0B,8BAA8B;KAC7F,CAAA;IACD,IAAI,yBAAyB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;QAC3D,OAAO,IAAI,CAAA,CAAE,+DAA+D;IAC9E,CAAC;IAED,OAAO,KAAK,CAAA;AACd,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"patterns.d.ts","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/patterns.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAA;AAExD,MAAM,WAAW,wBAAwB;IACvC,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,qBAAqB,CAAA;IAC/B,WAAW,EAAE,MAAM,CAAA;IACnB,YAAY,EAAE,MAAM,CAAA;IACpB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;CACrB;AAED,eAAO,MAAM,mBAAmB,EAAE,wBAAwB,
|
|
1
|
+
{"version":3,"file":"patterns.d.ts","sourceRoot":"","sources":["../../../src/layer2/dangerous-functions/patterns.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAA;AAExD,MAAM,WAAW,wBAAwB;IACvC,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,qBAAqB,CAAA;IAC/B,WAAW,EAAE,MAAM,CAAA;IACnB,YAAY,EAAE,MAAM,CAAA;IACpB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;CACrB;AAED,eAAO,MAAM,mBAAmB,EAAE,wBAAwB,EA8IzD,CAAA;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAU/E"}
|
|
@@ -48,9 +48,11 @@ exports.DANGEROUS_FUNCTIONS = [
|
|
|
48
48
|
languages: ['py'],
|
|
49
49
|
},
|
|
50
50
|
// SQL injection risks
|
|
51
|
+
// Note: .execute is too generic (used by axios, tRPC, request utilities)
|
|
52
|
+
// Focus on .query and .raw which are more SQL-specific
|
|
51
53
|
{
|
|
52
54
|
name: 'Raw SQL query construction',
|
|
53
|
-
pattern: /\.(query|
|
|
55
|
+
pattern: /\.(query|raw)\s*\(\s*[`'"].*\$\{|\.query\s*\(\s*['"].*\+/gi,
|
|
54
56
|
severity: 'critical',
|
|
55
57
|
description: 'String concatenation in SQL queries can lead to SQL injection',
|
|
56
58
|
suggestedFix: 'Use parameterized queries or prepared statements',
|