driftdetect-core 0.4.5 → 0.5.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/LICENSE +21 -0
- package/dist/boundaries/boundary-scanner.d.ts.map +1 -1
- package/dist/boundaries/boundary-scanner.js +184 -18
- package/dist/boundaries/boundary-scanner.js.map +1 -1
- package/dist/boundaries/types.d.ts +34 -2
- package/dist/boundaries/types.d.ts.map +1 -1
- package/dist/call-graph/analysis/graph-builder.d.ts +3 -0
- package/dist/call-graph/analysis/graph-builder.d.ts.map +1 -1
- package/dist/call-graph/analysis/graph-builder.js +81 -18
- package/dist/call-graph/analysis/graph-builder.js.map +1 -1
- package/dist/call-graph/extractors/csharp-data-access-extractor.d.ts +8 -0
- package/dist/call-graph/extractors/csharp-data-access-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/csharp-data-access-extractor.js +18 -5
- package/dist/call-graph/extractors/csharp-data-access-extractor.js.map +1 -1
- package/dist/call-graph/extractors/csharp-extractor.d.ts +35 -0
- package/dist/call-graph/extractors/csharp-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/csharp-extractor.js +362 -4
- package/dist/call-graph/extractors/csharp-extractor.js.map +1 -1
- package/dist/call-graph/extractors/csharp-hybrid-extractor.d.ts +37 -0
- package/dist/call-graph/extractors/csharp-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/csharp-hybrid-extractor.js +408 -0
- package/dist/call-graph/extractors/csharp-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/extractors/data-access-extractor.d.ts +16 -2
- package/dist/call-graph/extractors/data-access-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/data-access-extractor.js +114 -5
- package/dist/call-graph/extractors/data-access-extractor.js.map +1 -1
- package/dist/call-graph/extractors/hybrid-extractor-base.d.ts +102 -0
- package/dist/call-graph/extractors/hybrid-extractor-base.d.ts.map +1 -0
- package/dist/call-graph/extractors/hybrid-extractor-base.js +289 -0
- package/dist/call-graph/extractors/hybrid-extractor-base.js.map +1 -0
- package/dist/call-graph/extractors/index.d.ts +17 -13
- package/dist/call-graph/extractors/index.d.ts.map +1 -1
- package/dist/call-graph/extractors/index.js +24 -23
- package/dist/call-graph/extractors/index.js.map +1 -1
- package/dist/call-graph/extractors/java-data-access-extractor.d.ts +8 -0
- package/dist/call-graph/extractors/java-data-access-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/java-data-access-extractor.js +20 -6
- package/dist/call-graph/extractors/java-data-access-extractor.js.map +1 -1
- package/dist/call-graph/extractors/java-extractor.d.ts +15 -0
- package/dist/call-graph/extractors/java-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/java-extractor.js +120 -4
- package/dist/call-graph/extractors/java-extractor.js.map +1 -1
- package/dist/call-graph/extractors/java-hybrid-extractor.d.ts +36 -0
- package/dist/call-graph/extractors/java-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/java-hybrid-extractor.js +426 -0
- package/dist/call-graph/extractors/java-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/extractors/php-data-access-extractor.d.ts +8 -0
- package/dist/call-graph/extractors/php-data-access-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/php-data-access-extractor.js +20 -6
- package/dist/call-graph/extractors/php-data-access-extractor.js.map +1 -1
- package/dist/call-graph/extractors/php-extractor.d.ts +48 -1
- package/dist/call-graph/extractors/php-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/php-extractor.js +460 -6
- package/dist/call-graph/extractors/php-extractor.js.map +1 -1
- package/dist/call-graph/extractors/php-hybrid-extractor.d.ts +35 -0
- package/dist/call-graph/extractors/php-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/php-hybrid-extractor.js +393 -0
- package/dist/call-graph/extractors/php-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/extractors/python-data-access-extractor.d.ts +8 -0
- package/dist/call-graph/extractors/python-data-access-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/python-data-access-extractor.js +20 -6
- package/dist/call-graph/extractors/python-data-access-extractor.js.map +1 -1
- package/dist/call-graph/extractors/python-hybrid-extractor.d.ts +85 -0
- package/dist/call-graph/extractors/python-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/python-hybrid-extractor.js +462 -0
- package/dist/call-graph/extractors/python-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/extractors/regex/base-regex-extractor.d.ts +154 -0
- package/dist/call-graph/extractors/regex/base-regex-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/base-regex-extractor.js +346 -0
- package/dist/call-graph/extractors/regex/base-regex-extractor.js.map +1 -0
- package/dist/call-graph/extractors/regex/csharp-regex.d.ts +34 -0
- package/dist/call-graph/extractors/regex/csharp-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/csharp-regex.js +393 -0
- package/dist/call-graph/extractors/regex/csharp-regex.js.map +1 -0
- package/dist/call-graph/extractors/regex/index.d.ts +25 -0
- package/dist/call-graph/extractors/regex/index.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/index.js +66 -0
- package/dist/call-graph/extractors/regex/index.js.map +1 -0
- package/dist/call-graph/extractors/regex/java-regex.d.ts +34 -0
- package/dist/call-graph/extractors/regex/java-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/java-regex.js +327 -0
- package/dist/call-graph/extractors/regex/java-regex.js.map +1 -0
- package/dist/call-graph/extractors/regex/php-regex.d.ts +30 -0
- package/dist/call-graph/extractors/regex/php-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/php-regex.js +333 -0
- package/dist/call-graph/extractors/regex/php-regex.js.map +1 -0
- package/dist/call-graph/extractors/regex/python-regex.d.ts +46 -0
- package/dist/call-graph/extractors/regex/python-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/python-regex.js +380 -0
- package/dist/call-graph/extractors/regex/python-regex.js.map +1 -0
- package/dist/call-graph/extractors/regex/typescript-regex.d.ts +27 -0
- package/dist/call-graph/extractors/regex/typescript-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/typescript-regex.js +349 -0
- package/dist/call-graph/extractors/regex/typescript-regex.js.map +1 -0
- package/dist/call-graph/extractors/semantic-data-access-scanner.d.ts +11 -0
- package/dist/call-graph/extractors/semantic-data-access-scanner.d.ts.map +1 -1
- package/dist/call-graph/extractors/semantic-data-access-scanner.js +53 -2
- package/dist/call-graph/extractors/semantic-data-access-scanner.js.map +1 -1
- package/dist/call-graph/extractors/types.d.ts +111 -0
- package/dist/call-graph/extractors/types.d.ts.map +1 -0
- package/dist/call-graph/extractors/types.js +68 -0
- package/dist/call-graph/extractors/types.js.map +1 -0
- package/dist/call-graph/extractors/typescript-data-access-extractor.d.ts +8 -0
- package/dist/call-graph/extractors/typescript-data-access-extractor.d.ts.map +1 -1
- package/dist/call-graph/extractors/typescript-data-access-extractor.js +31 -10
- package/dist/call-graph/extractors/typescript-data-access-extractor.js.map +1 -1
- package/dist/call-graph/extractors/typescript-hybrid-extractor.d.ts +116 -0
- package/dist/call-graph/extractors/typescript-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/typescript-hybrid-extractor.js +635 -0
- package/dist/call-graph/extractors/typescript-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/index.d.ts +2 -4
- package/dist/call-graph/index.d.ts.map +1 -1
- package/dist/call-graph/index.js +5 -6
- package/dist/call-graph/index.js.map +1 -1
- package/dist/error-handling/error-handling-analyzer.d.ts +73 -0
- package/dist/error-handling/error-handling-analyzer.d.ts.map +1 -0
- package/dist/error-handling/error-handling-analyzer.js +706 -0
- package/dist/error-handling/error-handling-analyzer.js.map +1 -0
- package/dist/error-handling/index.d.ts +8 -0
- package/dist/error-handling/index.d.ts.map +1 -0
- package/dist/error-handling/index.js +8 -0
- package/dist/error-handling/index.js.map +1 -0
- package/dist/error-handling/types.d.ts +307 -0
- package/dist/error-handling/types.d.ts.map +1 -0
- package/dist/error-handling/types.js +7 -0
- package/dist/error-handling/types.js.map +1 -0
- package/dist/index.d.ts +18 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +44 -5
- package/dist/index.js.map +1 -1
- package/dist/lake/pattern-shard-store.d.ts +6 -0
- package/dist/lake/pattern-shard-store.d.ts.map +1 -1
- package/dist/lake/pattern-shard-store.js +6 -0
- package/dist/lake/pattern-shard-store.js.map +1 -1
- package/dist/language-intelligence/base-normalizer.d.ts +68 -0
- package/dist/language-intelligence/base-normalizer.d.ts.map +1 -0
- package/dist/language-intelligence/base-normalizer.js +210 -0
- package/dist/language-intelligence/base-normalizer.js.map +1 -0
- package/dist/language-intelligence/framework-registry.d.ts +89 -0
- package/dist/language-intelligence/framework-registry.d.ts.map +1 -0
- package/dist/language-intelligence/framework-registry.js +165 -0
- package/dist/language-intelligence/framework-registry.js.map +1 -0
- package/dist/language-intelligence/frameworks/aspnet.d.ts +11 -0
- package/dist/language-intelligence/frameworks/aspnet.d.ts.map +1 -0
- package/dist/language-intelligence/frameworks/aspnet.js +325 -0
- package/dist/language-intelligence/frameworks/aspnet.js.map +1 -0
- package/dist/language-intelligence/frameworks/fastapi.d.ts +11 -0
- package/dist/language-intelligence/frameworks/fastapi.d.ts.map +1 -0
- package/dist/language-intelligence/frameworks/fastapi.js +188 -0
- package/dist/language-intelligence/frameworks/fastapi.js.map +1 -0
- package/dist/language-intelligence/frameworks/index.d.ts +32 -0
- package/dist/language-intelligence/frameworks/index.d.ts.map +1 -0
- package/dist/language-intelligence/frameworks/index.js +51 -0
- package/dist/language-intelligence/frameworks/index.js.map +1 -0
- package/dist/language-intelligence/frameworks/laravel.d.ts +12 -0
- package/dist/language-intelligence/frameworks/laravel.d.ts.map +1 -0
- package/dist/language-intelligence/frameworks/laravel.js +194 -0
- package/dist/language-intelligence/frameworks/laravel.js.map +1 -0
- package/dist/language-intelligence/frameworks/nestjs.d.ts +11 -0
- package/dist/language-intelligence/frameworks/nestjs.d.ts.map +1 -0
- package/dist/language-intelligence/frameworks/nestjs.js +307 -0
- package/dist/language-intelligence/frameworks/nestjs.js.map +1 -0
- package/dist/language-intelligence/frameworks/spring.d.ts +11 -0
- package/dist/language-intelligence/frameworks/spring.d.ts.map +1 -0
- package/dist/language-intelligence/frameworks/spring.js +369 -0
- package/dist/language-intelligence/frameworks/spring.js.map +1 -0
- package/dist/language-intelligence/index.d.ts +33 -0
- package/dist/language-intelligence/index.d.ts.map +1 -0
- package/dist/language-intelligence/index.js +37 -0
- package/dist/language-intelligence/index.js.map +1 -0
- package/dist/language-intelligence/language-intelligence.d.ts +99 -0
- package/dist/language-intelligence/language-intelligence.d.ts.map +1 -0
- package/dist/language-intelligence/language-intelligence.js +239 -0
- package/dist/language-intelligence/language-intelligence.js.map +1 -0
- package/dist/language-intelligence/normalizers/csharp-normalizer.d.ts +39 -0
- package/dist/language-intelligence/normalizers/csharp-normalizer.d.ts.map +1 -0
- package/dist/language-intelligence/normalizers/csharp-normalizer.js +86 -0
- package/dist/language-intelligence/normalizers/csharp-normalizer.js.map +1 -0
- package/dist/language-intelligence/normalizers/index.d.ts +25 -0
- package/dist/language-intelligence/normalizers/index.d.ts.map +1 -0
- package/dist/language-intelligence/normalizers/index.js +60 -0
- package/dist/language-intelligence/normalizers/index.js.map +1 -0
- package/dist/language-intelligence/normalizers/java-normalizer.d.ts +39 -0
- package/dist/language-intelligence/normalizers/java-normalizer.d.ts.map +1 -0
- package/dist/language-intelligence/normalizers/java-normalizer.js +96 -0
- package/dist/language-intelligence/normalizers/java-normalizer.js.map +1 -0
- package/dist/language-intelligence/normalizers/php-normalizer.d.ts +39 -0
- package/dist/language-intelligence/normalizers/php-normalizer.d.ts.map +1 -0
- package/dist/language-intelligence/normalizers/php-normalizer.js +86 -0
- package/dist/language-intelligence/normalizers/php-normalizer.js.map +1 -0
- package/dist/language-intelligence/normalizers/python-normalizer.d.ts +39 -0
- package/dist/language-intelligence/normalizers/python-normalizer.d.ts.map +1 -0
- package/dist/language-intelligence/normalizers/python-normalizer.js +95 -0
- package/dist/language-intelligence/normalizers/python-normalizer.js.map +1 -0
- package/dist/language-intelligence/normalizers/typescript-normalizer.d.ts +39 -0
- package/dist/language-intelligence/normalizers/typescript-normalizer.d.ts.map +1 -0
- package/dist/language-intelligence/normalizers/typescript-normalizer.js +84 -0
- package/dist/language-intelligence/normalizers/typescript-normalizer.js.map +1 -0
- package/dist/language-intelligence/types.d.ts +270 -0
- package/dist/language-intelligence/types.d.ts.map +1 -0
- package/dist/language-intelligence/types.js +9 -0
- package/dist/language-intelligence/types.js.map +1 -0
- package/dist/module-coupling/coupling-analyzer.d.ts +73 -0
- package/dist/module-coupling/coupling-analyzer.d.ts.map +1 -0
- package/dist/module-coupling/coupling-analyzer.js +668 -0
- package/dist/module-coupling/coupling-analyzer.js.map +1 -0
- package/dist/module-coupling/index.d.ts +9 -0
- package/dist/module-coupling/index.d.ts.map +1 -0
- package/dist/module-coupling/index.js +9 -0
- package/dist/module-coupling/index.js.map +1 -0
- package/dist/module-coupling/types.d.ts +273 -0
- package/dist/module-coupling/types.d.ts.map +1 -0
- package/dist/module-coupling/types.js +8 -0
- package/dist/module-coupling/types.js.map +1 -0
- package/dist/patterns/adapters/index.d.ts +11 -0
- package/dist/patterns/adapters/index.d.ts.map +1 -0
- package/dist/patterns/adapters/index.js +11 -0
- package/dist/patterns/adapters/index.js.map +1 -0
- package/dist/patterns/adapters/pattern-store-adapter.d.ts +59 -0
- package/dist/patterns/adapters/pattern-store-adapter.d.ts.map +1 -0
- package/dist/patterns/adapters/pattern-store-adapter.js +468 -0
- package/dist/patterns/adapters/pattern-store-adapter.js.map +1 -0
- package/dist/patterns/adapters/service-factory.d.ts +40 -0
- package/dist/patterns/adapters/service-factory.d.ts.map +1 -0
- package/dist/patterns/adapters/service-factory.js +144 -0
- package/dist/patterns/adapters/service-factory.js.map +1 -0
- package/dist/patterns/errors.d.ts +32 -0
- package/dist/patterns/errors.d.ts.map +1 -0
- package/dist/patterns/errors.js +45 -0
- package/dist/patterns/errors.js.map +1 -0
- package/dist/patterns/impl/cached-repository.d.ts +79 -0
- package/dist/patterns/impl/cached-repository.d.ts.map +1 -0
- package/dist/patterns/impl/cached-repository.js +296 -0
- package/dist/patterns/impl/cached-repository.js.map +1 -0
- package/dist/patterns/impl/file-repository.d.ts +75 -0
- package/dist/patterns/impl/file-repository.d.ts.map +1 -0
- package/dist/patterns/impl/file-repository.js +507 -0
- package/dist/patterns/impl/file-repository.js.map +1 -0
- package/dist/patterns/impl/index.d.ts +16 -0
- package/dist/patterns/impl/index.d.ts.map +1 -0
- package/dist/patterns/impl/index.js +21 -0
- package/dist/patterns/impl/index.js.map +1 -0
- package/dist/patterns/impl/memory-repository.d.ts +56 -0
- package/dist/patterns/impl/memory-repository.d.ts.map +1 -0
- package/dist/patterns/impl/memory-repository.js +323 -0
- package/dist/patterns/impl/memory-repository.js.map +1 -0
- package/dist/patterns/impl/pattern-service.d.ts +52 -0
- package/dist/patterns/impl/pattern-service.d.ts.map +1 -0
- package/dist/patterns/impl/pattern-service.js +382 -0
- package/dist/patterns/impl/pattern-service.js.map +1 -0
- package/dist/patterns/impl/repository-factory.d.ts +44 -0
- package/dist/patterns/impl/repository-factory.d.ts.map +1 -0
- package/dist/patterns/impl/repository-factory.js +140 -0
- package/dist/patterns/impl/repository-factory.js.map +1 -0
- package/dist/patterns/impl/unified-file-repository.d.ts +111 -0
- package/dist/patterns/impl/unified-file-repository.d.ts.map +1 -0
- package/dist/patterns/impl/unified-file-repository.js +677 -0
- package/dist/patterns/impl/unified-file-repository.js.map +1 -0
- package/dist/patterns/index.d.ts +23 -0
- package/dist/patterns/index.d.ts.map +1 -0
- package/dist/patterns/index.js +41 -0
- package/dist/patterns/index.js.map +1 -0
- package/dist/patterns/repository.d.ts +241 -0
- package/dist/patterns/repository.d.ts.map +1 -0
- package/dist/patterns/repository.js +23 -0
- package/dist/patterns/repository.js.map +1 -0
- package/dist/patterns/service.d.ts +245 -0
- package/dist/patterns/service.d.ts.map +1 -0
- package/dist/patterns/service.js +25 -0
- package/dist/patterns/service.js.map +1 -0
- package/dist/patterns/types.d.ts +227 -0
- package/dist/patterns/types.d.ts.map +1 -0
- package/dist/patterns/types.js +117 -0
- package/dist/patterns/types.js.map +1 -0
- package/dist/scanner/file-processor-worker.d.ts +66 -0
- package/dist/scanner/file-processor-worker.d.ts.map +1 -0
- package/dist/scanner/file-processor-worker.js +189 -0
- package/dist/scanner/file-processor-worker.js.map +1 -0
- package/dist/scanner/index.d.ts +2 -0
- package/dist/scanner/index.d.ts.map +1 -1
- package/dist/scanner/index.js +2 -0
- package/dist/scanner/index.js.map +1 -1
- package/dist/scanner/threaded-worker-pool.d.ts +182 -0
- package/dist/scanner/threaded-worker-pool.d.ts.map +1 -0
- package/dist/scanner/threaded-worker-pool.js +243 -0
- package/dist/scanner/threaded-worker-pool.js.map +1 -0
- package/dist/store/pattern-store.d.ts +6 -0
- package/dist/store/pattern-store.d.ts.map +1 -1
- package/dist/store/pattern-store.js +6 -0
- package/dist/store/pattern-store.js.map +1 -1
- package/dist/store/types.d.ts +6 -3
- package/dist/store/types.d.ts.map +1 -1
- package/dist/store/types.js.map +1 -1
- package/dist/test-topology/extractors/base-test-extractor.d.ts +89 -0
- package/dist/test-topology/extractors/base-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/base-test-extractor.js +187 -0
- package/dist/test-topology/extractors/base-test-extractor.js.map +1 -0
- package/dist/test-topology/extractors/csharp-test-extractor.d.ts +23 -0
- package/dist/test-topology/extractors/csharp-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/csharp-test-extractor.js +367 -0
- package/dist/test-topology/extractors/csharp-test-extractor.js.map +1 -0
- package/dist/test-topology/extractors/index.d.ts +12 -0
- package/dist/test-topology/extractors/index.d.ts.map +1 -0
- package/dist/test-topology/extractors/index.js +12 -0
- package/dist/test-topology/extractors/index.js.map +1 -0
- package/dist/test-topology/extractors/java-test-extractor.d.ts +20 -0
- package/dist/test-topology/extractors/java-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/java-test-extractor.js +275 -0
- package/dist/test-topology/extractors/java-test-extractor.js.map +1 -0
- package/dist/test-topology/extractors/php-test-extractor.d.ts +24 -0
- package/dist/test-topology/extractors/php-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/php-test-extractor.js +409 -0
- package/dist/test-topology/extractors/php-test-extractor.js.map +1 -0
- package/dist/test-topology/extractors/python-test-extractor.d.ts +23 -0
- package/dist/test-topology/extractors/python-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/python-test-extractor.js +342 -0
- package/dist/test-topology/extractors/python-test-extractor.js.map +1 -0
- package/dist/test-topology/extractors/regex/csharp-test-regex.d.ts +51 -0
- package/dist/test-topology/extractors/regex/csharp-test-regex.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/csharp-test-regex.js +383 -0
- package/dist/test-topology/extractors/regex/csharp-test-regex.js.map +1 -0
- package/dist/test-topology/extractors/regex/index.d.ts +18 -0
- package/dist/test-topology/extractors/regex/index.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/index.js +43 -0
- package/dist/test-topology/extractors/regex/index.js.map +1 -0
- package/dist/test-topology/extractors/regex/java-test-regex.d.ts +50 -0
- package/dist/test-topology/extractors/regex/java-test-regex.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/java-test-regex.js +370 -0
- package/dist/test-topology/extractors/regex/java-test-regex.js.map +1 -0
- package/dist/test-topology/extractors/regex/php-test-regex.d.ts +56 -0
- package/dist/test-topology/extractors/regex/php-test-regex.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/php-test-regex.js +503 -0
- package/dist/test-topology/extractors/regex/php-test-regex.js.map +1 -0
- package/dist/test-topology/extractors/regex/python-test-regex.d.ts +57 -0
- package/dist/test-topology/extractors/regex/python-test-regex.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/python-test-regex.js +381 -0
- package/dist/test-topology/extractors/regex/python-test-regex.js.map +1 -0
- package/dist/test-topology/extractors/regex/typescript-test-regex.d.ts +60 -0
- package/dist/test-topology/extractors/regex/typescript-test-regex.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/typescript-test-regex.js +368 -0
- package/dist/test-topology/extractors/regex/typescript-test-regex.js.map +1 -0
- package/dist/test-topology/extractors/typescript-test-extractor.d.ts +24 -0
- package/dist/test-topology/extractors/typescript-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/typescript-test-extractor.js +266 -0
- package/dist/test-topology/extractors/typescript-test-extractor.js.map +1 -0
- package/dist/test-topology/hybrid-test-topology-analyzer.d.ts +98 -0
- package/dist/test-topology/hybrid-test-topology-analyzer.d.ts.map +1 -0
- package/dist/test-topology/hybrid-test-topology-analyzer.js +555 -0
- package/dist/test-topology/hybrid-test-topology-analyzer.js.map +1 -0
- package/dist/test-topology/index.d.ts +16 -0
- package/dist/test-topology/index.d.ts.map +1 -0
- package/dist/test-topology/index.js +19 -0
- package/dist/test-topology/index.js.map +1 -0
- package/dist/test-topology/test-topology-analyzer.d.ts +85 -0
- package/dist/test-topology/test-topology-analyzer.d.ts.map +1 -0
- package/dist/test-topology/test-topology-analyzer.js +538 -0
- package/dist/test-topology/test-topology-analyzer.js.map +1 -0
- package/dist/test-topology/types.d.ts +300 -0
- package/dist/test-topology/types.d.ts.map +1 -0
- package/dist/test-topology/types.js +7 -0
- package/dist/test-topology/types.js.map +1 -0
- package/dist/unified-provider/compat/index.d.ts +11 -0
- package/dist/unified-provider/compat/index.d.ts.map +1 -0
- package/dist/unified-provider/compat/index.js +13 -0
- package/dist/unified-provider/compat/index.js.map +1 -0
- package/dist/unified-provider/compat/legacy-extractors.d.ts +63 -0
- package/dist/unified-provider/compat/legacy-extractors.d.ts.map +1 -0
- package/dist/unified-provider/compat/legacy-extractors.js +80 -0
- package/dist/unified-provider/compat/legacy-extractors.js.map +1 -0
- package/dist/unified-provider/compat/legacy-scanner.d.ts +28 -0
- package/dist/unified-provider/compat/legacy-scanner.d.ts.map +1 -0
- package/dist/unified-provider/compat/legacy-scanner.js +31 -0
- package/dist/unified-provider/compat/legacy-scanner.js.map +1 -0
- package/dist/unified-provider/index.d.ts +28 -0
- package/dist/unified-provider/index.d.ts.map +1 -0
- package/dist/unified-provider/index.js +47 -0
- package/dist/unified-provider/index.js.map +1 -0
- package/dist/unified-provider/integration/index.d.ts +9 -0
- package/dist/unified-provider/integration/index.d.ts.map +1 -0
- package/dist/unified-provider/integration/index.js +11 -0
- package/dist/unified-provider/integration/index.js.map +1 -0
- package/dist/unified-provider/integration/unified-data-access-adapter.d.ts +75 -0
- package/dist/unified-provider/integration/unified-data-access-adapter.d.ts.map +1 -0
- package/dist/unified-provider/integration/unified-data-access-adapter.js +210 -0
- package/dist/unified-provider/integration/unified-data-access-adapter.js.map +1 -0
- package/dist/unified-provider/integration/unified-scanner.d.ts +90 -0
- package/dist/unified-provider/integration/unified-scanner.d.ts.map +1 -0
- package/dist/unified-provider/integration/unified-scanner.js +369 -0
- package/dist/unified-provider/integration/unified-scanner.js.map +1 -0
- package/dist/unified-provider/matching/base-matcher.d.ts +80 -0
- package/dist/unified-provider/matching/base-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/base-matcher.js +196 -0
- package/dist/unified-provider/matching/base-matcher.js.map +1 -0
- package/dist/unified-provider/matching/django-matcher.d.ts +32 -0
- package/dist/unified-provider/matching/django-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/django-matcher.js +107 -0
- package/dist/unified-provider/matching/django-matcher.js.map +1 -0
- package/dist/unified-provider/matching/drizzle-matcher.d.ts +25 -0
- package/dist/unified-provider/matching/drizzle-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/drizzle-matcher.js +123 -0
- package/dist/unified-provider/matching/drizzle-matcher.js.map +1 -0
- package/dist/unified-provider/matching/efcore-matcher.d.ts +27 -0
- package/dist/unified-provider/matching/efcore-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/efcore-matcher.js +88 -0
- package/dist/unified-provider/matching/efcore-matcher.js.map +1 -0
- package/dist/unified-provider/matching/eloquent-matcher.d.ts +32 -0
- package/dist/unified-provider/matching/eloquent-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/eloquent-matcher.js +162 -0
- package/dist/unified-provider/matching/eloquent-matcher.js.map +1 -0
- package/dist/unified-provider/matching/index.d.ts +19 -0
- package/dist/unified-provider/matching/index.d.ts.map +1 -0
- package/dist/unified-provider/matching/index.js +24 -0
- package/dist/unified-provider/matching/index.js.map +1 -0
- package/dist/unified-provider/matching/knex-matcher.d.ts +26 -0
- package/dist/unified-provider/matching/knex-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/knex-matcher.js +109 -0
- package/dist/unified-provider/matching/knex-matcher.js.map +1 -0
- package/dist/unified-provider/matching/matcher-registry.d.ts +55 -0
- package/dist/unified-provider/matching/matcher-registry.d.ts.map +1 -0
- package/dist/unified-provider/matching/matcher-registry.js +130 -0
- package/dist/unified-provider/matching/matcher-registry.js.map +1 -0
- package/dist/unified-provider/matching/mongoose-matcher.d.ts +30 -0
- package/dist/unified-provider/matching/mongoose-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/mongoose-matcher.js +132 -0
- package/dist/unified-provider/matching/mongoose-matcher.js.map +1 -0
- package/dist/unified-provider/matching/prisma-matcher.d.ts +31 -0
- package/dist/unified-provider/matching/prisma-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/prisma-matcher.js +123 -0
- package/dist/unified-provider/matching/prisma-matcher.js.map +1 -0
- package/dist/unified-provider/matching/raw-sql-matcher.d.ts +31 -0
- package/dist/unified-provider/matching/raw-sql-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/raw-sql-matcher.js +173 -0
- package/dist/unified-provider/matching/raw-sql-matcher.js.map +1 -0
- package/dist/unified-provider/matching/sequelize-matcher.d.ts +28 -0
- package/dist/unified-provider/matching/sequelize-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/sequelize-matcher.js +132 -0
- package/dist/unified-provider/matching/sequelize-matcher.js.map +1 -0
- package/dist/unified-provider/matching/spring-data-matcher.d.ts +32 -0
- package/dist/unified-provider/matching/spring-data-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/spring-data-matcher.js +112 -0
- package/dist/unified-provider/matching/spring-data-matcher.js.map +1 -0
- package/dist/unified-provider/matching/sqlalchemy-matcher.d.ts +32 -0
- package/dist/unified-provider/matching/sqlalchemy-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/sqlalchemy-matcher.js +201 -0
- package/dist/unified-provider/matching/sqlalchemy-matcher.js.map +1 -0
- package/dist/unified-provider/matching/supabase-matcher.d.ts +27 -0
- package/dist/unified-provider/matching/supabase-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/supabase-matcher.js +122 -0
- package/dist/unified-provider/matching/supabase-matcher.js.map +1 -0
- package/dist/unified-provider/matching/typeorm-matcher.d.ts +32 -0
- package/dist/unified-provider/matching/typeorm-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/typeorm-matcher.js +169 -0
- package/dist/unified-provider/matching/typeorm-matcher.js.map +1 -0
- package/dist/unified-provider/migration/deprecated-extractors.d.ts +104 -0
- package/dist/unified-provider/migration/deprecated-extractors.d.ts.map +1 -0
- package/dist/unified-provider/migration/deprecated-extractors.js +129 -0
- package/dist/unified-provider/migration/deprecated-extractors.js.map +1 -0
- package/dist/unified-provider/migration/deprecated-scanner.d.ts +40 -0
- package/dist/unified-provider/migration/deprecated-scanner.d.ts.map +1 -0
- package/dist/unified-provider/migration/deprecated-scanner.js +49 -0
- package/dist/unified-provider/migration/deprecated-scanner.js.map +1 -0
- package/dist/unified-provider/migration/index.d.ts +41 -0
- package/dist/unified-provider/migration/index.d.ts.map +1 -0
- package/dist/unified-provider/migration/index.js +43 -0
- package/dist/unified-provider/migration/index.js.map +1 -0
- package/dist/unified-provider/normalization/base-normalizer.d.ts +188 -0
- package/dist/unified-provider/normalization/base-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/base-normalizer.js +339 -0
- package/dist/unified-provider/normalization/base-normalizer.js.map +1 -0
- package/dist/unified-provider/normalization/csharp-normalizer.d.ts +58 -0
- package/dist/unified-provider/normalization/csharp-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/csharp-normalizer.js +467 -0
- package/dist/unified-provider/normalization/csharp-normalizer.js.map +1 -0
- package/dist/unified-provider/normalization/index.d.ts +23 -0
- package/dist/unified-provider/normalization/index.d.ts.map +1 -0
- package/dist/unified-provider/normalization/index.js +62 -0
- package/dist/unified-provider/normalization/index.js.map +1 -0
- package/dist/unified-provider/normalization/java-normalizer.d.ts +54 -0
- package/dist/unified-provider/normalization/java-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/java-normalizer.js +453 -0
- package/dist/unified-provider/normalization/java-normalizer.js.map +1 -0
- package/dist/unified-provider/normalization/php-normalizer.d.ts +54 -0
- package/dist/unified-provider/normalization/php-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/php-normalizer.js +489 -0
- package/dist/unified-provider/normalization/php-normalizer.js.map +1 -0
- package/dist/unified-provider/normalization/python-normalizer.d.ts +61 -0
- package/dist/unified-provider/normalization/python-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/python-normalizer.js +548 -0
- package/dist/unified-provider/normalization/python-normalizer.js.map +1 -0
- package/dist/unified-provider/normalization/typescript-normalizer.d.ts +60 -0
- package/dist/unified-provider/normalization/typescript-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/typescript-normalizer.js +608 -0
- package/dist/unified-provider/normalization/typescript-normalizer.js.map +1 -0
- package/dist/unified-provider/parsing/index.d.ts +5 -0
- package/dist/unified-provider/parsing/index.d.ts.map +1 -0
- package/dist/unified-provider/parsing/index.js +5 -0
- package/dist/unified-provider/parsing/index.js.map +1 -0
- package/dist/unified-provider/parsing/parser-registry.d.ts +70 -0
- package/dist/unified-provider/parsing/parser-registry.d.ts.map +1 -0
- package/dist/unified-provider/parsing/parser-registry.js +260 -0
- package/dist/unified-provider/parsing/parser-registry.js.map +1 -0
- package/dist/unified-provider/provider/index.d.ts +5 -0
- package/dist/unified-provider/provider/index.d.ts.map +1 -0
- package/dist/unified-provider/provider/index.js +5 -0
- package/dist/unified-provider/provider/index.js.map +1 -0
- package/dist/unified-provider/provider/unified-language-provider.d.ts +56 -0
- package/dist/unified-provider/provider/unified-language-provider.d.ts.map +1 -0
- package/dist/unified-provider/provider/unified-language-provider.js +212 -0
- package/dist/unified-provider/provider/unified-language-provider.js.map +1 -0
- package/dist/unified-provider/types.d.ts +389 -0
- package/dist/unified-provider/types.d.ts.map +1 -0
- package/dist/unified-provider/types.js +9 -0
- package/dist/unified-provider/types.js.map +1 -0
- package/dist/wrappers/clustering/clusterer.d.ts +43 -0
- package/dist/wrappers/clustering/clusterer.d.ts.map +1 -0
- package/dist/wrappers/clustering/clusterer.js +374 -0
- package/dist/wrappers/clustering/clusterer.js.map +1 -0
- package/dist/wrappers/clustering/exclusions.d.ts +47 -0
- package/dist/wrappers/clustering/exclusions.d.ts.map +1 -0
- package/dist/wrappers/clustering/exclusions.js +318 -0
- package/dist/wrappers/clustering/exclusions.js.map +1 -0
- package/dist/wrappers/clustering/index.d.ts +6 -0
- package/dist/wrappers/clustering/index.d.ts.map +1 -0
- package/dist/wrappers/clustering/index.js +6 -0
- package/dist/wrappers/clustering/index.js.map +1 -0
- package/dist/wrappers/detection/detector.d.ts +69 -0
- package/dist/wrappers/detection/detector.d.ts.map +1 -0
- package/dist/wrappers/detection/detector.js +279 -0
- package/dist/wrappers/detection/detector.js.map +1 -0
- package/dist/wrappers/detection/index.d.ts +5 -0
- package/dist/wrappers/detection/index.d.ts.map +1 -0
- package/dist/wrappers/detection/index.js +5 -0
- package/dist/wrappers/detection/index.js.map +1 -0
- package/dist/wrappers/export/index.d.ts +5 -0
- package/dist/wrappers/export/index.d.ts.map +1 -0
- package/dist/wrappers/export/index.js +5 -0
- package/dist/wrappers/export/index.js.map +1 -0
- package/dist/wrappers/export/json.d.ts +127 -0
- package/dist/wrappers/export/json.d.ts.map +1 -0
- package/dist/wrappers/export/json.js +160 -0
- package/dist/wrappers/export/json.js.map +1 -0
- package/dist/wrappers/index.d.ts +56 -0
- package/dist/wrappers/index.d.ts.map +1 -0
- package/dist/wrappers/index.js +159 -0
- package/dist/wrappers/index.js.map +1 -0
- package/dist/wrappers/integration/adapter.d.ts +52 -0
- package/dist/wrappers/integration/adapter.d.ts.map +1 -0
- package/dist/wrappers/integration/adapter.js +209 -0
- package/dist/wrappers/integration/adapter.js.map +1 -0
- package/dist/wrappers/integration/index.d.ts +9 -0
- package/dist/wrappers/integration/index.d.ts.map +1 -0
- package/dist/wrappers/integration/index.js +12 -0
- package/dist/wrappers/integration/index.js.map +1 -0
- package/dist/wrappers/integration/pattern-adapter.d.ts +52 -0
- package/dist/wrappers/integration/pattern-adapter.d.ts.map +1 -0
- package/dist/wrappers/integration/pattern-adapter.js +192 -0
- package/dist/wrappers/integration/pattern-adapter.js.map +1 -0
- package/dist/wrappers/integration/scanner.d.ts +85 -0
- package/dist/wrappers/integration/scanner.d.ts.map +1 -0
- package/dist/wrappers/integration/scanner.js +367 -0
- package/dist/wrappers/integration/scanner.js.map +1 -0
- package/dist/wrappers/primitives/discovery.d.ts +57 -0
- package/dist/wrappers/primitives/discovery.d.ts.map +1 -0
- package/dist/wrappers/primitives/discovery.js +389 -0
- package/dist/wrappers/primitives/discovery.js.map +1 -0
- package/dist/wrappers/primitives/index.d.ts +6 -0
- package/dist/wrappers/primitives/index.d.ts.map +1 -0
- package/dist/wrappers/primitives/index.js +6 -0
- package/dist/wrappers/primitives/index.js.map +1 -0
- package/dist/wrappers/primitives/registry.d.ts +63 -0
- package/dist/wrappers/primitives/registry.d.ts.map +1 -0
- package/dist/wrappers/primitives/registry.js +447 -0
- package/dist/wrappers/primitives/registry.js.map +1 -0
- package/dist/wrappers/types.d.ts +137 -0
- package/dist/wrappers/types.d.ts.map +1 -0
- package/dist/wrappers/types.js +7 -0
- package/dist/wrappers/types.js.map +1 -0
- package/package.json +23 -18
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Spring Data JPA Pattern Matcher
|
|
3
|
+
*
|
|
4
|
+
* Matches Spring Data JPA patterns:
|
|
5
|
+
* - userRepository.findAll()
|
|
6
|
+
* - userRepository.findById(id)
|
|
7
|
+
* - userRepository.save(user)
|
|
8
|
+
* - userRepository.delete(user)
|
|
9
|
+
* - userRepository.findByEmailAndActive(email, true)
|
|
10
|
+
*/
|
|
11
|
+
import { BaseMatcher } from './base-matcher.js';
|
|
12
|
+
/**
|
|
13
|
+
* Spring Data JPA pattern matcher
|
|
14
|
+
*/
|
|
15
|
+
export class SpringDataMatcher extends BaseMatcher {
|
|
16
|
+
id = 'spring-data';
|
|
17
|
+
name = 'Spring Data JPA';
|
|
18
|
+
languages = ['java'];
|
|
19
|
+
priority = 92;
|
|
20
|
+
readMethods = [
|
|
21
|
+
'findAll', 'findById', 'findOne', 'findAllById',
|
|
22
|
+
'existsById', 'exists', 'count', 'getOne', 'getById',
|
|
23
|
+
// Query derivation patterns
|
|
24
|
+
'findBy', 'findAllBy', 'findFirstBy', 'findTopBy',
|
|
25
|
+
'readBy', 'readAllBy', 'getBy', 'getAllBy',
|
|
26
|
+
'queryBy', 'queryAllBy', 'searchBy', 'searchAllBy',
|
|
27
|
+
'streamBy', 'streamAllBy',
|
|
28
|
+
'countBy', 'existsBy',
|
|
29
|
+
];
|
|
30
|
+
writeMethods = [
|
|
31
|
+
'save', 'saveAll', 'saveAndFlush', 'saveAllAndFlush',
|
|
32
|
+
'flush',
|
|
33
|
+
];
|
|
34
|
+
deleteMethods = [
|
|
35
|
+
'delete', 'deleteById', 'deleteAll', 'deleteAllById',
|
|
36
|
+
'deleteInBatch', 'deleteAllInBatch', 'deleteAllByIdInBatch',
|
|
37
|
+
'removeBy', 'deleteBy',
|
|
38
|
+
];
|
|
39
|
+
match(chain) {
|
|
40
|
+
// Look for repository pattern
|
|
41
|
+
const receiver = chain.receiver.toLowerCase();
|
|
42
|
+
if (!receiver.includes('repository') && !receiver.includes('repo') && !receiver.includes('dao')) {
|
|
43
|
+
return null;
|
|
44
|
+
}
|
|
45
|
+
if (chain.segments.length < 1)
|
|
46
|
+
return null;
|
|
47
|
+
const methodSegment = chain.segments[0];
|
|
48
|
+
if (!methodSegment?.isCall)
|
|
49
|
+
return null;
|
|
50
|
+
const methodName = methodSegment.name;
|
|
51
|
+
const operation = this.getOperation(methodName);
|
|
52
|
+
if (!operation)
|
|
53
|
+
return null;
|
|
54
|
+
// Infer table from repository name
|
|
55
|
+
const table = this.inferTableName(chain.receiver);
|
|
56
|
+
// Extract fields from query derivation method names
|
|
57
|
+
const fields = this.extractFieldsFromMethodName(methodName);
|
|
58
|
+
return this.createMatch({
|
|
59
|
+
table,
|
|
60
|
+
fields,
|
|
61
|
+
operation,
|
|
62
|
+
confidence: 0.9,
|
|
63
|
+
metadata: { methodName },
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
getOperation(methodName) {
|
|
67
|
+
// Check exact matches first
|
|
68
|
+
if (this.readMethods.includes(methodName))
|
|
69
|
+
return 'read';
|
|
70
|
+
if (this.writeMethods.includes(methodName))
|
|
71
|
+
return 'write';
|
|
72
|
+
if (this.deleteMethods.includes(methodName))
|
|
73
|
+
return 'delete';
|
|
74
|
+
// Check prefix patterns for query derivation
|
|
75
|
+
for (const prefix of this.readMethods) {
|
|
76
|
+
if (methodName.startsWith(prefix))
|
|
77
|
+
return 'read';
|
|
78
|
+
}
|
|
79
|
+
for (const prefix of this.deleteMethods) {
|
|
80
|
+
if (methodName.startsWith(prefix))
|
|
81
|
+
return 'delete';
|
|
82
|
+
}
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Extract field names from Spring Data query derivation method names
|
|
87
|
+
* e.g., findByEmailAndActiveTrue -> ['email', 'active']
|
|
88
|
+
*/
|
|
89
|
+
extractFieldsFromMethodName(methodName) {
|
|
90
|
+
const fields = [];
|
|
91
|
+
// Remove common prefixes
|
|
92
|
+
let remaining = methodName
|
|
93
|
+
.replace(/^(find|read|get|query|search|stream|count|exists|delete|remove)(All|First|Top\d*)?By/, '')
|
|
94
|
+
.replace(/^(OrderBy.*)$/, ''); // Remove OrderBy suffix
|
|
95
|
+
if (!remaining)
|
|
96
|
+
return fields;
|
|
97
|
+
// Split by And/Or
|
|
98
|
+
const parts = remaining.split(/(?:And|Or)/);
|
|
99
|
+
for (const part of parts) {
|
|
100
|
+
// Remove comparison suffixes
|
|
101
|
+
const fieldPart = part
|
|
102
|
+
.replace(/(Is|Equals|Not|IsNot|NotNull|Null|True|False|Before|After|LessThan|LessThanEqual|GreaterThan|GreaterThanEqual|Between|Like|NotLike|StartingWith|EndingWith|Containing|In|NotIn|IgnoreCase|OrderBy.*)$/, '');
|
|
103
|
+
if (fieldPart) {
|
|
104
|
+
// Convert to camelCase field name
|
|
105
|
+
const fieldName = fieldPart.charAt(0).toLowerCase() + fieldPart.slice(1);
|
|
106
|
+
fields.push(fieldName);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return [...new Set(fields)];
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
//# sourceMappingURL=spring-data-matcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spring-data-matcher.js","sourceRoot":"","sources":["../../../src/unified-provider/matching/spring-data-matcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SQLAlchemy Pattern Matcher
|
|
3
|
+
*
|
|
4
|
+
* Matches SQLAlchemy patterns:
|
|
5
|
+
* - session.query(User).filter(User.id == 1).all()
|
|
6
|
+
* - session.query(User).filter_by(id=1).first()
|
|
7
|
+
* - session.add(user)
|
|
8
|
+
* - session.delete(user)
|
|
9
|
+
* - select(User).where(User.id == 1)
|
|
10
|
+
* - insert(users).values(name='John')
|
|
11
|
+
* - update(users).where(users.c.id == 1).values(name='Jane')
|
|
12
|
+
* - delete(users).where(users.c.id == 1)
|
|
13
|
+
*/
|
|
14
|
+
import type { UnifiedCallChain, PatternMatchResult, UnifiedLanguage } from '../types.js';
|
|
15
|
+
import { BaseMatcher } from './base-matcher.js';
|
|
16
|
+
/**
|
|
17
|
+
* SQLAlchemy pattern matcher
|
|
18
|
+
*/
|
|
19
|
+
export declare class SQLAlchemyMatcher extends BaseMatcher {
|
|
20
|
+
readonly id = "sqlalchemy";
|
|
21
|
+
readonly name = "SQLAlchemy";
|
|
22
|
+
readonly languages: UnifiedLanguage[];
|
|
23
|
+
readonly priority = 93;
|
|
24
|
+
match(chain: UnifiedCallChain): PatternMatchResult | null;
|
|
25
|
+
private matchSessionPattern;
|
|
26
|
+
private handleQueryPattern;
|
|
27
|
+
private handleAddPattern;
|
|
28
|
+
private handleDeletePattern;
|
|
29
|
+
private matchCorePattern;
|
|
30
|
+
private extractKwargs;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=sqlalchemy-matcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqlalchemy-matcher.d.ts","sourceRoot":"","sources":["../../../src/unified-provider/matching/sqlalchemy-matcher.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD;;GAEG;AACH,qBAAa,iBAAkB,SAAQ,WAAW;IAChD,QAAQ,CAAC,EAAE,gBAAgB;IAC3B,QAAQ,CAAC,IAAI,gBAAgB;IAC7B,QAAQ,CAAC,SAAS,EAAE,eAAe,EAAE,CAAc;IACnD,QAAQ,CAAC,QAAQ,MAAM;IAOvB,KAAK,CAAC,KAAK,EAAE,gBAAgB,GAAG,kBAAkB,GAAG,IAAI;IAYzD,OAAO,CAAC,mBAAmB;IA0B3B,OAAO,CAAC,kBAAkB;IAyC1B,OAAO,CAAC,gBAAgB;IAwBxB,OAAO,CAAC,mBAAmB;IAsB3B,OAAO,CAAC,gBAAgB;IAyDxB,OAAO,CAAC,aAAa;CAatB"}
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SQLAlchemy Pattern Matcher
|
|
3
|
+
*
|
|
4
|
+
* Matches SQLAlchemy patterns:
|
|
5
|
+
* - session.query(User).filter(User.id == 1).all()
|
|
6
|
+
* - session.query(User).filter_by(id=1).first()
|
|
7
|
+
* - session.add(user)
|
|
8
|
+
* - session.delete(user)
|
|
9
|
+
* - select(User).where(User.id == 1)
|
|
10
|
+
* - insert(users).values(name='John')
|
|
11
|
+
* - update(users).where(users.c.id == 1).values(name='Jane')
|
|
12
|
+
* - delete(users).where(users.c.id == 1)
|
|
13
|
+
*/
|
|
14
|
+
import { BaseMatcher } from './base-matcher.js';
|
|
15
|
+
/**
|
|
16
|
+
* SQLAlchemy pattern matcher
|
|
17
|
+
*/
|
|
18
|
+
export class SQLAlchemyMatcher extends BaseMatcher {
|
|
19
|
+
id = 'sqlalchemy';
|
|
20
|
+
name = 'SQLAlchemy';
|
|
21
|
+
languages = ['python'];
|
|
22
|
+
priority = 93;
|
|
23
|
+
// Method lists for reference - actual detection uses inline checks
|
|
24
|
+
// Read: query, get, filter, filter_by, all, first, one, one_or_none, scalar, count, exists, select, join, outerjoin
|
|
25
|
+
// Write: add, add_all, merge, flush, commit, insert, update
|
|
26
|
+
// Delete: delete
|
|
27
|
+
match(chain) {
|
|
28
|
+
// Pattern 1: session.query(Model)
|
|
29
|
+
const sessionMatch = this.matchSessionPattern(chain);
|
|
30
|
+
if (sessionMatch)
|
|
31
|
+
return sessionMatch;
|
|
32
|
+
// Pattern 2: select(Model) / insert(table) / update(table) / delete(table)
|
|
33
|
+
const coreMatch = this.matchCorePattern(chain);
|
|
34
|
+
if (coreMatch)
|
|
35
|
+
return coreMatch;
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
matchSessionPattern(chain) {
|
|
39
|
+
const receiver = chain.receiver.toLowerCase();
|
|
40
|
+
if (!receiver.includes('session') && !receiver.includes('db')) {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
// Look for query() or add/delete
|
|
44
|
+
const queryIndex = chain.segments.findIndex(s => s.name === 'query');
|
|
45
|
+
const addIndex = chain.segments.findIndex(s => s.name === 'add' || s.name === 'add_all');
|
|
46
|
+
const deleteIndex = chain.segments.findIndex(s => s.name === 'delete');
|
|
47
|
+
if (queryIndex !== -1) {
|
|
48
|
+
return this.handleQueryPattern(chain, queryIndex);
|
|
49
|
+
}
|
|
50
|
+
if (addIndex !== -1) {
|
|
51
|
+
return this.handleAddPattern(chain, addIndex);
|
|
52
|
+
}
|
|
53
|
+
if (deleteIndex !== -1) {
|
|
54
|
+
return this.handleDeletePattern(chain, deleteIndex);
|
|
55
|
+
}
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
handleQueryPattern(chain, queryIndex) {
|
|
59
|
+
const querySegment = chain.segments[queryIndex];
|
|
60
|
+
if (!querySegment?.args[0])
|
|
61
|
+
return null;
|
|
62
|
+
// Get model name from query(Model)
|
|
63
|
+
const modelArg = querySegment.args[0];
|
|
64
|
+
const modelName = modelArg.type === 'identifier'
|
|
65
|
+
? modelArg.value
|
|
66
|
+
: 'unknown';
|
|
67
|
+
// Determine operation from subsequent methods
|
|
68
|
+
let operation = 'read';
|
|
69
|
+
const fields = [];
|
|
70
|
+
for (let i = queryIndex + 1; i < chain.segments.length; i++) {
|
|
71
|
+
const segment = chain.segments[i];
|
|
72
|
+
if (!segment)
|
|
73
|
+
continue;
|
|
74
|
+
if (segment.name === 'delete') {
|
|
75
|
+
operation = 'delete';
|
|
76
|
+
}
|
|
77
|
+
else if (segment.name === 'update') {
|
|
78
|
+
operation = 'write';
|
|
79
|
+
}
|
|
80
|
+
else if (segment.name === 'filter_by') {
|
|
81
|
+
// Extract fields from filter_by kwargs
|
|
82
|
+
this.extractKwargs(segment.args, fields);
|
|
83
|
+
}
|
|
84
|
+
else if (segment.name === 'filter') {
|
|
85
|
+
// filter() uses expressions, harder to extract
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
const table = this.inferTableName(modelName);
|
|
89
|
+
return this.createMatch({
|
|
90
|
+
table,
|
|
91
|
+
fields: [...new Set(fields)],
|
|
92
|
+
operation,
|
|
93
|
+
confidence: 0.9,
|
|
94
|
+
metadata: { pattern: 'session.query', modelName },
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
handleAddPattern(chain, addIndex) {
|
|
98
|
+
const addSegment = chain.segments[addIndex];
|
|
99
|
+
if (!addSegment?.args[0])
|
|
100
|
+
return null;
|
|
101
|
+
// Try to infer model from the argument
|
|
102
|
+
const arg = addSegment.args[0];
|
|
103
|
+
let modelName = 'unknown';
|
|
104
|
+
if (arg.type === 'identifier') {
|
|
105
|
+
// Might be a variable name like 'user'
|
|
106
|
+
modelName = arg.value;
|
|
107
|
+
}
|
|
108
|
+
const table = this.inferTableName(modelName);
|
|
109
|
+
return this.createMatch({
|
|
110
|
+
table,
|
|
111
|
+
fields: [],
|
|
112
|
+
operation: 'write',
|
|
113
|
+
confidence: 0.8,
|
|
114
|
+
metadata: { pattern: 'session.add' },
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
handleDeletePattern(chain, deleteIndex) {
|
|
118
|
+
const deleteSegment = chain.segments[deleteIndex];
|
|
119
|
+
if (!deleteSegment?.args[0])
|
|
120
|
+
return null;
|
|
121
|
+
const arg = deleteSegment.args[0];
|
|
122
|
+
let modelName = 'unknown';
|
|
123
|
+
if (arg.type === 'identifier') {
|
|
124
|
+
modelName = arg.value;
|
|
125
|
+
}
|
|
126
|
+
const table = this.inferTableName(modelName);
|
|
127
|
+
return this.createMatch({
|
|
128
|
+
table,
|
|
129
|
+
fields: [],
|
|
130
|
+
operation: 'delete',
|
|
131
|
+
confidence: 0.8,
|
|
132
|
+
metadata: { pattern: 'session.delete' },
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
matchCorePattern(chain) {
|
|
136
|
+
// Look for select/insert/update/delete as first segment
|
|
137
|
+
const firstSegment = chain.segments[0];
|
|
138
|
+
if (!firstSegment?.isCall)
|
|
139
|
+
return null;
|
|
140
|
+
const method = firstSegment.name;
|
|
141
|
+
if (!['select', 'insert', 'update', 'delete'].includes(method)) {
|
|
142
|
+
return null;
|
|
143
|
+
}
|
|
144
|
+
// Get table/model from first argument
|
|
145
|
+
const tableArg = firstSegment.args[0];
|
|
146
|
+
if (!tableArg)
|
|
147
|
+
return null;
|
|
148
|
+
const tableName = tableArg.type === 'identifier'
|
|
149
|
+
? this.inferTableName(tableArg.value)
|
|
150
|
+
: tableArg.stringValue ?? 'unknown';
|
|
151
|
+
let operation;
|
|
152
|
+
const fields = [];
|
|
153
|
+
switch (method) {
|
|
154
|
+
case 'select':
|
|
155
|
+
operation = 'read';
|
|
156
|
+
break;
|
|
157
|
+
case 'insert':
|
|
158
|
+
operation = 'write';
|
|
159
|
+
// Look for values()
|
|
160
|
+
const valuesIndex = chain.segments.findIndex(s => s.name === 'values');
|
|
161
|
+
if (valuesIndex !== -1) {
|
|
162
|
+
this.extractKwargs(chain.segments[valuesIndex]?.args ?? [], fields);
|
|
163
|
+
}
|
|
164
|
+
break;
|
|
165
|
+
case 'update':
|
|
166
|
+
operation = 'write';
|
|
167
|
+
// Look for values()
|
|
168
|
+
const updateValuesIndex = chain.segments.findIndex(s => s.name === 'values');
|
|
169
|
+
if (updateValuesIndex !== -1) {
|
|
170
|
+
this.extractKwargs(chain.segments[updateValuesIndex]?.args ?? [], fields);
|
|
171
|
+
}
|
|
172
|
+
break;
|
|
173
|
+
case 'delete':
|
|
174
|
+
operation = 'delete';
|
|
175
|
+
break;
|
|
176
|
+
default:
|
|
177
|
+
return null;
|
|
178
|
+
}
|
|
179
|
+
return this.createMatch({
|
|
180
|
+
table: tableName,
|
|
181
|
+
fields: [...new Set(fields)],
|
|
182
|
+
operation,
|
|
183
|
+
confidence: 0.9,
|
|
184
|
+
metadata: { pattern: 'core' },
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
extractKwargs(args, fields) {
|
|
188
|
+
for (const arg of args) {
|
|
189
|
+
if (arg.value.includes('=')) {
|
|
190
|
+
const match = arg.value.match(/^(\w+)=/);
|
|
191
|
+
if (match?.[1]) {
|
|
192
|
+
fields.push(match[1]);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
if (arg.type === 'object' && arg.properties) {
|
|
196
|
+
fields.push(...Object.keys(arg.properties));
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
//# sourceMappingURL=sqlalchemy-matcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sqlalchemy-matcher.js","sourceRoot":"","sources":["../../../src/unified-provider/matching/sqlalchemy-matcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Supabase Pattern Matcher
|
|
3
|
+
*
|
|
4
|
+
* Matches Supabase client patterns:
|
|
5
|
+
* - supabase.from('table').select('*')
|
|
6
|
+
* - supabase.from('table').insert({...})
|
|
7
|
+
* - supabase.from('table').update({...}).eq('id', 1)
|
|
8
|
+
* - supabase.from('table').delete().eq('id', 1)
|
|
9
|
+
*/
|
|
10
|
+
import type { UnifiedCallChain, PatternMatchResult, UnifiedLanguage } from '../types.js';
|
|
11
|
+
import { BaseMatcher } from './base-matcher.js';
|
|
12
|
+
/**
|
|
13
|
+
* Supabase pattern matcher
|
|
14
|
+
*/
|
|
15
|
+
export declare class SupabaseMatcher extends BaseMatcher {
|
|
16
|
+
readonly id = "supabase";
|
|
17
|
+
readonly name = "Supabase";
|
|
18
|
+
readonly languages: UnifiedLanguage[];
|
|
19
|
+
readonly priority = 100;
|
|
20
|
+
match(chain: UnifiedCallChain): PatternMatchResult | null;
|
|
21
|
+
private matchFromIndex;
|
|
22
|
+
/**
|
|
23
|
+
* Check if method is a Supabase where clause method
|
|
24
|
+
*/
|
|
25
|
+
private isSupabaseWhereMethod;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=supabase-matcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supabase-matcher.d.ts","sourceRoot":"","sources":["../../../src/unified-provider/matching/supabase-matcher.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD;;GAEG;AACH,qBAAa,eAAgB,SAAQ,WAAW;IAC9C,QAAQ,CAAC,EAAE,cAAc;IACzB,QAAQ,CAAC,IAAI,cAAc;IAC3B,QAAQ,CAAC,SAAS,EAAE,eAAe,EAAE,CAA0C;IAC/E,QAAQ,CAAC,QAAQ,OAAO;IAExB,KAAK,CAAC,KAAK,EAAE,gBAAgB,GAAG,kBAAkB,GAAG,IAAI;IAazD,OAAO,CAAC,cAAc;IAwEtB;;OAEG;IACH,OAAO,CAAC,qBAAqB;CAmB9B"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Supabase Pattern Matcher
|
|
3
|
+
*
|
|
4
|
+
* Matches Supabase client patterns:
|
|
5
|
+
* - supabase.from('table').select('*')
|
|
6
|
+
* - supabase.from('table').insert({...})
|
|
7
|
+
* - supabase.from('table').update({...}).eq('id', 1)
|
|
8
|
+
* - supabase.from('table').delete().eq('id', 1)
|
|
9
|
+
*/
|
|
10
|
+
import { BaseMatcher } from './base-matcher.js';
|
|
11
|
+
/**
|
|
12
|
+
* Supabase pattern matcher
|
|
13
|
+
*/
|
|
14
|
+
export class SupabaseMatcher extends BaseMatcher {
|
|
15
|
+
id = 'supabase';
|
|
16
|
+
name = 'Supabase';
|
|
17
|
+
languages = ['typescript', 'javascript', 'python'];
|
|
18
|
+
priority = 100;
|
|
19
|
+
match(chain) {
|
|
20
|
+
// Find .from() segment
|
|
21
|
+
const fromIndex = this.findSegment(chain, 'from');
|
|
22
|
+
if (fromIndex === -1) {
|
|
23
|
+
// Also check for from_ (Python SDK uses this)
|
|
24
|
+
const fromUnderscoreIndex = this.findSegment(chain, 'from_');
|
|
25
|
+
if (fromUnderscoreIndex === -1)
|
|
26
|
+
return null;
|
|
27
|
+
return this.matchFromIndex(chain, fromUnderscoreIndex);
|
|
28
|
+
}
|
|
29
|
+
return this.matchFromIndex(chain, fromIndex);
|
|
30
|
+
}
|
|
31
|
+
matchFromIndex(chain, fromIndex) {
|
|
32
|
+
// Get table name from .from('table')
|
|
33
|
+
const table = this.getFirstStringArg(chain, fromIndex);
|
|
34
|
+
if (!table)
|
|
35
|
+
return null;
|
|
36
|
+
// Determine operation and extract fields
|
|
37
|
+
let operation = 'read';
|
|
38
|
+
let fields = [];
|
|
39
|
+
const whereFields = [];
|
|
40
|
+
for (let i = fromIndex + 1; i < chain.segments.length; i++) {
|
|
41
|
+
const segment = chain.segments[i];
|
|
42
|
+
if (!segment)
|
|
43
|
+
continue;
|
|
44
|
+
const method = segment.name;
|
|
45
|
+
// Select operation
|
|
46
|
+
if (method === 'select') {
|
|
47
|
+
operation = 'read';
|
|
48
|
+
const selectArg = this.getFirstStringArg(chain, i);
|
|
49
|
+
if (selectArg) {
|
|
50
|
+
fields = this.extractFieldsFromString(selectArg);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
// Insert operation
|
|
54
|
+
else if (method === 'insert' || method === 'upsert') {
|
|
55
|
+
operation = 'write';
|
|
56
|
+
if (segment.args.length > 0 && segment.args[0]) {
|
|
57
|
+
const arg = segment.args[0];
|
|
58
|
+
if (arg.type === 'object') {
|
|
59
|
+
fields = this.extractFieldsFromObject(arg);
|
|
60
|
+
}
|
|
61
|
+
else if (arg.type === 'array' && arg.elements && arg.elements[0]) {
|
|
62
|
+
// Array of objects - get fields from first element
|
|
63
|
+
fields = this.extractFieldsFromObject(arg.elements[0]);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
// Update operation
|
|
68
|
+
else if (method === 'update') {
|
|
69
|
+
operation = 'write';
|
|
70
|
+
if (segment.args.length > 0 && segment.args[0]) {
|
|
71
|
+
fields = this.extractFieldsFromObject(segment.args[0]);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
// Delete operation
|
|
75
|
+
else if (method === 'delete') {
|
|
76
|
+
operation = 'delete';
|
|
77
|
+
}
|
|
78
|
+
// Where clause methods - extract field names
|
|
79
|
+
else if (this.isSupabaseWhereMethod(method)) {
|
|
80
|
+
const field = this.extractWhereField(chain, i);
|
|
81
|
+
if (field) {
|
|
82
|
+
whereFields.push(field);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
// Merge fields with where clause fields (deduplicated)
|
|
87
|
+
const allFields = [...new Set([...fields, ...whereFields])];
|
|
88
|
+
return this.createMatch({
|
|
89
|
+
table,
|
|
90
|
+
fields: allFields,
|
|
91
|
+
operation,
|
|
92
|
+
confidence: 0.95,
|
|
93
|
+
metadata: {
|
|
94
|
+
fromIndex,
|
|
95
|
+
hasWhereClause: whereFields.length > 0,
|
|
96
|
+
},
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Check if method is a Supabase where clause method
|
|
101
|
+
*/
|
|
102
|
+
isSupabaseWhereMethod(method) {
|
|
103
|
+
const supabaseWhereMethods = [
|
|
104
|
+
// Comparison
|
|
105
|
+
'eq', 'neq', 'gt', 'gte', 'lt', 'lte',
|
|
106
|
+
// Pattern matching
|
|
107
|
+
'like', 'ilike',
|
|
108
|
+
// Null checks
|
|
109
|
+
'is',
|
|
110
|
+
// Array operations
|
|
111
|
+
'in', 'contains', 'containedBy', 'overlaps',
|
|
112
|
+
// Range operations
|
|
113
|
+
'rangeGt', 'rangeGte', 'rangeLt', 'rangeLte', 'rangeAdjacent',
|
|
114
|
+
// Text search
|
|
115
|
+
'textSearch', 'match',
|
|
116
|
+
// Logical
|
|
117
|
+
'not', 'or', 'filter',
|
|
118
|
+
];
|
|
119
|
+
return supabaseWhereMethods.includes(method);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=supabase-matcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"supabase-matcher.js","sourceRoot":"","sources":["../../../src/unified-provider/matching/supabase-matcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TypeORM Pattern Matcher
|
|
3
|
+
*
|
|
4
|
+
* Matches TypeORM patterns:
|
|
5
|
+
* - repository.find()
|
|
6
|
+
* - repository.findOne({ where: { id: 1 } })
|
|
7
|
+
* - repository.save(entity)
|
|
8
|
+
* - repository.delete({ id: 1 })
|
|
9
|
+
* - Entity.find()
|
|
10
|
+
* - getRepository(Entity).find()
|
|
11
|
+
*/
|
|
12
|
+
import type { UnifiedCallChain, PatternMatchResult, UnifiedLanguage } from '../types.js';
|
|
13
|
+
import { BaseMatcher } from './base-matcher.js';
|
|
14
|
+
/**
|
|
15
|
+
* TypeORM pattern matcher
|
|
16
|
+
*/
|
|
17
|
+
export declare class TypeORMMatcher extends BaseMatcher {
|
|
18
|
+
readonly id = "typeorm";
|
|
19
|
+
readonly name = "TypeORM";
|
|
20
|
+
readonly languages: UnifiedLanguage[];
|
|
21
|
+
readonly priority = 90;
|
|
22
|
+
private readonly readMethods;
|
|
23
|
+
private readonly writeMethods;
|
|
24
|
+
private readonly deleteMethods;
|
|
25
|
+
match(chain: UnifiedCallChain): PatternMatchResult | null;
|
|
26
|
+
private matchRepositoryPattern;
|
|
27
|
+
private matchEntityPattern;
|
|
28
|
+
private matchGetRepositoryPattern;
|
|
29
|
+
private getOperation;
|
|
30
|
+
private extractFields;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=typeorm-matcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeorm-matcher.d.ts","sourceRoot":"","sources":["../../../src/unified-provider/matching/typeorm-matcher.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,eAAe,EAAiB,MAAM,aAAa,CAAC;AACxG,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD;;GAEG;AACH,qBAAa,cAAe,SAAQ,WAAW;IAC7C,QAAQ,CAAC,EAAE,aAAa;IACxB,QAAQ,CAAC,IAAI,aAAa;IAC1B,QAAQ,CAAC,SAAS,EAAE,eAAe,EAAE,CAAgC;IACrE,QAAQ,CAAC,QAAQ,MAAM;IAEvB,OAAO,CAAC,QAAQ,CAAC,WAAW,CAI1B;IAEF,OAAO,CAAC,QAAQ,CAAC,YAAY,CAE3B;IAEF,OAAO,CAAC,QAAQ,CAAC,aAAa,CAE5B;IAEF,KAAK,CAAC,KAAK,EAAE,gBAAgB,GAAG,kBAAkB,GAAG,IAAI;IAgBzD,OAAO,CAAC,sBAAsB;IA0B9B,OAAO,CAAC,kBAAkB;IA+B1B,OAAO,CAAC,yBAAyB;IAsCjC,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,aAAa;CAgCtB"}
|