@rbalchii/anchor-engine 4.7.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 +609 -0
- package/README.md +317 -0
- package/anchor.bat +5 -0
- package/docs/API.md +314 -0
- package/docs/DEPLOYMENT.md +448 -0
- package/docs/INDEX.md +226 -0
- package/docs/STAR_Whitepaper_Executive.md +216 -0
- package/docs/TROUBLESHOOTING.md +535 -0
- package/docs/archive/GIT_BACKUP_VERIFICATION.md +297 -0
- package/docs/archive/adoption-guide.md +264 -0
- package/docs/archive/adoption-preparation.md +179 -0
- package/docs/archive/agent-harness-integration.md +227 -0
- package/docs/archive/api-reference.md +106 -0
- package/docs/archive/api_flows_diagram.md +118 -0
- package/docs/archive/architecture.md +410 -0
- package/docs/archive/architecture_diagram.md +174 -0
- package/docs/archive/broader-adoption-preparation.md +175 -0
- package/docs/archive/browser-paradigm-architecture.md +163 -0
- package/docs/archive/chat-integration.md +124 -0
- package/docs/archive/community-adoption-materials.md +103 -0
- package/docs/archive/community-adoption.md +147 -0
- package/docs/archive/comparison-with-siloed-solutions.md +192 -0
- package/docs/archive/comprehensive-docs.md +156 -0
- package/docs/archive/data_flow_diagram.md +251 -0
- package/docs/archive/enhancement-implementation-summary.md +146 -0
- package/docs/archive/evolution-summary.md +141 -0
- package/docs/archive/ingestion_pipeline_diagram.md +198 -0
- package/docs/archive/native-module-profiling-results.md +135 -0
- package/docs/archive/positioning-document.md +158 -0
- package/docs/archive/positioning.md +175 -0
- package/docs/archive/query-builder-documentation.md +218 -0
- package/docs/archive/quick-reference.md +40 -0
- package/docs/archive/quickstart.md +63 -0
- package/docs/archive/relationship-narrative-discovery.md +141 -0
- package/docs/archive/search-logic-improvement-plan.md +336 -0
- package/docs/archive/search_architecture_diagram.md +212 -0
- package/docs/archive/semantic-architecture-guide.md +97 -0
- package/docs/archive/sequence-diagrams.md +128 -0
- package/docs/archive/system_components_diagram.md +296 -0
- package/docs/archive/test-framework-integration.md +109 -0
- package/docs/archive/testing-framework-documentation.md +397 -0
- package/docs/archive/testing-framework-summary.md +121 -0
- package/docs/archive/testing-framework.md +377 -0
- package/docs/archive/ui-architecture.md +75 -0
- package/docs/arxiv/BIBLIOGRAPHY.bib +145 -0
- package/docs/arxiv/RELATED_WORK.tex +39 -0
- package/docs/arxiv/compile.bat +48 -0
- package/docs/arxiv/joss_response.md +33 -0
- package/docs/arxiv/prepare-submission.bat +46 -0
- package/docs/arxiv/review.md +128 -0
- package/docs/arxiv/star-whitepaper.tex +657 -0
- package/docs/code-patterns.md +289 -0
- package/docs/whitepaper.md +445 -0
- package/engine/dist/agent/runtime.d.ts +41 -0
- package/engine/dist/agent/runtime.d.ts.map +1 -0
- package/engine/dist/agent/runtime.js +73 -0
- package/engine/dist/agent/runtime.js.map +1 -0
- package/engine/dist/commands/audit-tags.d.ts +14 -0
- package/engine/dist/commands/audit-tags.d.ts.map +1 -0
- package/engine/dist/commands/audit-tags.js +180 -0
- package/engine/dist/commands/audit-tags.js.map +1 -0
- package/engine/dist/commands/distill.d.ts +19 -0
- package/engine/dist/commands/distill.d.ts.map +1 -0
- package/engine/dist/commands/distill.js +114 -0
- package/engine/dist/commands/distill.js.map +1 -0
- package/engine/dist/commands/generate-synonyms.d.ts +14 -0
- package/engine/dist/commands/generate-synonyms.d.ts.map +1 -0
- package/engine/dist/commands/generate-synonyms.js +91 -0
- package/engine/dist/commands/generate-synonyms.js.map +1 -0
- package/engine/dist/config/index.d.ts +115 -0
- package/engine/dist/config/index.d.ts.map +1 -0
- package/engine/dist/config/index.js +326 -0
- package/engine/dist/config/index.js.map +1 -0
- package/engine/dist/config/max-recall-config.d.ts +102 -0
- package/engine/dist/config/max-recall-config.d.ts.map +1 -0
- package/engine/dist/config/max-recall-config.js +102 -0
- package/engine/dist/config/max-recall-config.js.map +1 -0
- package/engine/dist/config/paths.d.ts +40 -0
- package/engine/dist/config/paths.d.ts.map +1 -0
- package/engine/dist/config/paths.js +49 -0
- package/engine/dist/config/paths.js.map +1 -0
- package/engine/dist/core/batch.d.ts +19 -0
- package/engine/dist/core/batch.d.ts.map +1 -0
- package/engine/dist/core/batch.js +37 -0
- package/engine/dist/core/batch.js.map +1 -0
- package/engine/dist/core/db.d.ts +58 -0
- package/engine/dist/core/db.d.ts.map +1 -0
- package/engine/dist/core/db.js +563 -0
- package/engine/dist/core/db.js.map +1 -0
- package/engine/dist/core/inference/ChatWorker.d.ts +2 -0
- package/engine/dist/core/inference/ChatWorker.d.ts.map +1 -0
- package/engine/dist/core/inference/ChatWorker.js +28 -0
- package/engine/dist/core/inference/ChatWorker.js.map +1 -0
- package/engine/dist/core/inference/context_manager.d.ts +49 -0
- package/engine/dist/core/inference/context_manager.d.ts.map +1 -0
- package/engine/dist/core/inference/context_manager.js +199 -0
- package/engine/dist/core/inference/context_manager.js.map +1 -0
- package/engine/dist/core/inference/llamaLoaderWorker.d.ts +2 -0
- package/engine/dist/core/inference/llamaLoaderWorker.d.ts.map +1 -0
- package/engine/dist/core/inference/llamaLoaderWorker.js +23 -0
- package/engine/dist/core/inference/llamaLoaderWorker.js.map +1 -0
- package/engine/dist/core/vector.d.ts +40 -0
- package/engine/dist/core/vector.d.ts.map +1 -0
- package/engine/dist/core/vector.js +167 -0
- package/engine/dist/core/vector.js.map +1 -0
- package/engine/dist/index.d.ts +4 -0
- package/engine/dist/index.d.ts.map +1 -0
- package/engine/dist/index.js +400 -0
- package/engine/dist/index.js.map +1 -0
- package/engine/dist/middleware/auth.d.ts +14 -0
- package/engine/dist/middleware/auth.d.ts.map +1 -0
- package/engine/dist/middleware/auth.js +44 -0
- package/engine/dist/middleware/auth.js.map +1 -0
- package/engine/dist/middleware/request-tracing.d.ts +29 -0
- package/engine/dist/middleware/request-tracing.d.ts.map +1 -0
- package/engine/dist/middleware/request-tracing.js +115 -0
- package/engine/dist/middleware/request-tracing.js.map +1 -0
- package/engine/dist/middleware/validate.d.ts +30 -0
- package/engine/dist/middleware/validate.d.ts.map +1 -0
- package/engine/dist/middleware/validate.js +117 -0
- package/engine/dist/middleware/validate.js.map +1 -0
- package/engine/dist/native/index.d.ts +106 -0
- package/engine/dist/native/index.d.ts.map +1 -0
- package/engine/dist/native/index.js +230 -0
- package/engine/dist/native/index.js.map +1 -0
- package/engine/dist/native/types.d.ts +45 -0
- package/engine/dist/native/types.d.ts.map +1 -0
- package/engine/dist/native/types.js +6 -0
- package/engine/dist/native/types.js.map +1 -0
- package/engine/dist/profiling/atomization-profiling.d.ts +8 -0
- package/engine/dist/profiling/atomization-profiling.d.ts.map +1 -0
- package/engine/dist/profiling/atomization-profiling.js +108 -0
- package/engine/dist/profiling/atomization-profiling.js.map +1 -0
- package/engine/dist/profiling/bottleneck-identification.d.ts +8 -0
- package/engine/dist/profiling/bottleneck-identification.d.ts.map +1 -0
- package/engine/dist/profiling/bottleneck-identification.js +249 -0
- package/engine/dist/profiling/bottleneck-identification.js.map +1 -0
- package/engine/dist/profiling/content-sanitization-profiling.d.ts +12 -0
- package/engine/dist/profiling/content-sanitization-profiling.d.ts.map +1 -0
- package/engine/dist/profiling/content-sanitization-profiling.js +266 -0
- package/engine/dist/profiling/content-sanitization-profiling.js.map +1 -0
- package/engine/dist/profiling/simhash-profiling.d.ts +11 -0
- package/engine/dist/profiling/simhash-profiling.d.ts.map +1 -0
- package/engine/dist/profiling/simhash-profiling.js +168 -0
- package/engine/dist/profiling/simhash-profiling.js.map +1 -0
- package/engine/dist/routes/api.d.ts +9 -0
- package/engine/dist/routes/api.d.ts.map +1 -0
- package/engine/dist/routes/api.js +37 -0
- package/engine/dist/routes/api.js.map +1 -0
- package/engine/dist/routes/enhanced-api.d.ts +9 -0
- package/engine/dist/routes/enhanced-api.d.ts.map +1 -0
- package/engine/dist/routes/enhanced-api.js +139 -0
- package/engine/dist/routes/enhanced-api.js.map +1 -0
- package/engine/dist/routes/health.d.ts +8 -0
- package/engine/dist/routes/health.d.ts.map +1 -0
- package/engine/dist/routes/health.js +89 -0
- package/engine/dist/routes/health.js.map +1 -0
- package/engine/dist/routes/monitoring.d.ts +8 -0
- package/engine/dist/routes/monitoring.d.ts.map +1 -0
- package/engine/dist/routes/monitoring.js +509 -0
- package/engine/dist/routes/monitoring.js.map +1 -0
- package/engine/dist/routes/v1/admin.d.ts +3 -0
- package/engine/dist/routes/v1/admin.d.ts.map +1 -0
- package/engine/dist/routes/v1/admin.js +261 -0
- package/engine/dist/routes/v1/admin.js.map +1 -0
- package/engine/dist/routes/v1/atoms.d.ts +3 -0
- package/engine/dist/routes/v1/atoms.d.ts.map +1 -0
- package/engine/dist/routes/v1/atoms.js +172 -0
- package/engine/dist/routes/v1/atoms.js.map +1 -0
- package/engine/dist/routes/v1/backup.d.ts +3 -0
- package/engine/dist/routes/v1/backup.d.ts.map +1 -0
- package/engine/dist/routes/v1/backup.js +100 -0
- package/engine/dist/routes/v1/backup.js.map +1 -0
- package/engine/dist/routes/v1/git.d.ts +3 -0
- package/engine/dist/routes/v1/git.d.ts.map +1 -0
- package/engine/dist/routes/v1/git.js +316 -0
- package/engine/dist/routes/v1/git.js.map +1 -0
- package/engine/dist/routes/v1/ingest.d.ts +3 -0
- package/engine/dist/routes/v1/ingest.d.ts.map +1 -0
- package/engine/dist/routes/v1/ingest.js +66 -0
- package/engine/dist/routes/v1/ingest.js.map +1 -0
- package/engine/dist/routes/v1/memory.d.ts +14 -0
- package/engine/dist/routes/v1/memory.d.ts.map +1 -0
- package/engine/dist/routes/v1/memory.js +87 -0
- package/engine/dist/routes/v1/memory.js.map +1 -0
- package/engine/dist/routes/v1/research.d.ts +3 -0
- package/engine/dist/routes/v1/research.d.ts.map +1 -0
- package/engine/dist/routes/v1/research.js +109 -0
- package/engine/dist/routes/v1/research.js.map +1 -0
- package/engine/dist/routes/v1/search.d.ts +3 -0
- package/engine/dist/routes/v1/search.d.ts.map +1 -0
- package/engine/dist/routes/v1/search.js +180 -0
- package/engine/dist/routes/v1/search.js.map +1 -0
- package/engine/dist/routes/v1/settings.d.ts +8 -0
- package/engine/dist/routes/v1/settings.d.ts.map +1 -0
- package/engine/dist/routes/v1/settings.js +211 -0
- package/engine/dist/routes/v1/settings.js.map +1 -0
- package/engine/dist/routes/v1/system.d.ts +3 -0
- package/engine/dist/routes/v1/system.d.ts.map +1 -0
- package/engine/dist/routes/v1/system.js +326 -0
- package/engine/dist/routes/v1/system.js.map +1 -0
- package/engine/dist/routes/v1/tags.d.ts +3 -0
- package/engine/dist/routes/v1/tags.d.ts.map +1 -0
- package/engine/dist/routes/v1/tags.js +102 -0
- package/engine/dist/routes/v1/tags.js.map +1 -0
- package/engine/dist/server-8080.d.ts +2 -0
- package/engine/dist/server-8080.d.ts.map +1 -0
- package/engine/dist/server-8080.js +74 -0
- package/engine/dist/server-8080.js.map +1 -0
- package/engine/dist/services/backup/backup-restore.d.ts +37 -0
- package/engine/dist/services/backup/backup-restore.d.ts.map +1 -0
- package/engine/dist/services/backup/backup-restore.js +385 -0
- package/engine/dist/services/backup/backup-restore.js.map +1 -0
- package/engine/dist/services/backup/backup.d.ts +14 -0
- package/engine/dist/services/backup/backup.d.ts.map +1 -0
- package/engine/dist/services/backup/backup.js +442 -0
- package/engine/dist/services/backup/backup.js.map +1 -0
- package/engine/dist/services/distillation/radial-distiller-v2.d.ts +127 -0
- package/engine/dist/services/distillation/radial-distiller-v2.d.ts.map +1 -0
- package/engine/dist/services/distillation/radial-distiller-v2.js +503 -0
- package/engine/dist/services/distillation/radial-distiller-v2.js.map +1 -0
- package/engine/dist/services/distillation/radial-distiller.d.ts +63 -0
- package/engine/dist/services/distillation/radial-distiller.d.ts.map +1 -0
- package/engine/dist/services/distillation/radial-distiller.js +394 -0
- package/engine/dist/services/distillation/radial-distiller.js.map +1 -0
- package/engine/dist/services/health-check-enhanced.d.ts +89 -0
- package/engine/dist/services/health-check-enhanced.d.ts.map +1 -0
- package/engine/dist/services/health-check-enhanced.js +417 -0
- package/engine/dist/services/health-check-enhanced.js.map +1 -0
- package/engine/dist/services/idle-manager.d.ts +56 -0
- package/engine/dist/services/idle-manager.d.ts.map +1 -0
- package/engine/dist/services/idle-manager.js +210 -0
- package/engine/dist/services/idle-manager.js.map +1 -0
- package/engine/dist/services/inference/inference-service.d.ts +27 -0
- package/engine/dist/services/inference/inference-service.d.ts.map +1 -0
- package/engine/dist/services/inference/inference-service.js +89 -0
- package/engine/dist/services/inference/inference-service.js.map +1 -0
- package/engine/dist/services/inference/inference.d.ts +59 -0
- package/engine/dist/services/inference/inference.d.ts.map +1 -0
- package/engine/dist/services/inference/inference.js +131 -0
- package/engine/dist/services/inference/inference.js.map +1 -0
- package/engine/dist/services/ingest/atomizer-service.d.ts +74 -0
- package/engine/dist/services/ingest/atomizer-service.d.ts.map +1 -0
- package/engine/dist/services/ingest/atomizer-service.js +982 -0
- package/engine/dist/services/ingest/atomizer-service.js.map +1 -0
- package/engine/dist/services/ingest/content-cleaner.d.ts +43 -0
- package/engine/dist/services/ingest/content-cleaner.d.ts.map +1 -0
- package/engine/dist/services/ingest/content-cleaner.js +166 -0
- package/engine/dist/services/ingest/content-cleaner.js.map +1 -0
- package/engine/dist/services/ingest/github-ingest-service.d.ts +103 -0
- package/engine/dist/services/ingest/github-ingest-service.d.ts.map +1 -0
- package/engine/dist/services/ingest/github-ingest-service.js +537 -0
- package/engine/dist/services/ingest/github-ingest-service.js.map +1 -0
- package/engine/dist/services/ingest/ingest-atomic.d.ts +16 -0
- package/engine/dist/services/ingest/ingest-atomic.d.ts.map +1 -0
- package/engine/dist/services/ingest/ingest-atomic.js +437 -0
- package/engine/dist/services/ingest/ingest-atomic.js.map +1 -0
- package/engine/dist/services/ingest/ingest.d.ts +50 -0
- package/engine/dist/services/ingest/ingest.d.ts.map +1 -0
- package/engine/dist/services/ingest/ingest.js +230 -0
- package/engine/dist/services/ingest/ingest.js.map +1 -0
- package/engine/dist/services/ingest/watchdog.d.ts +31 -0
- package/engine/dist/services/ingest/watchdog.d.ts.map +1 -0
- package/engine/dist/services/ingest/watchdog.js +400 -0
- package/engine/dist/services/ingest/watchdog.js.map +1 -0
- package/engine/dist/services/llm/context.d.ts +6 -0
- package/engine/dist/services/llm/context.d.ts.map +1 -0
- package/engine/dist/services/llm/context.js +80 -0
- package/engine/dist/services/llm/context.js.map +1 -0
- package/engine/dist/services/llm/provider.d.ts +23 -0
- package/engine/dist/services/llm/provider.d.ts.map +1 -0
- package/engine/dist/services/llm/provider.js +338 -0
- package/engine/dist/services/llm/provider.js.map +1 -0
- package/engine/dist/services/llm/reader.d.ts +12 -0
- package/engine/dist/services/llm/reader.d.ts.map +1 -0
- package/engine/dist/services/llm/reader.js +40 -0
- package/engine/dist/services/llm/reader.js.map +1 -0
- package/engine/dist/services/mirror/mirror.d.ts +28 -0
- package/engine/dist/services/mirror/mirror.d.ts.map +1 -0
- package/engine/dist/services/mirror/mirror.js +208 -0
- package/engine/dist/services/mirror/mirror.js.map +1 -0
- package/engine/dist/services/nlp/nlp-service.d.ts +70 -0
- package/engine/dist/services/nlp/nlp-service.d.ts.map +1 -0
- package/engine/dist/services/nlp/nlp-service.js +151 -0
- package/engine/dist/services/nlp/nlp-service.js.map +1 -0
- package/engine/dist/services/nlp/query-parser.d.ts +9 -0
- package/engine/dist/services/nlp/query-parser.d.ts.map +1 -0
- package/engine/dist/services/nlp/query-parser.js +29 -0
- package/engine/dist/services/nlp/query-parser.js.map +1 -0
- package/engine/dist/services/query-builder/DataFrame.d.ts +95 -0
- package/engine/dist/services/query-builder/DataFrame.d.ts.map +1 -0
- package/engine/dist/services/query-builder/DataFrame.js +263 -0
- package/engine/dist/services/query-builder/DataFrame.js.map +1 -0
- package/engine/dist/services/query-builder/QueryBuilder.d.ts +106 -0
- package/engine/dist/services/query-builder/QueryBuilder.d.ts.map +1 -0
- package/engine/dist/services/query-builder/QueryBuilder.js +235 -0
- package/engine/dist/services/query-builder/QueryBuilder.js.map +1 -0
- package/engine/dist/services/query-builder/utils/export.d.ts +11 -0
- package/engine/dist/services/query-builder/utils/export.d.ts.map +1 -0
- package/engine/dist/services/query-builder/utils/export.js +130 -0
- package/engine/dist/services/query-builder/utils/export.js.map +1 -0
- package/engine/dist/services/research/researcher.d.ts +15 -0
- package/engine/dist/services/research/researcher.d.ts.map +1 -0
- package/engine/dist/services/research/researcher.js +123 -0
- package/engine/dist/services/research/researcher.js.map +1 -0
- package/engine/dist/services/scribe/scribe.d.ts +43 -0
- package/engine/dist/services/scribe/scribe.d.ts.map +1 -0
- package/engine/dist/services/scribe/scribe.js +135 -0
- package/engine/dist/services/scribe/scribe.js.map +1 -0
- package/engine/dist/services/search/bright-nodes.d.ts +41 -0
- package/engine/dist/services/search/bright-nodes.d.ts.map +1 -0
- package/engine/dist/services/search/bright-nodes.js +117 -0
- package/engine/dist/services/search/bright-nodes.js.map +1 -0
- package/engine/dist/services/search/context-inflator.d.ts +63 -0
- package/engine/dist/services/search/context-inflator.d.ts.map +1 -0
- package/engine/dist/services/search/context-inflator.js +649 -0
- package/engine/dist/services/search/context-inflator.js.map +1 -0
- package/engine/dist/services/search/context-manager.d.ts +34 -0
- package/engine/dist/services/search/context-manager.d.ts.map +1 -0
- package/engine/dist/services/search/context-manager.js +124 -0
- package/engine/dist/services/search/context-manager.js.map +1 -0
- package/engine/dist/services/search/distributed-query.d.ts +38 -0
- package/engine/dist/services/search/distributed-query.d.ts.map +1 -0
- package/engine/dist/services/search/distributed-query.js +105 -0
- package/engine/dist/services/search/distributed-query.js.map +1 -0
- package/engine/dist/services/search/explore.d.ts +73 -0
- package/engine/dist/services/search/explore.d.ts.map +1 -0
- package/engine/dist/services/search/explore.js +388 -0
- package/engine/dist/services/search/explore.js.map +1 -0
- package/engine/dist/services/search/graph-context-serializer.d.ts +76 -0
- package/engine/dist/services/search/graph-context-serializer.d.ts.map +1 -0
- package/engine/dist/services/search/graph-context-serializer.js +435 -0
- package/engine/dist/services/search/graph-context-serializer.js.map +1 -0
- package/engine/dist/services/search/llm-context-formatter.d.ts +122 -0
- package/engine/dist/services/search/llm-context-formatter.d.ts.map +1 -0
- package/engine/dist/services/search/llm-context-formatter.js +394 -0
- package/engine/dist/services/search/llm-context-formatter.js.map +1 -0
- package/engine/dist/services/search/physics-tag-walker.d.ts +115 -0
- package/engine/dist/services/search/physics-tag-walker.d.ts.map +1 -0
- package/engine/dist/services/search/physics-tag-walker.js +611 -0
- package/engine/dist/services/search/physics-tag-walker.js.map +1 -0
- package/engine/dist/services/search/query-parser.d.ts +66 -0
- package/engine/dist/services/search/query-parser.d.ts.map +1 -0
- package/engine/dist/services/search/query-parser.js +346 -0
- package/engine/dist/services/search/query-parser.js.map +1 -0
- package/engine/dist/services/search/search-utils.d.ts +100 -0
- package/engine/dist/services/search/search-utils.d.ts.map +1 -0
- package/engine/dist/services/search/search-utils.js +473 -0
- package/engine/dist/services/search/search-utils.js.map +1 -0
- package/engine/dist/services/search/search.d.ts +116 -0
- package/engine/dist/services/search/search.d.ts.map +1 -0
- package/engine/dist/services/search/search.js +1286 -0
- package/engine/dist/services/search/search.js.map +1 -0
- package/engine/dist/services/search/sovereign-system-prompt.d.ts +48 -0
- package/engine/dist/services/search/sovereign-system-prompt.d.ts.map +1 -0
- package/engine/dist/services/search/sovereign-system-prompt.js +101 -0
- package/engine/dist/services/search/sovereign-system-prompt.js.map +1 -0
- package/engine/dist/services/search/streaming-search.d.ts +51 -0
- package/engine/dist/services/search/streaming-search.d.ts.map +1 -0
- package/engine/dist/services/search/streaming-search.js +94 -0
- package/engine/dist/services/search/streaming-search.js.map +1 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.d.ts +53 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.js +625 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.js.map +1 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.d.ts +68 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.js +176 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.js.map +1 -0
- package/engine/dist/services/semantic/semantic-search.d.ts +52 -0
- package/engine/dist/services/semantic/semantic-search.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-search.js +649 -0
- package/engine/dist/services/semantic/semantic-search.js.map +1 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.d.ts +64 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.js +191 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.js.map +1 -0
- package/engine/dist/services/semantic/types/semantic.d.ts +26 -0
- package/engine/dist/services/semantic/types/semantic.d.ts.map +1 -0
- package/engine/dist/services/semantic/types/semantic.js +7 -0
- package/engine/dist/services/semantic/types/semantic.js.map +1 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.d.ts +79 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.d.ts.map +1 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.js +415 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.js.map +1 -0
- package/engine/dist/services/system-status.d.ts +68 -0
- package/engine/dist/services/system-status.d.ts.map +1 -0
- package/engine/dist/services/system-status.js +107 -0
- package/engine/dist/services/system-status.js.map +1 -0
- package/engine/dist/services/tags/discovery.d.ts +16 -0
- package/engine/dist/services/tags/discovery.d.ts.map +1 -0
- package/engine/dist/services/tags/discovery.js +206 -0
- package/engine/dist/services/tags/discovery.js.map +1 -0
- package/engine/dist/services/tags/gliner.d.ts +18 -0
- package/engine/dist/services/tags/gliner.d.ts.map +1 -0
- package/engine/dist/services/tags/gliner.js +119 -0
- package/engine/dist/services/tags/gliner.js.map +1 -0
- package/engine/dist/services/tags/infector.d.ts +21 -0
- package/engine/dist/services/tags/infector.d.ts.map +1 -0
- package/engine/dist/services/tags/infector.js +168 -0
- package/engine/dist/services/tags/infector.js.map +1 -0
- package/engine/dist/services/tags/tag-auditor.d.ts +77 -0
- package/engine/dist/services/tags/tag-auditor.d.ts.map +1 -0
- package/engine/dist/services/tags/tag-auditor.js +283 -0
- package/engine/dist/services/tags/tag-auditor.js.map +1 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.d.ts +50 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.d.ts.map +1 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.js +291 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.js.map +1 -0
- package/engine/dist/services/vision/vision_service.d.ts +4 -0
- package/engine/dist/services/vision/vision_service.d.ts.map +1 -0
- package/engine/dist/services/vision/vision_service.js +197 -0
- package/engine/dist/services/vision/vision_service.js.map +1 -0
- package/engine/dist/test-framework/core.d.ts +133 -0
- package/engine/dist/test-framework/core.d.ts.map +1 -0
- package/engine/dist/test-framework/core.js +313 -0
- package/engine/dist/test-framework/core.js.map +1 -0
- package/engine/dist/test-framework/dataset-runner.d.ts +78 -0
- package/engine/dist/test-framework/dataset-runner.d.ts.map +1 -0
- package/engine/dist/test-framework/dataset-runner.js +223 -0
- package/engine/dist/test-framework/dataset-runner.js.map +1 -0
- package/engine/dist/test-framework/diagnostic-tests.d.ts +38 -0
- package/engine/dist/test-framework/diagnostic-tests.d.ts.map +1 -0
- package/engine/dist/test-framework/diagnostic-tests.js +283 -0
- package/engine/dist/test-framework/diagnostic-tests.js.map +1 -0
- package/engine/dist/test-framework/performance-regression-tests.d.ts +30 -0
- package/engine/dist/test-framework/performance-regression-tests.d.ts.map +1 -0
- package/engine/dist/test-framework/performance-regression-tests.js +331 -0
- package/engine/dist/test-framework/performance-regression-tests.js.map +1 -0
- package/engine/dist/types/api.d.ts +53 -0
- package/engine/dist/types/api.d.ts.map +1 -0
- package/engine/dist/types/api.js +2 -0
- package/engine/dist/types/api.js.map +1 -0
- package/engine/dist/types/atomic.d.ts +42 -0
- package/engine/dist/types/atomic.d.ts.map +1 -0
- package/engine/dist/types/atomic.js +10 -0
- package/engine/dist/types/atomic.js.map +1 -0
- package/engine/dist/types/context-protocol.d.ts +137 -0
- package/engine/dist/types/context-protocol.d.ts.map +1 -0
- package/engine/dist/types/context-protocol.js +28 -0
- package/engine/dist/types/context-protocol.js.map +1 -0
- package/engine/dist/types/context.d.ts +2 -0
- package/engine/dist/types/context.d.ts.map +1 -0
- package/engine/dist/types/context.js +2 -0
- package/engine/dist/types/context.js.map +1 -0
- package/engine/dist/types/index.d.ts +20 -0
- package/engine/dist/types/index.d.ts.map +1 -0
- package/engine/dist/types/index.js +18 -0
- package/engine/dist/types/index.js.map +1 -0
- package/engine/dist/types/search.d.ts +31 -0
- package/engine/dist/types/search.d.ts.map +1 -0
- package/engine/dist/types/search.js +2 -0
- package/engine/dist/types/search.js.map +1 -0
- package/engine/dist/types/taxonomy.d.ts +137 -0
- package/engine/dist/types/taxonomy.d.ts.map +1 -0
- package/engine/dist/types/taxonomy.js +138 -0
- package/engine/dist/types/taxonomy.js.map +1 -0
- package/engine/dist/types/taxonomy.simple.d.ts +131 -0
- package/engine/dist/types/taxonomy.simple.d.ts.map +1 -0
- package/engine/dist/types/taxonomy.simple.js +132 -0
- package/engine/dist/types/taxonomy.simple.js.map +1 -0
- package/engine/dist/types/tool-call.d.ts +16 -0
- package/engine/dist/types/tool-call.d.ts.map +1 -0
- package/engine/dist/types/tool-call.js +6 -0
- package/engine/dist/types/tool-call.js.map +1 -0
- package/engine/dist/types/trace.d.ts +25 -0
- package/engine/dist/types/trace.d.ts.map +1 -0
- package/engine/dist/types/trace.js +5 -0
- package/engine/dist/types/trace.js.map +1 -0
- package/engine/dist/utils/adaptive-concurrency.d.ts +81 -0
- package/engine/dist/utils/adaptive-concurrency.d.ts.map +1 -0
- package/engine/dist/utils/adaptive-concurrency.js +266 -0
- package/engine/dist/utils/adaptive-concurrency.js.map +1 -0
- package/engine/dist/utils/date_extractor.d.ts +2 -0
- package/engine/dist/utils/date_extractor.d.ts.map +1 -0
- package/engine/dist/utils/date_extractor.js +32 -0
- package/engine/dist/utils/date_extractor.js.map +1 -0
- package/engine/dist/utils/native-module-manager.d.ts +48 -0
- package/engine/dist/utils/native-module-manager.d.ts.map +1 -0
- package/engine/dist/utils/native-module-manager.js +265 -0
- package/engine/dist/utils/native-module-manager.js.map +1 -0
- package/engine/dist/utils/native-module-profiler.d.ts +66 -0
- package/engine/dist/utils/native-module-profiler.d.ts.map +1 -0
- package/engine/dist/utils/native-module-profiler.js +182 -0
- package/engine/dist/utils/native-module-profiler.js.map +1 -0
- package/engine/dist/utils/path-manager.d.ts +59 -0
- package/engine/dist/utils/path-manager.d.ts.map +1 -0
- package/engine/dist/utils/path-manager.js +154 -0
- package/engine/dist/utils/path-manager.js.map +1 -0
- package/engine/dist/utils/performance-monitor.d.ts +92 -0
- package/engine/dist/utils/performance-monitor.d.ts.map +1 -0
- package/engine/dist/utils/performance-monitor.js +221 -0
- package/engine/dist/utils/performance-monitor.js.map +1 -0
- package/engine/dist/utils/process-manager.d.ts +18 -0
- package/engine/dist/utils/process-manager.d.ts.map +1 -0
- package/engine/dist/utils/process-manager.js +100 -0
- package/engine/dist/utils/process-manager.js.map +1 -0
- package/engine/dist/utils/request-tracer.d.ts +131 -0
- package/engine/dist/utils/request-tracer.d.ts.map +1 -0
- package/engine/dist/utils/request-tracer.js +414 -0
- package/engine/dist/utils/request-tracer.js.map +1 -0
- package/engine/dist/utils/resource-manager.d.ts +108 -0
- package/engine/dist/utils/resource-manager.d.ts.map +1 -0
- package/engine/dist/utils/resource-manager.js +235 -0
- package/engine/dist/utils/resource-manager.js.map +1 -0
- package/engine/dist/utils/safe-dns.d.ts +14 -0
- package/engine/dist/utils/safe-dns.d.ts.map +1 -0
- package/engine/dist/utils/safe-dns.js +105 -0
- package/engine/dist/utils/safe-dns.js.map +1 -0
- package/engine/dist/utils/structured-logger.d.ts +124 -0
- package/engine/dist/utils/structured-logger.d.ts.map +1 -0
- package/engine/dist/utils/structured-logger.js +332 -0
- package/engine/dist/utils/structured-logger.js.map +1 -0
- package/engine/dist/utils/tag-cleanup.d.ts +11 -0
- package/engine/dist/utils/tag-cleanup.d.ts.map +1 -0
- package/engine/dist/utils/tag-cleanup.js +111 -0
- package/engine/dist/utils/tag-cleanup.js.map +1 -0
- package/engine/dist/utils/tag-filter.d.ts +19 -0
- package/engine/dist/utils/tag-filter.d.ts.map +1 -0
- package/engine/dist/utils/tag-filter.js +147 -0
- package/engine/dist/utils/tag-filter.js.map +1 -0
- package/engine/dist/utils/tag-modulation.d.ts +80 -0
- package/engine/dist/utils/tag-modulation.d.ts.map +1 -0
- package/engine/dist/utils/tag-modulation.js +284 -0
- package/engine/dist/utils/tag-modulation.js.map +1 -0
- package/engine/dist/utils/timer.d.ts +40 -0
- package/engine/dist/utils/timer.d.ts.map +1 -0
- package/engine/dist/utils/timer.js +76 -0
- package/engine/dist/utils/timer.js.map +1 -0
- package/engine/dist/utils/token-utils.d.ts +19 -0
- package/engine/dist/utils/token-utils.d.ts.map +1 -0
- package/engine/dist/utils/token-utils.js +71 -0
- package/engine/dist/utils/token-utils.js.map +1 -0
- package/engine/dist/utils/wasm-module-loader.d.ts +50 -0
- package/engine/dist/utils/wasm-module-loader.d.ts.map +1 -0
- package/engine/dist/utils/wasm-module-loader.js +136 -0
- package/engine/dist/utils/wasm-module-loader.js.map +1 -0
- package/engine/package.json +105 -0
- package/package.json +106 -0
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Anchor DataFrame - In-Memory Data Manipulation
|
|
3
|
+
*
|
|
4
|
+
* Provides a pandas-like interface for in-memory data operations
|
|
5
|
+
* Designed to work with query results from the Anchor system
|
|
6
|
+
*/
|
|
7
|
+
export class DataFrame {
|
|
8
|
+
data;
|
|
9
|
+
constructor(data = []) {
|
|
10
|
+
this.data = [...data]; // Create a copy to avoid external mutations
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Create a DataFrame from query results
|
|
14
|
+
*/
|
|
15
|
+
static from(data) {
|
|
16
|
+
return new DataFrame(data);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Get the number of rows in the DataFrame
|
|
20
|
+
*/
|
|
21
|
+
get length() {
|
|
22
|
+
return this.data.length;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Get the column names in the DataFrame
|
|
26
|
+
*/
|
|
27
|
+
get columns() {
|
|
28
|
+
if (this.data.length === 0)
|
|
29
|
+
return [];
|
|
30
|
+
return Object.keys(this.data[0]);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Select specific columns from the DataFrame
|
|
34
|
+
*/
|
|
35
|
+
select(columnMap) {
|
|
36
|
+
const newData = this.data.map(row => {
|
|
37
|
+
const newRow = {};
|
|
38
|
+
for (const [newCol, selectorFn] of Object.entries(columnMap)) {
|
|
39
|
+
newRow[newCol] = selectorFn(row);
|
|
40
|
+
}
|
|
41
|
+
return newRow;
|
|
42
|
+
});
|
|
43
|
+
return new DataFrame(newData);
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Filter rows based on a condition
|
|
47
|
+
*/
|
|
48
|
+
filter(condition) {
|
|
49
|
+
const filteredData = this.data.filter(condition);
|
|
50
|
+
return new DataFrame(filteredData);
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Transform columns using mapping functions
|
|
54
|
+
*/
|
|
55
|
+
transform(transformations) {
|
|
56
|
+
const transformedData = this.data.map(row => {
|
|
57
|
+
const newRow = { ...row };
|
|
58
|
+
for (const [col, transformFn] of Object.entries(transformations)) {
|
|
59
|
+
newRow[col] = transformFn(row);
|
|
60
|
+
}
|
|
61
|
+
return newRow;
|
|
62
|
+
});
|
|
63
|
+
return new DataFrame(transformedData);
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Sort the DataFrame by a specific column
|
|
67
|
+
*/
|
|
68
|
+
sort(column, direction = 'asc') {
|
|
69
|
+
const sortedData = [...this.data].sort((a, b) => {
|
|
70
|
+
const valA = a[column];
|
|
71
|
+
const valB = b[column];
|
|
72
|
+
// Handle null/undefined values
|
|
73
|
+
if (valA == null && valB == null)
|
|
74
|
+
return 0;
|
|
75
|
+
if (valA == null)
|
|
76
|
+
return direction === 'asc' ? -1 : 1;
|
|
77
|
+
if (valB == null)
|
|
78
|
+
return direction === 'asc' ? 1 : -1;
|
|
79
|
+
// Compare values
|
|
80
|
+
if (valA < valB)
|
|
81
|
+
return direction === 'asc' ? -1 : 1;
|
|
82
|
+
if (valA > valB)
|
|
83
|
+
return direction === 'asc' ? 1 : -1;
|
|
84
|
+
return 0;
|
|
85
|
+
});
|
|
86
|
+
return new DataFrame(sortedData);
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Limit the number of rows in the DataFrame
|
|
90
|
+
*/
|
|
91
|
+
head(n) {
|
|
92
|
+
const limitedData = this.data.slice(0, n);
|
|
93
|
+
return new DataFrame(limitedData);
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Skip the first n rows
|
|
97
|
+
*/
|
|
98
|
+
tail(n) {
|
|
99
|
+
const tailData = this.data.slice(-n);
|
|
100
|
+
return new DataFrame(tailData);
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Skip the first n rows
|
|
104
|
+
*/
|
|
105
|
+
skip(n) {
|
|
106
|
+
const skippedData = this.data.slice(n);
|
|
107
|
+
return new DataFrame(skippedData);
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Group rows by a specific column
|
|
111
|
+
*/
|
|
112
|
+
groupBy(column) {
|
|
113
|
+
const grouped = {};
|
|
114
|
+
for (const row of this.data) {
|
|
115
|
+
const key = String(row[column]);
|
|
116
|
+
if (!grouped[key]) {
|
|
117
|
+
grouped[key] = [];
|
|
118
|
+
}
|
|
119
|
+
grouped[key].push(row);
|
|
120
|
+
}
|
|
121
|
+
return grouped;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Aggregate data by applying functions to groups
|
|
125
|
+
*/
|
|
126
|
+
agg(aggregations) {
|
|
127
|
+
// For now, just return aggregated values for the whole dataset
|
|
128
|
+
// In a more complex implementation, this would work with groupBy
|
|
129
|
+
const result = {};
|
|
130
|
+
for (const [col, aggFn] of Object.entries(aggregations)) {
|
|
131
|
+
const values = this.data.map(row => row[col]);
|
|
132
|
+
result[col] = aggFn(values);
|
|
133
|
+
}
|
|
134
|
+
return [result];
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Get unique values for a specific column
|
|
138
|
+
*/
|
|
139
|
+
unique(column) {
|
|
140
|
+
const seen = new Set();
|
|
141
|
+
const uniqueValues = [];
|
|
142
|
+
for (const row of this.data) {
|
|
143
|
+
const value = row[column];
|
|
144
|
+
if (!seen.has(value)) {
|
|
145
|
+
seen.add(value);
|
|
146
|
+
uniqueValues.push(value);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return uniqueValues;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Count occurrences of each unique value in a column
|
|
153
|
+
*/
|
|
154
|
+
valueCounts(column) {
|
|
155
|
+
const counts = {};
|
|
156
|
+
for (const row of this.data) {
|
|
157
|
+
const value = String(row[column]);
|
|
158
|
+
counts[value] = (counts[value] || 0) + 1;
|
|
159
|
+
}
|
|
160
|
+
return counts;
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Apply a function to each row
|
|
164
|
+
*/
|
|
165
|
+
map(fn) {
|
|
166
|
+
return this.data.map(fn);
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Convert DataFrame to an array of objects
|
|
170
|
+
*/
|
|
171
|
+
toArray() {
|
|
172
|
+
return [...this.data];
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Convert DataFrame to CSV format
|
|
176
|
+
*/
|
|
177
|
+
toCSV() {
|
|
178
|
+
if (this.data.length === 0) {
|
|
179
|
+
return '';
|
|
180
|
+
}
|
|
181
|
+
// Get headers from the first row
|
|
182
|
+
const headers = Object.keys(this.data[0]);
|
|
183
|
+
const headerRow = headers.join(',');
|
|
184
|
+
// Convert each row to CSV
|
|
185
|
+
const rows = this.data.map(row => {
|
|
186
|
+
return headers.map(header => {
|
|
187
|
+
let value = row[header];
|
|
188
|
+
if (value === null || value === undefined) {
|
|
189
|
+
return '';
|
|
190
|
+
}
|
|
191
|
+
value = String(value);
|
|
192
|
+
// Escape quotes and wrap in quotes if needed
|
|
193
|
+
if (value.includes(',') || value.includes('"') || value.includes('\n')) {
|
|
194
|
+
value = '"' + value.replace(/"/g, '""') + '"';
|
|
195
|
+
}
|
|
196
|
+
return value;
|
|
197
|
+
}).join(',');
|
|
198
|
+
});
|
|
199
|
+
return [headerRow, ...rows].join('\n');
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Convert DataFrame to JSON format
|
|
203
|
+
*/
|
|
204
|
+
toJSON() {
|
|
205
|
+
return JSON.stringify(this.data, null, 2);
|
|
206
|
+
}
|
|
207
|
+
/**
|
|
208
|
+
* Convert DataFrame to a formatted table string
|
|
209
|
+
*/
|
|
210
|
+
toTable() {
|
|
211
|
+
if (this.data.length === 0) {
|
|
212
|
+
return 'No results';
|
|
213
|
+
}
|
|
214
|
+
// Get headers
|
|
215
|
+
const headers = Object.keys(this.data[0]);
|
|
216
|
+
// Calculate column widths
|
|
217
|
+
const colWidths = {};
|
|
218
|
+
for (const header of headers) {
|
|
219
|
+
colWidths[header] = Math.max(header.length, ...this.data.map(row => String(row[header] ?? '').length));
|
|
220
|
+
}
|
|
221
|
+
// Create header row
|
|
222
|
+
const headerRow = headers.map(header => header.padEnd(colWidths[header])).join(' | ');
|
|
223
|
+
// Create separator row
|
|
224
|
+
const separatorRow = headers.map(header => '-'.repeat(colWidths[header])).join('-|-');
|
|
225
|
+
// Create data rows
|
|
226
|
+
const dataRows = this.data.map(row => headers.map(header => String(row[header] ?? '').padEnd(colWidths[header])).join(' | '));
|
|
227
|
+
// Combine all rows
|
|
228
|
+
return [headerRow, separatorRow, ...dataRows].join('\n');
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Export DataFrame to a file
|
|
232
|
+
*/
|
|
233
|
+
async export(filename, format = 'json') {
|
|
234
|
+
let content;
|
|
235
|
+
switch (format.toLowerCase()) {
|
|
236
|
+
case 'csv':
|
|
237
|
+
content = this.toCSV();
|
|
238
|
+
break;
|
|
239
|
+
case 'json':
|
|
240
|
+
content = this.toJSON();
|
|
241
|
+
break;
|
|
242
|
+
case 'table':
|
|
243
|
+
content = this.toTable();
|
|
244
|
+
break;
|
|
245
|
+
case 'yaml': {
|
|
246
|
+
const yaml = await import('js-yaml');
|
|
247
|
+
content = yaml.dump(this.data);
|
|
248
|
+
break;
|
|
249
|
+
}
|
|
250
|
+
default:
|
|
251
|
+
throw new Error(`Unsupported export format: ${format}`);
|
|
252
|
+
}
|
|
253
|
+
// Use Node.js fs module to write file
|
|
254
|
+
const fs = await import('fs/promises');
|
|
255
|
+
const path = await import('path');
|
|
256
|
+
// Ensure the directory exists
|
|
257
|
+
const dir = path.dirname(filename);
|
|
258
|
+
await fs.mkdir(dir, { recursive: true });
|
|
259
|
+
// Write the file
|
|
260
|
+
await fs.writeFile(filename, content);
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
//# sourceMappingURL=DataFrame.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataFrame.js","sourceRoot":"","sources":["../../../src/services/query-builder/DataFrame.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Anchor Query Builder - Simplified Database Query Interface
|
|
3
|
+
*
|
|
4
|
+
* Provides a fluent API for constructing database queries with JavaScript transformations
|
|
5
|
+
* Designed to be LLM-friendly and human-readable while maintaining performance
|
|
6
|
+
*/
|
|
7
|
+
import { DataFrame } from './DataFrame.js';
|
|
8
|
+
export type TransformFunction = (row: any) => any;
|
|
9
|
+
export interface QueryResult {
|
|
10
|
+
rows: any[];
|
|
11
|
+
fields: string[];
|
|
12
|
+
}
|
|
13
|
+
export type ExportFormat = 'csv' | 'json' | 'yaml' | 'table';
|
|
14
|
+
export interface QueryBuilderOptions {
|
|
15
|
+
tableName: string;
|
|
16
|
+
selectFields: string[];
|
|
17
|
+
whereConditions: Array<{
|
|
18
|
+
field: string;
|
|
19
|
+
operator: string;
|
|
20
|
+
value: any;
|
|
21
|
+
}>;
|
|
22
|
+
orderByClause: {
|
|
23
|
+
field: string;
|
|
24
|
+
direction: 'ASC' | 'DESC';
|
|
25
|
+
} | null;
|
|
26
|
+
limitValue: number | null;
|
|
27
|
+
transformFunctions: Record<string, TransformFunction>;
|
|
28
|
+
}
|
|
29
|
+
export interface DatabaseInterface {
|
|
30
|
+
run(query: string, params?: any[]): Promise<any>;
|
|
31
|
+
}
|
|
32
|
+
export declare class QueryBuilder {
|
|
33
|
+
private options;
|
|
34
|
+
private sqlCache;
|
|
35
|
+
private paramsCache;
|
|
36
|
+
private db;
|
|
37
|
+
constructor(db: DatabaseInterface, tableName: string);
|
|
38
|
+
/**
|
|
39
|
+
* Validates that an identifier (table/field name) contains only safe characters
|
|
40
|
+
* to prevent SQL injection attacks. Identifiers must contain only alphanumeric
|
|
41
|
+
* characters, underscores, and start with a letter or underscore.
|
|
42
|
+
*/
|
|
43
|
+
private validateIdentifier;
|
|
44
|
+
/**
|
|
45
|
+
* Escapes an identifier (table/field name) for use in SQL by wrapping it in double quotes
|
|
46
|
+
* and escaping any internal double quotes by doubling them
|
|
47
|
+
*/
|
|
48
|
+
private escapeIdentifier;
|
|
49
|
+
/**
|
|
50
|
+
* Select specific fields from the table
|
|
51
|
+
*/
|
|
52
|
+
select(fields: string[]): QueryBuilder;
|
|
53
|
+
/**
|
|
54
|
+
* Add WHERE condition to the query
|
|
55
|
+
*/
|
|
56
|
+
where(field: string, operator: string, value: any): QueryBuilder;
|
|
57
|
+
/**
|
|
58
|
+
* Add ORDER BY clause to the query
|
|
59
|
+
*/
|
|
60
|
+
orderBy(field: string, direction?: 'ASC' | 'DESC'): QueryBuilder;
|
|
61
|
+
/**
|
|
62
|
+
* Add LIMIT clause to the query
|
|
63
|
+
*/
|
|
64
|
+
limit(count: number): QueryBuilder;
|
|
65
|
+
/**
|
|
66
|
+
* Add JavaScript transformation functions to computed fields
|
|
67
|
+
*/
|
|
68
|
+
transform(transformations: Record<string, TransformFunction>): QueryBuilder;
|
|
69
|
+
/**
|
|
70
|
+
* Build the SQL query string and parameters
|
|
71
|
+
*/
|
|
72
|
+
private buildQuery;
|
|
73
|
+
/**
|
|
74
|
+
* Apply JavaScript transformations to the results
|
|
75
|
+
*/
|
|
76
|
+
private applyTransformations;
|
|
77
|
+
/**
|
|
78
|
+
* Clear cached SQL and parameters when query changes
|
|
79
|
+
*/
|
|
80
|
+
private clearCache;
|
|
81
|
+
/**
|
|
82
|
+
* Execute the query and return results
|
|
83
|
+
*/
|
|
84
|
+
execute(): Promise<any[]>;
|
|
85
|
+
/**
|
|
86
|
+
* Execute the query and return a DataFrame
|
|
87
|
+
*/
|
|
88
|
+
toDataFrame(): Promise<DataFrame>;
|
|
89
|
+
/**
|
|
90
|
+
* Export results to specified format and file
|
|
91
|
+
*/
|
|
92
|
+
export(filename: string, format?: ExportFormat): Promise<void>;
|
|
93
|
+
/**
|
|
94
|
+
* Get the generated SQL query (for debugging)
|
|
95
|
+
*/
|
|
96
|
+
getSQL(): {
|
|
97
|
+
sql: string;
|
|
98
|
+
params: any[];
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Convenience function to start building a query
|
|
103
|
+
* This assumes the db instance is available in the context where it's used
|
|
104
|
+
*/
|
|
105
|
+
export declare function createQueryBuilder(db: DatabaseInterface, table: string): QueryBuilder;
|
|
106
|
+
//# sourceMappingURL=QueryBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"QueryBuilder.d.ts","sourceRoot":"","sources":["../../../src/services/query-builder/QueryBuilder.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,MAAM,MAAM,iBAAiB,GAAG,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,CAAC;AAElD,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,MAAM,YAAY,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAE7D,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,eAAe,EAAE,KAAK,CAAC;QACrB,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,KAAK,EAAE,GAAG,CAAC;KACZ,CAAC,CAAC;IACH,aAAa,EAAE;QACb,KAAK,EAAE,MAAM,CAAC;QACd,SAAS,EAAE,KAAK,GAAG,MAAM,CAAC;KAC3B,GAAG,IAAI,CAAC;IACT,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;CACvD;AAGD,MAAM,WAAW,iBAAiB;IAChC,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;CAClD;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,OAAO,CAAsB;IACrC,OAAO,CAAC,QAAQ,CAAuB;IACvC,OAAO,CAAC,WAAW,CAAsB;IACzC,OAAO,CAAC,EAAE,CAAoB;gBAElB,EAAE,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM;IAapD;;;;OAIG;IACH,OAAO,CAAC,kBAAkB;IAa1B;;;OAGG;IACH,OAAO,CAAC,gBAAgB;IAIxB;;OAEG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,YAAY;IAgBtC;;OAEG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,YAAY;IAOhE;;OAEG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,GAAE,KAAK,GAAG,MAAc,GAAG,YAAY;IAOvE;;OAEG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY;IAMlC;;OAEG;IACH,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,GAAG,YAAY;IAM3E;;OAEG;IACH,OAAO,CAAC,UAAU;IA4ElB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAgB5B;;OAEG;IACH,OAAO,CAAC,UAAU;IAKlB;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;IAM/B;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,SAAS,CAAC;IAKvC;;OAEG;IACG,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,YAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ5E;;OAEG;IACH,MAAM,IAAI;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,GAAG,EAAE,CAAA;KAAE;CAGzC;AAED;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,GAAG,YAAY,CAErF"}
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Anchor Query Builder - Simplified Database Query Interface
|
|
3
|
+
*
|
|
4
|
+
* Provides a fluent API for constructing database queries with JavaScript transformations
|
|
5
|
+
* Designed to be LLM-friendly and human-readable while maintaining performance
|
|
6
|
+
*/
|
|
7
|
+
import { DataFrame } from './DataFrame.js';
|
|
8
|
+
export class QueryBuilder {
|
|
9
|
+
options;
|
|
10
|
+
sqlCache = null;
|
|
11
|
+
paramsCache = null;
|
|
12
|
+
db;
|
|
13
|
+
constructor(db, tableName) {
|
|
14
|
+
this.db = db;
|
|
15
|
+
this.validateIdentifier(tableName, 'table name');
|
|
16
|
+
this.options = {
|
|
17
|
+
tableName,
|
|
18
|
+
selectFields: [],
|
|
19
|
+
whereConditions: [],
|
|
20
|
+
orderByClause: null,
|
|
21
|
+
limitValue: null,
|
|
22
|
+
transformFunctions: {}
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Validates that an identifier (table/field name) contains only safe characters
|
|
27
|
+
* to prevent SQL injection attacks. Identifiers must contain only alphanumeric
|
|
28
|
+
* characters, underscores, and start with a letter or underscore.
|
|
29
|
+
*/
|
|
30
|
+
validateIdentifier(identifier, contextName = 'identifier') {
|
|
31
|
+
// Allow alphanumeric characters and underscores, must start with letter or underscore
|
|
32
|
+
const safeIdentifierPattern = /^[a-zA-Z_][a-zA-Z0-9_]*$/;
|
|
33
|
+
if (!safeIdentifierPattern.test(identifier)) {
|
|
34
|
+
throw new Error(`Invalid ${contextName}: "${identifier}". ` +
|
|
35
|
+
`Identifiers must contain only alphanumeric characters and underscores, ` +
|
|
36
|
+
`and must start with a letter or underscore.`);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Escapes an identifier (table/field name) for use in SQL by wrapping it in double quotes
|
|
41
|
+
* and escaping any internal double quotes by doubling them
|
|
42
|
+
*/
|
|
43
|
+
escapeIdentifier(identifier) {
|
|
44
|
+
return '"' + identifier.replace(/"/g, '""') + '"';
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Select specific fields from the table
|
|
48
|
+
*/
|
|
49
|
+
select(fields) {
|
|
50
|
+
// Validate all field names before storing them, but allow '*' as a wildcard
|
|
51
|
+
const validatedFields = [];
|
|
52
|
+
for (const field of fields) {
|
|
53
|
+
if (field === '*') {
|
|
54
|
+
validatedFields.push(field);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
this.validateIdentifier(field, 'field name');
|
|
58
|
+
validatedFields.push(field);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
this.options.selectFields = validatedFields;
|
|
62
|
+
this.clearCache();
|
|
63
|
+
return this;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Add WHERE condition to the query
|
|
67
|
+
*/
|
|
68
|
+
where(field, operator, value) {
|
|
69
|
+
this.validateIdentifier(field, 'field name');
|
|
70
|
+
this.options.whereConditions.push({ field, operator, value });
|
|
71
|
+
this.clearCache();
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Add ORDER BY clause to the query
|
|
76
|
+
*/
|
|
77
|
+
orderBy(field, direction = 'ASC') {
|
|
78
|
+
this.validateIdentifier(field, 'field name');
|
|
79
|
+
this.options.orderByClause = { field, direction };
|
|
80
|
+
this.clearCache();
|
|
81
|
+
return this;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Add LIMIT clause to the query
|
|
85
|
+
*/
|
|
86
|
+
limit(count) {
|
|
87
|
+
this.options.limitValue = count;
|
|
88
|
+
this.clearCache();
|
|
89
|
+
return this;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Add JavaScript transformation functions to computed fields
|
|
93
|
+
*/
|
|
94
|
+
transform(transformations) {
|
|
95
|
+
this.options.transformFunctions = { ...this.options.transformFunctions, ...transformations };
|
|
96
|
+
this.clearCache();
|
|
97
|
+
return this;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Build the SQL query string and parameters
|
|
101
|
+
*/
|
|
102
|
+
buildQuery() {
|
|
103
|
+
if (this.sqlCache && this.paramsCache) {
|
|
104
|
+
return { sql: this.sqlCache, params: this.paramsCache };
|
|
105
|
+
}
|
|
106
|
+
let sql = 'SELECT ';
|
|
107
|
+
if (this.options.selectFields.length === 0 ||
|
|
108
|
+
(this.options.selectFields.length === 1 && this.options.selectFields[0] === '*')) {
|
|
109
|
+
sql += '*';
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
sql += this.options.selectFields
|
|
113
|
+
.map(field => field === '*' ? '*' : this.escapeIdentifier(field))
|
|
114
|
+
.join(', ');
|
|
115
|
+
}
|
|
116
|
+
sql += ` FROM ${this.escapeIdentifier(this.options.tableName)}`;
|
|
117
|
+
const params = [];
|
|
118
|
+
if (this.options.whereConditions.length > 0) {
|
|
119
|
+
const whereClauses = this.options.whereConditions.map(condition => {
|
|
120
|
+
// Handle different operators
|
|
121
|
+
let operator = condition.operator.toUpperCase();
|
|
122
|
+
if (operator === 'LIKE') {
|
|
123
|
+
params.push(`%${condition.value}%`);
|
|
124
|
+
return `${this.escapeIdentifier(condition.field)} LIKE $${params.length}`;
|
|
125
|
+
}
|
|
126
|
+
else if (operator === 'CONTAINS') {
|
|
127
|
+
// Convert CONTAINS to LIKE for PGlite
|
|
128
|
+
params.push(`%${condition.value}%`);
|
|
129
|
+
return `${this.escapeIdentifier(condition.field)} LIKE $${params.length}`;
|
|
130
|
+
}
|
|
131
|
+
else if (operator === '=') {
|
|
132
|
+
params.push(condition.value);
|
|
133
|
+
return `${this.escapeIdentifier(condition.field)} = $${params.length}`;
|
|
134
|
+
}
|
|
135
|
+
else if (operator === '>') {
|
|
136
|
+
params.push(condition.value);
|
|
137
|
+
return `${this.escapeIdentifier(condition.field)} > $${params.length}`;
|
|
138
|
+
}
|
|
139
|
+
else if (operator === '<') {
|
|
140
|
+
params.push(condition.value);
|
|
141
|
+
return `${this.escapeIdentifier(condition.field)} < $${params.length}`;
|
|
142
|
+
}
|
|
143
|
+
else if (operator === '>=') {
|
|
144
|
+
params.push(condition.value);
|
|
145
|
+
return `${this.escapeIdentifier(condition.field)} >= $${params.length}`;
|
|
146
|
+
}
|
|
147
|
+
else if (operator === '<=') {
|
|
148
|
+
params.push(condition.value);
|
|
149
|
+
return `${this.escapeIdentifier(condition.field)} <= $${params.length}`;
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
// Default to equality
|
|
153
|
+
params.push(condition.value);
|
|
154
|
+
return `${this.escapeIdentifier(condition.field)} = $${params.length}`;
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
sql += ` WHERE ${whereClauses.join(' AND ')}`;
|
|
158
|
+
}
|
|
159
|
+
if (this.options.orderByClause) {
|
|
160
|
+
const rawDirection = String(this.options.orderByClause.direction || '').toUpperCase();
|
|
161
|
+
const safeDirection = rawDirection === 'ASC' || rawDirection === 'DESC' ? rawDirection : 'ASC';
|
|
162
|
+
sql += ` ORDER BY ${this.escapeIdentifier(this.options.orderByClause.field)} ${safeDirection}`;
|
|
163
|
+
}
|
|
164
|
+
if (this.options.limitValue !== null) {
|
|
165
|
+
const limit = Number(this.options.limitValue);
|
|
166
|
+
if (!Number.isSafeInteger(limit) || limit <= 0) {
|
|
167
|
+
throw new Error('Invalid limit value for query');
|
|
168
|
+
}
|
|
169
|
+
sql += ` LIMIT ${limit}`;
|
|
170
|
+
}
|
|
171
|
+
this.sqlCache = sql;
|
|
172
|
+
this.paramsCache = params;
|
|
173
|
+
return { sql, params };
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Apply JavaScript transformations to the results
|
|
177
|
+
*/
|
|
178
|
+
applyTransformations(rows) {
|
|
179
|
+
if (Object.keys(this.options.transformFunctions).length === 0) {
|
|
180
|
+
return rows;
|
|
181
|
+
}
|
|
182
|
+
return rows.map(row => {
|
|
183
|
+
const newRow = { ...row };
|
|
184
|
+
for (const [fieldName, transformFn] of Object.entries(this.options.transformFunctions)) {
|
|
185
|
+
newRow[fieldName] = transformFn(row);
|
|
186
|
+
}
|
|
187
|
+
return newRow;
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Clear cached SQL and parameters when query changes
|
|
192
|
+
*/
|
|
193
|
+
clearCache() {
|
|
194
|
+
this.sqlCache = null;
|
|
195
|
+
this.paramsCache = null;
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* Execute the query and return results
|
|
199
|
+
*/
|
|
200
|
+
async execute() {
|
|
201
|
+
const { sql, params } = this.buildQuery();
|
|
202
|
+
const result = await this.db.run(sql, params);
|
|
203
|
+
return this.applyTransformations(result.rows || []);
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Execute the query and return a DataFrame
|
|
207
|
+
*/
|
|
208
|
+
async toDataFrame() {
|
|
209
|
+
const results = await this.execute();
|
|
210
|
+
return DataFrame.from(results);
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Export results to specified format and file
|
|
214
|
+
*/
|
|
215
|
+
async export(filename, format = 'json') {
|
|
216
|
+
const results = await this.execute();
|
|
217
|
+
// Import the export utility
|
|
218
|
+
const { exportResults } = await import('./utils/export.js');
|
|
219
|
+
await exportResults(results, filename, format);
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Get the generated SQL query (for debugging)
|
|
223
|
+
*/
|
|
224
|
+
getSQL() {
|
|
225
|
+
return this.buildQuery();
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Convenience function to start building a query
|
|
230
|
+
* This assumes the db instance is available in the context where it's used
|
|
231
|
+
*/
|
|
232
|
+
export function createQueryBuilder(db, table) {
|
|
233
|
+
return new QueryBuilder(db, table);
|
|
234
|
+
}
|
|
235
|
+
//# sourceMappingURL=QueryBuilder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"QueryBuilder.js","sourceRoot":"","sources":["../../../src/services/query-builder/QueryBuilder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Export Utility Functions
|
|
3
|
+
*
|
|
4
|
+
* Provides functionality to export query results in various formats
|
|
5
|
+
*/
|
|
6
|
+
export type ExportFormat = 'csv' | 'json' | 'yaml' | 'table';
|
|
7
|
+
/**
|
|
8
|
+
* Export results to specified format and file
|
|
9
|
+
*/
|
|
10
|
+
export declare function exportResults(results: any[], filename: string, format?: ExportFormat): Promise<void>;
|
|
11
|
+
//# sourceMappingURL=export.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../../../src/services/query-builder/utils/export.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,MAAM,MAAM,YAAY,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAE7D;;GAEG;AACH,wBAAsB,aAAa,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,YAAqB,GAAG,OAAO,CAAC,IAAI,CAAC,CA0BlH"}
|