@nxuss/lemma 0.1.1 → 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.
Files changed (452) hide show
  1. package/README.md +195 -13
  2. package/dist/cjs/cloud/KeyManager.d.ts.map +1 -0
  3. package/dist/cjs/cloud/KeyManager.js.map +1 -0
  4. package/dist/cjs/cloud/TenantCache.d.ts.map +1 -0
  5. package/dist/cjs/cloud/TenantCache.js.map +1 -0
  6. package/dist/cjs/cloud/index.d.ts.map +1 -0
  7. package/dist/cjs/cloud/index.js.map +1 -0
  8. package/dist/cjs/cloud/server.d.ts.map +1 -0
  9. package/dist/cjs/cloud/server.js.map +1 -0
  10. package/dist/cjs/cloud/types.d.ts.map +1 -0
  11. package/dist/cjs/cloud/types.js.map +1 -0
  12. package/dist/cjs/config/index.d.ts.map +1 -0
  13. package/dist/cjs/config/index.js.map +1 -0
  14. package/dist/cjs/consensus/ConsensusEngine.d.ts.map +1 -0
  15. package/dist/cjs/consensus/ConsensusEngine.js.map +1 -0
  16. package/dist/cjs/consensus/ModelPool.d.ts.map +1 -0
  17. package/dist/cjs/consensus/ModelPool.js.map +1 -0
  18. package/dist/cjs/consensus/index.d.ts.map +1 -0
  19. package/dist/cjs/consensus/index.js.map +1 -0
  20. package/dist/cjs/core/AgentRegistry.d.ts.map +1 -0
  21. package/dist/cjs/core/AgentRegistry.js.map +1 -0
  22. package/dist/cjs/core/DashboardBroadcaster.d.ts.map +1 -0
  23. package/dist/cjs/core/DashboardBroadcaster.js.map +1 -0
  24. package/dist/cjs/core/OrchestrationEngine.d.ts.map +1 -0
  25. package/dist/cjs/core/OrchestrationEngine.js.map +1 -0
  26. package/dist/cjs/core/SubconsciousEngine.d.ts.map +1 -0
  27. package/dist/cjs/core/SubconsciousEngine.js.map +1 -0
  28. package/dist/cjs/core/WebSocketServer.d.ts.map +1 -0
  29. package/dist/cjs/core/WebSocketServer.js.map +1 -0
  30. package/dist/cjs/core/index.d.ts.map +1 -0
  31. package/dist/cjs/core/index.js.map +1 -0
  32. package/dist/cjs/core/router.d.ts.map +1 -0
  33. package/dist/cjs/core/router.js.map +1 -0
  34. package/dist/{embed → cjs/embed}/index.d.ts +66 -1
  35. package/dist/cjs/embed/index.d.ts.map +1 -0
  36. package/dist/cjs/embed/index.js +979 -0
  37. package/dist/cjs/embed/index.js.map +1 -0
  38. package/dist/cjs/embed.d.ts.map +1 -0
  39. package/dist/cjs/embed.js.map +1 -0
  40. package/dist/cjs/examples/basic-usage.d.ts +12 -0
  41. package/dist/cjs/examples/basic-usage.d.ts.map +1 -0
  42. package/dist/cjs/examples/basic-usage.js +128 -0
  43. package/dist/cjs/examples/basic-usage.js.map +1 -0
  44. package/dist/cjs/index.d.ts.map +1 -0
  45. package/dist/cjs/index.js.map +1 -0
  46. package/dist/cjs/package.json +3 -0
  47. package/dist/cjs/protocol/flows.d.ts.map +1 -0
  48. package/dist/cjs/protocol/flows.js.map +1 -0
  49. package/dist/cjs/protocol/iap.d.ts.map +1 -0
  50. package/dist/cjs/protocol/iap.js.map +1 -0
  51. package/dist/cjs/protocol/index.d.ts.map +1 -0
  52. package/dist/cjs/protocol/index.js.map +1 -0
  53. package/dist/cjs/protocol/types.d.ts.map +1 -0
  54. package/dist/cjs/protocol/types.js.map +1 -0
  55. package/dist/cjs/protocol/utils.d.ts.map +1 -0
  56. package/dist/cjs/protocol/utils.js.map +1 -0
  57. package/dist/cjs/protocol/validators.d.ts.map +1 -0
  58. package/dist/cjs/protocol/validators.js.map +1 -0
  59. package/dist/cjs/security/AuthManager.d.ts.map +1 -0
  60. package/dist/cjs/security/AuthManager.js.map +1 -0
  61. package/dist/cjs/security/MessageSanitizer.d.ts.map +1 -0
  62. package/dist/cjs/security/MessageSanitizer.js.map +1 -0
  63. package/dist/cjs/security/RateLimiter.d.ts.map +1 -0
  64. package/dist/cjs/security/RateLimiter.js.map +1 -0
  65. package/dist/cjs/security/SecurityMiddleware.d.ts.map +1 -0
  66. package/dist/cjs/security/SecurityMiddleware.js.map +1 -0
  67. package/dist/cjs/security/index.d.ts.map +1 -0
  68. package/dist/cjs/security/index.js.map +1 -0
  69. package/dist/cjs/speculative/PredictionEngine.d.ts.map +1 -0
  70. package/dist/cjs/speculative/PredictionEngine.js.map +1 -0
  71. package/dist/cjs/speculative/SpeculativeCache.d.ts.map +1 -0
  72. package/dist/cjs/speculative/SpeculativeCache.js.map +1 -0
  73. package/dist/cjs/speculative/SpeculativeEngine.d.ts.map +1 -0
  74. package/dist/cjs/speculative/SpeculativeEngine.js.map +1 -0
  75. package/dist/cjs/speculative/WorkerPool.d.ts.map +1 -0
  76. package/dist/cjs/speculative/WorkerPool.js.map +1 -0
  77. package/dist/cjs/speculative/index.d.ts.map +1 -0
  78. package/dist/cjs/speculative/index.js.map +1 -0
  79. package/dist/cjs/subconscious/EmbeddingService.d.ts.map +1 -0
  80. package/dist/cjs/subconscious/EmbeddingService.js.map +1 -0
  81. package/dist/cjs/subconscious/SemanticCache.d.ts.map +1 -0
  82. package/dist/cjs/subconscious/SemanticCache.js.map +1 -0
  83. package/dist/cjs/subconscious/SubconsciousEngine.d.ts.map +1 -0
  84. package/dist/cjs/subconscious/SubconsciousEngine.js.map +1 -0
  85. package/dist/cjs/subconscious/VectorStore.d.ts.map +1 -0
  86. package/dist/cjs/subconscious/VectorStore.js.map +1 -0
  87. package/dist/cjs/subconscious/cache.d.ts.map +1 -0
  88. package/dist/cjs/subconscious/cache.js.map +1 -0
  89. package/dist/cjs/subconscious/embeddings.d.ts.map +1 -0
  90. package/dist/cjs/subconscious/embeddings.js.map +1 -0
  91. package/dist/cjs/subconscious/index.d.ts.map +1 -0
  92. package/dist/cjs/subconscious/index.js.map +1 -0
  93. package/dist/cjs/types/index.d.ts.map +1 -0
  94. package/dist/cjs/types/index.js.map +1 -0
  95. package/dist/cjs/utils/logger.d.ts.map +1 -0
  96. package/dist/cjs/utils/logger.js.map +1 -0
  97. package/dist/esm/cloud/KeyManager.d.ts +29 -0
  98. package/dist/esm/cloud/KeyManager.d.ts.map +1 -0
  99. package/dist/esm/cloud/KeyManager.js +135 -0
  100. package/dist/esm/cloud/KeyManager.js.map +1 -0
  101. package/dist/esm/cloud/TenantCache.d.ts +29 -0
  102. package/dist/esm/cloud/TenantCache.d.ts.map +1 -0
  103. package/dist/esm/cloud/TenantCache.js +125 -0
  104. package/dist/esm/cloud/TenantCache.js.map +1 -0
  105. package/dist/esm/cloud/index.d.ts +4 -0
  106. package/dist/esm/cloud/index.d.ts.map +1 -0
  107. package/dist/esm/cloud/index.js +4 -0
  108. package/dist/esm/cloud/index.js.map +1 -0
  109. package/dist/esm/cloud/server.d.ts +17 -0
  110. package/dist/esm/cloud/server.d.ts.map +1 -0
  111. package/dist/esm/cloud/server.js +181 -0
  112. package/dist/esm/cloud/server.js.map +1 -0
  113. package/dist/esm/cloud/types.d.ts +35 -0
  114. package/dist/esm/cloud/types.d.ts.map +1 -0
  115. package/dist/esm/cloud/types.js +11 -0
  116. package/dist/esm/cloud/types.js.map +1 -0
  117. package/dist/esm/config/index.d.ts +44 -0
  118. package/dist/esm/config/index.d.ts.map +1 -0
  119. package/dist/esm/config/index.js +151 -0
  120. package/dist/esm/config/index.js.map +1 -0
  121. package/dist/esm/consensus/ConsensusEngine.d.ts +119 -0
  122. package/dist/esm/consensus/ConsensusEngine.d.ts.map +1 -0
  123. package/dist/esm/consensus/ConsensusEngine.js +310 -0
  124. package/dist/esm/consensus/ConsensusEngine.js.map +1 -0
  125. package/dist/esm/consensus/ModelPool.d.ts +103 -0
  126. package/dist/esm/consensus/ModelPool.d.ts.map +1 -0
  127. package/dist/esm/consensus/ModelPool.js +269 -0
  128. package/dist/esm/consensus/ModelPool.js.map +1 -0
  129. package/dist/esm/consensus/index.d.ts +8 -0
  130. package/dist/esm/consensus/index.d.ts.map +1 -0
  131. package/dist/esm/consensus/index.js +8 -0
  132. package/dist/esm/consensus/index.js.map +1 -0
  133. package/dist/esm/core/AgentRegistry.d.ts +89 -0
  134. package/dist/esm/core/AgentRegistry.d.ts.map +1 -0
  135. package/dist/esm/core/AgentRegistry.js +260 -0
  136. package/dist/esm/core/AgentRegistry.js.map +1 -0
  137. package/dist/esm/core/DashboardBroadcaster.d.ts +67 -0
  138. package/dist/esm/core/DashboardBroadcaster.d.ts.map +1 -0
  139. package/dist/esm/core/DashboardBroadcaster.js +260 -0
  140. package/dist/esm/core/DashboardBroadcaster.js.map +1 -0
  141. package/dist/esm/core/OrchestrationEngine.d.ts +85 -0
  142. package/dist/esm/core/OrchestrationEngine.d.ts.map +1 -0
  143. package/dist/esm/core/OrchestrationEngine.js +457 -0
  144. package/dist/esm/core/OrchestrationEngine.js.map +1 -0
  145. package/dist/esm/core/SubconsciousEngine.d.ts +53 -0
  146. package/dist/esm/core/SubconsciousEngine.d.ts.map +1 -0
  147. package/dist/esm/core/SubconsciousEngine.js +278 -0
  148. package/dist/esm/core/SubconsciousEngine.js.map +1 -0
  149. package/dist/esm/core/WebSocketServer.d.ts +89 -0
  150. package/dist/esm/core/WebSocketServer.d.ts.map +1 -0
  151. package/dist/esm/core/WebSocketServer.js +380 -0
  152. package/dist/esm/core/WebSocketServer.js.map +1 -0
  153. package/dist/esm/core/index.d.ts +15 -0
  154. package/dist/esm/core/index.d.ts.map +1 -0
  155. package/dist/esm/core/index.js +15 -0
  156. package/dist/esm/core/index.js.map +1 -0
  157. package/dist/esm/core/router.d.ts +105 -0
  158. package/dist/esm/core/router.d.ts.map +1 -0
  159. package/dist/esm/core/router.js +416 -0
  160. package/dist/esm/core/router.js.map +1 -0
  161. package/dist/esm/embed/index.d.ts +218 -0
  162. package/dist/esm/embed/index.d.ts.map +1 -0
  163. package/dist/esm/embed/index.js +939 -0
  164. package/dist/esm/embed/index.js.map +1 -0
  165. package/dist/esm/embed.d.ts +11 -0
  166. package/dist/esm/embed.d.ts.map +1 -0
  167. package/dist/esm/embed.js +11 -0
  168. package/dist/esm/embed.js.map +1 -0
  169. package/dist/esm/examples/basic-usage.d.ts +12 -0
  170. package/dist/esm/examples/basic-usage.d.ts.map +1 -0
  171. package/dist/esm/examples/basic-usage.js +126 -0
  172. package/dist/esm/examples/basic-usage.js.map +1 -0
  173. package/dist/esm/index.d.ts +83 -0
  174. package/dist/esm/index.d.ts.map +1 -0
  175. package/dist/esm/index.js +132 -0
  176. package/dist/esm/index.js.map +1 -0
  177. package/dist/esm/package.json +3 -0
  178. package/dist/esm/protocol/flows.d.ts +126 -0
  179. package/dist/esm/protocol/flows.d.ts.map +1 -0
  180. package/dist/esm/protocol/flows.js +338 -0
  181. package/dist/esm/protocol/flows.js.map +1 -0
  182. package/dist/esm/protocol/iap.d.ts +54 -0
  183. package/dist/esm/protocol/iap.d.ts.map +1 -0
  184. package/dist/esm/protocol/iap.js +104 -0
  185. package/dist/esm/protocol/iap.js.map +1 -0
  186. package/dist/esm/protocol/index.d.ts +23 -0
  187. package/dist/esm/protocol/index.d.ts.map +1 -0
  188. package/dist/esm/protocol/index.js +28 -0
  189. package/dist/esm/protocol/index.js.map +1 -0
  190. package/dist/esm/protocol/types.d.ts +332 -0
  191. package/dist/esm/protocol/types.d.ts.map +1 -0
  192. package/dist/esm/protocol/types.js +54 -0
  193. package/dist/esm/protocol/types.js.map +1 -0
  194. package/dist/esm/protocol/utils.d.ts +130 -0
  195. package/dist/esm/protocol/utils.d.ts.map +1 -0
  196. package/dist/esm/protocol/utils.js +260 -0
  197. package/dist/esm/protocol/utils.js.map +1 -0
  198. package/dist/esm/protocol/validators.d.ts +54 -0
  199. package/dist/esm/protocol/validators.d.ts.map +1 -0
  200. package/dist/esm/protocol/validators.js +332 -0
  201. package/dist/esm/protocol/validators.js.map +1 -0
  202. package/dist/esm/security/AuthManager.d.ts +73 -0
  203. package/dist/esm/security/AuthManager.d.ts.map +1 -0
  204. package/dist/esm/security/AuthManager.js +95 -0
  205. package/dist/esm/security/AuthManager.js.map +1 -0
  206. package/dist/esm/security/MessageSanitizer.d.ts +51 -0
  207. package/dist/esm/security/MessageSanitizer.d.ts.map +1 -0
  208. package/dist/esm/security/MessageSanitizer.js +178 -0
  209. package/dist/esm/security/MessageSanitizer.js.map +1 -0
  210. package/dist/esm/security/RateLimiter.d.ts +46 -0
  211. package/dist/esm/security/RateLimiter.d.ts.map +1 -0
  212. package/dist/esm/security/RateLimiter.js +129 -0
  213. package/dist/esm/security/RateLimiter.js.map +1 -0
  214. package/dist/esm/security/SecurityMiddleware.d.ts +90 -0
  215. package/dist/esm/security/SecurityMiddleware.d.ts.map +1 -0
  216. package/dist/esm/security/SecurityMiddleware.js +144 -0
  217. package/dist/esm/security/SecurityMiddleware.js.map +1 -0
  218. package/dist/esm/security/index.d.ts +35 -0
  219. package/dist/esm/security/index.d.ts.map +1 -0
  220. package/dist/esm/security/index.js +35 -0
  221. package/dist/esm/security/index.js.map +1 -0
  222. package/dist/esm/speculative/PredictionEngine.d.ts +99 -0
  223. package/dist/esm/speculative/PredictionEngine.d.ts.map +1 -0
  224. package/dist/esm/speculative/PredictionEngine.js +284 -0
  225. package/dist/esm/speculative/PredictionEngine.js.map +1 -0
  226. package/dist/esm/speculative/SpeculativeCache.d.ts +117 -0
  227. package/dist/esm/speculative/SpeculativeCache.d.ts.map +1 -0
  228. package/dist/esm/speculative/SpeculativeCache.js +288 -0
  229. package/dist/esm/speculative/SpeculativeCache.js.map +1 -0
  230. package/dist/esm/speculative/SpeculativeEngine.d.ts +114 -0
  231. package/dist/esm/speculative/SpeculativeEngine.d.ts.map +1 -0
  232. package/dist/esm/speculative/SpeculativeEngine.js +240 -0
  233. package/dist/esm/speculative/SpeculativeEngine.js.map +1 -0
  234. package/dist/esm/speculative/WorkerPool.d.ts +109 -0
  235. package/dist/esm/speculative/WorkerPool.d.ts.map +1 -0
  236. package/dist/esm/speculative/WorkerPool.js +323 -0
  237. package/dist/esm/speculative/WorkerPool.js.map +1 -0
  238. package/dist/esm/speculative/index.d.ts +10 -0
  239. package/dist/esm/speculative/index.d.ts.map +1 -0
  240. package/dist/esm/speculative/index.js +10 -0
  241. package/dist/esm/speculative/index.js.map +1 -0
  242. package/dist/esm/subconscious/EmbeddingService.d.ts +73 -0
  243. package/dist/esm/subconscious/EmbeddingService.d.ts.map +1 -0
  244. package/dist/esm/subconscious/EmbeddingService.js +189 -0
  245. package/dist/esm/subconscious/EmbeddingService.js.map +1 -0
  246. package/dist/esm/subconscious/SemanticCache.d.ts +82 -0
  247. package/dist/esm/subconscious/SemanticCache.d.ts.map +1 -0
  248. package/dist/esm/subconscious/SemanticCache.js +160 -0
  249. package/dist/esm/subconscious/SemanticCache.js.map +1 -0
  250. package/dist/esm/subconscious/SubconsciousEngine.d.ts +121 -0
  251. package/dist/esm/subconscious/SubconsciousEngine.d.ts.map +1 -0
  252. package/dist/esm/subconscious/SubconsciousEngine.js +237 -0
  253. package/dist/esm/subconscious/SubconsciousEngine.js.map +1 -0
  254. package/dist/esm/subconscious/VectorStore.d.ts +54 -0
  255. package/dist/esm/subconscious/VectorStore.d.ts.map +1 -0
  256. package/dist/esm/subconscious/VectorStore.js +164 -0
  257. package/dist/esm/subconscious/VectorStore.js.map +1 -0
  258. package/dist/esm/subconscious/cache.d.ts +34 -0
  259. package/dist/esm/subconscious/cache.d.ts.map +1 -0
  260. package/dist/esm/subconscious/cache.js +152 -0
  261. package/dist/{subconscious → esm/subconscious}/cache.js.map +1 -1
  262. package/dist/esm/subconscious/embeddings.d.ts +25 -0
  263. package/dist/esm/subconscious/embeddings.d.ts.map +1 -0
  264. package/dist/esm/subconscious/embeddings.js +58 -0
  265. package/dist/esm/subconscious/embeddings.js.map +1 -0
  266. package/dist/esm/subconscious/index.d.ts +12 -0
  267. package/dist/esm/subconscious/index.d.ts.map +1 -0
  268. package/dist/esm/subconscious/index.js +12 -0
  269. package/dist/esm/subconscious/index.js.map +1 -0
  270. package/dist/esm/types/index.d.ts +286 -0
  271. package/dist/esm/types/index.d.ts.map +1 -0
  272. package/dist/esm/types/index.js +40 -0
  273. package/dist/esm/types/index.js.map +1 -0
  274. package/dist/esm/utils/logger.d.ts +63 -0
  275. package/dist/esm/utils/logger.d.ts.map +1 -0
  276. package/dist/esm/utils/logger.js +122 -0
  277. package/dist/esm/utils/logger.js.map +1 -0
  278. package/package.json +74 -12
  279. package/dist/cloud/KeyManager.d.ts.map +0 -1
  280. package/dist/cloud/KeyManager.js.map +0 -1
  281. package/dist/cloud/TenantCache.d.ts.map +0 -1
  282. package/dist/cloud/TenantCache.js.map +0 -1
  283. package/dist/cloud/index.d.ts.map +0 -1
  284. package/dist/cloud/index.js.map +0 -1
  285. package/dist/cloud/server.d.ts.map +0 -1
  286. package/dist/cloud/server.js.map +0 -1
  287. package/dist/cloud/types.d.ts.map +0 -1
  288. package/dist/cloud/types.js.map +0 -1
  289. package/dist/config/index.d.ts.map +0 -1
  290. package/dist/config/index.js.map +0 -1
  291. package/dist/consensus/ConsensusEngine.d.ts.map +0 -1
  292. package/dist/consensus/ConsensusEngine.js.map +0 -1
  293. package/dist/consensus/ModelPool.d.ts.map +0 -1
  294. package/dist/consensus/ModelPool.js.map +0 -1
  295. package/dist/consensus/index.d.ts.map +0 -1
  296. package/dist/consensus/index.js.map +0 -1
  297. package/dist/core/AgentRegistry.d.ts.map +0 -1
  298. package/dist/core/AgentRegistry.js.map +0 -1
  299. package/dist/core/DashboardBroadcaster.d.ts.map +0 -1
  300. package/dist/core/DashboardBroadcaster.js.map +0 -1
  301. package/dist/core/OrchestrationEngine.d.ts.map +0 -1
  302. package/dist/core/OrchestrationEngine.js.map +0 -1
  303. package/dist/core/SubconsciousEngine.d.ts.map +0 -1
  304. package/dist/core/SubconsciousEngine.js.map +0 -1
  305. package/dist/core/WebSocketServer.d.ts.map +0 -1
  306. package/dist/core/WebSocketServer.js.map +0 -1
  307. package/dist/core/index.d.ts.map +0 -1
  308. package/dist/core/index.js.map +0 -1
  309. package/dist/core/router.d.ts.map +0 -1
  310. package/dist/core/router.js.map +0 -1
  311. package/dist/embed/index.d.ts.map +0 -1
  312. package/dist/embed/index.js +0 -408
  313. package/dist/embed/index.js.map +0 -1
  314. package/dist/embed.d.ts.map +0 -1
  315. package/dist/embed.js.map +0 -1
  316. package/dist/index.d.ts.map +0 -1
  317. package/dist/index.js.map +0 -1
  318. package/dist/protocol/flows.d.ts.map +0 -1
  319. package/dist/protocol/flows.js.map +0 -1
  320. package/dist/protocol/iap.d.ts.map +0 -1
  321. package/dist/protocol/iap.js.map +0 -1
  322. package/dist/protocol/index.d.ts.map +0 -1
  323. package/dist/protocol/index.js.map +0 -1
  324. package/dist/protocol/types.d.ts.map +0 -1
  325. package/dist/protocol/types.js.map +0 -1
  326. package/dist/protocol/utils.d.ts.map +0 -1
  327. package/dist/protocol/utils.js.map +0 -1
  328. package/dist/protocol/validators.d.ts.map +0 -1
  329. package/dist/protocol/validators.js.map +0 -1
  330. package/dist/security/AuthManager.d.ts.map +0 -1
  331. package/dist/security/AuthManager.js.map +0 -1
  332. package/dist/security/MessageSanitizer.d.ts.map +0 -1
  333. package/dist/security/MessageSanitizer.js.map +0 -1
  334. package/dist/security/RateLimiter.d.ts.map +0 -1
  335. package/dist/security/RateLimiter.js.map +0 -1
  336. package/dist/security/SecurityMiddleware.d.ts.map +0 -1
  337. package/dist/security/SecurityMiddleware.js.map +0 -1
  338. package/dist/security/index.d.ts.map +0 -1
  339. package/dist/security/index.js.map +0 -1
  340. package/dist/speculative/PredictionEngine.d.ts.map +0 -1
  341. package/dist/speculative/PredictionEngine.js.map +0 -1
  342. package/dist/speculative/SpeculativeCache.d.ts.map +0 -1
  343. package/dist/speculative/SpeculativeCache.js.map +0 -1
  344. package/dist/speculative/SpeculativeEngine.d.ts.map +0 -1
  345. package/dist/speculative/SpeculativeEngine.js.map +0 -1
  346. package/dist/speculative/WorkerPool.d.ts.map +0 -1
  347. package/dist/speculative/WorkerPool.js.map +0 -1
  348. package/dist/speculative/index.d.ts.map +0 -1
  349. package/dist/speculative/index.js.map +0 -1
  350. package/dist/subconscious/EmbeddingService.d.ts.map +0 -1
  351. package/dist/subconscious/EmbeddingService.js.map +0 -1
  352. package/dist/subconscious/SemanticCache.d.ts.map +0 -1
  353. package/dist/subconscious/SemanticCache.js.map +0 -1
  354. package/dist/subconscious/SubconsciousEngine.d.ts.map +0 -1
  355. package/dist/subconscious/SubconsciousEngine.js.map +0 -1
  356. package/dist/subconscious/VectorStore.d.ts.map +0 -1
  357. package/dist/subconscious/VectorStore.js.map +0 -1
  358. package/dist/subconscious/cache.d.ts.map +0 -1
  359. package/dist/subconscious/embeddings.d.ts.map +0 -1
  360. package/dist/subconscious/embeddings.js.map +0 -1
  361. package/dist/subconscious/index.d.ts.map +0 -1
  362. package/dist/subconscious/index.js.map +0 -1
  363. package/dist/types/index.d.ts.map +0 -1
  364. package/dist/types/index.js.map +0 -1
  365. package/dist/utils/logger.d.ts.map +0 -1
  366. package/dist/utils/logger.js.map +0 -1
  367. /package/dist/{cloud → cjs/cloud}/KeyManager.d.ts +0 -0
  368. /package/dist/{cloud → cjs/cloud}/KeyManager.js +0 -0
  369. /package/dist/{cloud → cjs/cloud}/TenantCache.d.ts +0 -0
  370. /package/dist/{cloud → cjs/cloud}/TenantCache.js +0 -0
  371. /package/dist/{cloud → cjs/cloud}/index.d.ts +0 -0
  372. /package/dist/{cloud → cjs/cloud}/index.js +0 -0
  373. /package/dist/{cloud → cjs/cloud}/server.d.ts +0 -0
  374. /package/dist/{cloud → cjs/cloud}/server.js +0 -0
  375. /package/dist/{cloud → cjs/cloud}/types.d.ts +0 -0
  376. /package/dist/{cloud → cjs/cloud}/types.js +0 -0
  377. /package/dist/{config → cjs/config}/index.d.ts +0 -0
  378. /package/dist/{config → cjs/config}/index.js +0 -0
  379. /package/dist/{consensus → cjs/consensus}/ConsensusEngine.d.ts +0 -0
  380. /package/dist/{consensus → cjs/consensus}/ConsensusEngine.js +0 -0
  381. /package/dist/{consensus → cjs/consensus}/ModelPool.d.ts +0 -0
  382. /package/dist/{consensus → cjs/consensus}/ModelPool.js +0 -0
  383. /package/dist/{consensus → cjs/consensus}/index.d.ts +0 -0
  384. /package/dist/{consensus → cjs/consensus}/index.js +0 -0
  385. /package/dist/{core → cjs/core}/AgentRegistry.d.ts +0 -0
  386. /package/dist/{core → cjs/core}/AgentRegistry.js +0 -0
  387. /package/dist/{core → cjs/core}/DashboardBroadcaster.d.ts +0 -0
  388. /package/dist/{core → cjs/core}/DashboardBroadcaster.js +0 -0
  389. /package/dist/{core → cjs/core}/OrchestrationEngine.d.ts +0 -0
  390. /package/dist/{core → cjs/core}/OrchestrationEngine.js +0 -0
  391. /package/dist/{core → cjs/core}/SubconsciousEngine.d.ts +0 -0
  392. /package/dist/{core → cjs/core}/SubconsciousEngine.js +0 -0
  393. /package/dist/{core → cjs/core}/WebSocketServer.d.ts +0 -0
  394. /package/dist/{core → cjs/core}/WebSocketServer.js +0 -0
  395. /package/dist/{core → cjs/core}/index.d.ts +0 -0
  396. /package/dist/{core → cjs/core}/index.js +0 -0
  397. /package/dist/{core → cjs/core}/router.d.ts +0 -0
  398. /package/dist/{core → cjs/core}/router.js +0 -0
  399. /package/dist/{embed.d.ts → cjs/embed.d.ts} +0 -0
  400. /package/dist/{embed.js → cjs/embed.js} +0 -0
  401. /package/dist/{index.d.ts → cjs/index.d.ts} +0 -0
  402. /package/dist/{index.js → cjs/index.js} +0 -0
  403. /package/dist/{protocol → cjs/protocol}/flows.d.ts +0 -0
  404. /package/dist/{protocol → cjs/protocol}/flows.js +0 -0
  405. /package/dist/{protocol → cjs/protocol}/iap.d.ts +0 -0
  406. /package/dist/{protocol → cjs/protocol}/iap.js +0 -0
  407. /package/dist/{protocol → cjs/protocol}/index.d.ts +0 -0
  408. /package/dist/{protocol → cjs/protocol}/index.js +0 -0
  409. /package/dist/{protocol → cjs/protocol}/types.d.ts +0 -0
  410. /package/dist/{protocol → cjs/protocol}/types.js +0 -0
  411. /package/dist/{protocol → cjs/protocol}/utils.d.ts +0 -0
  412. /package/dist/{protocol → cjs/protocol}/utils.js +0 -0
  413. /package/dist/{protocol → cjs/protocol}/validators.d.ts +0 -0
  414. /package/dist/{protocol → cjs/protocol}/validators.js +0 -0
  415. /package/dist/{security → cjs/security}/AuthManager.d.ts +0 -0
  416. /package/dist/{security → cjs/security}/AuthManager.js +0 -0
  417. /package/dist/{security → cjs/security}/MessageSanitizer.d.ts +0 -0
  418. /package/dist/{security → cjs/security}/MessageSanitizer.js +0 -0
  419. /package/dist/{security → cjs/security}/RateLimiter.d.ts +0 -0
  420. /package/dist/{security → cjs/security}/RateLimiter.js +0 -0
  421. /package/dist/{security → cjs/security}/SecurityMiddleware.d.ts +0 -0
  422. /package/dist/{security → cjs/security}/SecurityMiddleware.js +0 -0
  423. /package/dist/{security → cjs/security}/index.d.ts +0 -0
  424. /package/dist/{security → cjs/security}/index.js +0 -0
  425. /package/dist/{speculative → cjs/speculative}/PredictionEngine.d.ts +0 -0
  426. /package/dist/{speculative → cjs/speculative}/PredictionEngine.js +0 -0
  427. /package/dist/{speculative → cjs/speculative}/SpeculativeCache.d.ts +0 -0
  428. /package/dist/{speculative → cjs/speculative}/SpeculativeCache.js +0 -0
  429. /package/dist/{speculative → cjs/speculative}/SpeculativeEngine.d.ts +0 -0
  430. /package/dist/{speculative → cjs/speculative}/SpeculativeEngine.js +0 -0
  431. /package/dist/{speculative → cjs/speculative}/WorkerPool.d.ts +0 -0
  432. /package/dist/{speculative → cjs/speculative}/WorkerPool.js +0 -0
  433. /package/dist/{speculative → cjs/speculative}/index.d.ts +0 -0
  434. /package/dist/{speculative → cjs/speculative}/index.js +0 -0
  435. /package/dist/{subconscious → cjs/subconscious}/EmbeddingService.d.ts +0 -0
  436. /package/dist/{subconscious → cjs/subconscious}/EmbeddingService.js +0 -0
  437. /package/dist/{subconscious → cjs/subconscious}/SemanticCache.d.ts +0 -0
  438. /package/dist/{subconscious → cjs/subconscious}/SemanticCache.js +0 -0
  439. /package/dist/{subconscious → cjs/subconscious}/SubconsciousEngine.d.ts +0 -0
  440. /package/dist/{subconscious → cjs/subconscious}/SubconsciousEngine.js +0 -0
  441. /package/dist/{subconscious → cjs/subconscious}/VectorStore.d.ts +0 -0
  442. /package/dist/{subconscious → cjs/subconscious}/VectorStore.js +0 -0
  443. /package/dist/{subconscious → cjs/subconscious}/cache.d.ts +0 -0
  444. /package/dist/{subconscious → cjs/subconscious}/cache.js +0 -0
  445. /package/dist/{subconscious → cjs/subconscious}/embeddings.d.ts +0 -0
  446. /package/dist/{subconscious → cjs/subconscious}/embeddings.js +0 -0
  447. /package/dist/{subconscious → cjs/subconscious}/index.d.ts +0 -0
  448. /package/dist/{subconscious → cjs/subconscious}/index.js +0 -0
  449. /package/dist/{types → cjs/types}/index.d.ts +0 -0
  450. /package/dist/{types → cjs/types}/index.js +0 -0
  451. /package/dist/{utils → cjs/utils}/logger.d.ts +0 -0
  452. /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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"}