@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,414 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Request Tracing System for Anchor Engine
|
|
3
|
+
*
|
|
4
|
+
* Implements comprehensive request tracing for debugging and monitoring
|
|
5
|
+
* following Standard 078: Process Isolation & Live Diagnostics
|
|
6
|
+
*/
|
|
7
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
8
|
+
import { logWithContext } from '../utils/structured-logger.js';
|
|
9
|
+
import { performanceMonitor } from '../utils/performance-monitor.js';
|
|
10
|
+
export class RequestTracer {
|
|
11
|
+
static instance;
|
|
12
|
+
activeSpans;
|
|
13
|
+
traceContext;
|
|
14
|
+
constructor() {
|
|
15
|
+
this.activeSpans = new Map();
|
|
16
|
+
this.traceContext = new WeakMap();
|
|
17
|
+
}
|
|
18
|
+
static getInstance() {
|
|
19
|
+
if (!RequestTracer.instance) {
|
|
20
|
+
RequestTracer.instance = new RequestTracer();
|
|
21
|
+
}
|
|
22
|
+
return RequestTracer.instance;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Start a new trace for a request
|
|
26
|
+
*/
|
|
27
|
+
startTrace(operation, tags) {
|
|
28
|
+
const traceId = uuidv4();
|
|
29
|
+
const spanId = uuidv4();
|
|
30
|
+
const span = {
|
|
31
|
+
id: spanId,
|
|
32
|
+
traceId,
|
|
33
|
+
operation,
|
|
34
|
+
startTime: Date.now(),
|
|
35
|
+
status: 'started',
|
|
36
|
+
tags
|
|
37
|
+
};
|
|
38
|
+
this.activeSpans.set(spanId, span);
|
|
39
|
+
const context = {
|
|
40
|
+
traceId,
|
|
41
|
+
spanId
|
|
42
|
+
};
|
|
43
|
+
logWithContext.info('TRACE_START', {
|
|
44
|
+
traceId,
|
|
45
|
+
spanId,
|
|
46
|
+
operation,
|
|
47
|
+
tags
|
|
48
|
+
});
|
|
49
|
+
return context;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Start a child span within a trace
|
|
53
|
+
*/
|
|
54
|
+
startChildSpan(parentContext, operation, tags) {
|
|
55
|
+
const spanId = uuidv4();
|
|
56
|
+
const span = {
|
|
57
|
+
id: spanId,
|
|
58
|
+
parentId: parentContext.spanId,
|
|
59
|
+
traceId: parentContext.traceId,
|
|
60
|
+
operation,
|
|
61
|
+
startTime: Date.now(),
|
|
62
|
+
status: 'started',
|
|
63
|
+
tags
|
|
64
|
+
};
|
|
65
|
+
this.activeSpans.set(spanId, span);
|
|
66
|
+
const context = {
|
|
67
|
+
traceId: parentContext.traceId,
|
|
68
|
+
spanId,
|
|
69
|
+
parentId: parentContext.spanId
|
|
70
|
+
};
|
|
71
|
+
logWithContext.info('SPAN_START', {
|
|
72
|
+
traceId: parentContext.traceId,
|
|
73
|
+
spanId,
|
|
74
|
+
parentId: parentContext.spanId,
|
|
75
|
+
operation,
|
|
76
|
+
tags
|
|
77
|
+
});
|
|
78
|
+
return context;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* End a trace span
|
|
82
|
+
*/
|
|
83
|
+
endTrace(context, status = 'completed', tags) {
|
|
84
|
+
const span = this.activeSpans.get(context.spanId);
|
|
85
|
+
if (!span) {
|
|
86
|
+
logWithContext.warn('Attempted to end non-existent span', {
|
|
87
|
+
spanId: context.spanId,
|
|
88
|
+
traceId: context.traceId
|
|
89
|
+
});
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
span.endTime = Date.now();
|
|
93
|
+
span.duration = span.endTime - span.startTime;
|
|
94
|
+
span.status = status;
|
|
95
|
+
if (tags) {
|
|
96
|
+
span.tags = { ...span.tags, ...tags };
|
|
97
|
+
}
|
|
98
|
+
// Update the span in the map
|
|
99
|
+
this.activeSpans.set(context.spanId, span);
|
|
100
|
+
logWithContext.info('TRACE_END', {
|
|
101
|
+
traceId: context.traceId,
|
|
102
|
+
spanId: context.spanId,
|
|
103
|
+
operation: span.operation,
|
|
104
|
+
duration: span.duration,
|
|
105
|
+
status,
|
|
106
|
+
tags
|
|
107
|
+
});
|
|
108
|
+
// Record performance metric
|
|
109
|
+
if (span.duration) {
|
|
110
|
+
performanceMonitor.recordOperation(`${span.operation}_duration`, span.duration);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Add a log to a trace span
|
|
115
|
+
*/
|
|
116
|
+
addLog(context, level, message, fields) {
|
|
117
|
+
const span = this.activeSpans.get(context.spanId);
|
|
118
|
+
if (!span) {
|
|
119
|
+
return; // Silently fail if span doesn't exist
|
|
120
|
+
}
|
|
121
|
+
if (!span.logs) {
|
|
122
|
+
span.logs = [];
|
|
123
|
+
}
|
|
124
|
+
span.logs.push({
|
|
125
|
+
timestamp: Date.now(),
|
|
126
|
+
level,
|
|
127
|
+
message,
|
|
128
|
+
fields
|
|
129
|
+
});
|
|
130
|
+
// Update the span in the map
|
|
131
|
+
this.activeSpans.set(context.spanId, span);
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Add tags to a trace span
|
|
135
|
+
*/
|
|
136
|
+
addTags(context, tags) {
|
|
137
|
+
const span = this.activeSpans.get(context.spanId);
|
|
138
|
+
if (!span) {
|
|
139
|
+
return; // Silently fail if span doesn't exist
|
|
140
|
+
}
|
|
141
|
+
if (!span.tags) {
|
|
142
|
+
span.tags = {};
|
|
143
|
+
}
|
|
144
|
+
span.tags = { ...span.tags, ...tags };
|
|
145
|
+
// Update the span in the map
|
|
146
|
+
this.activeSpans.set(context.spanId, span);
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Get trace information for debugging
|
|
150
|
+
*/
|
|
151
|
+
getTrace(traceId) {
|
|
152
|
+
const spans = Array.from(this.activeSpans.values()).filter(span => span.traceId === traceId);
|
|
153
|
+
return spans.length > 0 ? spans : null;
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Get active spans for a trace
|
|
157
|
+
*/
|
|
158
|
+
getActiveSpans(traceId) {
|
|
159
|
+
return Array.from(this.activeSpans.values()).filter(span => span.traceId === traceId && span.status === 'started');
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get all completed spans for a trace
|
|
163
|
+
*/
|
|
164
|
+
getCompletedSpans(traceId) {
|
|
165
|
+
return Array.from(this.activeSpans.values()).filter(span => span.traceId === traceId && span.status === 'completed');
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Get trace summary
|
|
169
|
+
*/
|
|
170
|
+
getTraceSummary(traceId) {
|
|
171
|
+
const allSpans = this.getTrace(traceId);
|
|
172
|
+
if (!allSpans)
|
|
173
|
+
return null;
|
|
174
|
+
const completedSpans = allSpans.filter(s => s.status === 'completed');
|
|
175
|
+
const errorSpans = allSpans.filter(s => s.status === 'error');
|
|
176
|
+
const totalDuration = Math.max(...allSpans.map(s => s.duration || 0));
|
|
177
|
+
const operations = [...new Set(allSpans.map(s => s.operation))];
|
|
178
|
+
return {
|
|
179
|
+
traceId,
|
|
180
|
+
totalSpans: allSpans.length,
|
|
181
|
+
completedSpans: completedSpans.length,
|
|
182
|
+
errorSpans: errorSpans.length,
|
|
183
|
+
totalDuration,
|
|
184
|
+
operations
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Export trace data for external analysis
|
|
189
|
+
*/
|
|
190
|
+
exportTrace(traceId) {
|
|
191
|
+
const spans = this.getTrace(traceId);
|
|
192
|
+
if (!spans)
|
|
193
|
+
return null;
|
|
194
|
+
// Format for OpenTelemetry-compatible export
|
|
195
|
+
return {
|
|
196
|
+
traceId,
|
|
197
|
+
spans: spans.map(span => ({
|
|
198
|
+
spanId: span.id,
|
|
199
|
+
parentId: span.parentId,
|
|
200
|
+
operation: span.operation,
|
|
201
|
+
startTime: new Date(span.startTime).toISOString(),
|
|
202
|
+
endTime: span.endTime ? new Date(span.endTime).toISOString() : null,
|
|
203
|
+
duration: span.duration,
|
|
204
|
+
status: span.status,
|
|
205
|
+
tags: span.tags || {},
|
|
206
|
+
logs: span.logs || []
|
|
207
|
+
}))
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Clear expired traces (older than specified minutes)
|
|
212
|
+
*/
|
|
213
|
+
clearExpiredTraces(maxAgeMinutes = 30) {
|
|
214
|
+
const cutoffTime = Date.now() - (maxAgeMinutes * 60 * 1000);
|
|
215
|
+
let clearedCount = 0;
|
|
216
|
+
for (const [spanId, span] of this.activeSpans.entries()) {
|
|
217
|
+
// If span is completed and older than maxAge, remove it
|
|
218
|
+
if (span.status !== 'started' && span.endTime && span.endTime < cutoffTime) {
|
|
219
|
+
this.activeSpans.delete(spanId);
|
|
220
|
+
clearedCount++;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
return clearedCount;
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* Get all trace IDs
|
|
227
|
+
*/
|
|
228
|
+
getAllTraceIds() {
|
|
229
|
+
const traceIds = new Set();
|
|
230
|
+
for (const span of this.activeSpans.values()) {
|
|
231
|
+
traceIds.add(span.traceId);
|
|
232
|
+
}
|
|
233
|
+
return Array.from(traceIds);
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* Get recent traces (sorted by start time)
|
|
237
|
+
*/
|
|
238
|
+
getRecentTraces(limit = 50) {
|
|
239
|
+
const traces = Array.from(this.activeSpans.values())
|
|
240
|
+
.sort((a, b) => b.startTime - a.startTime)
|
|
241
|
+
.slice(0, limit)
|
|
242
|
+
.map(span => span.traceId);
|
|
243
|
+
return [...new Set(traces)]; // Remove duplicates
|
|
244
|
+
}
|
|
245
|
+
/**
|
|
246
|
+
* Get slowest traces based on total duration
|
|
247
|
+
*/
|
|
248
|
+
getSlowestTraces(limit = 10) {
|
|
249
|
+
const traceDurations = new Map();
|
|
250
|
+
for (const span of this.activeSpans.values()) {
|
|
251
|
+
if (span.duration) {
|
|
252
|
+
const existing = traceDurations.get(span.traceId) || 0;
|
|
253
|
+
traceDurations.set(span.traceId, Math.max(existing, span.duration));
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
return Array.from(traceDurations.entries())
|
|
257
|
+
.map(([traceId, duration]) => ({ traceId, duration }))
|
|
258
|
+
.sort((a, b) => b.duration - a.duration)
|
|
259
|
+
.slice(0, limit);
|
|
260
|
+
}
|
|
261
|
+
/**
|
|
262
|
+
* Record a performance metric (for compatibility with older code)
|
|
263
|
+
*/
|
|
264
|
+
record(operation, value) {
|
|
265
|
+
// For backward compatibility, we'll use the performance monitor if available
|
|
266
|
+
// This is a simple implementation - in a real system, you'd want to integrate
|
|
267
|
+
// with the actual performance monitoring system
|
|
268
|
+
console.log(`[RequestTracer] Recording metric: ${operation} = ${value}`);
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
// Create a global instance
|
|
272
|
+
export const requestTracer = RequestTracer.getInstance();
|
|
273
|
+
// Context manager for request context propagation
|
|
274
|
+
export class RequestContextManager {
|
|
275
|
+
static contextKey = 'request-context';
|
|
276
|
+
/**
|
|
277
|
+
* Set request context in the current execution context
|
|
278
|
+
*/
|
|
279
|
+
static setContext(context) {
|
|
280
|
+
// In a real implementation, this would use AsyncLocalStorage or similar
|
|
281
|
+
// For now, we'll use a global variable as a placeholder
|
|
282
|
+
global[RequestContextManager.contextKey] = context;
|
|
283
|
+
}
|
|
284
|
+
/**
|
|
285
|
+
* Get request context from the current execution context
|
|
286
|
+
*/
|
|
287
|
+
static getContext() {
|
|
288
|
+
const context = global[RequestContextManager.contextKey];
|
|
289
|
+
return context || null;
|
|
290
|
+
}
|
|
291
|
+
/**
|
|
292
|
+
* Clear request context
|
|
293
|
+
*/
|
|
294
|
+
static clearContext() {
|
|
295
|
+
delete global[RequestContextManager.contextKey];
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* Execute a function with request context
|
|
299
|
+
*/
|
|
300
|
+
static async withContext(context, fn) {
|
|
301
|
+
const previousContext = RequestContextManager.getContext();
|
|
302
|
+
RequestContextManager.setContext(context);
|
|
303
|
+
try {
|
|
304
|
+
return await fn();
|
|
305
|
+
}
|
|
306
|
+
finally {
|
|
307
|
+
RequestContextManager.setContext(previousContext || context);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
// Export a function to trace an operation
|
|
312
|
+
export async function traceOperation(operation, fn, tags, parentContext) {
|
|
313
|
+
const context = parentContext
|
|
314
|
+
? requestTracer.startChildSpan(parentContext, operation, tags)
|
|
315
|
+
: requestTracer.startTrace(operation, tags);
|
|
316
|
+
try {
|
|
317
|
+
const result = await fn();
|
|
318
|
+
requestTracer.endTrace(context, 'completed');
|
|
319
|
+
return result;
|
|
320
|
+
}
|
|
321
|
+
catch (error) {
|
|
322
|
+
requestTracer.endTrace(context, 'error', { error: error.message });
|
|
323
|
+
throw error;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
// Export a function to trace an ingestion operation specifically
|
|
327
|
+
export async function traceIngestion(content, source, fn) {
|
|
328
|
+
const context = requestTracer.startTrace('ingestion', {
|
|
329
|
+
source,
|
|
330
|
+
contentLength: content.length,
|
|
331
|
+
operation: 'ingest'
|
|
332
|
+
});
|
|
333
|
+
try {
|
|
334
|
+
const result = await fn();
|
|
335
|
+
requestTracer.endTrace(context, 'completed', {
|
|
336
|
+
status: 'success'
|
|
337
|
+
});
|
|
338
|
+
return result;
|
|
339
|
+
}
|
|
340
|
+
catch (error) {
|
|
341
|
+
requestTracer.endTrace(context, 'error', {
|
|
342
|
+
status: 'failed',
|
|
343
|
+
error: error.message
|
|
344
|
+
});
|
|
345
|
+
throw error;
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
// Export a function to trace a search operation specifically
|
|
349
|
+
export async function traceSearch(query, buckets, fn) {
|
|
350
|
+
const context = requestTracer.startTrace('search', {
|
|
351
|
+
query: query.substring(0, 100), // Truncate long queries
|
|
352
|
+
buckets,
|
|
353
|
+
operation: 'search'
|
|
354
|
+
});
|
|
355
|
+
try {
|
|
356
|
+
const result = await fn();
|
|
357
|
+
requestTracer.endTrace(context, 'completed', {
|
|
358
|
+
status: 'success'
|
|
359
|
+
});
|
|
360
|
+
return result;
|
|
361
|
+
}
|
|
362
|
+
catch (error) {
|
|
363
|
+
requestTracer.endTrace(context, 'error', {
|
|
364
|
+
status: 'failed',
|
|
365
|
+
error: error.message
|
|
366
|
+
});
|
|
367
|
+
throw error;
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
// Export a function to trace a database operation specifically
|
|
371
|
+
export async function traceDatabaseOperation(operation, query, fn) {
|
|
372
|
+
const context = requestTracer.startTrace(`db_${operation}`, {
|
|
373
|
+
operation,
|
|
374
|
+
queryLength: query.length,
|
|
375
|
+
operationType: 'database'
|
|
376
|
+
});
|
|
377
|
+
try {
|
|
378
|
+
const result = await fn();
|
|
379
|
+
requestTracer.endTrace(context, 'completed', {
|
|
380
|
+
status: 'success'
|
|
381
|
+
});
|
|
382
|
+
return result;
|
|
383
|
+
}
|
|
384
|
+
catch (error) {
|
|
385
|
+
requestTracer.endTrace(context, 'error', {
|
|
386
|
+
status: 'failed',
|
|
387
|
+
error: error.message
|
|
388
|
+
});
|
|
389
|
+
throw error;
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
// Export a function to trace a native module operation specifically
|
|
393
|
+
export async function traceNativeOperation(operation, module, fn) {
|
|
394
|
+
const context = requestTracer.startTrace(`native_${operation}`, {
|
|
395
|
+
module,
|
|
396
|
+
operation,
|
|
397
|
+
operationType: 'native'
|
|
398
|
+
});
|
|
399
|
+
try {
|
|
400
|
+
const result = await fn();
|
|
401
|
+
requestTracer.endTrace(context, 'completed', {
|
|
402
|
+
status: 'success'
|
|
403
|
+
});
|
|
404
|
+
return result;
|
|
405
|
+
}
|
|
406
|
+
catch (error) {
|
|
407
|
+
requestTracer.endTrace(context, 'error', {
|
|
408
|
+
status: 'failed',
|
|
409
|
+
error: error.message
|
|
410
|
+
});
|
|
411
|
+
throw error;
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
//# sourceMappingURL=request-tracer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-tracer.js","sourceRoot":"","sources":["../../src/utils/request-tracer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Memory Management and Resource Optimization for ECE
|
|
3
|
+
*
|
|
4
|
+
* Implements efficient memory usage patterns and resource management
|
|
5
|
+
* following Standard 062: Inference Worker Stability
|
|
6
|
+
*/
|
|
7
|
+
import * as v8 from 'v8';
|
|
8
|
+
export interface MemoryStats {
|
|
9
|
+
rss: number;
|
|
10
|
+
heapTotal: number;
|
|
11
|
+
heapUsed: number;
|
|
12
|
+
external: number;
|
|
13
|
+
arrayBuffers: number;
|
|
14
|
+
percentageUsed: number;
|
|
15
|
+
heapSpaces: HeapSpaceInfo[];
|
|
16
|
+
}
|
|
17
|
+
export interface HeapSpaceInfo {
|
|
18
|
+
name: string;
|
|
19
|
+
size: number;
|
|
20
|
+
used: number;
|
|
21
|
+
available: number;
|
|
22
|
+
physical: number;
|
|
23
|
+
}
|
|
24
|
+
export interface ResourceLimits {
|
|
25
|
+
maxHeapSize: number;
|
|
26
|
+
memoryThreshold: number;
|
|
27
|
+
maxAtomsInMemory: number;
|
|
28
|
+
gcThreshold: number;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Interface for system resource access to facilitate testing
|
|
32
|
+
*/
|
|
33
|
+
export interface SystemResources {
|
|
34
|
+
getTotalMemory(): number;
|
|
35
|
+
getMemoryUsage(): NodeJS.MemoryUsage;
|
|
36
|
+
getHeapStatistics(): v8.HeapInfo;
|
|
37
|
+
getHeapSpaceStatistics(): v8.HeapSpaceInfo[];
|
|
38
|
+
gc(): void;
|
|
39
|
+
hasGc(): boolean;
|
|
40
|
+
}
|
|
41
|
+
export declare class ResourceManager {
|
|
42
|
+
private static instance;
|
|
43
|
+
private limits;
|
|
44
|
+
private lastGCTime;
|
|
45
|
+
private gcCooldown;
|
|
46
|
+
private resources;
|
|
47
|
+
private monitoringInterval;
|
|
48
|
+
private constructor();
|
|
49
|
+
static getInstance(): ResourceManager;
|
|
50
|
+
/**
|
|
51
|
+
* Reset the singleton instance (for testing only)
|
|
52
|
+
*/
|
|
53
|
+
static resetInstance(): void;
|
|
54
|
+
/**
|
|
55
|
+
* Create an instance with specific resources (for testing only)
|
|
56
|
+
*/
|
|
57
|
+
static createInstanceForTesting(resources: SystemResources): ResourceManager;
|
|
58
|
+
/**
|
|
59
|
+
* Get current memory statistics
|
|
60
|
+
*/
|
|
61
|
+
getMemoryStats(): MemoryStats;
|
|
62
|
+
/**
|
|
63
|
+
* Get detailed heap space information
|
|
64
|
+
*/
|
|
65
|
+
private getHeapSpaceInfo;
|
|
66
|
+
/**
|
|
67
|
+
* Check if memory usage is approaching limits
|
|
68
|
+
*/
|
|
69
|
+
isMemoryCritical(): boolean;
|
|
70
|
+
/**
|
|
71
|
+
* Check if optimization is needed
|
|
72
|
+
*/
|
|
73
|
+
needsOptimization(): boolean;
|
|
74
|
+
/**
|
|
75
|
+
* Perform garbage collection if needed and allowed
|
|
76
|
+
*/
|
|
77
|
+
performGCIfNeeded(): void;
|
|
78
|
+
/**
|
|
79
|
+
* Force garbage collection (requires --expose-gc flag)
|
|
80
|
+
*/
|
|
81
|
+
performGarbageCollection(): void;
|
|
82
|
+
/**
|
|
83
|
+
* Optimize memory usage by clearing caches and releasing unused resources
|
|
84
|
+
*/
|
|
85
|
+
optimizeMemory(): void;
|
|
86
|
+
/**
|
|
87
|
+
* Clear internal caches to free up memory
|
|
88
|
+
*/
|
|
89
|
+
private clearInternalCaches;
|
|
90
|
+
/**
|
|
91
|
+
* Get resource limits
|
|
92
|
+
*/
|
|
93
|
+
getResourceLimits(): ResourceLimits;
|
|
94
|
+
/**
|
|
95
|
+
* Update resource limits
|
|
96
|
+
*/
|
|
97
|
+
updateLimits(newLimits: Partial<ResourceLimits>): void;
|
|
98
|
+
/**
|
|
99
|
+
* Monitor memory usage and trigger optimizations
|
|
100
|
+
*/
|
|
101
|
+
startMonitoring(intervalMs?: number): void;
|
|
102
|
+
/**
|
|
103
|
+
* Stop memory monitoring
|
|
104
|
+
*/
|
|
105
|
+
stopMonitoring(): void;
|
|
106
|
+
}
|
|
107
|
+
export declare const resourceManager: ResourceManager;
|
|
108
|
+
//# sourceMappingURL=resource-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resource-manager.d.ts","sourceRoot":"","sources":["../../src/utils/resource-manager.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AAGzB,MAAM,WAAW,WAAW;IAC1B,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,MAAM,CAAC;IACvB,UAAU,EAAE,aAAa,EAAE,CAAC;CAC7B;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,cAAc;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,cAAc,IAAI,MAAM,CAAC;IACzB,cAAc,IAAI,MAAM,CAAC,WAAW,CAAC;IACrC,iBAAiB,IAAI,EAAE,CAAC,QAAQ,CAAC;IACjC,sBAAsB,IAAI,EAAE,CAAC,aAAa,EAAE,CAAC;IAC7C,EAAE,IAAI,IAAI,CAAC;IACX,KAAK,IAAI,OAAO,CAAC;CAClB;AAiCD,qBAAa,eAAe;IAC1B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAkB;IACzC,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,UAAU,CAAiC;IACnD,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,OAAO;WAaO,WAAW,IAAI,eAAe;IAO5C;;OAEG;WACW,aAAa,IAAI,IAAI;IAKnC;;OAEG;WACW,wBAAwB,CAAC,SAAS,EAAE,eAAe,GAAG,eAAe;IAKnF;;OAEG;IACI,cAAc,IAAI,WAAW;IAgBpC;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAiBxB;;OAEG;IACI,gBAAgB,IAAI,OAAO;IAKlC;;OAEG;IACI,iBAAiB,IAAI,OAAO;IAKnC;;OAEG;IACI,iBAAiB,IAAI,IAAI;IAchC;;OAEG;IACI,wBAAwB,IAAI,IAAI;IAgBvC;;OAEG;IACI,cAAc,IAAI,IAAI;IAc7B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAY3B;;OAEG;IACI,iBAAiB,IAAI,cAAc;IAI1C;;OAEG;IACI,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,cAAc,CAAC,GAAG,IAAI;IAI7D;;OAEG;IACI,eAAe,CAAC,UAAU,GAAE,MAAsC,GAAG,IAAI;IAwBhF;;OAEG;IACI,cAAc,IAAI,IAAI;CAO9B;AAGD,eAAO,MAAM,eAAe,iBAAgC,CAAC"}
|