circle-ir-ai 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +105 -0
- package/LICENSE +15 -0
- package/README.md +336 -0
- package/dist/action-queue/aggregator.d.ts +40 -0
- package/dist/action-queue/aggregator.d.ts.map +1 -0
- package/dist/action-queue/aggregator.js +375 -0
- package/dist/action-queue/aggregator.js.map +1 -0
- package/dist/action-queue/index.d.ts +14 -0
- package/dist/action-queue/index.d.ts.map +1 -0
- package/dist/action-queue/index.js +17 -0
- package/dist/action-queue/index.js.map +1 -0
- package/dist/action-queue/queue.d.ts +74 -0
- package/dist/action-queue/queue.d.ts.map +1 -0
- package/dist/action-queue/queue.js +433 -0
- package/dist/action-queue/queue.js.map +1 -0
- package/dist/action-queue/types.d.ts +162 -0
- package/dist/action-queue/types.d.ts.map +1 -0
- package/dist/action-queue/types.js +44 -0
- package/dist/action-queue/types.js.map +1 -0
- package/dist/agents/enrichment-agent.d.ts +16 -0
- package/dist/agents/enrichment-agent.d.ts.map +1 -0
- package/dist/agents/enrichment-agent.js +102 -0
- package/dist/agents/enrichment-agent.js.map +1 -0
- package/dist/agents/index.d.ts +12 -0
- package/dist/agents/index.d.ts.map +1 -0
- package/dist/agents/index.js +15 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/agents/mastra/agents.d.ts +373 -0
- package/dist/agents/mastra/agents.d.ts.map +1 -0
- package/dist/agents/mastra/agents.js +347 -0
- package/dist/agents/mastra/agents.js.map +1 -0
- package/dist/agents/mastra/index.d.ts +12 -0
- package/dist/agents/mastra/index.d.ts.map +1 -0
- package/dist/agents/mastra/index.js +17 -0
- package/dist/agents/mastra/index.js.map +1 -0
- package/dist/agents/mastra/instance.d.ts +383 -0
- package/dist/agents/mastra/instance.d.ts.map +1 -0
- package/dist/agents/mastra/instance.js +37 -0
- package/dist/agents/mastra/instance.js.map +1 -0
- package/dist/agents/mastra/steps.d.ts +300 -0
- package/dist/agents/mastra/steps.d.ts.map +1 -0
- package/dist/agents/mastra/steps.js +468 -0
- package/dist/agents/mastra/steps.js.map +1 -0
- package/dist/agents/mastra/swarm.d.ts +106 -0
- package/dist/agents/mastra/swarm.d.ts.map +1 -0
- package/dist/agents/mastra/swarm.js +501 -0
- package/dist/agents/mastra/swarm.js.map +1 -0
- package/dist/agents/mastra/workflow.d.ts +81 -0
- package/dist/agents/mastra/workflow.d.ts.map +1 -0
- package/dist/agents/mastra/workflow.js +460 -0
- package/dist/agents/mastra/workflow.js.map +1 -0
- package/dist/agents/multi/agents/security.d.ts +29 -0
- package/dist/agents/multi/agents/security.d.ts.map +1 -0
- package/dist/agents/multi/agents/security.js +830 -0
- package/dist/agents/multi/agents/security.js.map +1 -0
- package/dist/agents/multi/extractor.d.ts +21 -0
- package/dist/agents/multi/extractor.d.ts.map +1 -0
- package/dist/agents/multi/extractor.js +483 -0
- package/dist/agents/multi/extractor.js.map +1 -0
- package/dist/agents/multi/index.d.ts +32 -0
- package/dist/agents/multi/index.d.ts.map +1 -0
- package/dist/agents/multi/index.js +34 -0
- package/dist/agents/multi/index.js.map +1 -0
- package/dist/agents/multi/runner.d.ts +79 -0
- package/dist/agents/multi/runner.d.ts.map +1 -0
- package/dist/agents/multi/runner.js +323 -0
- package/dist/agents/multi/runner.js.map +1 -0
- package/dist/agents/security-agent.d.ts +16 -0
- package/dist/agents/security-agent.d.ts.map +1 -0
- package/dist/agents/security-agent.js +299 -0
- package/dist/agents/security-agent.js.map +1 -0
- package/dist/agents/types.d.ts +373 -0
- package/dist/agents/types.d.ts.map +1 -0
- package/dist/agents/types.js +14 -0
- package/dist/agents/types.js.map +1 -0
- package/dist/agents/verification-agent.d.ts +23 -0
- package/dist/agents/verification-agent.d.ts.map +1 -0
- package/dist/agents/verification-agent.js +217 -0
- package/dist/agents/verification-agent.js.map +1 -0
- package/dist/agents/workflow.d.ts +30 -0
- package/dist/agents/workflow.d.ts.map +1 -0
- package/dist/agents/workflow.js +79 -0
- package/dist/agents/workflow.js.map +1 -0
- package/dist/analysis/enriched.d.ts +16 -0
- package/dist/analysis/enriched.d.ts.map +1 -0
- package/dist/analysis/enriched.js +297 -0
- package/dist/analysis/enriched.js.map +1 -0
- package/dist/analysis/llm-correlated-predicates.d.ts +80 -0
- package/dist/analysis/llm-correlated-predicates.d.ts.map +1 -0
- package/dist/analysis/llm-correlated-predicates.js +255 -0
- package/dist/analysis/llm-correlated-predicates.js.map +1 -0
- package/dist/analysis/llm-cross-file-taint.d.ts +86 -0
- package/dist/analysis/llm-cross-file-taint.d.ts.map +1 -0
- package/dist/analysis/llm-cross-file-taint.js +264 -0
- package/dist/analysis/llm-cross-file-taint.js.map +1 -0
- package/dist/analysis/pattern-discovery.d.ts +79 -0
- package/dist/analysis/pattern-discovery.d.ts.map +1 -0
- package/dist/analysis/pattern-discovery.js +447 -0
- package/dist/analysis/pattern-discovery.js.map +1 -0
- package/dist/cache/file-cache.d.ts +89 -0
- package/dist/cache/file-cache.d.ts.map +1 -0
- package/dist/cache/file-cache.js +208 -0
- package/dist/cache/file-cache.js.map +1 -0
- package/dist/cache/index.d.ts +6 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +5 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cli/args.d.ts +52 -0
- package/dist/cli/args.d.ts.map +1 -0
- package/dist/cli/args.js +422 -0
- package/dist/cli/args.js.map +1 -0
- package/dist/cli/colors.d.ts +31 -0
- package/dist/cli/colors.d.ts.map +1 -0
- package/dist/cli/colors.js +80 -0
- package/dist/cli/colors.js.map +1 -0
- package/dist/cli/commands/analyze-skill.d.ts +33 -0
- package/dist/cli/commands/analyze-skill.d.ts.map +1 -0
- package/dist/cli/commands/analyze-skill.js +217 -0
- package/dist/cli/commands/analyze-skill.js.map +1 -0
- package/dist/cli/commands/analyze.d.ts +18 -0
- package/dist/cli/commands/analyze.d.ts.map +1 -0
- package/dist/cli/commands/analyze.js +30 -0
- package/dist/cli/commands/analyze.js.map +1 -0
- package/dist/cli/commands/benchmark-runner.d.ts +42 -0
- package/dist/cli/commands/benchmark-runner.d.ts.map +1 -0
- package/dist/cli/commands/benchmark-runner.js +18 -0
- package/dist/cli/commands/benchmark-runner.js.map +1 -0
- package/dist/cli/commands/benchmark.d.ts +11 -0
- package/dist/cli/commands/benchmark.d.ts.map +1 -0
- package/dist/cli/commands/benchmark.js +90 -0
- package/dist/cli/commands/benchmark.js.map +1 -0
- package/dist/cli/commands/dead-code.d.ts +11 -0
- package/dist/cli/commands/dead-code.d.ts.map +1 -0
- package/dist/cli/commands/dead-code.js +65 -0
- package/dist/cli/commands/dead-code.js.map +1 -0
- package/dist/cli/commands/generate-spec.d.ts +11 -0
- package/dist/cli/commands/generate-spec.d.ts.map +1 -0
- package/dist/cli/commands/generate-spec.js +67 -0
- package/dist/cli/commands/generate-spec.js.map +1 -0
- package/dist/cli/commands/health.d.ts +11 -0
- package/dist/cli/commands/health.d.ts.map +1 -0
- package/dist/cli/commands/health.js +67 -0
- package/dist/cli/commands/health.js.map +1 -0
- package/dist/cli/commands/project.d.ts +21 -0
- package/dist/cli/commands/project.d.ts.map +1 -0
- package/dist/cli/commands/project.js +92 -0
- package/dist/cli/commands/project.js.map +1 -0
- package/dist/cli/commands/scan.d.ts +11 -0
- package/dist/cli/commands/scan.d.ts.map +1 -0
- package/dist/cli/commands/scan.js +68 -0
- package/dist/cli/commands/scan.js.map +1 -0
- package/dist/cli/commands/secrets.d.ts +11 -0
- package/dist/cli/commands/secrets.d.ts.map +1 -0
- package/dist/cli/commands/secrets.js +71 -0
- package/dist/cli/commands/secrets.js.map +1 -0
- package/dist/cli/commands/swarm.d.ts +20 -0
- package/dist/cli/commands/swarm.d.ts.map +1 -0
- package/dist/cli/commands/swarm.js +174 -0
- package/dist/cli/commands/swarm.js.map +1 -0
- package/dist/cli/config.d.ts +103 -0
- package/dist/cli/config.d.ts.map +1 -0
- package/dist/cli/config.js +307 -0
- package/dist/cli/config.js.map +1 -0
- package/dist/cli/discovery.d.ts +31 -0
- package/dist/cli/discovery.d.ts.map +1 -0
- package/dist/cli/discovery.js +212 -0
- package/dist/cli/discovery.js.map +1 -0
- package/dist/cli/formatters/index.d.ts +15 -0
- package/dist/cli/formatters/index.d.ts.map +1 -0
- package/dist/cli/formatters/index.js +51 -0
- package/dist/cli/formatters/index.js.map +1 -0
- package/dist/cli/formatters/json.d.ts +11 -0
- package/dist/cli/formatters/json.d.ts.map +1 -0
- package/dist/cli/formatters/json.js +12 -0
- package/dist/cli/formatters/json.js.map +1 -0
- package/dist/cli/formatters/project-json.d.ts +11 -0
- package/dist/cli/formatters/project-json.d.ts.map +1 -0
- package/dist/cli/formatters/project-json.js +12 -0
- package/dist/cli/formatters/project-json.js.map +1 -0
- package/dist/cli/formatters/project-sarif.d.ts +11 -0
- package/dist/cli/formatters/project-sarif.d.ts.map +1 -0
- package/dist/cli/formatters/project-sarif.js +127 -0
- package/dist/cli/formatters/project-sarif.js.map +1 -0
- package/dist/cli/formatters/project-summary.d.ts +11 -0
- package/dist/cli/formatters/project-summary.d.ts.map +1 -0
- package/dist/cli/formatters/project-summary.js +202 -0
- package/dist/cli/formatters/project-summary.js.map +1 -0
- package/dist/cli/formatters/sarif-shared.d.ts +101 -0
- package/dist/cli/formatters/sarif-shared.d.ts.map +1 -0
- package/dist/cli/formatters/sarif-shared.js +57 -0
- package/dist/cli/formatters/sarif-shared.js.map +1 -0
- package/dist/cli/formatters/sarif.d.ts +12 -0
- package/dist/cli/formatters/sarif.d.ts.map +1 -0
- package/dist/cli/formatters/sarif.js +92 -0
- package/dist/cli/formatters/sarif.js.map +1 -0
- package/dist/cli/formatters/summary.d.ts +11 -0
- package/dist/cli/formatters/summary.d.ts.map +1 -0
- package/dist/cli/formatters/summary.js +240 -0
- package/dist/cli/formatters/summary.js.map +1 -0
- package/dist/cli/formatters/two-phase-summary.d.ts +11 -0
- package/dist/cli/formatters/two-phase-summary.d.ts.map +1 -0
- package/dist/cli/formatters/two-phase-summary.js +188 -0
- package/dist/cli/formatters/two-phase-summary.js.map +1 -0
- package/dist/cli/index.d.ts +15 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +555 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/components/clustering.d.ts +60 -0
- package/dist/components/clustering.d.ts.map +1 -0
- package/dist/components/clustering.js +129 -0
- package/dist/components/clustering.js.map +1 -0
- package/dist/components/enrichment.d.ts +45 -0
- package/dist/components/enrichment.d.ts.map +1 -0
- package/dist/components/enrichment.js +193 -0
- package/dist/components/enrichment.js.map +1 -0
- package/dist/components/index.d.ts +29 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +56 -0
- package/dist/components/index.js.map +1 -0
- package/dist/dead-code/detector.d.ts +200 -0
- package/dist/dead-code/detector.d.ts.map +1 -0
- package/dist/dead-code/detector.js +1003 -0
- package/dist/dead-code/detector.js.map +1 -0
- package/dist/dead-code/index.d.ts +7 -0
- package/dist/dead-code/index.d.ts.map +1 -0
- package/dist/dead-code/index.js +7 -0
- package/dist/dead-code/index.js.map +1 -0
- package/dist/extractors/index.d.ts +15 -0
- package/dist/extractors/index.d.ts.map +1 -0
- package/dist/extractors/index.js +14 -0
- package/dist/extractors/index.js.map +1 -0
- package/dist/extractors/natural-language.d.ts +46 -0
- package/dist/extractors/natural-language.d.ts.map +1 -0
- package/dist/extractors/natural-language.js +228 -0
- package/dist/extractors/natural-language.js.map +1 -0
- package/dist/extractors/tree-sitter.d.ts +33 -0
- package/dist/extractors/tree-sitter.d.ts.map +1 -0
- package/dist/extractors/tree-sitter.js +69 -0
- package/dist/extractors/tree-sitter.js.map +1 -0
- package/dist/extractors/types.d.ts +62 -0
- package/dist/extractors/types.d.ts.map +1 -0
- package/dist/extractors/types.js +54 -0
- package/dist/extractors/types.js.map +1 -0
- package/dist/health-score/calculator.d.ts +123 -0
- package/dist/health-score/calculator.d.ts.map +1 -0
- package/dist/health-score/calculator.js +444 -0
- package/dist/health-score/calculator.js.map +1 -0
- package/dist/health-score/index.d.ts +12 -0
- package/dist/health-score/index.d.ts.map +1 -0
- package/dist/health-score/index.js +14 -0
- package/dist/health-score/index.js.map +1 -0
- package/dist/health-score/metrics.d.ts +142 -0
- package/dist/health-score/metrics.d.ts.map +1 -0
- package/dist/health-score/metrics.js +332 -0
- package/dist/health-score/metrics.js.map +1 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +43 -0
- package/dist/index.js.map +1 -0
- package/dist/llm/ax-client.d.ts +477 -0
- package/dist/llm/ax-client.d.ts.map +1 -0
- package/dist/llm/ax-client.js +1641 -0
- package/dist/llm/ax-client.js.map +1 -0
- package/dist/llm/config.d.ts +58 -0
- package/dist/llm/config.d.ts.map +1 -0
- package/dist/llm/config.js +97 -0
- package/dist/llm/config.js.map +1 -0
- package/dist/llm/discovery.d.ts +123 -0
- package/dist/llm/discovery.d.ts.map +1 -0
- package/dist/llm/discovery.js +505 -0
- package/dist/llm/discovery.js.map +1 -0
- package/dist/llm/enrichment.d.ts +108 -0
- package/dist/llm/enrichment.d.ts.map +1 -0
- package/dist/llm/enrichment.js +312 -0
- package/dist/llm/enrichment.js.map +1 -0
- package/dist/llm/index.d.ts +13 -0
- package/dist/llm/index.d.ts.map +1 -0
- package/dist/llm/index.js +22 -0
- package/dist/llm/index.js.map +1 -0
- package/dist/llm/language-context.d.ts +64 -0
- package/dist/llm/language-context.d.ts.map +1 -0
- package/dist/llm/language-context.js +492 -0
- package/dist/llm/language-context.js.map +1 -0
- package/dist/llm/pattern-verification.d.ts +39 -0
- package/dist/llm/pattern-verification.d.ts.map +1 -0
- package/dist/llm/pattern-verification.js +127 -0
- package/dist/llm/pattern-verification.js.map +1 -0
- package/dist/llm/prompt-security.d.ts +120 -0
- package/dist/llm/prompt-security.d.ts.map +1 -0
- package/dist/llm/prompt-security.js +301 -0
- package/dist/llm/prompt-security.js.map +1 -0
- package/dist/llm/prompts/index.d.ts +31 -0
- package/dist/llm/prompts/index.d.ts.map +1 -0
- package/dist/llm/prompts/index.js +92 -0
- package/dist/llm/prompts/index.js.map +1 -0
- package/dist/llm/prompts/rust.d.ts +30 -0
- package/dist/llm/prompts/rust.d.ts.map +1 -0
- package/dist/llm/prompts/rust.js +121 -0
- package/dist/llm/prompts/rust.js.map +1 -0
- package/dist/llm/schemas.d.ts +892 -0
- package/dist/llm/schemas.d.ts.map +1 -0
- package/dist/llm/schemas.js +258 -0
- package/dist/llm/schemas.js.map +1 -0
- package/dist/llm/verification.d.ts +127 -0
- package/dist/llm/verification.d.ts.map +1 -0
- package/dist/llm/verification.js +394 -0
- package/dist/llm/verification.js.map +1 -0
- package/dist/project/analyzer.d.ts +30 -0
- package/dist/project/analyzer.d.ts.map +1 -0
- package/dist/project/analyzer.js +358 -0
- package/dist/project/analyzer.js.map +1 -0
- package/dist/project/call-graph.d.ts +22 -0
- package/dist/project/call-graph.d.ts.map +1 -0
- package/dist/project/call-graph.js +246 -0
- package/dist/project/call-graph.js.map +1 -0
- package/dist/project/index.d.ts +18 -0
- package/dist/project/index.d.ts.map +1 -0
- package/dist/project/index.js +20 -0
- package/dist/project/index.js.map +1 -0
- package/dist/project/taint-paths.d.ts +22 -0
- package/dist/project/taint-paths.d.ts.map +1 -0
- package/dist/project/taint-paths.js +265 -0
- package/dist/project/taint-paths.js.map +1 -0
- package/dist/project/two-phase-analyzer.d.ts +143 -0
- package/dist/project/two-phase-analyzer.d.ts.map +1 -0
- package/dist/project/two-phase-analyzer.js +646 -0
- package/dist/project/two-phase-analyzer.js.map +1 -0
- package/dist/project/type-hierarchy.d.ts +28 -0
- package/dist/project/type-hierarchy.d.ts.map +1 -0
- package/dist/project/type-hierarchy.js +218 -0
- package/dist/project/type-hierarchy.js.map +1 -0
- package/dist/secret-scan/index.d.ts +12 -0
- package/dist/secret-scan/index.d.ts.map +1 -0
- package/dist/secret-scan/index.js +14 -0
- package/dist/secret-scan/index.js.map +1 -0
- package/dist/secret-scan/patterns.d.ts +38 -0
- package/dist/secret-scan/patterns.d.ts.map +1 -0
- package/dist/secret-scan/patterns.js +473 -0
- package/dist/secret-scan/patterns.js.map +1 -0
- package/dist/secret-scan/scanner.d.ts +162 -0
- package/dist/secret-scan/scanner.d.ts.map +1 -0
- package/dist/secret-scan/scanner.js +511 -0
- package/dist/secret-scan/scanner.js.map +1 -0
- package/dist/security-scan/index.d.ts +12 -0
- package/dist/security-scan/index.d.ts.map +1 -0
- package/dist/security-scan/index.js +15 -0
- package/dist/security-scan/index.js.map +1 -0
- package/dist/security-scan/owasp-mapping.d.ts +29 -0
- package/dist/security-scan/owasp-mapping.d.ts.map +1 -0
- package/dist/security-scan/owasp-mapping.js +246 -0
- package/dist/security-scan/owasp-mapping.js.map +1 -0
- package/dist/security-scan/scanner.d.ts +204 -0
- package/dist/security-scan/scanner.d.ts.map +1 -0
- package/dist/security-scan/scanner.js +693 -0
- package/dist/security-scan/scanner.js.map +1 -0
- package/dist/security-scan/trend-tracker.d.ts +150 -0
- package/dist/security-scan/trend-tracker.d.ts.map +1 -0
- package/dist/security-scan/trend-tracker.js +299 -0
- package/dist/security-scan/trend-tracker.js.map +1 -0
- package/dist/skills/bundle-loader.d.ts +26 -0
- package/dist/skills/bundle-loader.d.ts.map +1 -0
- package/dist/skills/bundle-loader.js +284 -0
- package/dist/skills/bundle-loader.js.map +1 -0
- package/dist/skills/capability-mismatch.d.ts +21 -0
- package/dist/skills/capability-mismatch.d.ts.map +1 -0
- package/dist/skills/capability-mismatch.js +188 -0
- package/dist/skills/capability-mismatch.js.map +1 -0
- package/dist/skills/index.d.ts +10 -0
- package/dist/skills/index.d.ts.map +1 -0
- package/dist/skills/index.js +9 -0
- package/dist/skills/index.js.map +1 -0
- package/dist/skills/skill-analyzer.d.ts +16 -0
- package/dist/skills/skill-analyzer.d.ts.map +1 -0
- package/dist/skills/skill-analyzer.js +361 -0
- package/dist/skills/skill-analyzer.js.map +1 -0
- package/dist/skills/types.d.ts +195 -0
- package/dist/skills/types.d.ts.map +1 -0
- package/dist/skills/types.js +7 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/specifica/conflict-resolver.d.ts +23 -0
- package/dist/specifica/conflict-resolver.d.ts.map +1 -0
- package/dist/specifica/conflict-resolver.js +129 -0
- package/dist/specifica/conflict-resolver.js.map +1 -0
- package/dist/specifica/evidence-aggregator.d.ts +33 -0
- package/dist/specifica/evidence-aggregator.d.ts.map +1 -0
- package/dist/specifica/evidence-aggregator.js +236 -0
- package/dist/specifica/evidence-aggregator.js.map +1 -0
- package/dist/specifica/evidence-extractor.d.ts +13 -0
- package/dist/specifica/evidence-extractor.d.ts.map +1 -0
- package/dist/specifica/evidence-extractor.js +431 -0
- package/dist/specifica/evidence-extractor.js.map +1 -0
- package/dist/specifica/feature-clustering.d.ts +19 -0
- package/dist/specifica/feature-clustering.d.ts.map +1 -0
- package/dist/specifica/feature-clustering.js +231 -0
- package/dist/specifica/feature-clustering.js.map +1 -0
- package/dist/specifica/generator.d.ts +16 -0
- package/dist/specifica/generator.d.ts.map +1 -0
- package/dist/specifica/generator.js +277 -0
- package/dist/specifica/generator.js.map +1 -0
- package/dist/specifica/index.d.ts +15 -0
- package/dist/specifica/index.d.ts.map +1 -0
- package/dist/specifica/index.js +18 -0
- package/dist/specifica/index.js.map +1 -0
- package/dist/specifica/prompts.d.ts +21 -0
- package/dist/specifica/prompts.d.ts.map +1 -0
- package/dist/specifica/prompts.js +196 -0
- package/dist/specifica/prompts.js.map +1 -0
- package/dist/specifica/spec-generator.d.ts +22 -0
- package/dist/specifica/spec-generator.d.ts.map +1 -0
- package/dist/specifica/spec-generator.js +229 -0
- package/dist/specifica/spec-generator.js.map +1 -0
- package/dist/specifica/types.d.ts +213 -0
- package/dist/specifica/types.d.ts.map +1 -0
- package/dist/specifica/types.js +7 -0
- package/dist/specifica/types.js.map +1 -0
- package/dist/utils/logger.d.ts +17 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +51 -0
- package/dist/utils/logger.js.map +1 -0
- package/package.json +99 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configuration File Loader
|
|
3
|
+
*
|
|
4
|
+
* Loads and parses .circle-ir.yaml configuration files.
|
|
5
|
+
*/
|
|
6
|
+
import type { TaintConfig } from 'circle-ir';
|
|
7
|
+
/**
|
|
8
|
+
* User configuration file schema.
|
|
9
|
+
*/
|
|
10
|
+
export interface UserConfig {
|
|
11
|
+
project?: {
|
|
12
|
+
name?: string;
|
|
13
|
+
framework?: string;
|
|
14
|
+
framework_version?: string;
|
|
15
|
+
};
|
|
16
|
+
include?: string[];
|
|
17
|
+
exclude?: string[];
|
|
18
|
+
analysis?: {
|
|
19
|
+
max_files?: number;
|
|
20
|
+
timeout_ms?: number;
|
|
21
|
+
severity_threshold?: 'critical' | 'high' | 'medium' | 'low';
|
|
22
|
+
};
|
|
23
|
+
rules?: {
|
|
24
|
+
sources?: UserSourcePattern[];
|
|
25
|
+
sinks?: UserSinkPattern[];
|
|
26
|
+
sanitizers?: UserSanitizerPattern[];
|
|
27
|
+
};
|
|
28
|
+
overrides?: {
|
|
29
|
+
disable_rules?: string[];
|
|
30
|
+
severity_overrides?: Record<string, string>;
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* User-defined source pattern (simplified).
|
|
35
|
+
*/
|
|
36
|
+
export interface UserSourcePattern {
|
|
37
|
+
method?: string;
|
|
38
|
+
class?: string;
|
|
39
|
+
annotation?: string;
|
|
40
|
+
type: string;
|
|
41
|
+
severity?: 'critical' | 'high' | 'medium' | 'low';
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* User-defined sink pattern (simplified).
|
|
45
|
+
*/
|
|
46
|
+
export interface UserSinkPattern {
|
|
47
|
+
method: string;
|
|
48
|
+
class?: string;
|
|
49
|
+
type: string;
|
|
50
|
+
cwe: string;
|
|
51
|
+
severity?: 'critical' | 'high' | 'medium' | 'low';
|
|
52
|
+
arg_positions?: number[];
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* User-defined sanitizer pattern (simplified).
|
|
56
|
+
*/
|
|
57
|
+
export interface UserSanitizerPattern {
|
|
58
|
+
method?: string;
|
|
59
|
+
class?: string;
|
|
60
|
+
annotation?: string;
|
|
61
|
+
removes: string[];
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Resolved configuration with all defaults applied.
|
|
65
|
+
*/
|
|
66
|
+
export interface ResolvedConfig {
|
|
67
|
+
project: {
|
|
68
|
+
name?: string;
|
|
69
|
+
framework?: string;
|
|
70
|
+
framework_version?: string;
|
|
71
|
+
};
|
|
72
|
+
include: string[];
|
|
73
|
+
exclude: string[];
|
|
74
|
+
analysis: {
|
|
75
|
+
max_files: number;
|
|
76
|
+
timeout_ms: number;
|
|
77
|
+
severity_threshold: 'critical' | 'high' | 'medium' | 'low';
|
|
78
|
+
};
|
|
79
|
+
taint: TaintConfig;
|
|
80
|
+
disabled_rules: Set<string>;
|
|
81
|
+
severity_overrides: Map<string, string>;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Find a config file by searching up from a directory.
|
|
85
|
+
*/
|
|
86
|
+
export declare function findConfigFile(startDir: string): string | null;
|
|
87
|
+
/**
|
|
88
|
+
* Load a config file.
|
|
89
|
+
*/
|
|
90
|
+
export declare function loadConfigFile(configPath: string): UserConfig;
|
|
91
|
+
/**
|
|
92
|
+
* Resolve configuration by merging user config with defaults.
|
|
93
|
+
*/
|
|
94
|
+
export declare function resolveConfig(userConfig: UserConfig | null): ResolvedConfig;
|
|
95
|
+
/**
|
|
96
|
+
* Load and resolve configuration.
|
|
97
|
+
*/
|
|
98
|
+
export declare function loadConfig(configPath: string | null, startDir?: string): ResolvedConfig;
|
|
99
|
+
/**
|
|
100
|
+
* Create an example config file.
|
|
101
|
+
*/
|
|
102
|
+
export declare function createExampleConfig(): string;
|
|
103
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/cli/config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configuration File Loader
|
|
3
|
+
*
|
|
4
|
+
* Loads and parses .circle-ir.yaml configuration files.
|
|
5
|
+
*/
|
|
6
|
+
import * as fs from 'fs';
|
|
7
|
+
import * as path from 'path';
|
|
8
|
+
import { DEFAULT_SOURCES, DEFAULT_SINKS, DEFAULT_SANITIZERS } from 'circle-ir';
|
|
9
|
+
/**
|
|
10
|
+
* Default config file names to search for.
|
|
11
|
+
*/
|
|
12
|
+
const CONFIG_FILE_NAMES = [
|
|
13
|
+
'.circle-ir.yaml',
|
|
14
|
+
'.circle-ir.yml',
|
|
15
|
+
'.circle-ir.json',
|
|
16
|
+
'circle-ir.config.yaml',
|
|
17
|
+
'circle-ir.config.yml',
|
|
18
|
+
'circle-ir.config.json',
|
|
19
|
+
];
|
|
20
|
+
/**
|
|
21
|
+
* Find a config file by searching up from a directory.
|
|
22
|
+
*/
|
|
23
|
+
export function findConfigFile(startDir) {
|
|
24
|
+
let currentDir = path.resolve(startDir);
|
|
25
|
+
const root = path.parse(currentDir).root;
|
|
26
|
+
while (currentDir !== root) {
|
|
27
|
+
for (const configName of CONFIG_FILE_NAMES) {
|
|
28
|
+
const configPath = path.join(currentDir, configName);
|
|
29
|
+
if (fs.existsSync(configPath)) {
|
|
30
|
+
return configPath;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
currentDir = path.dirname(currentDir);
|
|
34
|
+
}
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Load a config file.
|
|
39
|
+
*/
|
|
40
|
+
export function loadConfigFile(configPath) {
|
|
41
|
+
const content = fs.readFileSync(configPath, 'utf-8');
|
|
42
|
+
const ext = path.extname(configPath).toLowerCase();
|
|
43
|
+
if (ext === '.json') {
|
|
44
|
+
return JSON.parse(content);
|
|
45
|
+
}
|
|
46
|
+
// Parse YAML (simple implementation for common cases)
|
|
47
|
+
return parseSimpleYaml(content);
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Simple YAML parser for configuration files.
|
|
51
|
+
* Handles basic key-value pairs, arrays, and nested objects.
|
|
52
|
+
*/
|
|
53
|
+
function parseSimpleYaml(content) {
|
|
54
|
+
const lines = content.split('\n');
|
|
55
|
+
const result = {};
|
|
56
|
+
const stack = [{ obj: result, indent: -1 }];
|
|
57
|
+
for (let i = 0; i < lines.length; i++) {
|
|
58
|
+
const line = lines[i];
|
|
59
|
+
// Skip empty lines and comments
|
|
60
|
+
if (!line.trim() || line.trim().startsWith('#')) {
|
|
61
|
+
continue;
|
|
62
|
+
}
|
|
63
|
+
const indent = line.search(/\S/);
|
|
64
|
+
const trimmed = line.trim();
|
|
65
|
+
// Pop stack until we find the right parent
|
|
66
|
+
while (stack.length > 1 && stack[stack.length - 1].indent >= indent) {
|
|
67
|
+
stack.pop();
|
|
68
|
+
}
|
|
69
|
+
const parent = stack[stack.length - 1].obj;
|
|
70
|
+
// Array item
|
|
71
|
+
if (trimmed.startsWith('- ')) {
|
|
72
|
+
const value = trimmed.substring(2).trim();
|
|
73
|
+
if (!Array.isArray(parent)) {
|
|
74
|
+
// Find the array we're adding to
|
|
75
|
+
const keys = Object.keys(parent);
|
|
76
|
+
const lastKey = keys[keys.length - 1];
|
|
77
|
+
if (lastKey && !Array.isArray(parent[lastKey])) {
|
|
78
|
+
parent[lastKey] = [];
|
|
79
|
+
}
|
|
80
|
+
if (value.includes(':')) {
|
|
81
|
+
// Object in array
|
|
82
|
+
const obj = {};
|
|
83
|
+
parseInlineObject(value, obj);
|
|
84
|
+
parent[lastKey].push(obj);
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
parent[lastKey].push(parseValue(value));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
parent.push(parseValue(value));
|
|
92
|
+
}
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
// Key-value pair
|
|
96
|
+
const colonIndex = trimmed.indexOf(':');
|
|
97
|
+
if (colonIndex > 0) {
|
|
98
|
+
const key = trimmed.substring(0, colonIndex).trim();
|
|
99
|
+
const valueStr = trimmed.substring(colonIndex + 1).trim();
|
|
100
|
+
if (valueStr === '' || valueStr === '|' || valueStr === '>') {
|
|
101
|
+
// Nested object or multiline string
|
|
102
|
+
parent[key] = {};
|
|
103
|
+
stack.push({ obj: parent[key], indent });
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
parent[key] = parseValue(valueStr);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return result;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Parse inline object like "method: foo, class: Bar".
|
|
114
|
+
*/
|
|
115
|
+
function parseInlineObject(str, obj) {
|
|
116
|
+
const parts = str.split(',');
|
|
117
|
+
for (const part of parts) {
|
|
118
|
+
const colonIdx = part.indexOf(':');
|
|
119
|
+
if (colonIdx > 0) {
|
|
120
|
+
const key = part.substring(0, colonIdx).trim();
|
|
121
|
+
const value = part.substring(colonIdx + 1).trim();
|
|
122
|
+
obj[key] = parseValue(value);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Parse a YAML value.
|
|
128
|
+
*/
|
|
129
|
+
function parseValue(str) {
|
|
130
|
+
if (str === 'true')
|
|
131
|
+
return true;
|
|
132
|
+
if (str === 'false')
|
|
133
|
+
return false;
|
|
134
|
+
if (str === 'null')
|
|
135
|
+
return null;
|
|
136
|
+
if (/^-?\d+$/.test(str))
|
|
137
|
+
return parseInt(str, 10);
|
|
138
|
+
if (/^-?\d+\.\d+$/.test(str))
|
|
139
|
+
return parseFloat(str);
|
|
140
|
+
// Remove quotes
|
|
141
|
+
if ((str.startsWith('"') && str.endsWith('"')) ||
|
|
142
|
+
(str.startsWith("'") && str.endsWith("'"))) {
|
|
143
|
+
return str.slice(1, -1);
|
|
144
|
+
}
|
|
145
|
+
// Array notation
|
|
146
|
+
if (str.startsWith('[') && str.endsWith(']')) {
|
|
147
|
+
const inner = str.slice(1, -1).trim();
|
|
148
|
+
if (!inner)
|
|
149
|
+
return [];
|
|
150
|
+
return inner.split(',').map(s => parseValue(s.trim()));
|
|
151
|
+
}
|
|
152
|
+
return str;
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Resolve configuration by merging user config with defaults.
|
|
156
|
+
*/
|
|
157
|
+
export function resolveConfig(userConfig) {
|
|
158
|
+
const sources = [...DEFAULT_SOURCES];
|
|
159
|
+
const sinks = [...DEFAULT_SINKS];
|
|
160
|
+
const sanitizers = [...DEFAULT_SANITIZERS];
|
|
161
|
+
// Add user-defined rules
|
|
162
|
+
if (userConfig?.rules?.sources) {
|
|
163
|
+
for (const source of userConfig.rules.sources) {
|
|
164
|
+
sources.push({
|
|
165
|
+
method: source.method,
|
|
166
|
+
class: source.class,
|
|
167
|
+
annotation: source.annotation,
|
|
168
|
+
type: source.type,
|
|
169
|
+
severity: (source.severity || 'high'),
|
|
170
|
+
return_tainted: source.method ? true : undefined,
|
|
171
|
+
param_tainted: source.annotation ? true : undefined,
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
if (userConfig?.rules?.sinks) {
|
|
176
|
+
for (const sink of userConfig.rules.sinks) {
|
|
177
|
+
sinks.push({
|
|
178
|
+
method: sink.method,
|
|
179
|
+
class: sink.class,
|
|
180
|
+
type: sink.type,
|
|
181
|
+
cwe: sink.cwe,
|
|
182
|
+
severity: (sink.severity || 'high'),
|
|
183
|
+
arg_positions: sink.arg_positions || [0],
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
if (userConfig?.rules?.sanitizers) {
|
|
188
|
+
for (const sanitizer of userConfig.rules.sanitizers) {
|
|
189
|
+
sanitizers.push({
|
|
190
|
+
method: sanitizer.method,
|
|
191
|
+
class: sanitizer.class,
|
|
192
|
+
annotation: sanitizer.annotation,
|
|
193
|
+
removes: sanitizer.removes,
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
// Build disabled rules set
|
|
198
|
+
const disabled_rules = new Set(userConfig?.overrides?.disable_rules || []);
|
|
199
|
+
// Filter out disabled sinks
|
|
200
|
+
const filteredSinks = sinks.filter(s => !disabled_rules.has(s.cwe));
|
|
201
|
+
// Build severity overrides map
|
|
202
|
+
const severity_overrides = new Map(Object.entries(userConfig?.overrides?.severity_overrides || {}));
|
|
203
|
+
return {
|
|
204
|
+
project: {
|
|
205
|
+
name: userConfig?.project?.name,
|
|
206
|
+
framework: userConfig?.project?.framework,
|
|
207
|
+
framework_version: userConfig?.project?.framework_version,
|
|
208
|
+
},
|
|
209
|
+
include: userConfig?.include || [],
|
|
210
|
+
exclude: userConfig?.exclude || [],
|
|
211
|
+
analysis: {
|
|
212
|
+
max_files: userConfig?.analysis?.max_files || 10000,
|
|
213
|
+
timeout_ms: userConfig?.analysis?.timeout_ms || 300000,
|
|
214
|
+
severity_threshold: userConfig?.analysis?.severity_threshold || 'low',
|
|
215
|
+
},
|
|
216
|
+
taint: {
|
|
217
|
+
sources,
|
|
218
|
+
sinks: filteredSinks,
|
|
219
|
+
sanitizers,
|
|
220
|
+
},
|
|
221
|
+
disabled_rules,
|
|
222
|
+
severity_overrides,
|
|
223
|
+
};
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* Load and resolve configuration.
|
|
227
|
+
*/
|
|
228
|
+
export function loadConfig(configPath, startDir = process.cwd()) {
|
|
229
|
+
let userConfig = null;
|
|
230
|
+
if (configPath) {
|
|
231
|
+
// Explicit config file
|
|
232
|
+
if (!fs.existsSync(configPath)) {
|
|
233
|
+
throw new Error(`Config file not found: ${configPath}`);
|
|
234
|
+
}
|
|
235
|
+
userConfig = loadConfigFile(configPath);
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
// Search for config file
|
|
239
|
+
const foundConfig = findConfigFile(startDir);
|
|
240
|
+
if (foundConfig) {
|
|
241
|
+
userConfig = loadConfigFile(foundConfig);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
return resolveConfig(userConfig);
|
|
245
|
+
}
|
|
246
|
+
/**
|
|
247
|
+
* Create an example config file.
|
|
248
|
+
*/
|
|
249
|
+
export function createExampleConfig() {
|
|
250
|
+
return `# Circle-IR Configuration File
|
|
251
|
+
# Place this file as .circle-ir.yaml in your project root
|
|
252
|
+
|
|
253
|
+
# Project metadata
|
|
254
|
+
project:
|
|
255
|
+
name: my-project
|
|
256
|
+
framework: spring
|
|
257
|
+
framework_version: "5.3"
|
|
258
|
+
|
|
259
|
+
# File discovery patterns
|
|
260
|
+
include:
|
|
261
|
+
- "src/main/**/*.java"
|
|
262
|
+
exclude:
|
|
263
|
+
- "**/test/**"
|
|
264
|
+
- "**/generated/**"
|
|
265
|
+
|
|
266
|
+
# Analysis settings
|
|
267
|
+
analysis:
|
|
268
|
+
max_files: 1000
|
|
269
|
+
timeout_ms: 300000
|
|
270
|
+
severity_threshold: medium
|
|
271
|
+
|
|
272
|
+
# Custom security rules
|
|
273
|
+
rules:
|
|
274
|
+
# Custom sources (where tainted data enters)
|
|
275
|
+
sources:
|
|
276
|
+
- method: getUnsafeInput
|
|
277
|
+
class: CustomInput
|
|
278
|
+
type: custom_input
|
|
279
|
+
severity: high
|
|
280
|
+
|
|
281
|
+
# Custom sinks (dangerous operations)
|
|
282
|
+
sinks:
|
|
283
|
+
- method: unsafeOperation
|
|
284
|
+
class: DangerousClass
|
|
285
|
+
type: custom_vulnerability
|
|
286
|
+
cwe: CWE-1234
|
|
287
|
+
severity: critical
|
|
288
|
+
arg_positions: [0, 1]
|
|
289
|
+
|
|
290
|
+
# Custom sanitizers
|
|
291
|
+
sanitizers:
|
|
292
|
+
- method: sanitizeInput
|
|
293
|
+
class: SecurityUtils
|
|
294
|
+
removes: [sql_injection, xss]
|
|
295
|
+
|
|
296
|
+
# Rule overrides
|
|
297
|
+
overrides:
|
|
298
|
+
# Disable specific rules by CWE ID
|
|
299
|
+
disable_rules:
|
|
300
|
+
- CWE-79 # Disable XSS checks
|
|
301
|
+
|
|
302
|
+
# Override severity for specific rules
|
|
303
|
+
severity_overrides:
|
|
304
|
+
CWE-89: critical # Make SQL injection critical
|
|
305
|
+
`;
|
|
306
|
+
}
|
|
307
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/cli/config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* File Discovery Module
|
|
3
|
+
*
|
|
4
|
+
* Discovers source files in directories for project-level analysis.
|
|
5
|
+
*/
|
|
6
|
+
export interface DiscoveryOptions {
|
|
7
|
+
include?: string[];
|
|
8
|
+
exclude?: string[];
|
|
9
|
+
maxFiles?: number;
|
|
10
|
+
}
|
|
11
|
+
export interface DiscoveredFile {
|
|
12
|
+
path: string;
|
|
13
|
+
relativePath: string;
|
|
14
|
+
language: 'java' | 'c' | 'cpp' | 'javascript' | 'typescript' | 'rust' | 'python';
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Discover source files in a directory.
|
|
18
|
+
*/
|
|
19
|
+
export declare function discoverFiles(directory: string, options?: DiscoveryOptions): DiscoveredFile[];
|
|
20
|
+
/**
|
|
21
|
+
* Read file contents.
|
|
22
|
+
*/
|
|
23
|
+
export declare function readFileContent(filePath: string): string;
|
|
24
|
+
/**
|
|
25
|
+
* Get project statistics.
|
|
26
|
+
*/
|
|
27
|
+
export declare function getProjectStats(files: DiscoveredFile[]): {
|
|
28
|
+
total: number;
|
|
29
|
+
byLanguage: Record<string, number>;
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=discovery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"discovery.d.ts","sourceRoot":"","sources":["../../src/cli/discovery.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,MAAM,WAAW,gBAAgB;IAC/B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,GAAG,GAAG,GAAG,KAAK,GAAG,YAAY,GAAG,YAAY,GAAG,MAAM,GAAG,QAAQ,CAAC;CAClF;AAoCD;;GAEG;AACH,wBAAgB,aAAa,CAC3B,SAAS,EAAE,MAAM,EACjB,OAAO,GAAE,gBAAqB,GAC7B,cAAc,EAAE,CAkBlB;AAgJD;;GAEG;AACH,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAExD;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,cAAc,EAAE,GAAG;IACxD,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACpC,CAmBA"}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* File Discovery Module
|
|
3
|
+
*
|
|
4
|
+
* Discovers source files in directories for project-level analysis.
|
|
5
|
+
*/
|
|
6
|
+
import * as fs from 'fs';
|
|
7
|
+
import * as path from 'path';
|
|
8
|
+
// Default file extensions by language
|
|
9
|
+
const LANGUAGE_EXTENSIONS = {
|
|
10
|
+
java: ['.java'],
|
|
11
|
+
c: ['.c', '.h'],
|
|
12
|
+
cpp: ['.cpp', '.cc', '.cxx', '.hpp', '.hh', '.hxx'],
|
|
13
|
+
javascript: ['.js', '.jsx', '.mjs', '.cjs'],
|
|
14
|
+
typescript: ['.ts', '.tsx', '.mts', '.cts'],
|
|
15
|
+
rust: ['.rs'],
|
|
16
|
+
python: ['.py'],
|
|
17
|
+
};
|
|
18
|
+
// Default directories to exclude
|
|
19
|
+
const DEFAULT_EXCLUDES = [
|
|
20
|
+
'node_modules',
|
|
21
|
+
'.git',
|
|
22
|
+
'.svn',
|
|
23
|
+
'.hg',
|
|
24
|
+
'build',
|
|
25
|
+
'dist',
|
|
26
|
+
'target',
|
|
27
|
+
'out',
|
|
28
|
+
'bin',
|
|
29
|
+
'.idea',
|
|
30
|
+
'.vscode',
|
|
31
|
+
'__pycache__',
|
|
32
|
+
'.gradle',
|
|
33
|
+
'.m2',
|
|
34
|
+
'vendor',
|
|
35
|
+
'test',
|
|
36
|
+
'tests',
|
|
37
|
+
'**/test/**',
|
|
38
|
+
'**/tests/**',
|
|
39
|
+
];
|
|
40
|
+
/**
|
|
41
|
+
* Discover source files in a directory.
|
|
42
|
+
*/
|
|
43
|
+
export function discoverFiles(directory, options = {}) {
|
|
44
|
+
const files = [];
|
|
45
|
+
const excludePatterns = [...DEFAULT_EXCLUDES, ...(options.exclude || [])];
|
|
46
|
+
const includePatterns = options.include || [];
|
|
47
|
+
const maxFiles = options.maxFiles || 10000;
|
|
48
|
+
// Get all supported extensions
|
|
49
|
+
const allExtensions = new Set();
|
|
50
|
+
for (const exts of Object.values(LANGUAGE_EXTENSIONS)) {
|
|
51
|
+
for (const ext of exts) {
|
|
52
|
+
allExtensions.add(ext);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
// Recursively scan directory
|
|
56
|
+
scanDirectory(directory, directory, files, allExtensions, excludePatterns, includePatterns, maxFiles);
|
|
57
|
+
return files;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Recursively scan a directory for source files.
|
|
61
|
+
*/
|
|
62
|
+
function scanDirectory(rootDir, currentDir, files, extensions, excludePatterns, includePatterns, maxFiles) {
|
|
63
|
+
if (files.length >= maxFiles) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
let entries;
|
|
67
|
+
try {
|
|
68
|
+
entries = fs.readdirSync(currentDir, { withFileTypes: true });
|
|
69
|
+
}
|
|
70
|
+
catch {
|
|
71
|
+
// Directory not readable, skip
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
for (const entry of entries) {
|
|
75
|
+
if (files.length >= maxFiles) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
const fullPath = path.join(currentDir, entry.name);
|
|
79
|
+
const relativePath = path.relative(rootDir, fullPath);
|
|
80
|
+
// Check excludes
|
|
81
|
+
if (shouldExclude(relativePath, entry.name, excludePatterns)) {
|
|
82
|
+
continue;
|
|
83
|
+
}
|
|
84
|
+
if (entry.isDirectory()) {
|
|
85
|
+
scanDirectory(rootDir, fullPath, files, extensions, excludePatterns, includePatterns, maxFiles);
|
|
86
|
+
}
|
|
87
|
+
else if (entry.isFile()) {
|
|
88
|
+
const ext = path.extname(entry.name).toLowerCase();
|
|
89
|
+
if (extensions.has(ext)) {
|
|
90
|
+
// Check includes if specified
|
|
91
|
+
if (includePatterns.length > 0 && !matchesAnyPattern(relativePath, includePatterns)) {
|
|
92
|
+
continue;
|
|
93
|
+
}
|
|
94
|
+
const language = detectLanguage(ext);
|
|
95
|
+
if (language) {
|
|
96
|
+
files.push({
|
|
97
|
+
path: fullPath,
|
|
98
|
+
relativePath,
|
|
99
|
+
language,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Check if a path should be excluded.
|
|
108
|
+
*/
|
|
109
|
+
function shouldExclude(relativePath, name, patterns) {
|
|
110
|
+
for (const pattern of patterns) {
|
|
111
|
+
// Simple pattern matching
|
|
112
|
+
if (pattern.includes('*')) {
|
|
113
|
+
// Glob-like pattern
|
|
114
|
+
const regex = patternToRegex(pattern);
|
|
115
|
+
if (regex.test(relativePath) || regex.test(name)) {
|
|
116
|
+
return true;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
// Exact match or path contains
|
|
121
|
+
if (name === pattern || relativePath.includes(pattern)) {
|
|
122
|
+
return true;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
return false;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Check if path matches any include pattern.
|
|
130
|
+
*/
|
|
131
|
+
function matchesAnyPattern(relativePath, patterns) {
|
|
132
|
+
for (const pattern of patterns) {
|
|
133
|
+
if (pattern.includes('*')) {
|
|
134
|
+
const regex = patternToRegex(pattern);
|
|
135
|
+
if (regex.test(relativePath)) {
|
|
136
|
+
return true;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
if (relativePath.includes(pattern)) {
|
|
141
|
+
return true;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
return false;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Convert glob pattern to regex.
|
|
149
|
+
*/
|
|
150
|
+
function patternToRegex(pattern) {
|
|
151
|
+
const escaped = pattern
|
|
152
|
+
.replace(/[.+^${}()|[\]\\]/g, '\\$&')
|
|
153
|
+
.replace(/\*\*/g, '{{GLOBSTAR}}')
|
|
154
|
+
.replace(/\*/g, '[^/]*')
|
|
155
|
+
.replace(/{{GLOBSTAR}}/g, '.*');
|
|
156
|
+
return new RegExp(escaped);
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Detect language from file extension.
|
|
160
|
+
*/
|
|
161
|
+
function detectLanguage(ext) {
|
|
162
|
+
if (LANGUAGE_EXTENSIONS.java.includes(ext)) {
|
|
163
|
+
return 'java';
|
|
164
|
+
}
|
|
165
|
+
if (LANGUAGE_EXTENSIONS.c.includes(ext)) {
|
|
166
|
+
return 'c';
|
|
167
|
+
}
|
|
168
|
+
if (LANGUAGE_EXTENSIONS.cpp.includes(ext)) {
|
|
169
|
+
return 'cpp';
|
|
170
|
+
}
|
|
171
|
+
if (LANGUAGE_EXTENSIONS.javascript.includes(ext)) {
|
|
172
|
+
return 'javascript';
|
|
173
|
+
}
|
|
174
|
+
if (LANGUAGE_EXTENSIONS.typescript.includes(ext)) {
|
|
175
|
+
return 'typescript';
|
|
176
|
+
}
|
|
177
|
+
if (LANGUAGE_EXTENSIONS.rust.includes(ext)) {
|
|
178
|
+
return 'rust';
|
|
179
|
+
}
|
|
180
|
+
if (LANGUAGE_EXTENSIONS.python.includes(ext)) {
|
|
181
|
+
return 'python';
|
|
182
|
+
}
|
|
183
|
+
return null;
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Read file contents.
|
|
187
|
+
*/
|
|
188
|
+
export function readFileContent(filePath) {
|
|
189
|
+
return fs.readFileSync(filePath, 'utf-8');
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Get project statistics.
|
|
193
|
+
*/
|
|
194
|
+
export function getProjectStats(files) {
|
|
195
|
+
const byLanguage = {
|
|
196
|
+
java: 0,
|
|
197
|
+
c: 0,
|
|
198
|
+
cpp: 0,
|
|
199
|
+
javascript: 0,
|
|
200
|
+
typescript: 0,
|
|
201
|
+
rust: 0,
|
|
202
|
+
python: 0,
|
|
203
|
+
};
|
|
204
|
+
for (const file of files) {
|
|
205
|
+
byLanguage[file.language]++;
|
|
206
|
+
}
|
|
207
|
+
return {
|
|
208
|
+
total: files.length,
|
|
209
|
+
byLanguage,
|
|
210
|
+
};
|
|
211
|
+
}
|
|
212
|
+
//# sourceMappingURL=discovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"discovery.js","sourceRoot":"","sources":["../../src/cli/discovery.ts"],"names":[],"mappings":"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"}
|