@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,235 @@
|
|
|
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 os from 'os';
|
|
8
|
+
import * as v8 from 'v8';
|
|
9
|
+
import { config } from '../config/index.js';
|
|
10
|
+
/**
|
|
11
|
+
* Default implementation using real system resources
|
|
12
|
+
*/
|
|
13
|
+
class DefaultSystemResources {
|
|
14
|
+
getTotalMemory() {
|
|
15
|
+
return os.totalmem();
|
|
16
|
+
}
|
|
17
|
+
getMemoryUsage() {
|
|
18
|
+
return process.memoryUsage();
|
|
19
|
+
}
|
|
20
|
+
getHeapStatistics() {
|
|
21
|
+
return v8.getHeapStatistics();
|
|
22
|
+
}
|
|
23
|
+
getHeapSpaceStatistics() {
|
|
24
|
+
return v8.getHeapSpaceStatistics();
|
|
25
|
+
}
|
|
26
|
+
gc() {
|
|
27
|
+
if (global.gc) {
|
|
28
|
+
global.gc();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
hasGc() {
|
|
32
|
+
return !!global.gc;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
export class ResourceManager {
|
|
36
|
+
static instance;
|
|
37
|
+
limits;
|
|
38
|
+
lastGCTime = 0;
|
|
39
|
+
gcCooldown = config.GC_COOLDOWN_MS; // Configurable cooldown between forced GC
|
|
40
|
+
resources;
|
|
41
|
+
monitoringInterval = null;
|
|
42
|
+
constructor(resources) {
|
|
43
|
+
this.resources = resources || new DefaultSystemResources();
|
|
44
|
+
// Set default resource limits based on system capabilities
|
|
45
|
+
const totalMemory = this.resources.getTotalMemory();
|
|
46
|
+
this.limits = {
|
|
47
|
+
maxHeapSize: totalMemory * 0.6, // Use up to 60% of total memory
|
|
48
|
+
memoryThreshold: 0.7, // Optimize when 70% of heap is used
|
|
49
|
+
maxAtomsInMemory: config.MAX_ATOMS_IN_MEMORY, // Configurable max atoms to keep in memory at once
|
|
50
|
+
gcThreshold: 0.75 // Force GC when 75% of heap is used
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
static getInstance() {
|
|
54
|
+
if (!ResourceManager.instance) {
|
|
55
|
+
ResourceManager.instance = new ResourceManager();
|
|
56
|
+
}
|
|
57
|
+
return ResourceManager.instance;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Reset the singleton instance (for testing only)
|
|
61
|
+
*/
|
|
62
|
+
static resetInstance() {
|
|
63
|
+
// @ts-ignore
|
|
64
|
+
ResourceManager.instance = undefined;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Create an instance with specific resources (for testing only)
|
|
68
|
+
*/
|
|
69
|
+
static createInstanceForTesting(resources) {
|
|
70
|
+
ResourceManager.instance = new ResourceManager(resources);
|
|
71
|
+
return ResourceManager.instance;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Get current memory statistics
|
|
75
|
+
*/
|
|
76
|
+
getMemoryStats() {
|
|
77
|
+
const usage = this.resources.getMemoryUsage();
|
|
78
|
+
const heapStats = this.resources.getHeapStatistics();
|
|
79
|
+
const heapSpaces = this.getHeapSpaceInfo();
|
|
80
|
+
return {
|
|
81
|
+
rss: usage.rss,
|
|
82
|
+
heapTotal: usage.heapTotal,
|
|
83
|
+
heapUsed: usage.heapUsed,
|
|
84
|
+
external: usage.external,
|
|
85
|
+
arrayBuffers: usage.arrayBuffers,
|
|
86
|
+
percentageUsed: (usage.heapUsed / heapStats.heap_size_limit) * 100, // Correct metric relative to V8 limit
|
|
87
|
+
heapSpaces
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get detailed heap space information
|
|
92
|
+
*/
|
|
93
|
+
getHeapSpaceInfo() {
|
|
94
|
+
try {
|
|
95
|
+
const spaces = this.resources.getHeapSpaceStatistics();
|
|
96
|
+
return spaces.map(space => ({
|
|
97
|
+
name: space.space_name,
|
|
98
|
+
size: space.space_size,
|
|
99
|
+
used: space.space_used_size,
|
|
100
|
+
available: space.space_available_size,
|
|
101
|
+
physical: space.physical_space_size
|
|
102
|
+
}));
|
|
103
|
+
}
|
|
104
|
+
catch (error) {
|
|
105
|
+
// If heap space stats are not available, return empty array
|
|
106
|
+
console.warn('Could not retrieve heap space statistics:', error);
|
|
107
|
+
return [];
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Check if memory usage is approaching limits
|
|
112
|
+
*/
|
|
113
|
+
isMemoryCritical() {
|
|
114
|
+
const stats = this.getMemoryStats();
|
|
115
|
+
return stats.percentageUsed > this.limits.gcThreshold * 100;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Check if optimization is needed
|
|
119
|
+
*/
|
|
120
|
+
needsOptimization() {
|
|
121
|
+
const stats = this.getMemoryStats();
|
|
122
|
+
return stats.percentageUsed > this.limits.memoryThreshold * 100;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Perform garbage collection if needed and allowed
|
|
126
|
+
*/
|
|
127
|
+
performGCIfNeeded() {
|
|
128
|
+
if (!this.needsOptimization()) {
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
const now = Date.now();
|
|
132
|
+
if (now - this.lastGCTime < this.gcCooldown) {
|
|
133
|
+
// Still in cooldown period
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
this.performGarbageCollection();
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Force garbage collection (requires --expose-gc flag)
|
|
140
|
+
*/
|
|
141
|
+
performGarbageCollection() {
|
|
142
|
+
this.lastGCTime = Date.now();
|
|
143
|
+
try {
|
|
144
|
+
if (this.resources.hasGc()) {
|
|
145
|
+
console.log('[ResourceManager] Performing forced garbage collection...');
|
|
146
|
+
this.resources.gc();
|
|
147
|
+
console.log('[ResourceManager] Garbage collection completed.');
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
console.warn('[ResourceManager] Garbage collection not available. Run with --expose-gc flag for manual GC.');
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
catch (error) {
|
|
154
|
+
console.error('[ResourceManager] Error during garbage collection:', error);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Optimize memory usage by clearing caches and releasing unused resources
|
|
159
|
+
*/
|
|
160
|
+
optimizeMemory() {
|
|
161
|
+
console.log('[ResourceManager] Starting memory optimization...');
|
|
162
|
+
// Clear any internal caches (implement as needed)
|
|
163
|
+
this.clearInternalCaches();
|
|
164
|
+
// Perform GC if needed
|
|
165
|
+
this.performGCIfNeeded();
|
|
166
|
+
// Log memory stats after optimization
|
|
167
|
+
const stats = this.getMemoryStats();
|
|
168
|
+
console.log(`[ResourceManager] Memory optimization completed. Heap usage: ${stats.percentageUsed.toFixed(2)}%`);
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Clear internal caches to free up memory
|
|
172
|
+
*/
|
|
173
|
+
clearInternalCaches() {
|
|
174
|
+
// This is where you would clear any application-specific caches
|
|
175
|
+
// For example, atom caches, search result caches, etc.
|
|
176
|
+
console.log('[ResourceManager] Clearing internal caches...');
|
|
177
|
+
// Example: Clear any cached search results older than 5 minutes
|
|
178
|
+
// This would be implemented based on your specific caching needs
|
|
179
|
+
// Example: Clear any temporary data structures
|
|
180
|
+
// This would be implemented based on your specific needs
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Get resource limits
|
|
184
|
+
*/
|
|
185
|
+
getResourceLimits() {
|
|
186
|
+
return { ...this.limits };
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Update resource limits
|
|
190
|
+
*/
|
|
191
|
+
updateLimits(newLimits) {
|
|
192
|
+
this.limits = { ...this.limits, ...newLimits };
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Monitor memory usage and trigger optimizations
|
|
196
|
+
*/
|
|
197
|
+
startMonitoring(intervalMs = config.MONITORING_INTERVAL_MS) {
|
|
198
|
+
if (this.monitoringInterval !== null) {
|
|
199
|
+
this.stopMonitoring();
|
|
200
|
+
}
|
|
201
|
+
console.log(`[ResourceManager] Starting memory monitoring (interval: ${intervalMs}ms)`);
|
|
202
|
+
this.monitoringInterval = setInterval(() => {
|
|
203
|
+
const stats = this.getMemoryStats();
|
|
204
|
+
if (stats.percentageUsed > this.limits.gcThreshold * 100) {
|
|
205
|
+
console.log(`[ResourceManager] Memory usage critical: ${stats.percentageUsed.toFixed(2)}%`);
|
|
206
|
+
this.performGCIfNeeded();
|
|
207
|
+
}
|
|
208
|
+
else if (stats.percentageUsed > this.limits.memoryThreshold * 100) {
|
|
209
|
+
console.log(`[ResourceManager] Memory usage high: ${stats.percentageUsed.toFixed(2)}%`);
|
|
210
|
+
this.optimizeMemory();
|
|
211
|
+
}
|
|
212
|
+
// Log memory stats periodically if in debug mode
|
|
213
|
+
if (process.env['NODE_ENV'] === 'development' || process.env['DEBUG_MEMORY']) {
|
|
214
|
+
console.log(`[ResourceManager] RSS: ${(stats.rss / 1024 / 1024).toFixed(2)}MB, Heap: ${stats.percentageUsed.toFixed(2)}%`);
|
|
215
|
+
}
|
|
216
|
+
}, intervalMs);
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Stop memory monitoring
|
|
220
|
+
*/
|
|
221
|
+
stopMonitoring() {
|
|
222
|
+
if (this.monitoringInterval !== null) {
|
|
223
|
+
clearInterval(this.monitoringInterval);
|
|
224
|
+
this.monitoringInterval = null;
|
|
225
|
+
console.log(`[ResourceManager] Stopped memory monitoring`);
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
// Export singleton instance
|
|
230
|
+
export const resourceManager = ResourceManager.getInstance();
|
|
231
|
+
// Initialize monitoring if enabled
|
|
232
|
+
if (process.env['ECE_MEMORY_MONITORING'] !== 'false') {
|
|
233
|
+
resourceManager.startMonitoring();
|
|
234
|
+
}
|
|
235
|
+
//# sourceMappingURL=resource-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resource-manager.js","sourceRoot":"","sources":["../../src/utils/resource-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import dns from 'node:dns';
|
|
2
|
+
/**
|
|
3
|
+
* Checks if an IP address is private or reserved.
|
|
4
|
+
* Handles IPv4 and IPv6.
|
|
5
|
+
*
|
|
6
|
+
* @param ip - The IP address string
|
|
7
|
+
* @returns true if the IP is private or reserved, false otherwise.
|
|
8
|
+
*/
|
|
9
|
+
export declare function isPrivateIP(ip: string): boolean;
|
|
10
|
+
/**
|
|
11
|
+
* Custom DNS lookup function for `got` that prevents resolving to private IP addresses.
|
|
12
|
+
*/
|
|
13
|
+
export declare function safeLookup(hostname: string, options: dns.LookupOptions, callback: (err: NodeJS.ErrnoException | null, address: string | dns.LookupAddress[], family?: number) => void): void;
|
|
14
|
+
//# sourceMappingURL=safe-dns.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"safe-dns.d.ts","sourceRoot":"","sources":["../../src/utils/safe-dns.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,UAAU,CAAC;AAE3B;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAmE/C;AAED;;GAEG;AACH,wBAAgB,UAAU,CACtB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,GAAG,CAAC,aAAa,EAC1B,QAAQ,EAAE,CAAC,GAAG,EAAE,MAAM,CAAC,cAAc,GAAG,IAAI,EAAE,OAAO,EAAE,MAAM,GAAG,GAAG,CAAC,aAAa,EAAE,EAAE,MAAM,CAAC,EAAE,MAAM,KAAK,IAAI,GAC9G,IAAI,CA0BN"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import dns from 'node:dns';
|
|
2
|
+
/**
|
|
3
|
+
* Checks if an IP address is private or reserved.
|
|
4
|
+
* Handles IPv4 and IPv6.
|
|
5
|
+
*
|
|
6
|
+
* @param ip - The IP address string
|
|
7
|
+
* @returns true if the IP is private or reserved, false otherwise.
|
|
8
|
+
*/
|
|
9
|
+
export function isPrivateIP(ip) {
|
|
10
|
+
// IPv6 with embedded IPv4 (e.g., ::ffff:127.0.0.1)
|
|
11
|
+
if (ip.includes(':') && ip.includes('.')) {
|
|
12
|
+
const lowerIp = ip.toLowerCase();
|
|
13
|
+
// IPv4-mapped IPv6 ::ffff:127.0.0.1
|
|
14
|
+
if (lowerIp.startsWith('::ffff:')) {
|
|
15
|
+
const ipv4 = lowerIp.substring(7);
|
|
16
|
+
if (ipv4.includes('.')) {
|
|
17
|
+
return isPrivateIP(ipv4);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
// Also check for 0:0:0:0:0:ffff:127.0.0.1 style if not normalized
|
|
21
|
+
// It's likely an embedded IPv4
|
|
22
|
+
const parts = lowerIp.split(':');
|
|
23
|
+
const lastPart = parts[parts.length - 1];
|
|
24
|
+
if (lastPart.includes('.')) {
|
|
25
|
+
return isPrivateIP(lastPart);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
// IPv4
|
|
29
|
+
if (ip.includes('.')) {
|
|
30
|
+
const parts = ip.split('.').map(Number);
|
|
31
|
+
if (parts.length !== 4)
|
|
32
|
+
return false;
|
|
33
|
+
// 127.0.0.0/8 - Loopback
|
|
34
|
+
if (parts[0] === 127)
|
|
35
|
+
return true;
|
|
36
|
+
// 10.0.0.0/8 - Private Network
|
|
37
|
+
if (parts[0] === 10)
|
|
38
|
+
return true;
|
|
39
|
+
// 192.168.0.0/16 - Private Network
|
|
40
|
+
if (parts[0] === 192 && parts[1] === 168)
|
|
41
|
+
return true;
|
|
42
|
+
// 172.16.0.0/12 - Private Network (172.16.x.x - 172.31.x.x)
|
|
43
|
+
if (parts[0] === 172 && parts[1] >= 16 && parts[1] <= 31)
|
|
44
|
+
return true;
|
|
45
|
+
// 169.254.0.0/16 - Link-local
|
|
46
|
+
if (parts[0] === 169 && parts[1] === 254)
|
|
47
|
+
return true;
|
|
48
|
+
// 0.0.0.0/8 - Current network (only valid as source address)
|
|
49
|
+
if (parts[0] === 0)
|
|
50
|
+
return true;
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
// IPv6
|
|
54
|
+
else if (ip.includes(':')) {
|
|
55
|
+
const lowerIp = ip.toLowerCase();
|
|
56
|
+
// ::1/128 - Loopback
|
|
57
|
+
if (lowerIp === '::1' || lowerIp === '0:0:0:0:0:0:0:1')
|
|
58
|
+
return true;
|
|
59
|
+
// ::/128 - Unspecified
|
|
60
|
+
if (lowerIp === '::' || lowerIp === '0:0:0:0:0:0:0:0')
|
|
61
|
+
return true;
|
|
62
|
+
// fc00::/7 - Unique Local Address
|
|
63
|
+
// Check if starts with fc or fd (case insensitive)
|
|
64
|
+
const firstBlock = lowerIp.split(':')[0];
|
|
65
|
+
if (firstBlock.length > 0) {
|
|
66
|
+
const val = parseInt(firstBlock, 16);
|
|
67
|
+
// fc00::/7 covers fc00 to fdff
|
|
68
|
+
if (!isNaN(val) && ((val >> 8) & 0xfe) === 0xfc)
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
// fe80::/10 - Link-local
|
|
72
|
+
if (lowerIp.startsWith('fe8') || lowerIp.startsWith('fe9') || lowerIp.startsWith('fea') || lowerIp.startsWith('feb'))
|
|
73
|
+
return true;
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
return false;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Custom DNS lookup function for `got` that prevents resolving to private IP addresses.
|
|
80
|
+
*/
|
|
81
|
+
export function safeLookup(hostname, options, callback) {
|
|
82
|
+
dns.lookup(hostname, options, (err, address, family) => {
|
|
83
|
+
if (err) {
|
|
84
|
+
callback(err, address, family);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
const addressesToCheck = [];
|
|
88
|
+
if (Array.isArray(address)) {
|
|
89
|
+
address.forEach(a => addressesToCheck.push(a.address));
|
|
90
|
+
}
|
|
91
|
+
else if (typeof address === 'string') {
|
|
92
|
+
addressesToCheck.push(address);
|
|
93
|
+
}
|
|
94
|
+
for (const addr of addressesToCheck) {
|
|
95
|
+
if (isPrivateIP(addr)) {
|
|
96
|
+
const error = new Error(`DNS lookup for ${hostname} resolved to a private IP: ${addr}`);
|
|
97
|
+
error.code = 'ERR_SSRF_PROTECTION';
|
|
98
|
+
callback(error, address, family);
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
callback(null, address, family);
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=safe-dns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"safe-dns.js","sourceRoot":"","sources":["../../src/utils/safe-dns.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Structured Logger for Anchor Engine
|
|
3
|
+
*
|
|
4
|
+
* Implements standardized, structured logging with metrics collection
|
|
5
|
+
*/
|
|
6
|
+
import winston from 'winston';
|
|
7
|
+
declare const logger: winston.Logger;
|
|
8
|
+
declare class MetricsTracker {
|
|
9
|
+
private metrics;
|
|
10
|
+
private startTime;
|
|
11
|
+
constructor();
|
|
12
|
+
startTimer(operation: string): () => number;
|
|
13
|
+
recordMetric(operation: string, duration: number): void;
|
|
14
|
+
getMetrics(operation: string): {
|
|
15
|
+
count: number;
|
|
16
|
+
total: number;
|
|
17
|
+
min: number;
|
|
18
|
+
max: number;
|
|
19
|
+
last: number;
|
|
20
|
+
} | undefined;
|
|
21
|
+
getAllMetrics(): Record<string, any>;
|
|
22
|
+
reset(): void;
|
|
23
|
+
/**
|
|
24
|
+
* Prune old metrics to free memory (called during idle cleanup)
|
|
25
|
+
* Removes metrics older than TTL and enforces maximum size limit
|
|
26
|
+
*/
|
|
27
|
+
pruneOldMetrics(): void;
|
|
28
|
+
}
|
|
29
|
+
declare const metricsTracker: MetricsTracker;
|
|
30
|
+
export declare const logWithContext: {
|
|
31
|
+
/**
|
|
32
|
+
* Log an info message with context and metrics
|
|
33
|
+
*/
|
|
34
|
+
info: (message: string, context?: Record<string, any>) => void;
|
|
35
|
+
/**
|
|
36
|
+
* Log a warning with context
|
|
37
|
+
*/
|
|
38
|
+
warn: (message: string, context?: Record<string, any>) => void;
|
|
39
|
+
/**
|
|
40
|
+
* Log an error with context
|
|
41
|
+
*/
|
|
42
|
+
error: (message: string, error?: Error | string, context?: Record<string, any>) => void;
|
|
43
|
+
/**
|
|
44
|
+
* Log a debug message with context
|
|
45
|
+
*/
|
|
46
|
+
debug: (message: string, context?: Record<string, any>) => void;
|
|
47
|
+
/**
|
|
48
|
+
* Log a silly/verbose message with context
|
|
49
|
+
*/
|
|
50
|
+
silly: (message: string, context?: Record<string, any>) => void;
|
|
51
|
+
/**
|
|
52
|
+
* Log a performance metric
|
|
53
|
+
*/
|
|
54
|
+
performance: (operation: string, duration: number, context?: Record<string, any>) => void;
|
|
55
|
+
/**
|
|
56
|
+
* Start a timed operation
|
|
57
|
+
*/
|
|
58
|
+
startTimer: (operation: string) => () => number;
|
|
59
|
+
/**
|
|
60
|
+
* Get current metrics
|
|
61
|
+
*/
|
|
62
|
+
getMetrics: () => Record<string, any>;
|
|
63
|
+
/**
|
|
64
|
+
* Log ingestion event
|
|
65
|
+
*/
|
|
66
|
+
ingestion: (status: "success" | "partial" | "failed", details: Record<string, any>) => void;
|
|
67
|
+
/**
|
|
68
|
+
* Log search event
|
|
69
|
+
*/
|
|
70
|
+
search: (query: string, resultCount: number, duration: number, context?: Record<string, any>) => void;
|
|
71
|
+
/**
|
|
72
|
+
* Log system health event
|
|
73
|
+
*/
|
|
74
|
+
health: (status: "healthy" | "degraded" | "unhealthy", details: Record<string, any>) => void;
|
|
75
|
+
};
|
|
76
|
+
export { logger, metricsTracker };
|
|
77
|
+
export declare function getFormattedMetrics(): string;
|
|
78
|
+
export declare const StructuredLogger: {
|
|
79
|
+
/**
|
|
80
|
+
* Log an info message with context and metrics
|
|
81
|
+
*/
|
|
82
|
+
info: (message: string, context?: Record<string, any>) => void;
|
|
83
|
+
/**
|
|
84
|
+
* Log a warning with context
|
|
85
|
+
*/
|
|
86
|
+
warn: (message: string, context?: Record<string, any>) => void;
|
|
87
|
+
/**
|
|
88
|
+
* Log an error with context
|
|
89
|
+
*/
|
|
90
|
+
error: (message: string, error?: Error | string, context?: Record<string, any>) => void;
|
|
91
|
+
/**
|
|
92
|
+
* Log a debug message with context
|
|
93
|
+
*/
|
|
94
|
+
debug: (message: string, context?: Record<string, any>) => void;
|
|
95
|
+
/**
|
|
96
|
+
* Log a silly/verbose message with context
|
|
97
|
+
*/
|
|
98
|
+
silly: (message: string, context?: Record<string, any>) => void;
|
|
99
|
+
/**
|
|
100
|
+
* Log a performance metric
|
|
101
|
+
*/
|
|
102
|
+
performance: (operation: string, duration: number, context?: Record<string, any>) => void;
|
|
103
|
+
/**
|
|
104
|
+
* Start a timed operation
|
|
105
|
+
*/
|
|
106
|
+
startTimer: (operation: string) => () => number;
|
|
107
|
+
/**
|
|
108
|
+
* Get current metrics
|
|
109
|
+
*/
|
|
110
|
+
getMetrics: () => Record<string, any>;
|
|
111
|
+
/**
|
|
112
|
+
* Log ingestion event
|
|
113
|
+
*/
|
|
114
|
+
ingestion: (status: "success" | "partial" | "failed", details: Record<string, any>) => void;
|
|
115
|
+
/**
|
|
116
|
+
* Log search event
|
|
117
|
+
*/
|
|
118
|
+
search: (query: string, resultCount: number, duration: number, context?: Record<string, any>) => void;
|
|
119
|
+
/**
|
|
120
|
+
* Log system health event
|
|
121
|
+
*/
|
|
122
|
+
health: (status: "healthy" | "degraded" | "unhealthy", details: Record<string, any>) => void;
|
|
123
|
+
};
|
|
124
|
+
//# sourceMappingURL=structured-logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-logger.d.ts","sourceRoot":"","sources":["../../src/utils/structured-logger.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,OAAO,MAAM,SAAS,CAAC;AA+E9B,QAAA,MAAM,MAAM,gBAmDV,CAAC;AAGH,cAAM,cAAc;IAClB,OAAO,CAAC,OAAO,CAAwF;IACvG,OAAO,CAAC,SAAS,CAAS;;IAO1B,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,MAAM;IAU3C,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IAavD,UAAU,CAAC,SAAS,EAAE,MAAM;eA/BU,MAAM;eAAS,MAAM;aAAO,MAAM;aAAO,MAAM;cAAQ,MAAM;;IAmCnG,aAAa;IAmBb,KAAK;IAIL;;;OAGG;IACH,eAAe,IAAI,IAAI;CA6BxB;AAGD,QAAA,MAAM,cAAc,gBAAuB,CAAC;AAG5C,eAAO,MAAM,cAAc;IACzB;;OAEG;oBACa,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAcrD;;OAEG;oBACa,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQrD;;OAEG;qBACc,MAAM,UAAU,KAAK,GAAG,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAS9E;;OAEG;qBACc,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQtD;;OAEG;qBACc,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQtD;;OAEG;6BACsB,MAAM,YAAY,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAahF;;OAEG;4BACqB,MAAM,WA3KO,MAAM;IA+K3C;;OAEG;;IAKH;;OAEG;wBACiB,SAAS,GAAG,SAAS,GAAG,QAAQ,WAAW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAiBlF;;OAEG;oBACa,MAAM,eAAe,MAAM,YAAY,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAgB5F;;OAEG;qBACc,SAAS,GAAG,UAAU,GAAG,WAAW,WAAW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;CASpF,CAAC;AAGF,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC;AAGlC,wBAAgB,mBAAmB,IAAI,MAAM,CAG5C;AAGD,eAAO,MAAM,gBAAgB;IA3J3B;;OAEG;oBACa,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAcrD;;OAEG;oBACa,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQrD;;OAEG;qBACc,MAAM,UAAU,KAAK,GAAG,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAS9E;;OAEG;qBACc,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQtD;;OAEG;qBACc,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAQtD;;OAEG;6BACsB,MAAM,YAAY,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAahF;;OAEG;4BACqB,MAAM,WA3KO,MAAM;IA+K3C;;OAEG;;IAKH;;OAEG;wBACiB,SAAS,GAAG,SAAS,GAAG,QAAQ,WAAW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAiBlF;;OAEG;oBACa,MAAM,eAAe,MAAM,YAAY,MAAM,YAAY,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAgB5F;;OAEG;qBACc,SAAS,GAAG,UAAU,GAAG,WAAW,WAAW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;CAqBvC,CAAC"}
|