@ninebix/nmt-system 1.0.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 +70 -0
- package/README.md +465 -0
- package/dist/api/cli-server.d.ts +83 -0
- package/dist/api/cli-server.d.ts.map +1 -0
- package/dist/api/cli-server.js +597 -0
- package/dist/api/cli-server.js.map +1 -0
- package/dist/api/index.d.ts +6 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +6 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/middleware/index.d.ts +12 -0
- package/dist/api/middleware/index.d.ts.map +1 -0
- package/dist/api/middleware/index.js +13 -0
- package/dist/api/middleware/index.js.map +1 -0
- package/dist/api/middleware/logger.d.ts +21 -0
- package/dist/api/middleware/logger.d.ts.map +1 -0
- package/dist/api/middleware/logger.js +134 -0
- package/dist/api/middleware/logger.js.map +1 -0
- package/dist/api/middleware/rate-limit.d.ts +26 -0
- package/dist/api/middleware/rate-limit.d.ts.map +1 -0
- package/dist/api/middleware/rate-limit.js +107 -0
- package/dist/api/middleware/rate-limit.js.map +1 -0
- package/dist/api/middleware/response.d.ts +61 -0
- package/dist/api/middleware/response.d.ts.map +1 -0
- package/dist/api/middleware/response.js +86 -0
- package/dist/api/middleware/response.js.map +1 -0
- package/dist/api/middleware/validation.d.ts +43 -0
- package/dist/api/middleware/validation.d.ts.map +1 -0
- package/dist/api/middleware/validation.js +257 -0
- package/dist/api/middleware/validation.js.map +1 -0
- package/dist/api/server.d.ts +79 -0
- package/dist/api/server.d.ts.map +1 -0
- package/dist/api/server.js +2011 -0
- package/dist/api/server.js.map +1 -0
- package/dist/bin/nmt.d.ts +9 -0
- package/dist/bin/nmt.d.ts.map +1 -0
- package/dist/bin/nmt.js +1142 -0
- package/dist/bin/nmt.js.map +1 -0
- package/dist/cli/commands/attractor.d.ts +6 -0
- package/dist/cli/commands/attractor.d.ts.map +1 -0
- package/dist/cli/commands/attractor.js +167 -0
- package/dist/cli/commands/attractor.js.map +1 -0
- package/dist/cli/commands/dimension.d.ts +6 -0
- package/dist/cli/commands/dimension.d.ts.map +1 -0
- package/dist/cli/commands/dimension.js +85 -0
- package/dist/cli/commands/dimension.js.map +1 -0
- package/dist/cli/commands/index.d.ts +11 -0
- package/dist/cli/commands/index.d.ts.map +1 -0
- package/dist/cli/commands/index.js +11 -0
- package/dist/cli/commands/index.js.map +1 -0
- package/dist/cli/commands/infer.d.ts +6 -0
- package/dist/cli/commands/infer.d.ts.map +1 -0
- package/dist/cli/commands/infer.js +139 -0
- package/dist/cli/commands/infer.js.map +1 -0
- package/dist/cli/commands/learn.d.ts +6 -0
- package/dist/cli/commands/learn.d.ts.map +1 -0
- package/dist/cli/commands/learn.js +87 -0
- package/dist/cli/commands/learn.js.map +1 -0
- package/dist/cli/commands/orchestrate.d.ts +6 -0
- package/dist/cli/commands/orchestrate.d.ts.map +1 -0
- package/dist/cli/commands/orchestrate.js +279 -0
- package/dist/cli/commands/orchestrate.js.map +1 -0
- package/dist/cli/commands/prob.d.ts +6 -0
- package/dist/cli/commands/prob.d.ts.map +1 -0
- package/dist/cli/commands/prob.js +256 -0
- package/dist/cli/commands/prob.js.map +1 -0
- package/dist/cli/commands/quantum.d.ts +6 -0
- package/dist/cli/commands/quantum.d.ts.map +1 -0
- package/dist/cli/commands/quantum.js +150 -0
- package/dist/cli/commands/quantum.js.map +1 -0
- package/dist/cli/commands/sync.d.ts +65 -0
- package/dist/cli/commands/sync.d.ts.map +1 -0
- package/dist/cli/commands/sync.js +338 -0
- package/dist/cli/commands/sync.js.map +1 -0
- package/dist/cli/index.d.ts +9 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +9 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/probabilistic-commands.d.ts +39 -0
- package/dist/cli/probabilistic-commands.d.ts.map +1 -0
- package/dist/cli/probabilistic-commands.js +112 -0
- package/dist/cli/probabilistic-commands.js.map +1 -0
- package/dist/cli/types.d.ts +69 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +5 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/cli/utils/formatters.d.ts +51 -0
- package/dist/cli/utils/formatters.d.ts.map +1 -0
- package/dist/cli/utils/formatters.js +79 -0
- package/dist/cli/utils/formatters.js.map +1 -0
- package/dist/cli/utils/helpers.d.ts +21 -0
- package/dist/cli/utils/helpers.d.ts.map +1 -0
- package/dist/cli/utils/helpers.js +51 -0
- package/dist/cli/utils/helpers.js.map +1 -0
- package/dist/cli/utils/index.d.ts +7 -0
- package/dist/cli/utils/index.d.ts.map +1 -0
- package/dist/cli/utils/index.js +13 -0
- package/dist/cli/utils/index.js.map +1 -0
- package/dist/cli/utils/validators.d.ts +162 -0
- package/dist/cli/utils/validators.d.ts.map +1 -0
- package/dist/cli/utils/validators.js +351 -0
- package/dist/cli/utils/validators.js.map +1 -0
- package/dist/core/advanced-embedding.d.ts +154 -0
- package/dist/core/advanced-embedding.d.ts.map +1 -0
- package/dist/core/advanced-embedding.js +367 -0
- package/dist/core/advanced-embedding.js.map +1 -0
- package/dist/core/attractor-model.d.ts +381 -0
- package/dist/core/attractor-model.d.ts.map +1 -0
- package/dist/core/attractor-model.js +821 -0
- package/dist/core/attractor-model.js.map +1 -0
- package/dist/core/bidirectional-inference.d.ts +143 -0
- package/dist/core/bidirectional-inference.d.ts.map +1 -0
- package/dist/core/bidirectional-inference.js +501 -0
- package/dist/core/bidirectional-inference.js.map +1 -0
- package/dist/core/chunk-engine.d.ts +78 -0
- package/dist/core/chunk-engine.d.ts.map +1 -0
- package/dist/core/chunk-engine.js +192 -0
- package/dist/core/chunk-engine.js.map +1 -0
- package/dist/core/dynamic-embedding.d.ts +327 -0
- package/dist/core/dynamic-embedding.d.ts.map +1 -0
- package/dist/core/dynamic-embedding.js +527 -0
- package/dist/core/dynamic-embedding.js.map +1 -0
- package/dist/core/embedding-similarity.d.ts +68 -0
- package/dist/core/embedding-similarity.d.ts.map +1 -0
- package/dist/core/embedding-similarity.js +291 -0
- package/dist/core/embedding-similarity.js.map +1 -0
- package/dist/core/evolution-scheduler.d.ts +101 -0
- package/dist/core/evolution-scheduler.d.ts.map +1 -0
- package/dist/core/evolution-scheduler.js +235 -0
- package/dist/core/evolution-scheduler.js.map +1 -0
- package/dist/core/hierarchical-chunker.d.ts +108 -0
- package/dist/core/hierarchical-chunker.d.ts.map +1 -0
- package/dist/core/hierarchical-chunker.js +296 -0
- package/dist/core/hierarchical-chunker.js.map +1 -0
- package/dist/core/hnsw-index.d.ts +111 -0
- package/dist/core/hnsw-index.d.ts.map +1 -0
- package/dist/core/hnsw-index.js +466 -0
- package/dist/core/hnsw-index.js.map +1 -0
- package/dist/core/index.d.ts +23 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +25 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/language-analyzers.d.ts +124 -0
- package/dist/core/language-analyzers.d.ts.map +1 -0
- package/dist/core/language-analyzers.js +365 -0
- package/dist/core/language-analyzers.js.map +1 -0
- package/dist/core/local-embedding.d.ts +109 -0
- package/dist/core/local-embedding.d.ts.map +1 -0
- package/dist/core/local-embedding.js +222 -0
- package/dist/core/local-embedding.js.map +1 -0
- package/dist/core/merkle-engine.d.ts +263 -0
- package/dist/core/merkle-engine.d.ts.map +1 -0
- package/dist/core/merkle-engine.js +528 -0
- package/dist/core/merkle-engine.js.map +1 -0
- package/dist/core/multi-layer-reasoning.d.ts +178 -0
- package/dist/core/multi-layer-reasoning.d.ts.map +1 -0
- package/dist/core/multi-layer-reasoning.js +607 -0
- package/dist/core/multi-layer-reasoning.js.map +1 -0
- package/dist/core/neuron-graph.d.ts +134 -0
- package/dist/core/neuron-graph.d.ts.map +1 -0
- package/dist/core/neuron-graph.js +436 -0
- package/dist/core/neuron-graph.js.map +1 -0
- package/dist/core/probabilistic-neuron.d.ts +251 -0
- package/dist/core/probabilistic-neuron.d.ts.map +1 -0
- package/dist/core/probabilistic-neuron.js +618 -0
- package/dist/core/probabilistic-neuron.js.map +1 -0
- package/dist/core/probabilistic-orchestrator.d.ts +408 -0
- package/dist/core/probabilistic-orchestrator.d.ts.map +1 -0
- package/dist/core/probabilistic-orchestrator.js +798 -0
- package/dist/core/probabilistic-orchestrator.js.map +1 -0
- package/dist/core/semantic-chunker.d.ts +117 -0
- package/dist/core/semantic-chunker.d.ts.map +1 -0
- package/dist/core/semantic-chunker.js +464 -0
- package/dist/core/semantic-chunker.js.map +1 -0
- package/dist/events/event-bus.d.ts +166 -0
- package/dist/events/event-bus.d.ts.map +1 -0
- package/dist/events/event-bus.js +228 -0
- package/dist/events/event-bus.js.map +1 -0
- package/dist/events/index.d.ts +7 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +7 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/progress-tracker.d.ts +150 -0
- package/dist/events/progress-tracker.d.ts.map +1 -0
- package/dist/events/progress-tracker.js +290 -0
- package/dist/events/progress-tracker.js.map +1 -0
- package/dist/extensions/clustering/community-detection.d.ts +90 -0
- package/dist/extensions/clustering/community-detection.d.ts.map +1 -0
- package/dist/extensions/clustering/community-detection.js +470 -0
- package/dist/extensions/clustering/community-detection.js.map +1 -0
- package/dist/extensions/clustering/index.d.ts +114 -0
- package/dist/extensions/clustering/index.d.ts.map +1 -0
- package/dist/extensions/clustering/index.js +468 -0
- package/dist/extensions/clustering/index.js.map +1 -0
- package/dist/extensions/clustering/topic-modeling.d.ts +86 -0
- package/dist/extensions/clustering/topic-modeling.d.ts.map +1 -0
- package/dist/extensions/clustering/topic-modeling.js +355 -0
- package/dist/extensions/clustering/topic-modeling.js.map +1 -0
- package/dist/extensions/distributed/coordinator.d.ts +114 -0
- package/dist/extensions/distributed/coordinator.d.ts.map +1 -0
- package/dist/extensions/distributed/coordinator.js +319 -0
- package/dist/extensions/distributed/coordinator.js.map +1 -0
- package/dist/extensions/distributed/index.d.ts +10 -0
- package/dist/extensions/distributed/index.d.ts.map +1 -0
- package/dist/extensions/distributed/index.js +10 -0
- package/dist/extensions/distributed/index.js.map +1 -0
- package/dist/extensions/distributed/queue.d.ts +157 -0
- package/dist/extensions/distributed/queue.d.ts.map +1 -0
- package/dist/extensions/distributed/queue.js +326 -0
- package/dist/extensions/distributed/queue.js.map +1 -0
- package/dist/extensions/distributed/scheduler.d.ts +107 -0
- package/dist/extensions/distributed/scheduler.d.ts.map +1 -0
- package/dist/extensions/distributed/scheduler.js +301 -0
- package/dist/extensions/distributed/scheduler.js.map +1 -0
- package/dist/extensions/distributed/worker.d.ts +112 -0
- package/dist/extensions/distributed/worker.d.ts.map +1 -0
- package/dist/extensions/distributed/worker.js +260 -0
- package/dist/extensions/distributed/worker.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/server.d.ts +43 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +494 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/services/adaptive-fallback.d.ts +140 -0
- package/dist/services/adaptive-fallback.d.ts.map +1 -0
- package/dist/services/adaptive-fallback.js +273 -0
- package/dist/services/adaptive-fallback.js.map +1 -0
- package/dist/services/answer-gate.d.ts +112 -0
- package/dist/services/answer-gate.d.ts.map +1 -0
- package/dist/services/answer-gate.js +299 -0
- package/dist/services/answer-gate.js.map +1 -0
- package/dist/services/auto-learning.d.ts +135 -0
- package/dist/services/auto-learning.d.ts.map +1 -0
- package/dist/services/auto-learning.js +413 -0
- package/dist/services/auto-learning.js.map +1 -0
- package/dist/services/context-compressor.d.ts +77 -0
- package/dist/services/context-compressor.d.ts.map +1 -0
- package/dist/services/context-compressor.js +234 -0
- package/dist/services/context-compressor.js.map +1 -0
- package/dist/services/efficient-rag.d.ts +140 -0
- package/dist/services/efficient-rag.d.ts.map +1 -0
- package/dist/services/efficient-rag.js +311 -0
- package/dist/services/efficient-rag.js.map +1 -0
- package/dist/services/embedding-provider.d.ts +72 -0
- package/dist/services/embedding-provider.d.ts.map +1 -0
- package/dist/services/embedding-provider.js +176 -0
- package/dist/services/embedding-provider.js.map +1 -0
- package/dist/services/file-ingestion.d.ts +72 -0
- package/dist/services/file-ingestion.d.ts.map +1 -0
- package/dist/services/file-ingestion.js +237 -0
- package/dist/services/file-ingestion.js.map +1 -0
- package/dist/services/four-stage-learning.d.ts +552 -0
- package/dist/services/four-stage-learning.d.ts.map +1 -0
- package/dist/services/four-stage-learning.js +1110 -0
- package/dist/services/four-stage-learning.js.map +1 -0
- package/dist/services/graph.d.ts +94 -0
- package/dist/services/graph.d.ts.map +1 -0
- package/dist/services/graph.js +292 -0
- package/dist/services/graph.js.map +1 -0
- package/dist/services/index.d.ts +15 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +18 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/ingestion.d.ts +98 -0
- package/dist/services/ingestion.d.ts.map +1 -0
- package/dist/services/ingestion.js +259 -0
- package/dist/services/ingestion.js.map +1 -0
- package/dist/services/learning.d.ts +67 -0
- package/dist/services/learning.d.ts.map +1 -0
- package/dist/services/learning.js +262 -0
- package/dist/services/learning.js.map +1 -0
- package/dist/services/llm-router.d.ts +143 -0
- package/dist/services/llm-router.d.ts.map +1 -0
- package/dist/services/llm-router.js +284 -0
- package/dist/services/llm-router.js.map +1 -0
- package/dist/services/llm.d.ts +86 -0
- package/dist/services/llm.d.ts.map +1 -0
- package/dist/services/llm.js +283 -0
- package/dist/services/llm.js.map +1 -0
- package/dist/services/metrics-dashboard.d.ts +262 -0
- package/dist/services/metrics-dashboard.d.ts.map +1 -0
- package/dist/services/metrics-dashboard.js +417 -0
- package/dist/services/metrics-dashboard.js.map +1 -0
- package/dist/services/neuron-lifecycle.d.ts +137 -0
- package/dist/services/neuron-lifecycle.d.ts.map +1 -0
- package/dist/services/neuron-lifecycle.js +422 -0
- package/dist/services/neuron-lifecycle.js.map +1 -0
- package/dist/services/nmt-pipeline.d.ts +219 -0
- package/dist/services/nmt-pipeline.d.ts.map +1 -0
- package/dist/services/nmt-pipeline.js +449 -0
- package/dist/services/nmt-pipeline.js.map +1 -0
- package/dist/services/query-cache.d.ts +136 -0
- package/dist/services/query-cache.d.ts.map +1 -0
- package/dist/services/query-cache.js +255 -0
- package/dist/services/query-cache.js.map +1 -0
- package/dist/services/query-normalize.d.ts +107 -0
- package/dist/services/query-normalize.d.ts.map +1 -0
- package/dist/services/query-normalize.js +366 -0
- package/dist/services/query-normalize.js.map +1 -0
- package/dist/services/query.d.ts +102 -0
- package/dist/services/query.d.ts.map +1 -0
- package/dist/services/query.js +227 -0
- package/dist/services/query.js.map +1 -0
- package/dist/services/text-embedding.d.ts +183 -0
- package/dist/services/text-embedding.d.ts.map +1 -0
- package/dist/services/text-embedding.js +633 -0
- package/dist/services/text-embedding.js.map +1 -0
- package/dist/services/verification-gate.d.ts +147 -0
- package/dist/services/verification-gate.d.ts.map +1 -0
- package/dist/services/verification-gate.js +344 -0
- package/dist/services/verification-gate.js.map +1 -0
- package/dist/services/verify.d.ts +114 -0
- package/dist/services/verify.d.ts.map +1 -0
- package/dist/services/verify.js +237 -0
- package/dist/services/verify.js.map +1 -0
- package/dist/services/web-search.d.ts +145 -0
- package/dist/services/web-search.d.ts.map +1 -0
- package/dist/services/web-search.js +534 -0
- package/dist/services/web-search.js.map +1 -0
- package/dist/src/api/cli-server.d.ts +83 -0
- package/dist/src/api/cli-server.d.ts.map +1 -0
- package/dist/src/api/cli-server.js +597 -0
- package/dist/src/api/cli-server.js.map +1 -0
- package/dist/src/api/index.d.ts +6 -0
- package/dist/src/api/index.d.ts.map +1 -0
- package/dist/src/api/index.js +6 -0
- package/dist/src/api/index.js.map +1 -0
- package/dist/src/cli/commands/attractor.d.ts +6 -0
- package/dist/src/cli/commands/attractor.d.ts.map +1 -0
- package/dist/src/cli/commands/attractor.js +167 -0
- package/dist/src/cli/commands/attractor.js.map +1 -0
- package/dist/src/cli/commands/dimension.d.ts +6 -0
- package/dist/src/cli/commands/dimension.d.ts.map +1 -0
- package/dist/src/cli/commands/dimension.js +85 -0
- package/dist/src/cli/commands/dimension.js.map +1 -0
- package/dist/src/cli/commands/index.d.ts +11 -0
- package/dist/src/cli/commands/index.d.ts.map +1 -0
- package/dist/src/cli/commands/index.js +11 -0
- package/dist/src/cli/commands/index.js.map +1 -0
- package/dist/src/cli/commands/infer.d.ts +6 -0
- package/dist/src/cli/commands/infer.d.ts.map +1 -0
- package/dist/src/cli/commands/infer.js +139 -0
- package/dist/src/cli/commands/infer.js.map +1 -0
- package/dist/src/cli/commands/learn.d.ts +6 -0
- package/dist/src/cli/commands/learn.d.ts.map +1 -0
- package/dist/src/cli/commands/learn.js +87 -0
- package/dist/src/cli/commands/learn.js.map +1 -0
- package/dist/src/cli/commands/orchestrate.d.ts +6 -0
- package/dist/src/cli/commands/orchestrate.d.ts.map +1 -0
- package/dist/src/cli/commands/orchestrate.js +279 -0
- package/dist/src/cli/commands/orchestrate.js.map +1 -0
- package/dist/src/cli/commands/prob.d.ts +6 -0
- package/dist/src/cli/commands/prob.d.ts.map +1 -0
- package/dist/src/cli/commands/prob.js +256 -0
- package/dist/src/cli/commands/prob.js.map +1 -0
- package/dist/src/cli/commands/sync.d.ts +65 -0
- package/dist/src/cli/commands/sync.d.ts.map +1 -0
- package/dist/src/cli/commands/sync.js +338 -0
- package/dist/src/cli/commands/sync.js.map +1 -0
- package/dist/src/cli/index.d.ts +9 -0
- package/dist/src/cli/index.d.ts.map +1 -0
- package/dist/src/cli/index.js +9 -0
- package/dist/src/cli/index.js.map +1 -0
- package/dist/src/cli/probabilistic-commands.d.ts +39 -0
- package/dist/src/cli/probabilistic-commands.d.ts.map +1 -0
- package/dist/src/cli/probabilistic-commands.js +112 -0
- package/dist/src/cli/probabilistic-commands.js.map +1 -0
- package/dist/src/cli/types.d.ts +69 -0
- package/dist/src/cli/types.d.ts.map +1 -0
- package/dist/src/cli/types.js +5 -0
- package/dist/src/cli/types.js.map +1 -0
- package/dist/src/cli/utils/formatters.d.ts +51 -0
- package/dist/src/cli/utils/formatters.d.ts.map +1 -0
- package/dist/src/cli/utils/formatters.js +79 -0
- package/dist/src/cli/utils/formatters.js.map +1 -0
- package/dist/src/cli/utils/helpers.d.ts +21 -0
- package/dist/src/cli/utils/helpers.d.ts.map +1 -0
- package/dist/src/cli/utils/helpers.js +51 -0
- package/dist/src/cli/utils/helpers.js.map +1 -0
- package/dist/src/cli/utils/index.d.ts +7 -0
- package/dist/src/cli/utils/index.d.ts.map +1 -0
- package/dist/src/cli/utils/index.js +13 -0
- package/dist/src/cli/utils/index.js.map +1 -0
- package/dist/src/cli/utils/validators.d.ts +162 -0
- package/dist/src/cli/utils/validators.d.ts.map +1 -0
- package/dist/src/cli/utils/validators.js +351 -0
- package/dist/src/cli/utils/validators.js.map +1 -0
- package/dist/src/core/attractor-model.d.ts +381 -0
- package/dist/src/core/attractor-model.d.ts.map +1 -0
- package/dist/src/core/attractor-model.js +821 -0
- package/dist/src/core/attractor-model.js.map +1 -0
- package/dist/src/core/bidirectional-inference.d.ts +143 -0
- package/dist/src/core/bidirectional-inference.d.ts.map +1 -0
- package/dist/src/core/bidirectional-inference.js +501 -0
- package/dist/src/core/bidirectional-inference.js.map +1 -0
- package/dist/src/core/chunk-engine.d.ts +78 -0
- package/dist/src/core/chunk-engine.d.ts.map +1 -0
- package/dist/src/core/chunk-engine.js +192 -0
- package/dist/src/core/chunk-engine.js.map +1 -0
- package/dist/src/core/dynamic-embedding.d.ts +327 -0
- package/dist/src/core/dynamic-embedding.d.ts.map +1 -0
- package/dist/src/core/dynamic-embedding.js +527 -0
- package/dist/src/core/dynamic-embedding.js.map +1 -0
- package/dist/src/core/evolution-scheduler.d.ts +101 -0
- package/dist/src/core/evolution-scheduler.d.ts.map +1 -0
- package/dist/src/core/evolution-scheduler.js +235 -0
- package/dist/src/core/evolution-scheduler.js.map +1 -0
- package/dist/src/core/hnsw-index.d.ts +111 -0
- package/dist/src/core/hnsw-index.d.ts.map +1 -0
- package/dist/src/core/hnsw-index.js +466 -0
- package/dist/src/core/hnsw-index.js.map +1 -0
- package/dist/src/core/index.d.ts +23 -0
- package/dist/src/core/index.d.ts.map +1 -0
- package/dist/src/core/index.js +25 -0
- package/dist/src/core/index.js.map +1 -0
- package/dist/src/core/merkle-engine.d.ts +263 -0
- package/dist/src/core/merkle-engine.d.ts.map +1 -0
- package/dist/src/core/merkle-engine.js +528 -0
- package/dist/src/core/merkle-engine.js.map +1 -0
- package/dist/src/core/neuron-graph.d.ts +134 -0
- package/dist/src/core/neuron-graph.d.ts.map +1 -0
- package/dist/src/core/neuron-graph.js +436 -0
- package/dist/src/core/neuron-graph.js.map +1 -0
- package/dist/src/core/probabilistic-neuron.d.ts +251 -0
- package/dist/src/core/probabilistic-neuron.d.ts.map +1 -0
- package/dist/src/core/probabilistic-neuron.js +618 -0
- package/dist/src/core/probabilistic-neuron.js.map +1 -0
- package/dist/src/core/probabilistic-orchestrator.d.ts +408 -0
- package/dist/src/core/probabilistic-orchestrator.d.ts.map +1 -0
- package/dist/src/core/probabilistic-orchestrator.js +798 -0
- package/dist/src/core/probabilistic-orchestrator.js.map +1 -0
- package/dist/src/events/event-bus.d.ts +166 -0
- package/dist/src/events/event-bus.d.ts.map +1 -0
- package/dist/src/events/event-bus.js +228 -0
- package/dist/src/events/event-bus.js.map +1 -0
- package/dist/src/events/index.d.ts +7 -0
- package/dist/src/events/index.d.ts.map +1 -0
- package/dist/src/events/index.js +7 -0
- package/dist/src/events/index.js.map +1 -0
- package/dist/src/events/progress-tracker.d.ts +150 -0
- package/dist/src/events/progress-tracker.d.ts.map +1 -0
- package/dist/src/events/progress-tracker.js +290 -0
- package/dist/src/events/progress-tracker.js.map +1 -0
- package/dist/src/extensions/clustering/index.d.ts +114 -0
- package/dist/src/extensions/clustering/index.d.ts.map +1 -0
- package/dist/src/extensions/clustering/index.js +468 -0
- package/dist/src/extensions/clustering/index.js.map +1 -0
- package/dist/src/index.d.ts +14 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +20 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/mcp/server.d.ts +43 -0
- package/dist/src/mcp/server.d.ts.map +1 -0
- package/dist/src/mcp/server.js +494 -0
- package/dist/src/mcp/server.js.map +1 -0
- package/dist/src/services/embedding-provider.d.ts +72 -0
- package/dist/src/services/embedding-provider.d.ts.map +1 -0
- package/dist/src/services/embedding-provider.js +176 -0
- package/dist/src/services/embedding-provider.js.map +1 -0
- package/dist/src/services/four-stage-learning.d.ts +552 -0
- package/dist/src/services/four-stage-learning.d.ts.map +1 -0
- package/dist/src/services/four-stage-learning.js +1110 -0
- package/dist/src/services/four-stage-learning.js.map +1 -0
- package/dist/src/services/index.d.ts +15 -0
- package/dist/src/services/index.d.ts.map +1 -0
- package/dist/src/services/index.js +18 -0
- package/dist/src/services/index.js.map +1 -0
- package/dist/src/services/ingestion.d.ts +98 -0
- package/dist/src/services/ingestion.d.ts.map +1 -0
- package/dist/src/services/ingestion.js +259 -0
- package/dist/src/services/ingestion.js.map +1 -0
- package/dist/src/services/query.d.ts +102 -0
- package/dist/src/services/query.d.ts.map +1 -0
- package/dist/src/services/query.js +227 -0
- package/dist/src/services/query.js.map +1 -0
- package/dist/src/services/text-embedding.d.ts +183 -0
- package/dist/src/services/text-embedding.d.ts.map +1 -0
- package/dist/src/services/text-embedding.js +633 -0
- package/dist/src/services/text-embedding.js.map +1 -0
- package/dist/src/services/verify.d.ts +114 -0
- package/dist/src/services/verify.d.ts.map +1 -0
- package/dist/src/services/verify.js +237 -0
- package/dist/src/services/verify.js.map +1 -0
- package/dist/src/storage/chunk-store.d.ts +107 -0
- package/dist/src/storage/chunk-store.d.ts.map +1 -0
- package/dist/src/storage/chunk-store.js +293 -0
- package/dist/src/storage/chunk-store.js.map +1 -0
- package/dist/src/storage/index-store.d.ts +126 -0
- package/dist/src/storage/index-store.d.ts.map +1 -0
- package/dist/src/storage/index-store.js +316 -0
- package/dist/src/storage/index-store.js.map +1 -0
- package/dist/src/storage/index.d.ts +45 -0
- package/dist/src/storage/index.d.ts.map +1 -0
- package/dist/src/storage/index.js +52 -0
- package/dist/src/storage/index.js.map +1 -0
- package/dist/src/storage/neuron-store.d.ts +121 -0
- package/dist/src/storage/neuron-store.d.ts.map +1 -0
- package/dist/src/storage/neuron-store.js +466 -0
- package/dist/src/storage/neuron-store.js.map +1 -0
- package/dist/src/storage/probabilistic-store.d.ts +104 -0
- package/dist/src/storage/probabilistic-store.d.ts.map +1 -0
- package/dist/src/storage/probabilistic-store.js +257 -0
- package/dist/src/storage/probabilistic-store.js.map +1 -0
- package/dist/src/sync/change-journal.d.ts +171 -0
- package/dist/src/sync/change-journal.d.ts.map +1 -0
- package/dist/src/sync/change-journal.js +362 -0
- package/dist/src/sync/change-journal.js.map +1 -0
- package/dist/src/sync/index.d.ts +8 -0
- package/dist/src/sync/index.d.ts.map +1 -0
- package/dist/src/sync/index.js +8 -0
- package/dist/src/sync/index.js.map +1 -0
- package/dist/src/sync/state-sync.d.ts +241 -0
- package/dist/src/sync/state-sync.d.ts.map +1 -0
- package/dist/src/sync/state-sync.js +396 -0
- package/dist/src/sync/state-sync.js.map +1 -0
- package/dist/src/sync/vector-clock.d.ts +144 -0
- package/dist/src/sync/vector-clock.d.ts.map +1 -0
- package/dist/src/sync/vector-clock.js +266 -0
- package/dist/src/sync/vector-clock.js.map +1 -0
- package/dist/src/types/index.d.ts +224 -0
- package/dist/src/types/index.d.ts.map +1 -0
- package/dist/src/types/index.js +24 -0
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/utils/hash.d.ts +39 -0
- package/dist/src/utils/hash.d.ts.map +1 -0
- package/dist/src/utils/hash.js +56 -0
- package/dist/src/utils/hash.js.map +1 -0
- package/dist/src/utils/index.d.ts +26 -0
- package/dist/src/utils/index.d.ts.map +1 -0
- package/dist/src/utils/index.js +50 -0
- package/dist/src/utils/index.js.map +1 -0
- package/dist/src/utils/logger.d.ts +88 -0
- package/dist/src/utils/logger.d.ts.map +1 -0
- package/dist/src/utils/logger.js +157 -0
- package/dist/src/utils/logger.js.map +1 -0
- package/dist/src/utils/metrics.d.ts +232 -0
- package/dist/src/utils/metrics.d.ts.map +1 -0
- package/dist/src/utils/metrics.js +387 -0
- package/dist/src/utils/metrics.js.map +1 -0
- package/dist/src/utils/similarity.d.ts +64 -0
- package/dist/src/utils/similarity.d.ts.map +1 -0
- package/dist/src/utils/similarity.js +151 -0
- package/dist/src/utils/similarity.js.map +1 -0
- package/dist/src/utils/uuid.d.ts +23 -0
- package/dist/src/utils/uuid.d.ts.map +1 -0
- package/dist/src/utils/uuid.js +29 -0
- package/dist/src/utils/uuid.js.map +1 -0
- package/dist/storage/chunk-store.d.ts +107 -0
- package/dist/storage/chunk-store.d.ts.map +1 -0
- package/dist/storage/chunk-store.js +293 -0
- package/dist/storage/chunk-store.js.map +1 -0
- package/dist/storage/hybrid-adapters.d.ts +111 -0
- package/dist/storage/hybrid-adapters.d.ts.map +1 -0
- package/dist/storage/hybrid-adapters.js +223 -0
- package/dist/storage/hybrid-adapters.js.map +1 -0
- package/dist/storage/hybrid-store.d.ts +125 -0
- package/dist/storage/hybrid-store.d.ts.map +1 -0
- package/dist/storage/hybrid-store.js +655 -0
- package/dist/storage/hybrid-store.js.map +1 -0
- package/dist/storage/index-store.d.ts +126 -0
- package/dist/storage/index-store.d.ts.map +1 -0
- package/dist/storage/index-store.js +316 -0
- package/dist/storage/index-store.js.map +1 -0
- package/dist/storage/index.d.ts +45 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +52 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/neuron-store.d.ts +121 -0
- package/dist/storage/neuron-store.d.ts.map +1 -0
- package/dist/storage/neuron-store.js +466 -0
- package/dist/storage/neuron-store.js.map +1 -0
- package/dist/storage/ontology-store.d.ts +132 -0
- package/dist/storage/ontology-store.d.ts.map +1 -0
- package/dist/storage/ontology-store.js +319 -0
- package/dist/storage/ontology-store.js.map +1 -0
- package/dist/storage/probabilistic-store.d.ts +104 -0
- package/dist/storage/probabilistic-store.d.ts.map +1 -0
- package/dist/storage/probabilistic-store.js +257 -0
- package/dist/storage/probabilistic-store.js.map +1 -0
- package/dist/storage/redis-adapters.d.ts +102 -0
- package/dist/storage/redis-adapters.d.ts.map +1 -0
- package/dist/storage/redis-adapters.js +205 -0
- package/dist/storage/redis-adapters.js.map +1 -0
- package/dist/storage/redis-ontology-store.d.ts +146 -0
- package/dist/storage/redis-ontology-store.d.ts.map +1 -0
- package/dist/storage/redis-ontology-store.js +384 -0
- package/dist/storage/redis-ontology-store.js.map +1 -0
- package/dist/storage/redis-store.d.ts +174 -0
- package/dist/storage/redis-store.d.ts.map +1 -0
- package/dist/storage/redis-store.js +506 -0
- package/dist/storage/redis-store.js.map +1 -0
- package/dist/sync/change-journal.d.ts +171 -0
- package/dist/sync/change-journal.d.ts.map +1 -0
- package/dist/sync/change-journal.js +362 -0
- package/dist/sync/change-journal.js.map +1 -0
- package/dist/sync/index.d.ts +8 -0
- package/dist/sync/index.d.ts.map +1 -0
- package/dist/sync/index.js +8 -0
- package/dist/sync/index.js.map +1 -0
- package/dist/sync/state-sync.d.ts +241 -0
- package/dist/sync/state-sync.d.ts.map +1 -0
- package/dist/sync/state-sync.js +396 -0
- package/dist/sync/state-sync.js.map +1 -0
- package/dist/sync/vector-clock.d.ts +144 -0
- package/dist/sync/vector-clock.d.ts.map +1 -0
- package/dist/sync/vector-clock.js +266 -0
- package/dist/sync/vector-clock.js.map +1 -0
- package/dist/types/index.d.ts +224 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +24 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/hash.d.ts +39 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +56 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/index.d.ts +26 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +50 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logger.d.ts +88 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +157 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/metrics.d.ts +232 -0
- package/dist/utils/metrics.d.ts.map +1 -0
- package/dist/utils/metrics.js +387 -0
- package/dist/utils/metrics.js.map +1 -0
- package/dist/utils/similarity.d.ts +64 -0
- package/dist/utils/similarity.d.ts.map +1 -0
- package/dist/utils/similarity.js +151 -0
- package/dist/utils/similarity.js.map +1 -0
- package/dist/utils/uuid.d.ts +23 -0
- package/dist/utils/uuid.d.ts.map +1 -0
- package/dist/utils/uuid.js +29 -0
- package/dist/utils/uuid.js.map +1 -0
- package/package.json +72 -0
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Scheduler - Cron-based job scheduling
|
|
3
|
+
* @module extensions/distributed/scheduler
|
|
4
|
+
*/
|
|
5
|
+
import { EventEmitter } from 'events';
|
|
6
|
+
import { generateUUID } from '../../utils/uuid.js';
|
|
7
|
+
/**
|
|
8
|
+
* Scheduler Service
|
|
9
|
+
*/
|
|
10
|
+
export class Scheduler extends EventEmitter {
|
|
11
|
+
queue;
|
|
12
|
+
scheduledJobs;
|
|
13
|
+
timers;
|
|
14
|
+
running;
|
|
15
|
+
checkInterval;
|
|
16
|
+
checkTimer;
|
|
17
|
+
constructor(queue, checkInterval = 60000) {
|
|
18
|
+
super();
|
|
19
|
+
this.queue = queue;
|
|
20
|
+
this.scheduledJobs = new Map();
|
|
21
|
+
this.timers = new Map();
|
|
22
|
+
this.running = false;
|
|
23
|
+
this.checkInterval = checkInterval;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Start the scheduler
|
|
27
|
+
*/
|
|
28
|
+
start() {
|
|
29
|
+
if (this.running)
|
|
30
|
+
return;
|
|
31
|
+
this.running = true;
|
|
32
|
+
this.scheduleNextCheck();
|
|
33
|
+
this.emit('started');
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Stop the scheduler
|
|
37
|
+
*/
|
|
38
|
+
stop() {
|
|
39
|
+
this.running = false;
|
|
40
|
+
if (this.checkTimer) {
|
|
41
|
+
clearTimeout(this.checkTimer);
|
|
42
|
+
this.checkTimer = undefined;
|
|
43
|
+
}
|
|
44
|
+
for (const timer of this.timers.values()) {
|
|
45
|
+
clearTimeout(timer);
|
|
46
|
+
}
|
|
47
|
+
this.timers.clear();
|
|
48
|
+
this.emit('stopped');
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Add a scheduled job
|
|
52
|
+
*/
|
|
53
|
+
addScheduledJob(name, type, data, schedule, options) {
|
|
54
|
+
const job = {
|
|
55
|
+
id: generateUUID(),
|
|
56
|
+
name,
|
|
57
|
+
type,
|
|
58
|
+
data,
|
|
59
|
+
schedule,
|
|
60
|
+
options,
|
|
61
|
+
enabled: true,
|
|
62
|
+
runCount: 0,
|
|
63
|
+
createdAt: new Date().toISOString(),
|
|
64
|
+
nextRun: this.calculateNextRun(schedule)
|
|
65
|
+
};
|
|
66
|
+
this.scheduledJobs.set(job.id, job);
|
|
67
|
+
this.emit('job:added', job);
|
|
68
|
+
return job;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Remove a scheduled job
|
|
72
|
+
*/
|
|
73
|
+
removeScheduledJob(id) {
|
|
74
|
+
const job = this.scheduledJobs.get(id);
|
|
75
|
+
if (!job)
|
|
76
|
+
return false;
|
|
77
|
+
const timer = this.timers.get(id);
|
|
78
|
+
if (timer) {
|
|
79
|
+
clearTimeout(timer);
|
|
80
|
+
this.timers.delete(id);
|
|
81
|
+
}
|
|
82
|
+
this.scheduledJobs.delete(id);
|
|
83
|
+
this.emit('job:removed', job);
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Enable a scheduled job
|
|
88
|
+
*/
|
|
89
|
+
enableJob(id) {
|
|
90
|
+
const job = this.scheduledJobs.get(id);
|
|
91
|
+
if (!job)
|
|
92
|
+
return false;
|
|
93
|
+
job.enabled = true;
|
|
94
|
+
job.nextRun = this.calculateNextRun(job.schedule);
|
|
95
|
+
this.emit('job:enabled', job);
|
|
96
|
+
return true;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Disable a scheduled job
|
|
100
|
+
*/
|
|
101
|
+
disableJob(id) {
|
|
102
|
+
const job = this.scheduledJobs.get(id);
|
|
103
|
+
if (!job)
|
|
104
|
+
return false;
|
|
105
|
+
job.enabled = false;
|
|
106
|
+
const timer = this.timers.get(id);
|
|
107
|
+
if (timer) {
|
|
108
|
+
clearTimeout(timer);
|
|
109
|
+
this.timers.delete(id);
|
|
110
|
+
}
|
|
111
|
+
this.emit('job:disabled', job);
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Update a scheduled job
|
|
116
|
+
*/
|
|
117
|
+
updateScheduledJob(id, updates) {
|
|
118
|
+
const job = this.scheduledJobs.get(id);
|
|
119
|
+
if (!job)
|
|
120
|
+
return undefined;
|
|
121
|
+
if (updates.name !== undefined)
|
|
122
|
+
job.name = updates.name;
|
|
123
|
+
if (updates.data !== undefined)
|
|
124
|
+
job.data = updates.data;
|
|
125
|
+
if (updates.options !== undefined)
|
|
126
|
+
job.options = updates.options;
|
|
127
|
+
if (updates.schedule !== undefined) {
|
|
128
|
+
job.schedule = updates.schedule;
|
|
129
|
+
job.nextRun = this.calculateNextRun(job.schedule);
|
|
130
|
+
}
|
|
131
|
+
this.emit('job:updated', job);
|
|
132
|
+
return job;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Get scheduled job by ID
|
|
136
|
+
*/
|
|
137
|
+
getScheduledJob(id) {
|
|
138
|
+
return this.scheduledJobs.get(id);
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Get all scheduled jobs
|
|
142
|
+
*/
|
|
143
|
+
getAllScheduledJobs() {
|
|
144
|
+
return Array.from(this.scheduledJobs.values());
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Run a scheduled job immediately
|
|
148
|
+
*/
|
|
149
|
+
async runNow(id) {
|
|
150
|
+
const job = this.scheduledJobs.get(id);
|
|
151
|
+
if (!job) {
|
|
152
|
+
throw new Error(`Scheduled job not found: ${id}`);
|
|
153
|
+
}
|
|
154
|
+
await this.executeJob(job);
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Get next runs for all jobs
|
|
158
|
+
*/
|
|
159
|
+
getUpcomingRuns(count = 10) {
|
|
160
|
+
const upcoming = [];
|
|
161
|
+
for (const job of this.scheduledJobs.values()) {
|
|
162
|
+
if (!job.enabled || !job.nextRun)
|
|
163
|
+
continue;
|
|
164
|
+
upcoming.push({ job, runAt: job.nextRun });
|
|
165
|
+
}
|
|
166
|
+
upcoming.sort((a, b) => new Date(a.runAt).getTime() - new Date(b.runAt).getTime());
|
|
167
|
+
return upcoming.slice(0, count);
|
|
168
|
+
}
|
|
169
|
+
// ==================== Private Methods ====================
|
|
170
|
+
scheduleNextCheck() {
|
|
171
|
+
if (!this.running)
|
|
172
|
+
return;
|
|
173
|
+
this.checkTimer = setTimeout(() => {
|
|
174
|
+
this.checkScheduledJobs();
|
|
175
|
+
this.scheduleNextCheck();
|
|
176
|
+
}, this.checkInterval);
|
|
177
|
+
}
|
|
178
|
+
async checkScheduledJobs() {
|
|
179
|
+
const now = new Date();
|
|
180
|
+
for (const job of this.scheduledJobs.values()) {
|
|
181
|
+
if (!job.enabled || !job.nextRun)
|
|
182
|
+
continue;
|
|
183
|
+
const nextRun = new Date(job.nextRun);
|
|
184
|
+
if (nextRun <= now) {
|
|
185
|
+
try {
|
|
186
|
+
await this.executeJob(job);
|
|
187
|
+
}
|
|
188
|
+
catch (error) {
|
|
189
|
+
this.emit('job:error', job, error);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
async executeJob(job) {
|
|
195
|
+
job.lastRun = new Date().toISOString();
|
|
196
|
+
job.runCount++;
|
|
197
|
+
this.emit('job:executing', job);
|
|
198
|
+
try {
|
|
199
|
+
await this.queue.add(job.type, job.data, job.options);
|
|
200
|
+
job.nextRun = this.calculateNextRun(job.schedule);
|
|
201
|
+
this.emit('job:executed', job);
|
|
202
|
+
}
|
|
203
|
+
catch (error) {
|
|
204
|
+
this.emit('job:error', job, error);
|
|
205
|
+
throw error;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
calculateNextRun(schedule) {
|
|
209
|
+
const parsed = this.parseSchedule(schedule);
|
|
210
|
+
const now = new Date();
|
|
211
|
+
const next = new Date(now);
|
|
212
|
+
// Simple implementation - find next matching time
|
|
213
|
+
// For production, use a library like 'cron-parser'
|
|
214
|
+
let found = false;
|
|
215
|
+
let iterations = 0;
|
|
216
|
+
const maxIterations = 366 * 24 * 60; // Max 1 year
|
|
217
|
+
while (!found && iterations < maxIterations) {
|
|
218
|
+
next.setMinutes(next.getMinutes() + 1);
|
|
219
|
+
next.setSeconds(0);
|
|
220
|
+
next.setMilliseconds(0);
|
|
221
|
+
const matches = parsed.minute.includes(next.getMinutes()) &&
|
|
222
|
+
parsed.hour.includes(next.getHours()) &&
|
|
223
|
+
parsed.dayOfMonth.includes(next.getDate()) &&
|
|
224
|
+
parsed.month.includes(next.getMonth() + 1) &&
|
|
225
|
+
parsed.dayOfWeek.includes(next.getDay());
|
|
226
|
+
if (matches) {
|
|
227
|
+
found = true;
|
|
228
|
+
}
|
|
229
|
+
iterations++;
|
|
230
|
+
}
|
|
231
|
+
return found ? next.toISOString() : '';
|
|
232
|
+
}
|
|
233
|
+
parseSchedule(schedule) {
|
|
234
|
+
const parts = schedule.trim().split(/\s+/);
|
|
235
|
+
if (parts.length !== 5) {
|
|
236
|
+
throw new Error(`Invalid cron expression: ${schedule}`);
|
|
237
|
+
}
|
|
238
|
+
return {
|
|
239
|
+
minute: this.parseCronField(parts[0], 0, 59),
|
|
240
|
+
hour: this.parseCronField(parts[1], 0, 23),
|
|
241
|
+
dayOfMonth: this.parseCronField(parts[2], 1, 31),
|
|
242
|
+
month: this.parseCronField(parts[3], 1, 12),
|
|
243
|
+
dayOfWeek: this.parseCronField(parts[4], 0, 6)
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
parseCronField(field, min, max) {
|
|
247
|
+
const values = [];
|
|
248
|
+
if (field === '*') {
|
|
249
|
+
for (let i = min; i <= max; i++) {
|
|
250
|
+
values.push(i);
|
|
251
|
+
}
|
|
252
|
+
return values;
|
|
253
|
+
}
|
|
254
|
+
// Handle */n (every n)
|
|
255
|
+
if (field.startsWith('*/')) {
|
|
256
|
+
const step = parseInt(field.slice(2), 10);
|
|
257
|
+
for (let i = min; i <= max; i += step) {
|
|
258
|
+
values.push(i);
|
|
259
|
+
}
|
|
260
|
+
return values;
|
|
261
|
+
}
|
|
262
|
+
// Handle comma-separated values
|
|
263
|
+
const parts = field.split(',');
|
|
264
|
+
for (const part of parts) {
|
|
265
|
+
if (part.includes('-')) {
|
|
266
|
+
// Range
|
|
267
|
+
const [start, end] = part.split('-').map(n => parseInt(n, 10));
|
|
268
|
+
for (let i = start; i <= end; i++) {
|
|
269
|
+
values.push(i);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
// Single value
|
|
274
|
+
values.push(parseInt(part, 10));
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
return values.filter(v => v >= min && v <= max);
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
/**
|
|
281
|
+
* Create a scheduler
|
|
282
|
+
*/
|
|
283
|
+
export function createScheduler(queue, checkInterval) {
|
|
284
|
+
return new Scheduler(queue, checkInterval);
|
|
285
|
+
}
|
|
286
|
+
// Common schedule presets
|
|
287
|
+
export const SchedulePresets = {
|
|
288
|
+
EVERY_MINUTE: '* * * * *',
|
|
289
|
+
EVERY_5_MINUTES: '*/5 * * * *',
|
|
290
|
+
EVERY_15_MINUTES: '*/15 * * * *',
|
|
291
|
+
EVERY_30_MINUTES: '*/30 * * * *',
|
|
292
|
+
EVERY_HOUR: '0 * * * *',
|
|
293
|
+
EVERY_6_HOURS: '0 */6 * * *',
|
|
294
|
+
EVERY_12_HOURS: '0 */12 * * *',
|
|
295
|
+
DAILY_MIDNIGHT: '0 0 * * *',
|
|
296
|
+
DAILY_NOON: '0 12 * * *',
|
|
297
|
+
WEEKLY_SUNDAY: '0 0 * * 0',
|
|
298
|
+
WEEKLY_MONDAY: '0 0 * * 1',
|
|
299
|
+
MONTHLY_FIRST: '0 0 1 * *'
|
|
300
|
+
};
|
|
301
|
+
//# sourceMappingURL=scheduler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scheduler.js","sourceRoot":"","sources":["../../../src/extensions/distributed/scheduler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Worker - Distributed job processor
|
|
3
|
+
* @module extensions/distributed/worker
|
|
4
|
+
*/
|
|
5
|
+
import { EventEmitter } from 'events';
|
|
6
|
+
import type { Job, JobType, JobQueue } from './queue.js';
|
|
7
|
+
import type { ChunkEngine } from '../../core/chunk-engine.js';
|
|
8
|
+
import type { MerkleEngine } from '../../core/merkle-engine.js';
|
|
9
|
+
import type { HNSWIndex } from '../../core/hnsw-index.js';
|
|
10
|
+
import type { NeuronGraphManager } from '../../core/neuron-graph.js';
|
|
11
|
+
import type { ChunkStore } from '../../storage/chunk-store.js';
|
|
12
|
+
import type { NeuronStore } from '../../storage/neuron-store.js';
|
|
13
|
+
import type { IngestionService } from '../../services/ingestion.js';
|
|
14
|
+
import type { VerificationService } from '../../services/verify.js';
|
|
15
|
+
import type { ClusteringService } from '../clustering/index.js';
|
|
16
|
+
/**
|
|
17
|
+
* Worker status
|
|
18
|
+
*/
|
|
19
|
+
export type WorkerStatus = 'IDLE' | 'BUSY' | 'PAUSED' | 'STOPPED';
|
|
20
|
+
/**
|
|
21
|
+
* Worker configuration
|
|
22
|
+
*/
|
|
23
|
+
export interface WorkerConfig {
|
|
24
|
+
id?: string;
|
|
25
|
+
name?: string;
|
|
26
|
+
concurrency?: number;
|
|
27
|
+
jobTypes?: JobType[];
|
|
28
|
+
heartbeatInterval?: number;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Worker context - services available to job handlers
|
|
32
|
+
*/
|
|
33
|
+
export interface WorkerContext {
|
|
34
|
+
chunkEngine?: ChunkEngine;
|
|
35
|
+
merkleEngine?: MerkleEngine;
|
|
36
|
+
hnswIndex?: HNSWIndex;
|
|
37
|
+
graphManager?: NeuronGraphManager;
|
|
38
|
+
chunkStore?: ChunkStore;
|
|
39
|
+
neuronStore?: NeuronStore;
|
|
40
|
+
ingestionService?: IngestionService;
|
|
41
|
+
verifyService?: VerificationService;
|
|
42
|
+
clusteringService?: ClusteringService;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Worker statistics
|
|
46
|
+
*/
|
|
47
|
+
export interface WorkerStats {
|
|
48
|
+
id: string;
|
|
49
|
+
name: string;
|
|
50
|
+
status: WorkerStatus;
|
|
51
|
+
processedJobs: number;
|
|
52
|
+
failedJobs: number;
|
|
53
|
+
avgProcessingTime: number;
|
|
54
|
+
uptime: number;
|
|
55
|
+
lastHeartbeat: string;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Distributed Worker
|
|
59
|
+
*/
|
|
60
|
+
export declare class Worker extends EventEmitter {
|
|
61
|
+
readonly id: string;
|
|
62
|
+
readonly name: string;
|
|
63
|
+
private queue;
|
|
64
|
+
private context;
|
|
65
|
+
private status;
|
|
66
|
+
private concurrency;
|
|
67
|
+
private jobTypes;
|
|
68
|
+
private activeJobs;
|
|
69
|
+
private processedJobs;
|
|
70
|
+
private failedJobs;
|
|
71
|
+
private processingTimes;
|
|
72
|
+
private startTime;
|
|
73
|
+
private heartbeatInterval;
|
|
74
|
+
private heartbeatTimer?;
|
|
75
|
+
private handlers;
|
|
76
|
+
constructor(queue: JobQueue, context: WorkerContext, config?: WorkerConfig);
|
|
77
|
+
/**
|
|
78
|
+
* Start the worker
|
|
79
|
+
*/
|
|
80
|
+
start(): Promise<void>;
|
|
81
|
+
/**
|
|
82
|
+
* Stop the worker
|
|
83
|
+
*/
|
|
84
|
+
stop(): Promise<void>;
|
|
85
|
+
/**
|
|
86
|
+
* Pause the worker
|
|
87
|
+
*/
|
|
88
|
+
pause(): void;
|
|
89
|
+
/**
|
|
90
|
+
* Resume the worker
|
|
91
|
+
*/
|
|
92
|
+
resume(): void;
|
|
93
|
+
/**
|
|
94
|
+
* Register a custom job handler
|
|
95
|
+
*/
|
|
96
|
+
registerHandler(type: JobType, handler: (job: Job, ctx: WorkerContext) => Promise<unknown>): void;
|
|
97
|
+
/**
|
|
98
|
+
* Get worker statistics
|
|
99
|
+
*/
|
|
100
|
+
getStats(): WorkerStats;
|
|
101
|
+
/**
|
|
102
|
+
* Get active jobs
|
|
103
|
+
*/
|
|
104
|
+
getActiveJobs(): Job[];
|
|
105
|
+
private processJob;
|
|
106
|
+
private registerDefaultHandlers;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Create a worker
|
|
110
|
+
*/
|
|
111
|
+
export declare function createWorker(queue: JobQueue, context: WorkerContext, config?: WorkerConfig): Worker;
|
|
112
|
+
//# sourceMappingURL=worker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../../src/extensions/distributed/worker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Worker - Distributed job processor
|
|
3
|
+
* @module extensions/distributed/worker
|
|
4
|
+
*/
|
|
5
|
+
import { EventEmitter } from 'events';
|
|
6
|
+
import { generateUUID } from '../../utils/uuid.js';
|
|
7
|
+
/**
|
|
8
|
+
* Distributed Worker
|
|
9
|
+
*/
|
|
10
|
+
export class Worker extends EventEmitter {
|
|
11
|
+
id;
|
|
12
|
+
name;
|
|
13
|
+
queue;
|
|
14
|
+
context;
|
|
15
|
+
status;
|
|
16
|
+
concurrency;
|
|
17
|
+
jobTypes;
|
|
18
|
+
activeJobs;
|
|
19
|
+
processedJobs;
|
|
20
|
+
failedJobs;
|
|
21
|
+
processingTimes;
|
|
22
|
+
startTime;
|
|
23
|
+
heartbeatInterval;
|
|
24
|
+
heartbeatTimer;
|
|
25
|
+
handlers;
|
|
26
|
+
constructor(queue, context, config = {}) {
|
|
27
|
+
super();
|
|
28
|
+
this.id = config.id ?? generateUUID();
|
|
29
|
+
this.name = config.name ?? `worker-${this.id.slice(0, 8)}`;
|
|
30
|
+
this.queue = queue;
|
|
31
|
+
this.context = context;
|
|
32
|
+
this.status = 'IDLE';
|
|
33
|
+
this.concurrency = config.concurrency ?? 1;
|
|
34
|
+
this.jobTypes = new Set(config.jobTypes ?? []);
|
|
35
|
+
this.heartbeatInterval = config.heartbeatInterval ?? 30000;
|
|
36
|
+
this.activeJobs = new Map();
|
|
37
|
+
this.processedJobs = 0;
|
|
38
|
+
this.failedJobs = 0;
|
|
39
|
+
this.processingTimes = [];
|
|
40
|
+
this.startTime = Date.now();
|
|
41
|
+
this.handlers = new Map();
|
|
42
|
+
this.registerDefaultHandlers();
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Start the worker
|
|
46
|
+
*/
|
|
47
|
+
async start() {
|
|
48
|
+
if (this.status !== 'STOPPED' && this.status !== 'IDLE')
|
|
49
|
+
return;
|
|
50
|
+
this.status = 'IDLE';
|
|
51
|
+
this.startTime = Date.now();
|
|
52
|
+
// Register with queue
|
|
53
|
+
for (const [type, handler] of this.handlers) {
|
|
54
|
+
if (this.jobTypes.size === 0 || this.jobTypes.has(type)) {
|
|
55
|
+
this.queue.process(type, async (job) => {
|
|
56
|
+
return this.processJob(job, handler);
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
// Start heartbeat
|
|
61
|
+
this.heartbeatTimer = setInterval(() => {
|
|
62
|
+
this.emit('heartbeat', this.getStats());
|
|
63
|
+
}, this.heartbeatInterval);
|
|
64
|
+
this.emit('started', this.getStats());
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Stop the worker
|
|
68
|
+
*/
|
|
69
|
+
async stop() {
|
|
70
|
+
this.status = 'STOPPED';
|
|
71
|
+
// Stop heartbeat
|
|
72
|
+
if (this.heartbeatTimer) {
|
|
73
|
+
clearInterval(this.heartbeatTimer);
|
|
74
|
+
this.heartbeatTimer = undefined;
|
|
75
|
+
}
|
|
76
|
+
// Wait for active jobs
|
|
77
|
+
while (this.activeJobs.size > 0) {
|
|
78
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
79
|
+
}
|
|
80
|
+
this.emit('stopped', this.getStats());
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Pause the worker
|
|
84
|
+
*/
|
|
85
|
+
pause() {
|
|
86
|
+
this.status = 'PAUSED';
|
|
87
|
+
this.emit('paused', this.getStats());
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Resume the worker
|
|
91
|
+
*/
|
|
92
|
+
resume() {
|
|
93
|
+
if (this.status === 'PAUSED') {
|
|
94
|
+
this.status = 'IDLE';
|
|
95
|
+
this.emit('resumed', this.getStats());
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Register a custom job handler
|
|
100
|
+
*/
|
|
101
|
+
registerHandler(type, handler) {
|
|
102
|
+
this.handlers.set(type, handler);
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Get worker statistics
|
|
106
|
+
*/
|
|
107
|
+
getStats() {
|
|
108
|
+
const avgTime = this.processingTimes.length > 0
|
|
109
|
+
? this.processingTimes.reduce((a, b) => a + b, 0) / this.processingTimes.length
|
|
110
|
+
: 0;
|
|
111
|
+
return {
|
|
112
|
+
id: this.id,
|
|
113
|
+
name: this.name,
|
|
114
|
+
status: this.status,
|
|
115
|
+
processedJobs: this.processedJobs,
|
|
116
|
+
failedJobs: this.failedJobs,
|
|
117
|
+
avgProcessingTime: Math.round(avgTime),
|
|
118
|
+
uptime: Date.now() - this.startTime,
|
|
119
|
+
lastHeartbeat: new Date().toISOString()
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Get active jobs
|
|
124
|
+
*/
|
|
125
|
+
getActiveJobs() {
|
|
126
|
+
return Array.from(this.activeJobs.values());
|
|
127
|
+
}
|
|
128
|
+
// ==================== Private Methods ====================
|
|
129
|
+
async processJob(job, handler) {
|
|
130
|
+
if (this.status === 'PAUSED' || this.status === 'STOPPED') {
|
|
131
|
+
throw new Error('Worker is not accepting jobs');
|
|
132
|
+
}
|
|
133
|
+
this.status = 'BUSY';
|
|
134
|
+
this.activeJobs.set(job.id, job);
|
|
135
|
+
job.workerId = this.id;
|
|
136
|
+
const startTime = Date.now();
|
|
137
|
+
this.emit('job:started', job);
|
|
138
|
+
try {
|
|
139
|
+
const result = await handler(job, this.context);
|
|
140
|
+
this.processedJobs++;
|
|
141
|
+
this.processingTimes.push(Date.now() - startTime);
|
|
142
|
+
// Keep only last 100 times
|
|
143
|
+
if (this.processingTimes.length > 100) {
|
|
144
|
+
this.processingTimes.shift();
|
|
145
|
+
}
|
|
146
|
+
this.emit('job:completed', job, result);
|
|
147
|
+
return result;
|
|
148
|
+
}
|
|
149
|
+
catch (error) {
|
|
150
|
+
this.failedJobs++;
|
|
151
|
+
this.emit('job:failed', job, error);
|
|
152
|
+
throw error;
|
|
153
|
+
}
|
|
154
|
+
finally {
|
|
155
|
+
this.activeJobs.delete(job.id);
|
|
156
|
+
this.status = this.activeJobs.size > 0 ? 'BUSY' : 'IDLE';
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
registerDefaultHandlers() {
|
|
160
|
+
// Ingest text
|
|
161
|
+
this.handlers.set('INGEST_TEXT', async (job, ctx) => {
|
|
162
|
+
if (!ctx.ingestionService) {
|
|
163
|
+
throw new Error('Ingestion service not available');
|
|
164
|
+
}
|
|
165
|
+
const { text, options } = job.data;
|
|
166
|
+
return ctx.ingestionService.ingestText(text, options);
|
|
167
|
+
});
|
|
168
|
+
// Ingest batch
|
|
169
|
+
this.handlers.set('INGEST_BATCH', async (job, ctx) => {
|
|
170
|
+
if (!ctx.ingestionService) {
|
|
171
|
+
throw new Error('Ingestion service not available');
|
|
172
|
+
}
|
|
173
|
+
const { texts, options } = job.data;
|
|
174
|
+
const neurons = [];
|
|
175
|
+
for (let i = 0; i < texts.length; i++) {
|
|
176
|
+
const neuron = await ctx.ingestionService.ingestText(texts[i], options);
|
|
177
|
+
neurons.push(neuron);
|
|
178
|
+
// Update progress
|
|
179
|
+
this.queue.updateProgress(job.id, ((i + 1) / texts.length) * 100);
|
|
180
|
+
}
|
|
181
|
+
return neurons;
|
|
182
|
+
});
|
|
183
|
+
// Build index
|
|
184
|
+
this.handlers.set('BUILD_INDEX', async (job, ctx) => {
|
|
185
|
+
if (!ctx.hnswIndex || !ctx.neuronStore) {
|
|
186
|
+
throw new Error('HNSW index or neuron store not available');
|
|
187
|
+
}
|
|
188
|
+
const { rebuild } = job.data;
|
|
189
|
+
const ids = await ctx.neuronStore.getAllNeuronIds();
|
|
190
|
+
let processed = 0;
|
|
191
|
+
for (const id of ids) {
|
|
192
|
+
const neuron = await ctx.neuronStore.getNeuron(id);
|
|
193
|
+
if (neuron && !ctx.hnswIndex.has(id)) {
|
|
194
|
+
ctx.hnswIndex.insert(id, neuron.embedding);
|
|
195
|
+
}
|
|
196
|
+
processed++;
|
|
197
|
+
this.queue.updateProgress(job.id, (processed / ids.length) * 100);
|
|
198
|
+
}
|
|
199
|
+
return { indexed: processed };
|
|
200
|
+
});
|
|
201
|
+
// Cluster
|
|
202
|
+
this.handlers.set('CLUSTER', async (job, ctx) => {
|
|
203
|
+
if (!ctx.clusteringService) {
|
|
204
|
+
throw new Error('Clustering service not available');
|
|
205
|
+
}
|
|
206
|
+
const { algorithm, options } = job.data;
|
|
207
|
+
switch (algorithm) {
|
|
208
|
+
case 'kmeans':
|
|
209
|
+
return ctx.clusteringService.kmeans(options);
|
|
210
|
+
case 'dbscan':
|
|
211
|
+
return ctx.clusteringService.dbscan(options);
|
|
212
|
+
case 'hierarchical':
|
|
213
|
+
return ctx.clusteringService.hierarchical(options.targetClusters, options.linkage);
|
|
214
|
+
default:
|
|
215
|
+
throw new Error(`Unknown clustering algorithm: ${algorithm}`);
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
// Verify integrity
|
|
219
|
+
this.handlers.set('VERIFY_INTEGRITY', async (job, ctx) => {
|
|
220
|
+
if (!ctx.verifyService) {
|
|
221
|
+
throw new Error('Verification service not available');
|
|
222
|
+
}
|
|
223
|
+
const { neuronId, full } = job.data;
|
|
224
|
+
if (neuronId) {
|
|
225
|
+
return ctx.verifyService.verifyNeuron(neuronId);
|
|
226
|
+
}
|
|
227
|
+
else if (full) {
|
|
228
|
+
return ctx.verifyService.verifyAll();
|
|
229
|
+
}
|
|
230
|
+
else {
|
|
231
|
+
return ctx.verifyService.verifyChunkStore();
|
|
232
|
+
}
|
|
233
|
+
});
|
|
234
|
+
// Analyze graph
|
|
235
|
+
this.handlers.set('ANALYZE_GRAPH', async (job, ctx) => {
|
|
236
|
+
if (!ctx.graphManager) {
|
|
237
|
+
throw new Error('Graph manager not available');
|
|
238
|
+
}
|
|
239
|
+
const stats = await ctx.graphManager.getStats();
|
|
240
|
+
const components = await ctx.graphManager.getConnectedComponents();
|
|
241
|
+
return {
|
|
242
|
+
...stats,
|
|
243
|
+
componentCount: components.length,
|
|
244
|
+
componentSizes: components.map(c => c.size)
|
|
245
|
+
};
|
|
246
|
+
});
|
|
247
|
+
// Custom job - pass through
|
|
248
|
+
this.handlers.set('CUSTOM', async (job) => {
|
|
249
|
+
const { handler } = job.data;
|
|
250
|
+
throw new Error(`Custom handler '${handler}' not implemented`);
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Create a worker
|
|
256
|
+
*/
|
|
257
|
+
export function createWorker(queue, context, config) {
|
|
258
|
+
return new Worker(queue, context, config);
|
|
259
|
+
}
|
|
260
|
+
//# sourceMappingURL=worker.js.map
|