@nxuss/lemma 0.1.0 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +347 -181
- package/dist/cjs/cloud/KeyManager.d.ts.map +1 -0
- package/dist/cjs/cloud/KeyManager.js.map +1 -0
- package/dist/cjs/cloud/TenantCache.d.ts.map +1 -0
- package/dist/cjs/cloud/TenantCache.js.map +1 -0
- package/dist/cjs/cloud/index.d.ts.map +1 -0
- package/dist/cjs/cloud/index.js.map +1 -0
- package/dist/cjs/cloud/server.d.ts.map +1 -0
- package/dist/cjs/cloud/server.js.map +1 -0
- package/dist/cjs/cloud/types.d.ts.map +1 -0
- package/dist/cjs/cloud/types.js.map +1 -0
- package/dist/cjs/config/index.d.ts.map +1 -0
- package/dist/cjs/config/index.js.map +1 -0
- package/dist/cjs/consensus/ConsensusEngine.d.ts.map +1 -0
- package/dist/cjs/consensus/ConsensusEngine.js.map +1 -0
- package/dist/cjs/consensus/ModelPool.d.ts.map +1 -0
- package/dist/cjs/consensus/ModelPool.js.map +1 -0
- package/dist/cjs/consensus/index.d.ts.map +1 -0
- package/dist/cjs/consensus/index.js.map +1 -0
- package/dist/cjs/core/AgentRegistry.d.ts.map +1 -0
- package/dist/cjs/core/AgentRegistry.js.map +1 -0
- package/dist/cjs/core/DashboardBroadcaster.d.ts.map +1 -0
- package/dist/cjs/core/DashboardBroadcaster.js.map +1 -0
- package/dist/{core → cjs/core}/OrchestrationEngine.d.ts +1 -0
- package/dist/cjs/core/OrchestrationEngine.d.ts.map +1 -0
- package/dist/{core → cjs/core}/OrchestrationEngine.js +29 -23
- package/dist/cjs/core/OrchestrationEngine.js.map +1 -0
- package/dist/cjs/core/SubconsciousEngine.d.ts.map +1 -0
- package/dist/{core → cjs/core}/SubconsciousEngine.js +15 -3
- package/dist/cjs/core/SubconsciousEngine.js.map +1 -0
- package/dist/cjs/core/WebSocketServer.d.ts.map +1 -0
- package/dist/{core → cjs/core}/WebSocketServer.js +2 -1
- package/dist/cjs/core/WebSocketServer.js.map +1 -0
- package/dist/cjs/core/index.d.ts.map +1 -0
- package/dist/cjs/core/index.js.map +1 -0
- package/dist/cjs/core/router.d.ts.map +1 -0
- package/dist/cjs/core/router.js.map +1 -0
- package/dist/{embed → cjs/embed}/index.d.ts +66 -1
- package/dist/cjs/embed/index.d.ts.map +1 -0
- package/dist/cjs/embed/index.js +979 -0
- package/dist/cjs/embed/index.js.map +1 -0
- package/dist/cjs/embed.d.ts.map +1 -0
- package/dist/cjs/embed.js.map +1 -0
- package/dist/cjs/examples/basic-usage.d.ts +12 -0
- package/dist/cjs/examples/basic-usage.d.ts.map +1 -0
- package/dist/cjs/examples/basic-usage.js +128 -0
- package/dist/cjs/examples/basic-usage.js.map +1 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/protocol/flows.d.ts.map +1 -0
- package/dist/cjs/protocol/flows.js.map +1 -0
- package/dist/cjs/protocol/iap.d.ts.map +1 -0
- package/dist/cjs/protocol/iap.js.map +1 -0
- package/dist/cjs/protocol/index.d.ts.map +1 -0
- package/dist/cjs/protocol/index.js.map +1 -0
- package/dist/cjs/protocol/types.d.ts.map +1 -0
- package/dist/cjs/protocol/types.js.map +1 -0
- package/dist/cjs/protocol/utils.d.ts.map +1 -0
- package/dist/cjs/protocol/utils.js.map +1 -0
- package/dist/cjs/protocol/validators.d.ts.map +1 -0
- package/dist/cjs/protocol/validators.js.map +1 -0
- package/dist/cjs/security/AuthManager.d.ts.map +1 -0
- package/dist/cjs/security/AuthManager.js.map +1 -0
- package/dist/cjs/security/MessageSanitizer.d.ts.map +1 -0
- package/dist/{security → cjs/security}/MessageSanitizer.js +22 -6
- package/dist/cjs/security/MessageSanitizer.js.map +1 -0
- package/dist/cjs/security/RateLimiter.d.ts.map +1 -0
- package/dist/cjs/security/RateLimiter.js.map +1 -0
- package/dist/{security → cjs/security}/SecurityMiddleware.d.ts +3 -1
- package/dist/cjs/security/SecurityMiddleware.d.ts.map +1 -0
- package/dist/{security → cjs/security}/SecurityMiddleware.js +5 -3
- package/dist/cjs/security/SecurityMiddleware.js.map +1 -0
- package/dist/cjs/security/index.d.ts.map +1 -0
- package/dist/cjs/security/index.js.map +1 -0
- package/dist/cjs/speculative/PredictionEngine.d.ts.map +1 -0
- package/dist/cjs/speculative/PredictionEngine.js.map +1 -0
- package/dist/cjs/speculative/SpeculativeCache.d.ts.map +1 -0
- package/dist/cjs/speculative/SpeculativeCache.js.map +1 -0
- package/dist/cjs/speculative/SpeculativeEngine.d.ts.map +1 -0
- package/dist/cjs/speculative/SpeculativeEngine.js.map +1 -0
- package/dist/cjs/speculative/WorkerPool.d.ts.map +1 -0
- package/dist/cjs/speculative/WorkerPool.js.map +1 -0
- package/dist/cjs/speculative/index.d.ts.map +1 -0
- package/dist/cjs/speculative/index.js.map +1 -0
- package/dist/cjs/subconscious/EmbeddingService.d.ts.map +1 -0
- package/dist/cjs/subconscious/EmbeddingService.js.map +1 -0
- package/dist/cjs/subconscious/SemanticCache.d.ts.map +1 -0
- package/dist/cjs/subconscious/SemanticCache.js.map +1 -0
- package/dist/cjs/subconscious/SubconsciousEngine.d.ts.map +1 -0
- package/dist/cjs/subconscious/SubconsciousEngine.js.map +1 -0
- package/dist/cjs/subconscious/VectorStore.d.ts.map +1 -0
- package/dist/{subconscious → cjs/subconscious}/VectorStore.js +3 -3
- package/dist/cjs/subconscious/VectorStore.js.map +1 -0
- package/dist/cjs/subconscious/cache.d.ts.map +1 -0
- package/dist/cjs/subconscious/cache.js.map +1 -0
- package/dist/cjs/subconscious/embeddings.d.ts.map +1 -0
- package/dist/cjs/subconscious/embeddings.js.map +1 -0
- package/dist/cjs/subconscious/index.d.ts.map +1 -0
- package/dist/cjs/subconscious/index.js.map +1 -0
- package/dist/cjs/types/index.d.ts.map +1 -0
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/utils/logger.d.ts.map +1 -0
- package/dist/cjs/utils/logger.js.map +1 -0
- package/dist/esm/cloud/KeyManager.d.ts +29 -0
- package/dist/esm/cloud/KeyManager.d.ts.map +1 -0
- package/dist/esm/cloud/KeyManager.js +135 -0
- package/dist/esm/cloud/KeyManager.js.map +1 -0
- package/dist/esm/cloud/TenantCache.d.ts +29 -0
- package/dist/esm/cloud/TenantCache.d.ts.map +1 -0
- package/dist/esm/cloud/TenantCache.js +125 -0
- package/dist/esm/cloud/TenantCache.js.map +1 -0
- package/dist/esm/cloud/index.d.ts +4 -0
- package/dist/esm/cloud/index.d.ts.map +1 -0
- package/dist/esm/cloud/index.js +4 -0
- package/dist/esm/cloud/index.js.map +1 -0
- package/dist/esm/cloud/server.d.ts +17 -0
- package/dist/esm/cloud/server.d.ts.map +1 -0
- package/dist/esm/cloud/server.js +181 -0
- package/dist/esm/cloud/server.js.map +1 -0
- package/dist/esm/cloud/types.d.ts +35 -0
- package/dist/esm/cloud/types.d.ts.map +1 -0
- package/dist/esm/cloud/types.js +11 -0
- package/dist/esm/cloud/types.js.map +1 -0
- package/dist/esm/config/index.d.ts +44 -0
- package/dist/esm/config/index.d.ts.map +1 -0
- package/dist/esm/config/index.js +151 -0
- package/dist/esm/config/index.js.map +1 -0
- package/dist/esm/consensus/ConsensusEngine.d.ts +119 -0
- package/dist/esm/consensus/ConsensusEngine.d.ts.map +1 -0
- package/dist/esm/consensus/ConsensusEngine.js +310 -0
- package/dist/esm/consensus/ConsensusEngine.js.map +1 -0
- package/dist/esm/consensus/ModelPool.d.ts +103 -0
- package/dist/esm/consensus/ModelPool.d.ts.map +1 -0
- package/dist/esm/consensus/ModelPool.js +269 -0
- package/dist/esm/consensus/ModelPool.js.map +1 -0
- package/dist/esm/consensus/index.d.ts +8 -0
- package/dist/esm/consensus/index.d.ts.map +1 -0
- package/dist/esm/consensus/index.js +8 -0
- package/dist/esm/consensus/index.js.map +1 -0
- package/dist/esm/core/AgentRegistry.d.ts +89 -0
- package/dist/esm/core/AgentRegistry.d.ts.map +1 -0
- package/dist/esm/core/AgentRegistry.js +260 -0
- package/dist/esm/core/AgentRegistry.js.map +1 -0
- package/dist/esm/core/DashboardBroadcaster.d.ts +67 -0
- package/dist/esm/core/DashboardBroadcaster.d.ts.map +1 -0
- package/dist/esm/core/DashboardBroadcaster.js +260 -0
- package/dist/esm/core/DashboardBroadcaster.js.map +1 -0
- package/dist/esm/core/OrchestrationEngine.d.ts +85 -0
- package/dist/esm/core/OrchestrationEngine.d.ts.map +1 -0
- package/dist/esm/core/OrchestrationEngine.js +457 -0
- package/dist/esm/core/OrchestrationEngine.js.map +1 -0
- package/dist/esm/core/SubconsciousEngine.d.ts +53 -0
- package/dist/esm/core/SubconsciousEngine.d.ts.map +1 -0
- package/dist/esm/core/SubconsciousEngine.js +278 -0
- package/dist/esm/core/SubconsciousEngine.js.map +1 -0
- package/dist/esm/core/WebSocketServer.d.ts +89 -0
- package/dist/esm/core/WebSocketServer.d.ts.map +1 -0
- package/dist/esm/core/WebSocketServer.js +380 -0
- package/dist/esm/core/WebSocketServer.js.map +1 -0
- package/dist/esm/core/index.d.ts +15 -0
- package/dist/esm/core/index.d.ts.map +1 -0
- package/dist/esm/core/index.js +15 -0
- package/dist/esm/core/index.js.map +1 -0
- package/dist/esm/core/router.d.ts +105 -0
- package/dist/esm/core/router.d.ts.map +1 -0
- package/dist/esm/core/router.js +416 -0
- package/dist/esm/core/router.js.map +1 -0
- package/dist/esm/embed/index.d.ts +218 -0
- package/dist/esm/embed/index.d.ts.map +1 -0
- package/dist/esm/embed/index.js +939 -0
- package/dist/esm/embed/index.js.map +1 -0
- package/dist/esm/embed.d.ts +11 -0
- package/dist/esm/embed.d.ts.map +1 -0
- package/dist/esm/embed.js +11 -0
- package/dist/esm/embed.js.map +1 -0
- package/dist/esm/examples/basic-usage.d.ts +12 -0
- package/dist/esm/examples/basic-usage.d.ts.map +1 -0
- package/dist/esm/examples/basic-usage.js +126 -0
- package/dist/esm/examples/basic-usage.js.map +1 -0
- package/dist/esm/index.d.ts +83 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +132 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/protocol/flows.d.ts +126 -0
- package/dist/esm/protocol/flows.d.ts.map +1 -0
- package/dist/esm/protocol/flows.js +338 -0
- package/dist/esm/protocol/flows.js.map +1 -0
- package/dist/esm/protocol/iap.d.ts +54 -0
- package/dist/esm/protocol/iap.d.ts.map +1 -0
- package/dist/esm/protocol/iap.js +104 -0
- package/dist/esm/protocol/iap.js.map +1 -0
- package/dist/esm/protocol/index.d.ts +23 -0
- package/dist/esm/protocol/index.d.ts.map +1 -0
- package/dist/esm/protocol/index.js +28 -0
- package/dist/esm/protocol/index.js.map +1 -0
- package/dist/esm/protocol/types.d.ts +332 -0
- package/dist/esm/protocol/types.d.ts.map +1 -0
- package/dist/esm/protocol/types.js +54 -0
- package/dist/esm/protocol/types.js.map +1 -0
- package/dist/esm/protocol/utils.d.ts +130 -0
- package/dist/esm/protocol/utils.d.ts.map +1 -0
- package/dist/esm/protocol/utils.js +260 -0
- package/dist/esm/protocol/utils.js.map +1 -0
- package/dist/esm/protocol/validators.d.ts +54 -0
- package/dist/esm/protocol/validators.d.ts.map +1 -0
- package/dist/esm/protocol/validators.js +332 -0
- package/dist/esm/protocol/validators.js.map +1 -0
- package/dist/esm/security/AuthManager.d.ts +73 -0
- package/dist/esm/security/AuthManager.d.ts.map +1 -0
- package/dist/esm/security/AuthManager.js +95 -0
- package/dist/esm/security/AuthManager.js.map +1 -0
- package/dist/esm/security/MessageSanitizer.d.ts +51 -0
- package/dist/esm/security/MessageSanitizer.d.ts.map +1 -0
- package/dist/esm/security/MessageSanitizer.js +178 -0
- package/dist/esm/security/MessageSanitizer.js.map +1 -0
- package/dist/esm/security/RateLimiter.d.ts +46 -0
- package/dist/esm/security/RateLimiter.d.ts.map +1 -0
- package/dist/esm/security/RateLimiter.js +129 -0
- package/dist/esm/security/RateLimiter.js.map +1 -0
- package/dist/esm/security/SecurityMiddleware.d.ts +90 -0
- package/dist/esm/security/SecurityMiddleware.d.ts.map +1 -0
- package/dist/esm/security/SecurityMiddleware.js +144 -0
- package/dist/esm/security/SecurityMiddleware.js.map +1 -0
- package/dist/esm/security/index.d.ts +35 -0
- package/dist/esm/security/index.d.ts.map +1 -0
- package/dist/esm/security/index.js +35 -0
- package/dist/esm/security/index.js.map +1 -0
- package/dist/esm/speculative/PredictionEngine.d.ts +99 -0
- package/dist/esm/speculative/PredictionEngine.d.ts.map +1 -0
- package/dist/esm/speculative/PredictionEngine.js +284 -0
- package/dist/esm/speculative/PredictionEngine.js.map +1 -0
- package/dist/esm/speculative/SpeculativeCache.d.ts +117 -0
- package/dist/esm/speculative/SpeculativeCache.d.ts.map +1 -0
- package/dist/esm/speculative/SpeculativeCache.js +288 -0
- package/dist/esm/speculative/SpeculativeCache.js.map +1 -0
- package/dist/esm/speculative/SpeculativeEngine.d.ts +114 -0
- package/dist/esm/speculative/SpeculativeEngine.d.ts.map +1 -0
- package/dist/esm/speculative/SpeculativeEngine.js +240 -0
- package/dist/esm/speculative/SpeculativeEngine.js.map +1 -0
- package/dist/esm/speculative/WorkerPool.d.ts +109 -0
- package/dist/esm/speculative/WorkerPool.d.ts.map +1 -0
- package/dist/esm/speculative/WorkerPool.js +323 -0
- package/dist/esm/speculative/WorkerPool.js.map +1 -0
- package/dist/esm/speculative/index.d.ts +10 -0
- package/dist/esm/speculative/index.d.ts.map +1 -0
- package/dist/esm/speculative/index.js +10 -0
- package/dist/esm/speculative/index.js.map +1 -0
- package/dist/esm/subconscious/EmbeddingService.d.ts +73 -0
- package/dist/esm/subconscious/EmbeddingService.d.ts.map +1 -0
- package/dist/esm/subconscious/EmbeddingService.js +189 -0
- package/dist/esm/subconscious/EmbeddingService.js.map +1 -0
- package/dist/esm/subconscious/SemanticCache.d.ts +82 -0
- package/dist/esm/subconscious/SemanticCache.d.ts.map +1 -0
- package/dist/esm/subconscious/SemanticCache.js +160 -0
- package/dist/esm/subconscious/SemanticCache.js.map +1 -0
- package/dist/esm/subconscious/SubconsciousEngine.d.ts +121 -0
- package/dist/esm/subconscious/SubconsciousEngine.d.ts.map +1 -0
- package/dist/esm/subconscious/SubconsciousEngine.js +237 -0
- package/dist/esm/subconscious/SubconsciousEngine.js.map +1 -0
- package/dist/esm/subconscious/VectorStore.d.ts +54 -0
- package/dist/esm/subconscious/VectorStore.d.ts.map +1 -0
- package/dist/esm/subconscious/VectorStore.js +164 -0
- package/dist/esm/subconscious/VectorStore.js.map +1 -0
- package/dist/esm/subconscious/cache.d.ts +34 -0
- package/dist/esm/subconscious/cache.d.ts.map +1 -0
- package/dist/esm/subconscious/cache.js +152 -0
- package/dist/{subconscious → esm/subconscious}/cache.js.map +1 -1
- package/dist/esm/subconscious/embeddings.d.ts +25 -0
- package/dist/esm/subconscious/embeddings.d.ts.map +1 -0
- package/dist/esm/subconscious/embeddings.js +58 -0
- package/dist/esm/subconscious/embeddings.js.map +1 -0
- package/dist/esm/subconscious/index.d.ts +12 -0
- package/dist/esm/subconscious/index.d.ts.map +1 -0
- package/dist/esm/subconscious/index.js +12 -0
- package/dist/esm/subconscious/index.js.map +1 -0
- package/dist/esm/types/index.d.ts +286 -0
- package/dist/esm/types/index.d.ts.map +1 -0
- package/dist/esm/types/index.js +40 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/utils/logger.d.ts +63 -0
- package/dist/esm/utils/logger.d.ts.map +1 -0
- package/dist/esm/utils/logger.js +122 -0
- package/dist/esm/utils/logger.js.map +1 -0
- package/package.json +77 -13
- package/dist/cloud/KeyManager.d.ts.map +0 -1
- package/dist/cloud/KeyManager.js.map +0 -1
- package/dist/cloud/TenantCache.d.ts.map +0 -1
- package/dist/cloud/TenantCache.js.map +0 -1
- package/dist/cloud/index.d.ts.map +0 -1
- package/dist/cloud/index.js.map +0 -1
- package/dist/cloud/server.d.ts.map +0 -1
- package/dist/cloud/server.js.map +0 -1
- package/dist/cloud/types.d.ts.map +0 -1
- package/dist/cloud/types.js.map +0 -1
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/index.js.map +0 -1
- package/dist/consensus/ConsensusEngine.d.ts.map +0 -1
- package/dist/consensus/ConsensusEngine.js.map +0 -1
- package/dist/consensus/ModelPool.d.ts.map +0 -1
- package/dist/consensus/ModelPool.js.map +0 -1
- package/dist/consensus/index.d.ts.map +0 -1
- package/dist/consensus/index.js.map +0 -1
- package/dist/core/AgentRegistry.d.ts.map +0 -1
- package/dist/core/AgentRegistry.js.map +0 -1
- package/dist/core/DashboardBroadcaster.d.ts.map +0 -1
- package/dist/core/DashboardBroadcaster.js.map +0 -1
- package/dist/core/OrchestrationEngine.d.ts.map +0 -1
- package/dist/core/OrchestrationEngine.js.map +0 -1
- package/dist/core/SubconsciousEngine.d.ts.map +0 -1
- package/dist/core/SubconsciousEngine.js.map +0 -1
- package/dist/core/WebSocketServer.d.ts.map +0 -1
- package/dist/core/WebSocketServer.js.map +0 -1
- package/dist/core/index.d.ts.map +0 -1
- package/dist/core/index.js.map +0 -1
- package/dist/core/router.d.ts.map +0 -1
- package/dist/core/router.js.map +0 -1
- package/dist/embed/index.d.ts.map +0 -1
- package/dist/embed/index.js +0 -408
- package/dist/embed/index.js.map +0 -1
- package/dist/embed.d.ts.map +0 -1
- package/dist/embed.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/protocol/flows.d.ts.map +0 -1
- package/dist/protocol/flows.js.map +0 -1
- package/dist/protocol/iap.d.ts.map +0 -1
- package/dist/protocol/iap.js.map +0 -1
- package/dist/protocol/index.d.ts.map +0 -1
- package/dist/protocol/index.js.map +0 -1
- package/dist/protocol/types.d.ts.map +0 -1
- package/dist/protocol/types.js.map +0 -1
- package/dist/protocol/utils.d.ts.map +0 -1
- package/dist/protocol/utils.js.map +0 -1
- package/dist/protocol/validators.d.ts.map +0 -1
- package/dist/protocol/validators.js.map +0 -1
- package/dist/security/AuthManager.d.ts.map +0 -1
- package/dist/security/AuthManager.js.map +0 -1
- package/dist/security/MessageSanitizer.d.ts.map +0 -1
- package/dist/security/MessageSanitizer.js.map +0 -1
- package/dist/security/RateLimiter.d.ts.map +0 -1
- package/dist/security/RateLimiter.js.map +0 -1
- package/dist/security/SecurityMiddleware.d.ts.map +0 -1
- package/dist/security/SecurityMiddleware.js.map +0 -1
- package/dist/security/index.d.ts.map +0 -1
- package/dist/security/index.js.map +0 -1
- package/dist/speculative/PredictionEngine.d.ts.map +0 -1
- package/dist/speculative/PredictionEngine.js.map +0 -1
- package/dist/speculative/SpeculativeCache.d.ts.map +0 -1
- package/dist/speculative/SpeculativeCache.js.map +0 -1
- package/dist/speculative/SpeculativeEngine.d.ts.map +0 -1
- package/dist/speculative/SpeculativeEngine.js.map +0 -1
- package/dist/speculative/WorkerPool.d.ts.map +0 -1
- package/dist/speculative/WorkerPool.js.map +0 -1
- package/dist/speculative/index.d.ts.map +0 -1
- package/dist/speculative/index.js.map +0 -1
- package/dist/subconscious/EmbeddingService.d.ts.map +0 -1
- package/dist/subconscious/EmbeddingService.js.map +0 -1
- package/dist/subconscious/SemanticCache.d.ts.map +0 -1
- package/dist/subconscious/SemanticCache.js.map +0 -1
- package/dist/subconscious/SubconsciousEngine.d.ts.map +0 -1
- package/dist/subconscious/SubconsciousEngine.js.map +0 -1
- package/dist/subconscious/VectorStore.d.ts.map +0 -1
- package/dist/subconscious/VectorStore.js.map +0 -1
- package/dist/subconscious/cache.d.ts.map +0 -1
- package/dist/subconscious/embeddings.d.ts.map +0 -1
- package/dist/subconscious/embeddings.js.map +0 -1
- package/dist/subconscious/index.d.ts.map +0 -1
- package/dist/subconscious/index.js.map +0 -1
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js.map +0 -1
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js.map +0 -1
- /package/dist/{cloud → cjs/cloud}/KeyManager.d.ts +0 -0
- /package/dist/{cloud → cjs/cloud}/KeyManager.js +0 -0
- /package/dist/{cloud → cjs/cloud}/TenantCache.d.ts +0 -0
- /package/dist/{cloud → cjs/cloud}/TenantCache.js +0 -0
- /package/dist/{cloud → cjs/cloud}/index.d.ts +0 -0
- /package/dist/{cloud → cjs/cloud}/index.js +0 -0
- /package/dist/{cloud → cjs/cloud}/server.d.ts +0 -0
- /package/dist/{cloud → cjs/cloud}/server.js +0 -0
- /package/dist/{cloud → cjs/cloud}/types.d.ts +0 -0
- /package/dist/{cloud → cjs/cloud}/types.js +0 -0
- /package/dist/{config → cjs/config}/index.d.ts +0 -0
- /package/dist/{config → cjs/config}/index.js +0 -0
- /package/dist/{consensus → cjs/consensus}/ConsensusEngine.d.ts +0 -0
- /package/dist/{consensus → cjs/consensus}/ConsensusEngine.js +0 -0
- /package/dist/{consensus → cjs/consensus}/ModelPool.d.ts +0 -0
- /package/dist/{consensus → cjs/consensus}/ModelPool.js +0 -0
- /package/dist/{consensus → cjs/consensus}/index.d.ts +0 -0
- /package/dist/{consensus → cjs/consensus}/index.js +0 -0
- /package/dist/{core → cjs/core}/AgentRegistry.d.ts +0 -0
- /package/dist/{core → cjs/core}/AgentRegistry.js +0 -0
- /package/dist/{core → cjs/core}/DashboardBroadcaster.d.ts +0 -0
- /package/dist/{core → cjs/core}/DashboardBroadcaster.js +0 -0
- /package/dist/{core → cjs/core}/SubconsciousEngine.d.ts +0 -0
- /package/dist/{core → cjs/core}/WebSocketServer.d.ts +0 -0
- /package/dist/{core → cjs/core}/index.d.ts +0 -0
- /package/dist/{core → cjs/core}/index.js +0 -0
- /package/dist/{core → cjs/core}/router.d.ts +0 -0
- /package/dist/{core → cjs/core}/router.js +0 -0
- /package/dist/{embed.d.ts → cjs/embed.d.ts} +0 -0
- /package/dist/{embed.js → cjs/embed.js} +0 -0
- /package/dist/{index.d.ts → cjs/index.d.ts} +0 -0
- /package/dist/{index.js → cjs/index.js} +0 -0
- /package/dist/{protocol → cjs/protocol}/flows.d.ts +0 -0
- /package/dist/{protocol → cjs/protocol}/flows.js +0 -0
- /package/dist/{protocol → cjs/protocol}/iap.d.ts +0 -0
- /package/dist/{protocol → cjs/protocol}/iap.js +0 -0
- /package/dist/{protocol → cjs/protocol}/index.d.ts +0 -0
- /package/dist/{protocol → cjs/protocol}/index.js +0 -0
- /package/dist/{protocol → cjs/protocol}/types.d.ts +0 -0
- /package/dist/{protocol → cjs/protocol}/types.js +0 -0
- /package/dist/{protocol → cjs/protocol}/utils.d.ts +0 -0
- /package/dist/{protocol → cjs/protocol}/utils.js +0 -0
- /package/dist/{protocol → cjs/protocol}/validators.d.ts +0 -0
- /package/dist/{protocol → cjs/protocol}/validators.js +0 -0
- /package/dist/{security → cjs/security}/AuthManager.d.ts +0 -0
- /package/dist/{security → cjs/security}/AuthManager.js +0 -0
- /package/dist/{security → cjs/security}/MessageSanitizer.d.ts +0 -0
- /package/dist/{security → cjs/security}/RateLimiter.d.ts +0 -0
- /package/dist/{security → cjs/security}/RateLimiter.js +0 -0
- /package/dist/{security → cjs/security}/index.d.ts +0 -0
- /package/dist/{security → cjs/security}/index.js +0 -0
- /package/dist/{speculative → cjs/speculative}/PredictionEngine.d.ts +0 -0
- /package/dist/{speculative → cjs/speculative}/PredictionEngine.js +0 -0
- /package/dist/{speculative → cjs/speculative}/SpeculativeCache.d.ts +0 -0
- /package/dist/{speculative → cjs/speculative}/SpeculativeCache.js +0 -0
- /package/dist/{speculative → cjs/speculative}/SpeculativeEngine.d.ts +0 -0
- /package/dist/{speculative → cjs/speculative}/SpeculativeEngine.js +0 -0
- /package/dist/{speculative → cjs/speculative}/WorkerPool.d.ts +0 -0
- /package/dist/{speculative → cjs/speculative}/WorkerPool.js +0 -0
- /package/dist/{speculative → cjs/speculative}/index.d.ts +0 -0
- /package/dist/{speculative → cjs/speculative}/index.js +0 -0
- /package/dist/{subconscious → cjs/subconscious}/EmbeddingService.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/EmbeddingService.js +0 -0
- /package/dist/{subconscious → cjs/subconscious}/SemanticCache.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/SemanticCache.js +0 -0
- /package/dist/{subconscious → cjs/subconscious}/SubconsciousEngine.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/SubconsciousEngine.js +0 -0
- /package/dist/{subconscious → cjs/subconscious}/VectorStore.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/cache.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/cache.js +0 -0
- /package/dist/{subconscious → cjs/subconscious}/embeddings.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/embeddings.js +0 -0
- /package/dist/{subconscious → cjs/subconscious}/index.d.ts +0 -0
- /package/dist/{subconscious → cjs/subconscious}/index.js +0 -0
- /package/dist/{types → cjs/types}/index.d.ts +0 -0
- /package/dist/{types → cjs/types}/index.js +0 -0
- /package/dist/{utils → cjs/utils}/logger.d.ts +0 -0
- /package/dist/{utils → cjs/utils}/logger.js +0 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Manager
|
|
3
|
+
* Handles API key generation, validation, and agent authentication
|
|
4
|
+
*/
|
|
5
|
+
export interface ApiKey {
|
|
6
|
+
key: string;
|
|
7
|
+
agentId: string;
|
|
8
|
+
name: string;
|
|
9
|
+
createdAt: number;
|
|
10
|
+
expiresAt?: number;
|
|
11
|
+
permissions: string[];
|
|
12
|
+
rateLimit?: {
|
|
13
|
+
requestsPerMinute: number;
|
|
14
|
+
requestsPerHour: number;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export interface AuthConfig {
|
|
18
|
+
enabled: boolean;
|
|
19
|
+
requireApiKey: boolean;
|
|
20
|
+
allowedOrigins?: string[];
|
|
21
|
+
defaultRateLimit?: {
|
|
22
|
+
requestsPerMinute: number;
|
|
23
|
+
requestsPerHour: number;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
export declare class AuthManager {
|
|
27
|
+
private apiKeys;
|
|
28
|
+
private config;
|
|
29
|
+
constructor(config: AuthConfig);
|
|
30
|
+
/**
|
|
31
|
+
* Generate a new API key for an agent
|
|
32
|
+
*/
|
|
33
|
+
generateApiKey(agentId: string, name: string, options?: {
|
|
34
|
+
expiresIn?: number;
|
|
35
|
+
permissions?: string[];
|
|
36
|
+
rateLimit?: {
|
|
37
|
+
requestsPerMinute: number;
|
|
38
|
+
requestsPerHour: number;
|
|
39
|
+
};
|
|
40
|
+
}): string;
|
|
41
|
+
/**
|
|
42
|
+
* Validate an API key
|
|
43
|
+
*/
|
|
44
|
+
validateApiKey(key: string): {
|
|
45
|
+
valid: boolean;
|
|
46
|
+
apiKey?: ApiKey;
|
|
47
|
+
reason?: string;
|
|
48
|
+
};
|
|
49
|
+
/**
|
|
50
|
+
* Revoke an API key
|
|
51
|
+
*/
|
|
52
|
+
revokeApiKey(key: string): boolean;
|
|
53
|
+
/**
|
|
54
|
+
* List all API keys for an agent
|
|
55
|
+
*/
|
|
56
|
+
listApiKeys(agentId?: string): ApiKey[];
|
|
57
|
+
/**
|
|
58
|
+
* Check if agent has permission
|
|
59
|
+
*/
|
|
60
|
+
hasPermission(apiKey: ApiKey, permission: string): boolean;
|
|
61
|
+
/**
|
|
62
|
+
* Validate origin (CORS)
|
|
63
|
+
*/
|
|
64
|
+
validateOrigin(origin: string): boolean;
|
|
65
|
+
/**
|
|
66
|
+
* Get rate limit for API key
|
|
67
|
+
*/
|
|
68
|
+
getRateLimit(apiKey: ApiKey): {
|
|
69
|
+
requestsPerMinute: number;
|
|
70
|
+
requestsPerHour: number;
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=AuthManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthManager.d.ts","sourceRoot":"","sources":["../../../src/security/AuthManager.ts"],"names":[],"mappings":"AAEA;;;GAGG;AAEH,MAAM,WAAW,MAAM;IACrB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,SAAS,CAAC,EAAE;QACV,iBAAiB,EAAE,MAAM,CAAC;QAC1B,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,aAAa,EAAE,OAAO,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,gBAAgB,CAAC,EAAE;QACjB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,MAAM,CAAa;gBAEf,MAAM,EAAE,UAAU;IAI9B;;OAEG;IACH,cAAc,CACZ,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;QACR,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;QACvB,SAAS,CAAC,EAAE;YAAE,iBAAiB,EAAE,MAAM,CAAC;YAAC,eAAe,EAAE,MAAM,CAAA;SAAE,CAAC;KACpE,GACA,MAAM;IAqBT;;OAEG;IACH,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG;QAC3B,KAAK,EAAE,OAAO,CAAC;QACf,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB;IAuBD;;OAEG;IACH,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIlC;;OAEG;IACH,WAAW,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE;IAUvC;;OAEG;IACH,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO;IAQ1D;;OAEG;IACH,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAYvC;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG;QAC5B,iBAAiB,EAAE,MAAM,CAAC;QAC1B,eAAe,EAAE,MAAM,CAAC;KACzB;CASF"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import crypto from 'crypto';
|
|
2
|
+
export class AuthManager {
|
|
3
|
+
constructor(config) {
|
|
4
|
+
this.apiKeys = new Map();
|
|
5
|
+
this.config = config;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Generate a new API key for an agent
|
|
9
|
+
*/
|
|
10
|
+
generateApiKey(agentId, name, options) {
|
|
11
|
+
// Generate secure random key
|
|
12
|
+
const key = `lma_${crypto.randomBytes(32).toString('hex')}`;
|
|
13
|
+
const apiKey = {
|
|
14
|
+
key,
|
|
15
|
+
agentId,
|
|
16
|
+
name,
|
|
17
|
+
createdAt: Date.now(),
|
|
18
|
+
expiresAt: options?.expiresIn
|
|
19
|
+
? Date.now() + options.expiresIn
|
|
20
|
+
: undefined,
|
|
21
|
+
permissions: options?.permissions || ['*'],
|
|
22
|
+
rateLimit: options?.rateLimit || this.config.defaultRateLimit,
|
|
23
|
+
};
|
|
24
|
+
this.apiKeys.set(key, apiKey);
|
|
25
|
+
return key;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Validate an API key
|
|
29
|
+
*/
|
|
30
|
+
validateApiKey(key) {
|
|
31
|
+
if (!this.config.enabled || !this.config.requireApiKey) {
|
|
32
|
+
return { valid: true };
|
|
33
|
+
}
|
|
34
|
+
if (!key) {
|
|
35
|
+
return { valid: false, reason: 'API key required' };
|
|
36
|
+
}
|
|
37
|
+
const apiKey = this.apiKeys.get(key);
|
|
38
|
+
if (!apiKey) {
|
|
39
|
+
return { valid: false, reason: 'Invalid API key' };
|
|
40
|
+
}
|
|
41
|
+
// Check expiration
|
|
42
|
+
if (apiKey.expiresAt && Date.now() > apiKey.expiresAt) {
|
|
43
|
+
return { valid: false, reason: 'API key expired' };
|
|
44
|
+
}
|
|
45
|
+
return { valid: true, apiKey };
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Revoke an API key
|
|
49
|
+
*/
|
|
50
|
+
revokeApiKey(key) {
|
|
51
|
+
return this.apiKeys.delete(key);
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* List all API keys for an agent
|
|
55
|
+
*/
|
|
56
|
+
listApiKeys(agentId) {
|
|
57
|
+
const keys = Array.from(this.apiKeys.values());
|
|
58
|
+
if (agentId) {
|
|
59
|
+
return keys.filter((k) => k.agentId === agentId);
|
|
60
|
+
}
|
|
61
|
+
return keys;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Check if agent has permission
|
|
65
|
+
*/
|
|
66
|
+
hasPermission(apiKey, permission) {
|
|
67
|
+
if (apiKey.permissions.includes('*')) {
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
return apiKey.permissions.includes(permission);
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Validate origin (CORS)
|
|
74
|
+
*/
|
|
75
|
+
validateOrigin(origin) {
|
|
76
|
+
if (!this.config.allowedOrigins || this.config.allowedOrigins.length === 0) {
|
|
77
|
+
return true; // Allow all if not configured
|
|
78
|
+
}
|
|
79
|
+
if (this.config.allowedOrigins.includes('*')) {
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
return this.config.allowedOrigins.includes(origin);
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Get rate limit for API key
|
|
86
|
+
*/
|
|
87
|
+
getRateLimit(apiKey) {
|
|
88
|
+
return (apiKey.rateLimit ||
|
|
89
|
+
this.config.defaultRateLimit || {
|
|
90
|
+
requestsPerMinute: 60,
|
|
91
|
+
requestsPerHour: 1000,
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=AuthManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthManager.js","sourceRoot":"","sources":["../../../src/security/AuthManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Message Sanitizer
|
|
3
|
+
* Validates and sanitizes incoming messages to prevent injection attacks
|
|
4
|
+
*/
|
|
5
|
+
export interface SanitizationResult {
|
|
6
|
+
valid: boolean;
|
|
7
|
+
sanitized?: any;
|
|
8
|
+
errors?: string[];
|
|
9
|
+
}
|
|
10
|
+
export declare class MessageSanitizer {
|
|
11
|
+
private maxStringLength;
|
|
12
|
+
private maxArrayLength;
|
|
13
|
+
private maxObjectDepth;
|
|
14
|
+
constructor(options?: {
|
|
15
|
+
maxStringLength?: number;
|
|
16
|
+
maxArrayLength?: number;
|
|
17
|
+
maxObjectDepth?: number;
|
|
18
|
+
});
|
|
19
|
+
/**
|
|
20
|
+
* Sanitize a message
|
|
21
|
+
*/
|
|
22
|
+
sanitize(message: any): SanitizationResult;
|
|
23
|
+
/**
|
|
24
|
+
* Sanitize a value recursively
|
|
25
|
+
*/
|
|
26
|
+
private sanitizeValue;
|
|
27
|
+
/**
|
|
28
|
+
* Sanitize a string
|
|
29
|
+
*/
|
|
30
|
+
private sanitizeString;
|
|
31
|
+
/**
|
|
32
|
+
* Sanitize an array
|
|
33
|
+
*/
|
|
34
|
+
private sanitizeArray;
|
|
35
|
+
/**
|
|
36
|
+
* Sanitize an object
|
|
37
|
+
*/
|
|
38
|
+
private sanitizeObject;
|
|
39
|
+
/**
|
|
40
|
+
* Validate message structure
|
|
41
|
+
*/
|
|
42
|
+
validateMessageStructure(message: any): {
|
|
43
|
+
valid: boolean;
|
|
44
|
+
errors?: string[];
|
|
45
|
+
};
|
|
46
|
+
/**
|
|
47
|
+
* Sanitize and validate a message
|
|
48
|
+
*/
|
|
49
|
+
sanitizeAndValidate(message: any): SanitizationResult;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=MessageSanitizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageSanitizer.d.ts","sourceRoot":"","sources":["../../../src/security/MessageSanitizer.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,cAAc,CAAS;gBAEnB,OAAO,CAAC,EAAE;QACpB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,cAAc,CAAC,EAAE,MAAM,CAAC;KACzB;IAMD;;OAEG;IACH,QAAQ,CAAC,OAAO,EAAE,GAAG,GAAG,kBAAkB;IAmB1C;;OAEG;IACH,OAAO,CAAC,aAAa;IA8CrB;;OAEG;IACH,OAAO,CAAC,cAAc;IAkBtB;;OAEG;IACH,OAAO,CAAC,aAAa;IAUrB;;OAEG;IACH,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,wBAAwB,CAAC,OAAO,EAAE,GAAG,GAAG;QACtC,KAAK,EAAE,OAAO,CAAC;QACf,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;KACnB;IAmDD;;OAEG;IACH,mBAAmB,CAAC,OAAO,EAAE,GAAG,GAAG,kBAAkB;CAatD"}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Message Sanitizer
|
|
3
|
+
* Validates and sanitizes incoming messages to prevent injection attacks
|
|
4
|
+
*/
|
|
5
|
+
export class MessageSanitizer {
|
|
6
|
+
constructor(options) {
|
|
7
|
+
this.maxStringLength = options?.maxStringLength || 10000;
|
|
8
|
+
this.maxArrayLength = options?.maxArrayLength || 1000;
|
|
9
|
+
this.maxObjectDepth = options?.maxObjectDepth || 10;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Sanitize a message
|
|
13
|
+
*/
|
|
14
|
+
sanitize(message) {
|
|
15
|
+
const errors = [];
|
|
16
|
+
try {
|
|
17
|
+
const sanitized = this.sanitizeValue(message, 0, errors);
|
|
18
|
+
if (errors.length > 0) {
|
|
19
|
+
return { valid: false, errors };
|
|
20
|
+
}
|
|
21
|
+
return { valid: true, sanitized };
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
return {
|
|
25
|
+
valid: false,
|
|
26
|
+
errors: [`Sanitization error: ${error.message}`],
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Sanitize a value recursively
|
|
32
|
+
*/
|
|
33
|
+
sanitizeValue(value, depth, errors) {
|
|
34
|
+
// Check depth
|
|
35
|
+
if (depth > this.maxObjectDepth) {
|
|
36
|
+
errors.push(`Maximum object depth (${this.maxObjectDepth}) exceeded`);
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
// Handle null/undefined
|
|
40
|
+
if (value === null || value === undefined) {
|
|
41
|
+
return value;
|
|
42
|
+
}
|
|
43
|
+
// Handle strings
|
|
44
|
+
if (typeof value === 'string') {
|
|
45
|
+
return this.sanitizeString(value, errors);
|
|
46
|
+
}
|
|
47
|
+
// Handle numbers
|
|
48
|
+
if (typeof value === 'number') {
|
|
49
|
+
if (!Number.isFinite(value)) {
|
|
50
|
+
errors.push('Invalid number (NaN or Infinity)');
|
|
51
|
+
return 0;
|
|
52
|
+
}
|
|
53
|
+
return value;
|
|
54
|
+
}
|
|
55
|
+
// Handle booleans
|
|
56
|
+
if (typeof value === 'boolean') {
|
|
57
|
+
return value;
|
|
58
|
+
}
|
|
59
|
+
// Handle arrays
|
|
60
|
+
if (Array.isArray(value)) {
|
|
61
|
+
return this.sanitizeArray(value, depth, errors);
|
|
62
|
+
}
|
|
63
|
+
// Handle objects
|
|
64
|
+
if (typeof value === 'object') {
|
|
65
|
+
return this.sanitizeObject(value, depth, errors);
|
|
66
|
+
}
|
|
67
|
+
// Reject functions, symbols, etc.
|
|
68
|
+
errors.push(`Invalid type: ${typeof value}`);
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Sanitize a string
|
|
73
|
+
*/
|
|
74
|
+
sanitizeString(str, errors) {
|
|
75
|
+
// Check length
|
|
76
|
+
if (str.length > this.maxStringLength) {
|
|
77
|
+
errors.push(`String too long (${str.length} > ${this.maxStringLength})`);
|
|
78
|
+
return str.substring(0, this.maxStringLength);
|
|
79
|
+
}
|
|
80
|
+
// Remove null bytes
|
|
81
|
+
str = str.replace(/\0/g, '');
|
|
82
|
+
// Remove control characters (except newline, tab, carriage return)
|
|
83
|
+
str = str.replace(/[\x00-\x08\x0B-\x0C\x0E-\x1F\x7F]/g, '');
|
|
84
|
+
return str;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Sanitize an array
|
|
88
|
+
*/
|
|
89
|
+
sanitizeArray(arr, depth, errors) {
|
|
90
|
+
// Check length
|
|
91
|
+
if (arr.length > this.maxArrayLength) {
|
|
92
|
+
errors.push(`Array too long (${arr.length} > ${this.maxArrayLength})`);
|
|
93
|
+
arr = arr.slice(0, this.maxArrayLength);
|
|
94
|
+
}
|
|
95
|
+
return arr.map((item) => this.sanitizeValue(item, depth + 1, errors));
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Sanitize an object
|
|
99
|
+
*/
|
|
100
|
+
sanitizeObject(obj, depth, errors) {
|
|
101
|
+
const sanitized = {};
|
|
102
|
+
for (const key in obj) {
|
|
103
|
+
if (obj.hasOwnProperty(key)) {
|
|
104
|
+
// Sanitize key
|
|
105
|
+
const sanitizedKey = this.sanitizeString(key, errors);
|
|
106
|
+
// Sanitize value
|
|
107
|
+
sanitized[sanitizedKey] = this.sanitizeValue(obj[key], depth + 1, errors);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return sanitized;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Validate message structure
|
|
114
|
+
*/
|
|
115
|
+
validateMessageStructure(message) {
|
|
116
|
+
const errors = [];
|
|
117
|
+
// Check if message is an object
|
|
118
|
+
if (typeof message !== 'object' || message === null) {
|
|
119
|
+
errors.push('Message must be an object');
|
|
120
|
+
return { valid: false, errors };
|
|
121
|
+
}
|
|
122
|
+
// Check required fields
|
|
123
|
+
if (!message.type) {
|
|
124
|
+
errors.push('Message must have a "type" field');
|
|
125
|
+
}
|
|
126
|
+
// Accept either "id" or "messageId" (protocol uses messageId)
|
|
127
|
+
if (!message.id && !message.messageId) {
|
|
128
|
+
errors.push('Message must have an "id" field');
|
|
129
|
+
}
|
|
130
|
+
if (!message.timestamp) {
|
|
131
|
+
errors.push('Message must have a "timestamp" field');
|
|
132
|
+
}
|
|
133
|
+
// Validate timestamp — accept both Unix ms (number) and ISO 8601 (string)
|
|
134
|
+
if (message.timestamp) {
|
|
135
|
+
const now = Date.now();
|
|
136
|
+
let ts;
|
|
137
|
+
if (typeof message.timestamp === 'number') {
|
|
138
|
+
ts = message.timestamp;
|
|
139
|
+
}
|
|
140
|
+
else if (typeof message.timestamp === 'string') {
|
|
141
|
+
ts = new Date(message.timestamp).getTime();
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
ts = NaN;
|
|
145
|
+
}
|
|
146
|
+
if (isNaN(ts)) {
|
|
147
|
+
errors.push('Message timestamp is invalid');
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
const diff = Math.abs(now - ts);
|
|
151
|
+
// Allow 5 minutes clock skew
|
|
152
|
+
if (diff > 5 * 60 * 1000) {
|
|
153
|
+
errors.push('Message timestamp too far from current time');
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
return {
|
|
158
|
+
valid: errors.length === 0,
|
|
159
|
+
errors: errors.length > 0 ? errors : undefined,
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Sanitize and validate a message
|
|
164
|
+
*/
|
|
165
|
+
sanitizeAndValidate(message) {
|
|
166
|
+
// First validate structure
|
|
167
|
+
const structureValidation = this.validateMessageStructure(message);
|
|
168
|
+
if (!structureValidation.valid) {
|
|
169
|
+
return {
|
|
170
|
+
valid: false,
|
|
171
|
+
errors: structureValidation.errors,
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
// Then sanitize
|
|
175
|
+
return this.sanitize(message);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
//# sourceMappingURL=MessageSanitizer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageSanitizer.js","sourceRoot":"","sources":["../../../src/security/MessageSanitizer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rate Limiter
|
|
3
|
+
* Prevents abuse by limiting requests per agent
|
|
4
|
+
*/
|
|
5
|
+
export interface RateLimitConfig {
|
|
6
|
+
requestsPerMinute: number;
|
|
7
|
+
requestsPerHour: number;
|
|
8
|
+
blockDuration?: number;
|
|
9
|
+
}
|
|
10
|
+
export declare class RateLimiter {
|
|
11
|
+
private limits;
|
|
12
|
+
private cleanupInterval;
|
|
13
|
+
constructor();
|
|
14
|
+
/**
|
|
15
|
+
* Check if request is allowed
|
|
16
|
+
*/
|
|
17
|
+
checkLimit(identifier: string, config: RateLimitConfig): {
|
|
18
|
+
allowed: boolean;
|
|
19
|
+
remaining: {
|
|
20
|
+
perMinute: number;
|
|
21
|
+
perHour: number;
|
|
22
|
+
};
|
|
23
|
+
resetAt?: number;
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* Reset limits for an identifier
|
|
27
|
+
*/
|
|
28
|
+
reset(identifier: string): void;
|
|
29
|
+
/**
|
|
30
|
+
* Get current usage for an identifier
|
|
31
|
+
*/
|
|
32
|
+
getUsage(identifier: string): {
|
|
33
|
+
minuteRequests: number;
|
|
34
|
+
hourRequests: number;
|
|
35
|
+
blockedUntil?: number;
|
|
36
|
+
};
|
|
37
|
+
/**
|
|
38
|
+
* Cleanup old entries
|
|
39
|
+
*/
|
|
40
|
+
private cleanup;
|
|
41
|
+
/**
|
|
42
|
+
* Destroy rate limiter
|
|
43
|
+
*/
|
|
44
|
+
destroy(): void;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=RateLimiter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RateLimiter.d.ts","sourceRoot":"","sources":["../../../src/security/RateLimiter.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,eAAe;IAC9B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAQD,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAA0C;IACxD,OAAO,CAAC,eAAe,CAAiB;;IASxC;;OAEG;IACH,UAAU,CACR,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,eAAe,GACtB;QACD,OAAO,EAAE,OAAO,CAAC;QACjB,SAAS,EAAE;YACT,SAAS,EAAE,MAAM,CAAC;YAClB,OAAO,EAAE,MAAM,CAAC;SACjB,CAAC;QACF,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB;IA6ED;;OAEG;IACH,KAAK,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAI/B;;OAEG;IACH,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG;QAC5B,cAAc,EAAE,MAAM,CAAC;QACvB,YAAY,EAAE,MAAM,CAAC;QACrB,YAAY,CAAC,EAAE,MAAM,CAAC;KACvB;IAuBD;;OAEG;IACH,OAAO,CAAC,OAAO;IAgBf;;OAEG;IACH,OAAO,IAAI,IAAI;CAIhB"}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rate Limiter
|
|
3
|
+
* Prevents abuse by limiting requests per agent
|
|
4
|
+
*/
|
|
5
|
+
export class RateLimiter {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.limits = new Map();
|
|
8
|
+
// Cleanup old entries every 5 minutes
|
|
9
|
+
this.cleanupInterval = setInterval(() => {
|
|
10
|
+
this.cleanup();
|
|
11
|
+
}, 5 * 60 * 1000);
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Check if request is allowed
|
|
15
|
+
*/
|
|
16
|
+
checkLimit(identifier, config) {
|
|
17
|
+
const now = Date.now();
|
|
18
|
+
let entry = this.limits.get(identifier);
|
|
19
|
+
if (!entry) {
|
|
20
|
+
entry = {
|
|
21
|
+
minuteRequests: [],
|
|
22
|
+
hourRequests: [],
|
|
23
|
+
};
|
|
24
|
+
this.limits.set(identifier, entry);
|
|
25
|
+
}
|
|
26
|
+
// Check if blocked
|
|
27
|
+
if (entry.blockedUntil && now < entry.blockedUntil) {
|
|
28
|
+
return {
|
|
29
|
+
allowed: false,
|
|
30
|
+
remaining: { perMinute: 0, perHour: 0 },
|
|
31
|
+
resetAt: entry.blockedUntil,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
// Clean old requests
|
|
35
|
+
const oneMinuteAgo = now - 60 * 1000;
|
|
36
|
+
const oneHourAgo = now - 60 * 60 * 1000;
|
|
37
|
+
entry.minuteRequests = entry.minuteRequests.filter((t) => t > oneMinuteAgo);
|
|
38
|
+
entry.hourRequests = entry.hourRequests.filter((t) => t > oneHourAgo);
|
|
39
|
+
// Check limits
|
|
40
|
+
const minuteCount = entry.minuteRequests.length;
|
|
41
|
+
const hourCount = entry.hourRequests.length;
|
|
42
|
+
if (minuteCount >= config.requestsPerMinute) {
|
|
43
|
+
// Block if configured
|
|
44
|
+
if (config.blockDuration) {
|
|
45
|
+
entry.blockedUntil = now + config.blockDuration;
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
allowed: false,
|
|
49
|
+
remaining: {
|
|
50
|
+
perMinute: 0,
|
|
51
|
+
perHour: Math.max(0, config.requestsPerHour - hourCount),
|
|
52
|
+
},
|
|
53
|
+
resetAt: entry.minuteRequests[0] + 60 * 1000,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
if (hourCount >= config.requestsPerHour) {
|
|
57
|
+
// Block if configured
|
|
58
|
+
if (config.blockDuration) {
|
|
59
|
+
entry.blockedUntil = now + config.blockDuration;
|
|
60
|
+
}
|
|
61
|
+
return {
|
|
62
|
+
allowed: false,
|
|
63
|
+
remaining: {
|
|
64
|
+
perMinute: Math.max(0, config.requestsPerMinute - minuteCount),
|
|
65
|
+
perHour: 0,
|
|
66
|
+
},
|
|
67
|
+
resetAt: entry.hourRequests[0] + 60 * 60 * 1000,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
// Record request
|
|
71
|
+
entry.minuteRequests.push(now);
|
|
72
|
+
entry.hourRequests.push(now);
|
|
73
|
+
return {
|
|
74
|
+
allowed: true,
|
|
75
|
+
remaining: {
|
|
76
|
+
perMinute: config.requestsPerMinute - minuteCount - 1,
|
|
77
|
+
perHour: config.requestsPerHour - hourCount - 1,
|
|
78
|
+
},
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Reset limits for an identifier
|
|
83
|
+
*/
|
|
84
|
+
reset(identifier) {
|
|
85
|
+
this.limits.delete(identifier);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Get current usage for an identifier
|
|
89
|
+
*/
|
|
90
|
+
getUsage(identifier) {
|
|
91
|
+
const entry = this.limits.get(identifier);
|
|
92
|
+
if (!entry) {
|
|
93
|
+
return { minuteRequests: 0, hourRequests: 0 };
|
|
94
|
+
}
|
|
95
|
+
const now = Date.now();
|
|
96
|
+
const oneMinuteAgo = now - 60 * 1000;
|
|
97
|
+
const oneHourAgo = now - 60 * 60 * 1000;
|
|
98
|
+
const minuteRequests = entry.minuteRequests.filter((t) => t > oneMinuteAgo).length;
|
|
99
|
+
const hourRequests = entry.hourRequests.filter((t) => t > oneHourAgo).length;
|
|
100
|
+
return {
|
|
101
|
+
minuteRequests,
|
|
102
|
+
hourRequests,
|
|
103
|
+
blockedUntil: entry.blockedUntil,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Cleanup old entries
|
|
108
|
+
*/
|
|
109
|
+
cleanup() {
|
|
110
|
+
const now = Date.now();
|
|
111
|
+
const oneHourAgo = now - 60 * 60 * 1000;
|
|
112
|
+
for (const [identifier, entry] of this.limits.entries()) {
|
|
113
|
+
// Remove if no recent requests and not blocked
|
|
114
|
+
if (entry.hourRequests.length === 0 ||
|
|
115
|
+
(entry.hourRequests[entry.hourRequests.length - 1] < oneHourAgo &&
|
|
116
|
+
(!entry.blockedUntil || now > entry.blockedUntil))) {
|
|
117
|
+
this.limits.delete(identifier);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Destroy rate limiter
|
|
123
|
+
*/
|
|
124
|
+
destroy() {
|
|
125
|
+
clearInterval(this.cleanupInterval);
|
|
126
|
+
this.limits.clear();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
//# sourceMappingURL=RateLimiter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RateLimiter.js","sourceRoot":"","sources":["../../../src/security/RateLimiter.ts"],"names":[],"mappings":"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"}
|