codesift-mcp 0.3.0 → 0.4.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/README.md +143 -20
- package/dist/cache/hono-cache.d.ts +50 -0
- package/dist/cache/hono-cache.d.ts.map +1 -0
- package/dist/cache/hono-cache.js +132 -0
- package/dist/cache/hono-cache.js.map +1 -0
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +17 -2
- package/dist/cli/setup.js.map +1 -1
- package/dist/formatters-shortening.d.ts +13 -0
- package/dist/formatters-shortening.d.ts.map +1 -1
- package/dist/formatters-shortening.js +131 -0
- package/dist/formatters-shortening.js.map +1 -1
- package/dist/formatters.d.ts +38 -0
- package/dist/formatters.d.ts.map +1 -1
- package/dist/formatters.js +498 -0
- package/dist/formatters.js.map +1 -1
- package/dist/instructions.d.ts +1 -1
- package/dist/instructions.d.ts.map +1 -1
- package/dist/instructions.js +27 -26
- package/dist/instructions.js.map +1 -1
- package/dist/lsp/lsp-servers.d.ts.map +1 -1
- package/dist/lsp/lsp-servers.js +5 -0
- package/dist/lsp/lsp-servers.js.map +1 -1
- package/dist/lsp/lsp-tools.d.ts.map +1 -1
- package/dist/lsp/lsp-tools.js +1 -0
- package/dist/lsp/lsp-tools.js.map +1 -1
- package/dist/parser/astro-template.d.ts +47 -0
- package/dist/parser/astro-template.d.ts.map +1 -0
- package/dist/parser/astro-template.js +171 -0
- package/dist/parser/astro-template.js.map +1 -0
- package/dist/parser/extractors/_shared.d.ts +4 -0
- package/dist/parser/extractors/_shared.d.ts.map +1 -1
- package/dist/parser/extractors/_shared.js +8 -0
- package/dist/parser/extractors/_shared.js.map +1 -1
- package/dist/parser/extractors/astro.d.ts +4 -5
- package/dist/parser/extractors/astro.d.ts.map +1 -1
- package/dist/parser/extractors/astro.js +102 -26
- package/dist/parser/extractors/astro.js.map +1 -1
- package/dist/parser/extractors/gradle-kts.d.ts +4 -0
- package/dist/parser/extractors/gradle-kts.d.ts.map +1 -0
- package/dist/parser/extractors/gradle-kts.js +246 -0
- package/dist/parser/extractors/gradle-kts.js.map +1 -0
- package/dist/parser/extractors/hono-inline-analyzer.d.ts +34 -0
- package/dist/parser/extractors/hono-inline-analyzer.d.ts.map +1 -0
- package/dist/parser/extractors/hono-inline-analyzer.js +465 -0
- package/dist/parser/extractors/hono-inline-analyzer.js.map +1 -0
- package/dist/parser/extractors/hono-model.d.ts +196 -0
- package/dist/parser/extractors/hono-model.d.ts.map +1 -0
- package/dist/parser/extractors/hono-model.js +10 -0
- package/dist/parser/extractors/hono-model.js.map +1 -0
- package/dist/parser/extractors/hono.d.ts +118 -0
- package/dist/parser/extractors/hono.d.ts.map +1 -0
- package/dist/parser/extractors/hono.js +1527 -0
- package/dist/parser/extractors/hono.js.map +1 -0
- package/dist/parser/extractors/kotlin.d.ts +4 -0
- package/dist/parser/extractors/kotlin.d.ts.map +1 -0
- package/dist/parser/extractors/kotlin.js +521 -0
- package/dist/parser/extractors/kotlin.js.map +1 -0
- package/dist/parser/extractors/php.d.ts +22 -0
- package/dist/parser/extractors/php.d.ts.map +1 -0
- package/dist/parser/extractors/php.js +326 -0
- package/dist/parser/extractors/php.js.map +1 -0
- package/dist/parser/extractors/python.d.ts.map +1 -1
- package/dist/parser/extractors/python.js +234 -11
- package/dist/parser/extractors/python.js.map +1 -1
- package/dist/parser/extractors/sql.d.ts +33 -0
- package/dist/parser/extractors/sql.d.ts.map +1 -0
- package/dist/parser/extractors/sql.js +506 -0
- package/dist/parser/extractors/sql.js.map +1 -0
- package/dist/parser/extractors/typescript.d.ts.map +1 -1
- package/dist/parser/extractors/typescript.js +166 -3
- package/dist/parser/extractors/typescript.js.map +1 -1
- package/dist/parser/languages/tree-sitter-javascript.wasm +0 -0
- package/dist/parser/languages/tree-sitter-kotlin.wasm +0 -0
- package/dist/parser/languages/tree-sitter-php.wasm +0 -0
- package/dist/parser/languages/tree-sitter-php_only.wasm +0 -0
- package/dist/parser/languages/tree-sitter-python.wasm +0 -0
- package/dist/parser/parser-manager.d.ts +32 -0
- package/dist/parser/parser-manager.d.ts.map +1 -1
- package/dist/parser/parser-manager.js +82 -3
- package/dist/parser/parser-manager.js.map +1 -1
- package/dist/parser/symbol-extractor.d.ts.map +1 -1
- package/dist/parser/symbol-extractor.js +16 -0
- package/dist/parser/symbol-extractor.js.map +1 -1
- package/dist/register-tools.d.ts +37 -1
- package/dist/register-tools.d.ts.map +1 -1
- package/dist/register-tools.js +2657 -191
- package/dist/register-tools.js.map +1 -1
- package/dist/search/reranker.js +1 -1
- package/dist/search/reranker.js.map +1 -1
- package/dist/server-helpers.d.ts.map +1 -1
- package/dist/server-helpers.js +11 -0
- package/dist/server-helpers.js.map +1 -1
- package/dist/server.js +28 -1
- package/dist/server.js.map +1 -1
- package/dist/storage/index-store.d.ts +15 -1
- package/dist/storage/index-store.d.ts.map +1 -1
- package/dist/storage/index-store.js +27 -1
- package/dist/storage/index-store.js.map +1 -1
- package/dist/storage/session-state.d.ts +1 -1
- package/dist/storage/session-state.d.ts.map +1 -1
- package/dist/storage/session-state.js +6 -4
- package/dist/storage/session-state.js.map +1 -1
- package/dist/tools/agent-config-tools.d.ts +24 -0
- package/dist/tools/agent-config-tools.d.ts.map +1 -0
- package/dist/tools/agent-config-tools.js +119 -0
- package/dist/tools/agent-config-tools.js.map +1 -0
- package/dist/tools/architecture-tools.d.ts +23 -0
- package/dist/tools/architecture-tools.d.ts.map +1 -0
- package/dist/tools/architecture-tools.js +140 -0
- package/dist/tools/architecture-tools.js.map +1 -0
- package/dist/tools/astro-config.d.ts +33 -0
- package/dist/tools/astro-config.d.ts.map +1 -0
- package/dist/tools/astro-config.js +260 -0
- package/dist/tools/astro-config.js.map +1 -0
- package/dist/tools/astro-islands.d.ts +61 -0
- package/dist/tools/astro-islands.d.ts.map +1 -0
- package/dist/tools/astro-islands.js +240 -0
- package/dist/tools/astro-islands.js.map +1 -0
- package/dist/tools/astro-routes.d.ts +49 -0
- package/dist/tools/astro-routes.d.ts.map +1 -0
- package/dist/tools/astro-routes.js +119 -0
- package/dist/tools/astro-routes.js.map +1 -0
- package/dist/tools/audit-tools.d.ts +38 -0
- package/dist/tools/audit-tools.d.ts.map +1 -0
- package/dist/tools/audit-tools.js +248 -0
- package/dist/tools/audit-tools.js.map +1 -0
- package/dist/tools/celery-tools.d.ts +38 -0
- package/dist/tools/celery-tools.d.ts.map +1 -0
- package/dist/tools/celery-tools.js +154 -0
- package/dist/tools/celery-tools.js.map +1 -0
- package/dist/tools/clone-tools.js +1 -1
- package/dist/tools/clone-tools.js.map +1 -1
- package/dist/tools/complexity-tools.d.ts +4 -0
- package/dist/tools/complexity-tools.d.ts.map +1 -1
- package/dist/tools/complexity-tools.js +78 -4
- package/dist/tools/complexity-tools.js.map +1 -1
- package/dist/tools/compose-tools.d.ts +60 -0
- package/dist/tools/compose-tools.d.ts.map +1 -0
- package/dist/tools/compose-tools.js +203 -0
- package/dist/tools/compose-tools.js.map +1 -0
- package/dist/tools/coupling-tools.d.ts +50 -0
- package/dist/tools/coupling-tools.d.ts.map +1 -0
- package/dist/tools/coupling-tools.js +262 -0
- package/dist/tools/coupling-tools.js.map +1 -0
- package/dist/tools/dependency-audit-tools.d.ts +65 -0
- package/dist/tools/dependency-audit-tools.d.ts.map +1 -0
- package/dist/tools/dependency-audit-tools.js +553 -0
- package/dist/tools/dependency-audit-tools.js.map +1 -0
- package/dist/tools/django-settings.d.ts +22 -0
- package/dist/tools/django-settings.d.ts.map +1 -0
- package/dist/tools/django-settings.js +301 -0
- package/dist/tools/django-settings.js.map +1 -0
- package/dist/tools/frequency-tools.js +1 -1
- package/dist/tools/frequency-tools.js.map +1 -1
- package/dist/tools/graph-tools.d.ts +8 -2
- package/dist/tools/graph-tools.d.ts.map +1 -1
- package/dist/tools/graph-tools.js +44 -3
- package/dist/tools/graph-tools.js.map +1 -1
- package/dist/tools/hilt-tools.d.ts +55 -0
- package/dist/tools/hilt-tools.d.ts.map +1 -0
- package/dist/tools/hilt-tools.js +258 -0
- package/dist/tools/hilt-tools.js.map +1 -0
- package/dist/tools/hono-analyze-app.d.ts +48 -0
- package/dist/tools/hono-analyze-app.d.ts.map +1 -0
- package/dist/tools/hono-analyze-app.js +102 -0
- package/dist/tools/hono-analyze-app.js.map +1 -0
- package/dist/tools/hono-api-contract.d.ts +22 -0
- package/dist/tools/hono-api-contract.d.ts.map +1 -0
- package/dist/tools/hono-api-contract.js +80 -0
- package/dist/tools/hono-api-contract.js.map +1 -0
- package/dist/tools/hono-conditional-middleware.d.ts +27 -0
- package/dist/tools/hono-conditional-middleware.d.ts.map +1 -0
- package/dist/tools/hono-conditional-middleware.js +62 -0
- package/dist/tools/hono-conditional-middleware.js.map +1 -0
- package/dist/tools/hono-context-flow.d.ts +24 -0
- package/dist/tools/hono-context-flow.d.ts.map +1 -0
- package/dist/tools/hono-context-flow.js +78 -0
- package/dist/tools/hono-context-flow.js.map +1 -0
- package/dist/tools/hono-dead-routes.d.ts +26 -0
- package/dist/tools/hono-dead-routes.d.ts.map +1 -0
- package/dist/tools/hono-dead-routes.js +109 -0
- package/dist/tools/hono-dead-routes.js.map +1 -0
- package/dist/tools/hono-env-regression.d.ts +29 -0
- package/dist/tools/hono-env-regression.d.ts.map +1 -0
- package/dist/tools/hono-env-regression.js +157 -0
- package/dist/tools/hono-env-regression.js.map +1 -0
- package/dist/tools/hono-inline-analyze.d.ts +31 -0
- package/dist/tools/hono-inline-analyze.d.ts.map +1 -0
- package/dist/tools/hono-inline-analyze.js +67 -0
- package/dist/tools/hono-inline-analyze.js.map +1 -0
- package/dist/tools/hono-middleware-chain.d.ts +22 -0
- package/dist/tools/hono-middleware-chain.d.ts.map +1 -0
- package/dist/tools/hono-middleware-chain.js +84 -0
- package/dist/tools/hono-middleware-chain.js.map +1 -0
- package/dist/tools/hono-modules.d.ts +22 -0
- package/dist/tools/hono-modules.d.ts.map +1 -0
- package/dist/tools/hono-modules.js +126 -0
- package/dist/tools/hono-modules.js.map +1 -0
- package/dist/tools/hono-response-types.d.ts +37 -0
- package/dist/tools/hono-response-types.d.ts.map +1 -0
- package/dist/tools/hono-response-types.js +84 -0
- package/dist/tools/hono-response-types.js.map +1 -0
- package/dist/tools/hono-rpc-types.d.ts +21 -0
- package/dist/tools/hono-rpc-types.d.ts.map +1 -0
- package/dist/tools/hono-rpc-types.js +57 -0
- package/dist/tools/hono-rpc-types.js.map +1 -0
- package/dist/tools/hono-security.d.ts +21 -0
- package/dist/tools/hono-security.d.ts.map +1 -0
- package/dist/tools/hono-security.js +98 -0
- package/dist/tools/hono-security.js.map +1 -0
- package/dist/tools/hono-visualize.d.ts +13 -0
- package/dist/tools/hono-visualize.d.ts.map +1 -0
- package/dist/tools/hono-visualize.js +72 -0
- package/dist/tools/hono-visualize.js.map +1 -0
- package/dist/tools/hotspot-tools.d.ts.map +1 -1
- package/dist/tools/hotspot-tools.js +9 -7
- package/dist/tools/hotspot-tools.js.map +1 -1
- package/dist/tools/index-tools.d.ts +17 -0
- package/dist/tools/index-tools.d.ts.map +1 -1
- package/dist/tools/index-tools.js +210 -10
- package/dist/tools/index-tools.js.map +1 -1
- package/dist/tools/kotlin-tools.d.ts +142 -0
- package/dist/tools/kotlin-tools.d.ts.map +1 -0
- package/dist/tools/kotlin-tools.js +572 -0
- package/dist/tools/kotlin-tools.js.map +1 -0
- package/dist/tools/legacy-hono-conventions.d.ts +14 -0
- package/dist/tools/legacy-hono-conventions.d.ts.map +1 -0
- package/dist/tools/legacy-hono-conventions.js +152 -0
- package/dist/tools/legacy-hono-conventions.js.map +1 -0
- package/dist/tools/migration-lint-tools.d.ts +26 -0
- package/dist/tools/migration-lint-tools.d.ts.map +1 -0
- package/dist/tools/migration-lint-tools.js +247 -0
- package/dist/tools/migration-lint-tools.js.map +1 -0
- package/dist/tools/model-tools.d.ts +30 -0
- package/dist/tools/model-tools.d.ts.map +1 -0
- package/dist/tools/model-tools.js +145 -0
- package/dist/tools/model-tools.js.map +1 -0
- package/dist/tools/nest-ext-tools.d.ts +92 -0
- package/dist/tools/nest-ext-tools.d.ts.map +1 -0
- package/dist/tools/nest-ext-tools.js +359 -0
- package/dist/tools/nest-ext-tools.js.map +1 -0
- package/dist/tools/nest-tools.d.ts +171 -0
- package/dist/tools/nest-tools.d.ts.map +1 -0
- package/dist/tools/nest-tools.js +1042 -0
- package/dist/tools/nest-tools.js.map +1 -0
- package/dist/tools/nextjs-api-contract-readers.d.ts +14 -0
- package/dist/tools/nextjs-api-contract-readers.d.ts.map +1 -0
- package/dist/tools/nextjs-api-contract-readers.js +204 -0
- package/dist/tools/nextjs-api-contract-readers.js.map +1 -0
- package/dist/tools/nextjs-api-contract-tools.d.ts +57 -0
- package/dist/tools/nextjs-api-contract-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-api-contract-tools.js +144 -0
- package/dist/tools/nextjs-api-contract-tools.js.map +1 -0
- package/dist/tools/nextjs-boundary-tools.d.ts +39 -0
- package/dist/tools/nextjs-boundary-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-boundary-tools.js +152 -0
- package/dist/tools/nextjs-boundary-tools.js.map +1 -0
- package/dist/tools/nextjs-component-tools.d.ts +121 -0
- package/dist/tools/nextjs-component-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-component-tools.js +460 -0
- package/dist/tools/nextjs-component-tools.js.map +1 -0
- package/dist/tools/nextjs-data-flow-tools.d.ts +42 -0
- package/dist/tools/nextjs-data-flow-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-data-flow-tools.js +158 -0
- package/dist/tools/nextjs-data-flow-tools.js.map +1 -0
- package/dist/tools/nextjs-framework-audit-tools.d.ts +37 -0
- package/dist/tools/nextjs-framework-audit-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-framework-audit-tools.js +211 -0
- package/dist/tools/nextjs-framework-audit-tools.js.map +1 -0
- package/dist/tools/nextjs-link-tools.d.ts +41 -0
- package/dist/tools/nextjs-link-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-link-tools.js +157 -0
- package/dist/tools/nextjs-link-tools.js.map +1 -0
- package/dist/tools/nextjs-metadata-tools.d.ts +74 -0
- package/dist/tools/nextjs-metadata-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-metadata-tools.js +252 -0
- package/dist/tools/nextjs-metadata-tools.js.map +1 -0
- package/dist/tools/nextjs-middleware-coverage-tools.d.ts +41 -0
- package/dist/tools/nextjs-middleware-coverage-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-middleware-coverage-tools.js +88 -0
- package/dist/tools/nextjs-middleware-coverage-tools.js.map +1 -0
- package/dist/tools/nextjs-route-tools.d.ts +100 -0
- package/dist/tools/nextjs-route-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-route-tools.js +493 -0
- package/dist/tools/nextjs-route-tools.js.map +1 -0
- package/dist/tools/nextjs-security-readers.d.ts +22 -0
- package/dist/tools/nextjs-security-readers.d.ts.map +1 -0
- package/dist/tools/nextjs-security-readers.js +318 -0
- package/dist/tools/nextjs-security-readers.js.map +1 -0
- package/dist/tools/nextjs-security-scoring.d.ts +15 -0
- package/dist/tools/nextjs-security-scoring.d.ts.map +1 -0
- package/dist/tools/nextjs-security-scoring.js +65 -0
- package/dist/tools/nextjs-security-scoring.js.map +1 -0
- package/dist/tools/nextjs-security-tools.d.ts +75 -0
- package/dist/tools/nextjs-security-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-security-tools.js +153 -0
- package/dist/tools/nextjs-security-tools.js.map +1 -0
- package/dist/tools/nextjs-tools.d.ts +15 -0
- package/dist/tools/nextjs-tools.d.ts.map +1 -0
- package/dist/tools/nextjs-tools.js +15 -0
- package/dist/tools/nextjs-tools.js.map +1 -0
- package/dist/tools/outline-tools.d.ts.map +1 -1
- package/dist/tools/outline-tools.js +20 -0
- package/dist/tools/outline-tools.js.map +1 -1
- package/dist/tools/pattern-tools.d.ts +8 -0
- package/dist/tools/pattern-tools.d.ts.map +1 -1
- package/dist/tools/pattern-tools.js +561 -3
- package/dist/tools/pattern-tools.js.map +1 -1
- package/dist/tools/perf-tools.d.ts +32 -0
- package/dist/tools/perf-tools.d.ts.map +1 -0
- package/dist/tools/perf-tools.js +227 -0
- package/dist/tools/perf-tools.js.map +1 -0
- package/dist/tools/php-tools.d.ts +176 -0
- package/dist/tools/php-tools.d.ts.map +1 -0
- package/dist/tools/php-tools.js +543 -0
- package/dist/tools/php-tools.js.map +1 -0
- package/dist/tools/prisma-schema-tools.d.ts +44 -0
- package/dist/tools/prisma-schema-tools.d.ts.map +1 -0
- package/dist/tools/prisma-schema-tools.js +358 -0
- package/dist/tools/prisma-schema-tools.js.map +1 -0
- package/dist/tools/project-tools.d.ts +115 -6
- package/dist/tools/project-tools.d.ts.map +1 -1
- package/dist/tools/project-tools.js +594 -217
- package/dist/tools/project-tools.js.map +1 -1
- package/dist/tools/pyproject-tools.d.ts +23 -0
- package/dist/tools/pyproject-tools.d.ts.map +1 -0
- package/dist/tools/pyproject-tools.js +133 -0
- package/dist/tools/pyproject-tools.js.map +1 -0
- package/dist/tools/pytest-tools.d.ts +20 -0
- package/dist/tools/pytest-tools.d.ts.map +1 -0
- package/dist/tools/pytest-tools.js +106 -0
- package/dist/tools/pytest-tools.js.map +1 -0
- package/dist/tools/python-callers.d.ts +28 -0
- package/dist/tools/python-callers.d.ts.map +1 -0
- package/dist/tools/python-callers.js +110 -0
- package/dist/tools/python-callers.js.map +1 -0
- package/dist/tools/python-circular-imports.d.ts +19 -0
- package/dist/tools/python-circular-imports.d.ts.map +1 -0
- package/dist/tools/python-circular-imports.js +126 -0
- package/dist/tools/python-circular-imports.js.map +1 -0
- package/dist/tools/python-deps-analyzer.d.ts +46 -0
- package/dist/tools/python-deps-analyzer.d.ts.map +1 -0
- package/dist/tools/python-deps-analyzer.js +227 -0
- package/dist/tools/python-deps-analyzer.js.map +1 -0
- package/dist/tools/query-tools.d.ts +23 -0
- package/dist/tools/query-tools.d.ts.map +1 -0
- package/dist/tools/query-tools.js +256 -0
- package/dist/tools/query-tools.js.map +1 -0
- package/dist/tools/react-tools.d.ts +218 -0
- package/dist/tools/react-tools.d.ts.map +1 -0
- package/dist/tools/react-tools.js +714 -0
- package/dist/tools/react-tools.js.map +1 -0
- package/dist/tools/report-tools.js +47 -0
- package/dist/tools/report-tools.js.map +1 -1
- package/dist/tools/review-diff-tools.d.ts +2 -6
- package/dist/tools/review-diff-tools.d.ts.map +1 -1
- package/dist/tools/review-diff-tools.js +51 -66
- package/dist/tools/review-diff-tools.js.map +1 -1
- package/dist/tools/room-tools.d.ts +36 -0
- package/dist/tools/room-tools.d.ts.map +1 -0
- package/dist/tools/room-tools.js +147 -0
- package/dist/tools/room-tools.js.map +1 -0
- package/dist/tools/route-tools.d.ts +27 -1
- package/dist/tools/route-tools.d.ts.map +1 -1
- package/dist/tools/route-tools.js +744 -18
- package/dist/tools/route-tools.js.map +1 -1
- package/dist/tools/ruff-tools.d.ts +32 -0
- package/dist/tools/ruff-tools.d.ts.map +1 -0
- package/dist/tools/ruff-tools.js +114 -0
- package/dist/tools/ruff-tools.js.map +1 -0
- package/dist/tools/search-ranker.d.ts.map +1 -1
- package/dist/tools/search-ranker.js +7 -0
- package/dist/tools/search-ranker.js.map +1 -1
- package/dist/tools/serialization-tools.d.ts +24 -0
- package/dist/tools/serialization-tools.d.ts.map +1 -0
- package/dist/tools/serialization-tools.js +156 -0
- package/dist/tools/serialization-tools.js.map +1 -0
- package/dist/tools/sql-tools.d.ts +234 -0
- package/dist/tools/sql-tools.d.ts.map +1 -0
- package/dist/tools/sql-tools.js +1037 -0
- package/dist/tools/sql-tools.js.map +1 -0
- package/dist/tools/status-tools.d.ts +10 -0
- package/dist/tools/status-tools.d.ts.map +1 -0
- package/dist/tools/status-tools.js +32 -0
- package/dist/tools/status-tools.js.map +1 -0
- package/dist/tools/symbol-tools.d.ts +19 -0
- package/dist/tools/symbol-tools.d.ts.map +1 -1
- package/dist/tools/symbol-tools.js +78 -4
- package/dist/tools/symbol-tools.js.map +1 -1
- package/dist/tools/test-impact-tools.d.ts +29 -0
- package/dist/tools/test-impact-tools.d.ts.map +1 -0
- package/dist/tools/test-impact-tools.js +156 -0
- package/dist/tools/test-impact-tools.js.map +1 -0
- package/dist/tools/typecheck-tools.d.ts +39 -0
- package/dist/tools/typecheck-tools.d.ts.map +1 -0
- package/dist/tools/typecheck-tools.js +191 -0
- package/dist/tools/typecheck-tools.js.map +1 -0
- package/dist/tools/wiring-tools.d.ts +19 -0
- package/dist/tools/wiring-tools.d.ts.map +1 -0
- package/dist/tools/wiring-tools.js +147 -0
- package/dist/tools/wiring-tools.js.map +1 -0
- package/dist/types.d.ts +9 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/framework-detect.d.ts +18 -2
- package/dist/utils/framework-detect.d.ts.map +1 -1
- package/dist/utils/framework-detect.js +150 -3
- package/dist/utils/framework-detect.js.map +1 -1
- package/dist/utils/import-graph.d.ts +36 -0
- package/dist/utils/import-graph.d.ts.map +1 -1
- package/dist/utils/import-graph.js +212 -9
- package/dist/utils/import-graph.js.map +1 -1
- package/dist/utils/language-detect.d.ts +21 -0
- package/dist/utils/language-detect.d.ts.map +1 -0
- package/dist/utils/language-detect.js +183 -0
- package/dist/utils/language-detect.js.map +1 -0
- package/dist/utils/nextjs-ast-readers.d.ts +44 -0
- package/dist/utils/nextjs-ast-readers.d.ts.map +1 -0
- package/dist/utils/nextjs-ast-readers.js +341 -0
- package/dist/utils/nextjs-ast-readers.js.map +1 -0
- package/dist/utils/nextjs-audit-cache.d.ts +51 -0
- package/dist/utils/nextjs-audit-cache.d.ts.map +1 -0
- package/dist/utils/nextjs-audit-cache.js +116 -0
- package/dist/utils/nextjs-audit-cache.js.map +1 -0
- package/dist/utils/nextjs-metadata-readers.d.ts +65 -0
- package/dist/utils/nextjs-metadata-readers.d.ts.map +1 -0
- package/dist/utils/nextjs-metadata-readers.js +447 -0
- package/dist/utils/nextjs-metadata-readers.js.map +1 -0
- package/dist/utils/nextjs.d.ts +42 -0
- package/dist/utils/nextjs.d.ts.map +1 -0
- package/dist/utils/nextjs.js +284 -0
- package/dist/utils/nextjs.js.map +1 -0
- package/dist/utils/python-import-resolver.d.ts +42 -0
- package/dist/utils/python-import-resolver.d.ts.map +1 -0
- package/dist/utils/python-import-resolver.js +101 -0
- package/dist/utils/python-import-resolver.js.map +1 -0
- package/dist/utils/python-imports.d.ts +28 -0
- package/dist/utils/python-imports.d.ts.map +1 -0
- package/dist/utils/python-imports.js +117 -0
- package/dist/utils/python-imports.js.map +1 -0
- package/dist/utils/react-alias.d.ts +15 -0
- package/dist/utils/react-alias.d.ts.map +1 -0
- package/dist/utils/react-alias.js +31 -0
- package/dist/utils/react-alias.js.map +1 -0
- package/dist/utils/test-file.d.ts.map +1 -1
- package/dist/utils/test-file.js +7 -0
- package/dist/utils/test-file.js.map +1 -1
- package/dist/utils/walk.d.ts +22 -0
- package/dist/utils/walk.d.ts.map +1 -1
- package/dist/utils/walk.js +70 -2
- package/dist/utils/walk.js.map +1 -1
- package/package.json +3 -2
- package/rules/codesift.md +33 -5
- package/rules/codesift.mdc +33 -5
- package/rules/codex.md +33 -5
- package/rules/gemini.md +33 -5
- package/src/parser/languages/tree-sitter-javascript.wasm +0 -0
- package/src/parser/languages/tree-sitter-kotlin.wasm +0 -0
- package/src/parser/languages/tree-sitter-php.wasm +0 -0
- package/src/parser/languages/tree-sitter-php_only.wasm +0 -0
- package/src/parser/languages/tree-sitter-python.wasm +0 -0
|
@@ -0,0 +1,553 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* dependency_audit — composite tool that runs 4 dependency health checks
|
|
3
|
+
* in parallel: vulnerabilities, licenses, freshness, and lockfile integrity.
|
|
4
|
+
* Wraps existing CLI tools (npm/pnpm/yarn/bun audit + outdated).
|
|
5
|
+
*/
|
|
6
|
+
import { execFile } from "node:child_process";
|
|
7
|
+
import { promisify } from "node:util";
|
|
8
|
+
import { readFile, stat } from "node:fs/promises";
|
|
9
|
+
import { join } from "node:path";
|
|
10
|
+
import { getCodeIndex } from "./index-tools.js";
|
|
11
|
+
const execFileAsync = promisify(execFile);
|
|
12
|
+
// ---------------------------------------------------------------------------
|
|
13
|
+
// Constants
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
const CHECK_TIMEOUT_MS = 30_000;
|
|
16
|
+
const MAX_BUFFER = 64 * 1024 * 1024; // 64MB — npm audit can be large
|
|
17
|
+
const TOP_N = 20;
|
|
18
|
+
const SEVERITY_RANK = {
|
|
19
|
+
low: 0,
|
|
20
|
+
moderate: 1,
|
|
21
|
+
high: 2,
|
|
22
|
+
critical: 3,
|
|
23
|
+
};
|
|
24
|
+
// GPL, AGPL, LGPL, SSPL, EUPL, OSL family → copyleft/problematic for many orgs
|
|
25
|
+
const PROBLEMATIC_LICENSE_PATTERNS = [
|
|
26
|
+
/^GPL(-|$)/i,
|
|
27
|
+
/^AGPL(-|$)/i,
|
|
28
|
+
/^LGPL(-|$)/i,
|
|
29
|
+
/^SSPL(-|$)/i,
|
|
30
|
+
/^EUPL(-|$)/i,
|
|
31
|
+
/^OSL(-|$)/i,
|
|
32
|
+
/^CC-BY-NC/i,
|
|
33
|
+
/copyleft/i,
|
|
34
|
+
];
|
|
35
|
+
function withTimeout(promise, ms) {
|
|
36
|
+
return Promise.race([
|
|
37
|
+
promise,
|
|
38
|
+
new Promise((resolve) => setTimeout(() => resolve({ status: "timeout" }), ms)),
|
|
39
|
+
]);
|
|
40
|
+
}
|
|
41
|
+
function isTimeout(v) {
|
|
42
|
+
return v != null
|
|
43
|
+
&& typeof v === "object"
|
|
44
|
+
&& "status" in v
|
|
45
|
+
&& v.status === "timeout";
|
|
46
|
+
}
|
|
47
|
+
// ---------------------------------------------------------------------------
|
|
48
|
+
// Package manager detection
|
|
49
|
+
// ---------------------------------------------------------------------------
|
|
50
|
+
async function fileExists(path) {
|
|
51
|
+
try {
|
|
52
|
+
await stat(path);
|
|
53
|
+
return true;
|
|
54
|
+
}
|
|
55
|
+
catch {
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
async function detectPackageManager(workspace) {
|
|
60
|
+
if (await fileExists(join(workspace, "pnpm-lock.yaml")))
|
|
61
|
+
return "pnpm";
|
|
62
|
+
if (await fileExists(join(workspace, "yarn.lock")))
|
|
63
|
+
return "yarn";
|
|
64
|
+
if (await fileExists(join(workspace, "bun.lockb")))
|
|
65
|
+
return "bun";
|
|
66
|
+
if (await fileExists(join(workspace, "bun.lock")))
|
|
67
|
+
return "bun";
|
|
68
|
+
if (await fileExists(join(workspace, "package-lock.json")))
|
|
69
|
+
return "npm";
|
|
70
|
+
return "unknown";
|
|
71
|
+
}
|
|
72
|
+
function lockfileName(pm) {
|
|
73
|
+
switch (pm) {
|
|
74
|
+
case "npm": return "package-lock.json";
|
|
75
|
+
case "pnpm": return "pnpm-lock.yaml";
|
|
76
|
+
case "yarn": return "yarn.lock";
|
|
77
|
+
case "bun": return "bun.lockb";
|
|
78
|
+
default: return null;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
function emptyVulnAggregate() {
|
|
82
|
+
return {
|
|
83
|
+
total: 0,
|
|
84
|
+
by_severity: { critical: 0, high: 0, moderate: 0, low: 0 },
|
|
85
|
+
findings: [],
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
function normalizeSeverity(raw) {
|
|
89
|
+
if (typeof raw !== "string")
|
|
90
|
+
return null;
|
|
91
|
+
const s = raw.toLowerCase();
|
|
92
|
+
if (s === "critical" || s === "high" || s === "moderate" || s === "low") {
|
|
93
|
+
return s;
|
|
94
|
+
}
|
|
95
|
+
// npm sometimes emits "info" — treat as low
|
|
96
|
+
if (s === "info")
|
|
97
|
+
return "low";
|
|
98
|
+
return null;
|
|
99
|
+
}
|
|
100
|
+
function parseNpmAudit(stdout, minRank) {
|
|
101
|
+
const agg = emptyVulnAggregate();
|
|
102
|
+
let parsed;
|
|
103
|
+
try {
|
|
104
|
+
parsed = JSON.parse(stdout);
|
|
105
|
+
}
|
|
106
|
+
catch {
|
|
107
|
+
return agg;
|
|
108
|
+
}
|
|
109
|
+
if (!parsed || typeof parsed !== "object")
|
|
110
|
+
return agg;
|
|
111
|
+
const vulns = parsed.vulnerabilities;
|
|
112
|
+
if (!vulns || typeof vulns !== "object")
|
|
113
|
+
return agg;
|
|
114
|
+
for (const [pkg, data] of Object.entries(vulns)) {
|
|
115
|
+
if (!data || typeof data !== "object")
|
|
116
|
+
continue;
|
|
117
|
+
const entry = data;
|
|
118
|
+
const severity = normalizeSeverity(entry.severity);
|
|
119
|
+
if (!severity)
|
|
120
|
+
continue;
|
|
121
|
+
if (SEVERITY_RANK[severity] < minRank)
|
|
122
|
+
continue;
|
|
123
|
+
// `via` can be an array of strings or objects (when transitive)
|
|
124
|
+
const viaRaw = Array.isArray(entry.via) ? entry.via : [];
|
|
125
|
+
const via = viaRaw.map((v) => {
|
|
126
|
+
if (typeof v === "string")
|
|
127
|
+
return v;
|
|
128
|
+
if (v && typeof v === "object" && "name" in v && typeof v.name === "string") {
|
|
129
|
+
return v.name;
|
|
130
|
+
}
|
|
131
|
+
return "";
|
|
132
|
+
}).filter((s) => s.length > 0);
|
|
133
|
+
// fixAvailable may be boolean or an object
|
|
134
|
+
const fixAvailable = entry.fixAvailable === true
|
|
135
|
+
|| (entry.fixAvailable !== undefined && entry.fixAvailable !== false
|
|
136
|
+
&& typeof entry.fixAvailable === "object" && entry.fixAvailable !== null);
|
|
137
|
+
agg.total++;
|
|
138
|
+
agg.by_severity[severity]++;
|
|
139
|
+
const finding = {
|
|
140
|
+
package: pkg,
|
|
141
|
+
severity,
|
|
142
|
+
via,
|
|
143
|
+
fix_available: fixAvailable,
|
|
144
|
+
};
|
|
145
|
+
if (typeof entry.url === "string" && entry.url.length > 0) {
|
|
146
|
+
finding.advisory_url = entry.url;
|
|
147
|
+
}
|
|
148
|
+
agg.findings.push(finding);
|
|
149
|
+
}
|
|
150
|
+
// Sort by severity (critical first), then by package name
|
|
151
|
+
agg.findings.sort((a, b) => SEVERITY_RANK[b.severity] - SEVERITY_RANK[a.severity]
|
|
152
|
+
|| a.package.localeCompare(b.package));
|
|
153
|
+
agg.findings = agg.findings.slice(0, TOP_N);
|
|
154
|
+
return agg;
|
|
155
|
+
}
|
|
156
|
+
async function runAudit(pm, workspace, minRank) {
|
|
157
|
+
if (pm === "unknown") {
|
|
158
|
+
throw new Error("cannot run audit: unknown package manager");
|
|
159
|
+
}
|
|
160
|
+
// All supported package managers accept `audit --json`
|
|
161
|
+
const args = ["audit", "--json"];
|
|
162
|
+
// execFile with non-zero exit is treated as error, but npm audit exits
|
|
163
|
+
// non-zero when vulnerabilities are found. We still want the stdout.
|
|
164
|
+
try {
|
|
165
|
+
const { stdout } = await execFileAsync(pm, args, {
|
|
166
|
+
cwd: workspace,
|
|
167
|
+
maxBuffer: MAX_BUFFER,
|
|
168
|
+
timeout: CHECK_TIMEOUT_MS,
|
|
169
|
+
// Don't inherit the parent's TTY; force non-interactive output
|
|
170
|
+
env: { ...process.env, CI: "1", NO_COLOR: "1" },
|
|
171
|
+
});
|
|
172
|
+
return parseNpmAudit(stdout, minRank);
|
|
173
|
+
}
|
|
174
|
+
catch (err) {
|
|
175
|
+
// Non-zero exit is normal if vulns exist; stdout may still hold the JSON
|
|
176
|
+
if (err && typeof err === "object" && "stdout" in err) {
|
|
177
|
+
const stdout = err.stdout;
|
|
178
|
+
if (typeof stdout === "string" && stdout.trim().length > 0) {
|
|
179
|
+
return parseNpmAudit(stdout, minRank);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
throw err;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
function isProblematicLicense(license) {
|
|
186
|
+
return PROBLEMATIC_LICENSE_PATTERNS.some((pat) => pat.test(license));
|
|
187
|
+
}
|
|
188
|
+
function normalizeLicenseField(raw) {
|
|
189
|
+
if (typeof raw === "string")
|
|
190
|
+
return raw;
|
|
191
|
+
// SPDX object form: { type: "MIT" }
|
|
192
|
+
if (raw && typeof raw === "object") {
|
|
193
|
+
const obj = raw;
|
|
194
|
+
if (typeof obj.type === "string")
|
|
195
|
+
return obj.type;
|
|
196
|
+
}
|
|
197
|
+
return "UNKNOWN";
|
|
198
|
+
}
|
|
199
|
+
async function scanLicenses(workspace, indexFiles) {
|
|
200
|
+
const agg = {
|
|
201
|
+
total: 0,
|
|
202
|
+
problematic: [],
|
|
203
|
+
distribution: {},
|
|
204
|
+
};
|
|
205
|
+
// Look for node_modules/<pkg>/package.json entries in the index.
|
|
206
|
+
// Scoped packages: node_modules/@scope/pkg/package.json (depth 3)
|
|
207
|
+
// Regular: node_modules/pkg/package.json (depth 2)
|
|
208
|
+
const pkgManifests = indexFiles.filter((f) => {
|
|
209
|
+
if (!f.path.includes("node_modules/"))
|
|
210
|
+
return false;
|
|
211
|
+
if (!f.path.endsWith("/package.json"))
|
|
212
|
+
return false;
|
|
213
|
+
// Strip everything up to and including "node_modules/"
|
|
214
|
+
const idx = f.path.lastIndexOf("node_modules/");
|
|
215
|
+
const tail = f.path.slice(idx + "node_modules/".length);
|
|
216
|
+
const parts = tail.split("/");
|
|
217
|
+
// Regular: ["pkg", "package.json"] (2 parts)
|
|
218
|
+
// Scoped: ["@scope", "pkg", "package.json"] (3 parts)
|
|
219
|
+
if (parts.length === 2)
|
|
220
|
+
return true;
|
|
221
|
+
if (parts.length === 3 && parts[0].startsWith("@"))
|
|
222
|
+
return true;
|
|
223
|
+
return false;
|
|
224
|
+
});
|
|
225
|
+
for (const file of pkgManifests) {
|
|
226
|
+
try {
|
|
227
|
+
const absPath = join(workspace, file.path);
|
|
228
|
+
const source = await readFile(absPath, "utf-8");
|
|
229
|
+
const json = JSON.parse(source);
|
|
230
|
+
const pkgName = typeof json.name === "string" ? json.name : file.path;
|
|
231
|
+
// Prefer `license` (SPDX), fall back to legacy `licenses` array
|
|
232
|
+
let license = "UNKNOWN";
|
|
233
|
+
if (json.license !== undefined) {
|
|
234
|
+
license = normalizeLicenseField(json.license);
|
|
235
|
+
}
|
|
236
|
+
else if (Array.isArray(json.licenses) && json.licenses.length > 0) {
|
|
237
|
+
license = normalizeLicenseField(json.licenses[0]);
|
|
238
|
+
}
|
|
239
|
+
agg.total++;
|
|
240
|
+
agg.distribution[license] = (agg.distribution[license] ?? 0) + 1;
|
|
241
|
+
if (isProblematicLicense(license)) {
|
|
242
|
+
agg.problematic.push({
|
|
243
|
+
package: pkgName,
|
|
244
|
+
license,
|
|
245
|
+
is_problematic: true,
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
catch {
|
|
250
|
+
// Skip unreadable / malformed manifests
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
return agg;
|
|
254
|
+
}
|
|
255
|
+
function parseMajor(version) {
|
|
256
|
+
const cleaned = version.replace(/^[\^~>=<v\s]+/, "");
|
|
257
|
+
const first = cleaned.split(".")[0];
|
|
258
|
+
if (!first)
|
|
259
|
+
return null;
|
|
260
|
+
const num = parseInt(first, 10);
|
|
261
|
+
return Number.isNaN(num) ? null : num;
|
|
262
|
+
}
|
|
263
|
+
function parseOutdated(stdout) {
|
|
264
|
+
const agg = { outdated_count: 0, major_gaps: [] };
|
|
265
|
+
if (!stdout.trim())
|
|
266
|
+
return agg;
|
|
267
|
+
let parsed;
|
|
268
|
+
try {
|
|
269
|
+
parsed = JSON.parse(stdout);
|
|
270
|
+
}
|
|
271
|
+
catch {
|
|
272
|
+
return agg;
|
|
273
|
+
}
|
|
274
|
+
if (!parsed || typeof parsed !== "object")
|
|
275
|
+
return agg;
|
|
276
|
+
const entries = [];
|
|
277
|
+
for (const [pkg, data] of Object.entries(parsed)) {
|
|
278
|
+
if (!data || typeof data !== "object")
|
|
279
|
+
continue;
|
|
280
|
+
const entry = data;
|
|
281
|
+
const current = typeof entry.current === "string" ? entry.current : "";
|
|
282
|
+
const latest = typeof entry.latest === "string" ? entry.latest : "";
|
|
283
|
+
if (!current || !latest)
|
|
284
|
+
continue;
|
|
285
|
+
const currMajor = parseMajor(current);
|
|
286
|
+
const latestMajor = parseMajor(latest);
|
|
287
|
+
const gap = currMajor !== null && latestMajor !== null
|
|
288
|
+
? Math.max(0, latestMajor - currMajor)
|
|
289
|
+
: 0;
|
|
290
|
+
entries.push({
|
|
291
|
+
package: pkg,
|
|
292
|
+
current,
|
|
293
|
+
latest,
|
|
294
|
+
major_gap: gap,
|
|
295
|
+
});
|
|
296
|
+
}
|
|
297
|
+
agg.outdated_count = entries.length;
|
|
298
|
+
entries.sort((a, b) => b.major_gap - a.major_gap || a.package.localeCompare(b.package));
|
|
299
|
+
agg.major_gaps = entries.slice(0, TOP_N);
|
|
300
|
+
return agg;
|
|
301
|
+
}
|
|
302
|
+
async function runOutdated(pm, workspace) {
|
|
303
|
+
if (pm === "unknown") {
|
|
304
|
+
throw new Error("cannot run outdated: unknown package manager");
|
|
305
|
+
}
|
|
306
|
+
// npm/pnpm/yarn/bun all accept `outdated --json`. Yarn Classic emits NDJSON
|
|
307
|
+
// (different schema); we only support the modern JSON form here.
|
|
308
|
+
const args = ["outdated", "--json"];
|
|
309
|
+
try {
|
|
310
|
+
const { stdout } = await execFileAsync(pm, args, {
|
|
311
|
+
cwd: workspace,
|
|
312
|
+
maxBuffer: MAX_BUFFER,
|
|
313
|
+
timeout: CHECK_TIMEOUT_MS,
|
|
314
|
+
env: { ...process.env, CI: "1", NO_COLOR: "1" },
|
|
315
|
+
});
|
|
316
|
+
return parseOutdated(stdout);
|
|
317
|
+
}
|
|
318
|
+
catch (err) {
|
|
319
|
+
// `npm outdated` exits 1 when outdated packages exist, but stdout still has JSON
|
|
320
|
+
if (err && typeof err === "object" && "stdout" in err) {
|
|
321
|
+
const stdout = err.stdout;
|
|
322
|
+
if (typeof stdout === "string" && stdout.trim().length > 0) {
|
|
323
|
+
return parseOutdated(stdout);
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
throw err;
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
function cleanVersionRange(range) {
|
|
330
|
+
return range.replace(/^[\^~>=<v\s]+/, "").trim();
|
|
331
|
+
}
|
|
332
|
+
function versionSatisfiesManifest(manifestRange, installed) {
|
|
333
|
+
// Lightweight check: caret/tilde compatibility on the major.
|
|
334
|
+
const cleaned = cleanVersionRange(manifestRange);
|
|
335
|
+
const manifestMajor = parseMajor(cleaned);
|
|
336
|
+
const installedMajor = parseMajor(installed);
|
|
337
|
+
if (manifestMajor === null || installedMajor === null)
|
|
338
|
+
return true;
|
|
339
|
+
// Accept exact equality of major version as "in range" for drift detection
|
|
340
|
+
return manifestMajor === installedMajor;
|
|
341
|
+
}
|
|
342
|
+
async function checkLockfile(workspace, pm) {
|
|
343
|
+
const agg = { present: false, issues: [] };
|
|
344
|
+
const lockName = lockfileName(pm);
|
|
345
|
+
if (!lockName) {
|
|
346
|
+
agg.issues.push({
|
|
347
|
+
type: "missing",
|
|
348
|
+
message: "No supported lockfile found",
|
|
349
|
+
});
|
|
350
|
+
return agg;
|
|
351
|
+
}
|
|
352
|
+
const lockPath = join(workspace, lockName);
|
|
353
|
+
if (!(await fileExists(lockPath))) {
|
|
354
|
+
agg.issues.push({
|
|
355
|
+
type: "missing",
|
|
356
|
+
message: `Lockfile ${lockName} is missing`,
|
|
357
|
+
});
|
|
358
|
+
return agg;
|
|
359
|
+
}
|
|
360
|
+
agg.present = true;
|
|
361
|
+
// Only npm (package-lock.json v2+) is parsed in detail here; others just
|
|
362
|
+
// report presence and skip deep drift/duplicate analysis.
|
|
363
|
+
if (pm !== "npm")
|
|
364
|
+
return agg;
|
|
365
|
+
let manifest = {};
|
|
366
|
+
try {
|
|
367
|
+
const manifestSrc = await readFile(join(workspace, "package.json"), "utf-8");
|
|
368
|
+
manifest = JSON.parse(manifestSrc);
|
|
369
|
+
}
|
|
370
|
+
catch {
|
|
371
|
+
agg.issues.push({
|
|
372
|
+
type: "missing",
|
|
373
|
+
message: "package.json could not be read",
|
|
374
|
+
});
|
|
375
|
+
return agg;
|
|
376
|
+
}
|
|
377
|
+
let lock = {};
|
|
378
|
+
try {
|
|
379
|
+
const lockSrc = await readFile(lockPath, "utf-8");
|
|
380
|
+
lock = JSON.parse(lockSrc);
|
|
381
|
+
}
|
|
382
|
+
catch {
|
|
383
|
+
agg.issues.push({
|
|
384
|
+
type: "missing",
|
|
385
|
+
message: `Lockfile ${lockName} could not be parsed`,
|
|
386
|
+
});
|
|
387
|
+
return agg;
|
|
388
|
+
}
|
|
389
|
+
// Declared deps from manifest
|
|
390
|
+
const declared = {};
|
|
391
|
+
for (const field of ["dependencies", "devDependencies", "optionalDependencies"]) {
|
|
392
|
+
const bag = manifest[field];
|
|
393
|
+
if (bag && typeof bag === "object") {
|
|
394
|
+
for (const [name, range] of Object.entries(bag)) {
|
|
395
|
+
if (typeof range === "string")
|
|
396
|
+
declared[name] = range;
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
// Walk installed versions from `packages` (v2+). Root entry has key "" —
|
|
401
|
+
// every other key starts with "node_modules/".
|
|
402
|
+
const installedVersions = new Map();
|
|
403
|
+
const packages = lock.packages ?? {};
|
|
404
|
+
for (const [key, data] of Object.entries(packages)) {
|
|
405
|
+
if (!key.startsWith("node_modules/"))
|
|
406
|
+
continue;
|
|
407
|
+
const lastIdx = key.lastIndexOf("node_modules/");
|
|
408
|
+
const tail = key.slice(lastIdx + "node_modules/".length);
|
|
409
|
+
// Scoped names include a slash
|
|
410
|
+
const parts = tail.split("/");
|
|
411
|
+
let name;
|
|
412
|
+
if (parts.length >= 2 && parts[0].startsWith("@")) {
|
|
413
|
+
name = `${parts[0]}/${parts[1]}`;
|
|
414
|
+
}
|
|
415
|
+
else {
|
|
416
|
+
name = parts[0];
|
|
417
|
+
}
|
|
418
|
+
if (!name)
|
|
419
|
+
continue;
|
|
420
|
+
const version = data && typeof data === "object" && "version" in data
|
|
421
|
+
&& typeof data.version === "string"
|
|
422
|
+
? data.version
|
|
423
|
+
: null;
|
|
424
|
+
if (!version)
|
|
425
|
+
continue;
|
|
426
|
+
if (!installedVersions.has(name))
|
|
427
|
+
installedVersions.set(name, new Set());
|
|
428
|
+
installedVersions.get(name).add(version);
|
|
429
|
+
}
|
|
430
|
+
// Detect drift: manifest says ^1.x but installed is 0.x
|
|
431
|
+
for (const [name, range] of Object.entries(declared)) {
|
|
432
|
+
const versions = installedVersions.get(name);
|
|
433
|
+
if (!versions || versions.size === 0) {
|
|
434
|
+
agg.issues.push({
|
|
435
|
+
type: "missing",
|
|
436
|
+
package: name,
|
|
437
|
+
message: `${name} declared in package.json but not present in lockfile`,
|
|
438
|
+
});
|
|
439
|
+
continue;
|
|
440
|
+
}
|
|
441
|
+
for (const installed of versions) {
|
|
442
|
+
if (!versionSatisfiesManifest(range, installed)) {
|
|
443
|
+
agg.issues.push({
|
|
444
|
+
type: "drift",
|
|
445
|
+
package: name,
|
|
446
|
+
message: `${name}: manifest range ${range} does not match installed ${installed}`,
|
|
447
|
+
});
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
// Detect duplicates: same package name appearing with multiple versions in the tree
|
|
452
|
+
for (const [name, versions] of installedVersions) {
|
|
453
|
+
if (versions.size > 1) {
|
|
454
|
+
agg.issues.push({
|
|
455
|
+
type: "duplicate",
|
|
456
|
+
package: name,
|
|
457
|
+
message: `${name} installed with ${versions.size} different versions: ${[...versions].join(", ")}`,
|
|
458
|
+
});
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
return agg;
|
|
462
|
+
}
|
|
463
|
+
// ---------------------------------------------------------------------------
|
|
464
|
+
// Main composite tool
|
|
465
|
+
// ---------------------------------------------------------------------------
|
|
466
|
+
export async function dependencyAudit(repo, options) {
|
|
467
|
+
const startMs = Date.now();
|
|
468
|
+
const index = await getCodeIndex(repo);
|
|
469
|
+
if (!index) {
|
|
470
|
+
throw new Error(`Repository "${repo}" not found. Index it first with index_folder.`);
|
|
471
|
+
}
|
|
472
|
+
const workspace = options?.workspace_path ?? index.root;
|
|
473
|
+
const minRank = SEVERITY_RANK[options?.min_severity ?? "low"];
|
|
474
|
+
const skipLicenses = options?.skip_licenses === true;
|
|
475
|
+
const pm = await detectPackageManager(workspace);
|
|
476
|
+
const errors = [];
|
|
477
|
+
// Fan out 4 checks in parallel with per-check timeout
|
|
478
|
+
const [vulnRes, licenseRes, freshRes, lockRes] = await Promise.allSettled([
|
|
479
|
+
pm === "unknown"
|
|
480
|
+
? Promise.resolve(emptyVulnAggregate())
|
|
481
|
+
: withTimeout(runAudit(pm, workspace, minRank), CHECK_TIMEOUT_MS),
|
|
482
|
+
skipLicenses
|
|
483
|
+
? Promise.resolve({ total: 0, problematic: [], distribution: {} })
|
|
484
|
+
: withTimeout(scanLicenses(workspace, index.files), CHECK_TIMEOUT_MS),
|
|
485
|
+
pm === "unknown"
|
|
486
|
+
? Promise.resolve({ outdated_count: 0, major_gaps: [] })
|
|
487
|
+
: withTimeout(runOutdated(pm, workspace), CHECK_TIMEOUT_MS),
|
|
488
|
+
withTimeout(checkLockfile(workspace, pm), CHECK_TIMEOUT_MS),
|
|
489
|
+
]);
|
|
490
|
+
// Extract results — any failure becomes an error[] entry, never crashes the audit
|
|
491
|
+
let vulnerabilities = emptyVulnAggregate();
|
|
492
|
+
if (vulnRes.status === "fulfilled") {
|
|
493
|
+
if (isTimeout(vulnRes.value)) {
|
|
494
|
+
errors.push("vulnerabilities: check timed out");
|
|
495
|
+
}
|
|
496
|
+
else {
|
|
497
|
+
vulnerabilities = vulnRes.value;
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
else {
|
|
501
|
+
errors.push(`vulnerabilities: ${vulnRes.reason instanceof Error ? vulnRes.reason.message : String(vulnRes.reason)}`);
|
|
502
|
+
}
|
|
503
|
+
let licenses = { total: 0, problematic: [], distribution: {} };
|
|
504
|
+
if (licenseRes.status === "fulfilled") {
|
|
505
|
+
if (isTimeout(licenseRes.value)) {
|
|
506
|
+
errors.push("licenses: check timed out");
|
|
507
|
+
}
|
|
508
|
+
else {
|
|
509
|
+
licenses = licenseRes.value;
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
else {
|
|
513
|
+
errors.push(`licenses: ${licenseRes.reason instanceof Error ? licenseRes.reason.message : String(licenseRes.reason)}`);
|
|
514
|
+
}
|
|
515
|
+
let freshness = { outdated_count: 0, major_gaps: [] };
|
|
516
|
+
if (freshRes.status === "fulfilled") {
|
|
517
|
+
if (isTimeout(freshRes.value)) {
|
|
518
|
+
errors.push("freshness: check timed out");
|
|
519
|
+
}
|
|
520
|
+
else {
|
|
521
|
+
freshness = freshRes.value;
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
else {
|
|
525
|
+
errors.push(`freshness: ${freshRes.reason instanceof Error ? freshRes.reason.message : String(freshRes.reason)}`);
|
|
526
|
+
}
|
|
527
|
+
let lockfile = { present: false, issues: [] };
|
|
528
|
+
if (lockRes.status === "fulfilled") {
|
|
529
|
+
if (isTimeout(lockRes.value)) {
|
|
530
|
+
errors.push("lockfile: check timed out");
|
|
531
|
+
}
|
|
532
|
+
else {
|
|
533
|
+
lockfile = lockRes.value;
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
else {
|
|
537
|
+
errors.push(`lockfile: ${lockRes.reason instanceof Error ? lockRes.reason.message : String(lockRes.reason)}`);
|
|
538
|
+
}
|
|
539
|
+
if (pm === "unknown") {
|
|
540
|
+
errors.push("package_manager: could not detect from lockfile");
|
|
541
|
+
}
|
|
542
|
+
return {
|
|
543
|
+
workspace,
|
|
544
|
+
package_manager: pm,
|
|
545
|
+
vulnerabilities,
|
|
546
|
+
licenses,
|
|
547
|
+
freshness,
|
|
548
|
+
lockfile,
|
|
549
|
+
duration_ms: Date.now() - startMs,
|
|
550
|
+
errors,
|
|
551
|
+
};
|
|
552
|
+
}
|
|
553
|
+
//# sourceMappingURL=dependency-audit-tools.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependency-audit-tools.js","sourceRoot":"","sources":["../../src/tools/dependency-audit-tools.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export interface SettingsFinding {
|
|
2
|
+
rule: string;
|
|
3
|
+
severity: "critical" | "high" | "medium" | "low";
|
|
4
|
+
message: string;
|
|
5
|
+
file: string;
|
|
6
|
+
line: number;
|
|
7
|
+
match: string;
|
|
8
|
+
fix: string;
|
|
9
|
+
}
|
|
10
|
+
export interface DjangoSettingsResult {
|
|
11
|
+
files_scanned: string[];
|
|
12
|
+
findings: SettingsFinding[];
|
|
13
|
+
total: number;
|
|
14
|
+
by_severity: Record<string, number>;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Analyze Django settings files for security and configuration anti-patterns.
|
|
18
|
+
*/
|
|
19
|
+
export declare function analyzeDjangoSettings(repo: string, options?: {
|
|
20
|
+
settings_file?: string;
|
|
21
|
+
}): Promise<DjangoSettingsResult>;
|
|
22
|
+
//# sourceMappingURL=django-settings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"django-settings.d.ts","sourceRoot":"","sources":["../../src/tools/django-settings.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;IACjD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,QAAQ,EAAE,eAAe,EAAE,CAAC;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACrC;AAwOD;;GAEG;AACH,wBAAsB,qBAAqB,CACzC,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;IACR,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,GACA,OAAO,CAAC,oBAAoB,CAAC,CAiE/B"}
|