beddel 0.2.3 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (542) hide show
  1. package/README.md +138 -595
  2. package/dist/client.d.ts +10 -0
  3. package/dist/client.d.ts.map +1 -0
  4. package/dist/client.js +9 -0
  5. package/dist/core/parser.d.ts +25 -0
  6. package/dist/core/parser.d.ts.map +1 -0
  7. package/dist/core/parser.js +31 -0
  8. package/dist/core/variable-resolver.d.ts +23 -0
  9. package/dist/core/variable-resolver.d.ts.map +1 -0
  10. package/dist/core/variable-resolver.js +98 -0
  11. package/dist/core/workflow.d.ts +39 -0
  12. package/dist/core/workflow.d.ts.map +1 -0
  13. package/dist/core/workflow.js +64 -0
  14. package/dist/index.d.ts +14 -36
  15. package/dist/index.d.ts.map +1 -1
  16. package/dist/index.js +15 -130
  17. package/dist/primitives/index.d.ts +37 -0
  18. package/dist/primitives/index.d.ts.map +1 -0
  19. package/dist/primitives/index.js +72 -0
  20. package/dist/primitives/llm.d.ts +56 -0
  21. package/dist/primitives/llm.d.ts.map +1 -0
  22. package/dist/primitives/llm.js +156 -0
  23. package/dist/primitives/output.d.ts +28 -0
  24. package/dist/primitives/output.d.ts.map +1 -0
  25. package/dist/primitives/output.js +39 -0
  26. package/dist/server/handler.d.ts +7 -0
  27. package/dist/server/handler.d.ts.map +1 -0
  28. package/dist/server/handler.js +55 -0
  29. package/dist/server.d.ts +10 -0
  30. package/dist/server.d.ts.map +1 -0
  31. package/dist/server.js +9 -0
  32. package/dist/tools/index.d.ts +49 -0
  33. package/dist/tools/index.d.ts.map +1 -0
  34. package/dist/tools/index.js +96 -0
  35. package/dist/types/index.d.ts +54 -0
  36. package/dist/types/index.d.ts.map +1 -0
  37. package/dist/types/index.js +5 -0
  38. package/docs/architecture/api-reference.md +307 -0
  39. package/docs/architecture/components.md +246 -0
  40. package/docs/architecture/core-workflows.md +236 -0
  41. package/docs/architecture/high-level-architecture.md +76 -0
  42. package/docs/architecture/index.md +31 -0
  43. package/docs/architecture/source-tree.md +92 -0
  44. package/docs/architecture/tech-stack.md +25 -0
  45. package/docs/prd/epic-list.md +101 -0
  46. package/docs/prd/goals-context.md +23 -0
  47. package/docs/prd/index.md +21 -0
  48. package/docs/prd/requirements.md +25 -0
  49. package/docs/prd/technical-assumptions.md +35 -0
  50. package/package.json +31 -118
  51. package/src/client.ts +18 -0
  52. package/src/core/parser.ts +36 -0
  53. package/src/core/variable-resolver.ts +114 -0
  54. package/src/core/workflow.ts +77 -0
  55. package/src/index.ts +25 -159
  56. package/src/primitives/index.ts +83 -0
  57. package/src/primitives/llm.ts +210 -0
  58. package/src/primitives/output.ts +65 -0
  59. package/src/server/handler.ts +80 -0
  60. package/src/server.ts +10 -0
  61. package/src/tools/index.ts +118 -0
  62. package/src/types/index.ts +62 -0
  63. package/tsconfig.json +27 -0
  64. package/CHANGELOG.md +0 -78
  65. package/LICENSE +0 -21
  66. package/dist/agents/chat/chat.handler.d.ts +0 -12
  67. package/dist/agents/chat/chat.handler.d.ts.map +0 -1
  68. package/dist/agents/chat/chat.handler.js +0 -143
  69. package/dist/agents/chat/chat.handler.js.map +0 -1
  70. package/dist/agents/chat/chat.schema.d.ts +0 -38
  71. package/dist/agents/chat/chat.schema.d.ts.map +0 -1
  72. package/dist/agents/chat/chat.schema.js +0 -31
  73. package/dist/agents/chat/chat.schema.js.map +0 -1
  74. package/dist/agents/chat/chat.types.d.ts +0 -42
  75. package/dist/agents/chat/chat.types.d.ts.map +0 -1
  76. package/dist/agents/chat/chat.types.js +0 -6
  77. package/dist/agents/chat/chat.types.js.map +0 -1
  78. package/dist/agents/chat/chat.yaml +0 -150
  79. package/dist/agents/chat/index.d.ts +0 -16
  80. package/dist/agents/chat/index.d.ts.map +0 -1
  81. package/dist/agents/chat/index.js +0 -21
  82. package/dist/agents/chat/index.js.map +0 -1
  83. package/dist/agents/chromadb/chromadb.handler.d.ts +0 -12
  84. package/dist/agents/chromadb/chromadb.handler.d.ts.map +0 -1
  85. package/dist/agents/chromadb/chromadb.handler.js +0 -139
  86. package/dist/agents/chromadb/chromadb.handler.js.map +0 -1
  87. package/dist/agents/chromadb/chromadb.schema.d.ts +0 -36
  88. package/dist/agents/chromadb/chromadb.schema.d.ts.map +0 -1
  89. package/dist/agents/chromadb/chromadb.schema.js +0 -33
  90. package/dist/agents/chromadb/chromadb.schema.js.map +0 -1
  91. package/dist/agents/chromadb/chromadb.types.d.ts +0 -49
  92. package/dist/agents/chromadb/chromadb.types.d.ts.map +0 -1
  93. package/dist/agents/chromadb/chromadb.types.js +0 -6
  94. package/dist/agents/chromadb/chromadb.types.js.map +0 -1
  95. package/dist/agents/chromadb/chromadb.yaml +0 -128
  96. package/dist/agents/chromadb/index.d.ts +0 -15
  97. package/dist/agents/chromadb/index.d.ts.map +0 -1
  98. package/dist/agents/chromadb/index.js +0 -20
  99. package/dist/agents/chromadb/index.js.map +0 -1
  100. package/dist/agents/gemini-vectorize/gemini-vectorize.handler.d.ts +0 -8
  101. package/dist/agents/gemini-vectorize/gemini-vectorize.handler.d.ts.map +0 -1
  102. package/dist/agents/gemini-vectorize/gemini-vectorize.handler.js +0 -58
  103. package/dist/agents/gemini-vectorize/gemini-vectorize.handler.js.map +0 -1
  104. package/dist/agents/gemini-vectorize/gemini-vectorize.schema.d.ts +0 -22
  105. package/dist/agents/gemini-vectorize/gemini-vectorize.schema.d.ts.map +0 -1
  106. package/dist/agents/gemini-vectorize/gemini-vectorize.schema.js +0 -20
  107. package/dist/agents/gemini-vectorize/gemini-vectorize.schema.js.map +0 -1
  108. package/dist/agents/gemini-vectorize/gemini-vectorize.types.d.ts +0 -32
  109. package/dist/agents/gemini-vectorize/gemini-vectorize.types.d.ts.map +0 -1
  110. package/dist/agents/gemini-vectorize/gemini-vectorize.types.js +0 -6
  111. package/dist/agents/gemini-vectorize/gemini-vectorize.types.js.map +0 -1
  112. package/dist/agents/gemini-vectorize/gemini-vectorize.yaml +0 -84
  113. package/dist/agents/gemini-vectorize/index.d.ts +0 -15
  114. package/dist/agents/gemini-vectorize/index.d.ts.map +0 -1
  115. package/dist/agents/gemini-vectorize/index.js +0 -20
  116. package/dist/agents/gemini-vectorize/index.js.map +0 -1
  117. package/dist/agents/gitmcp/gitmcp.handler.d.ts +0 -12
  118. package/dist/agents/gitmcp/gitmcp.handler.d.ts.map +0 -1
  119. package/dist/agents/gitmcp/gitmcp.handler.js +0 -95
  120. package/dist/agents/gitmcp/gitmcp.handler.js.map +0 -1
  121. package/dist/agents/gitmcp/gitmcp.schema.d.ts +0 -17
  122. package/dist/agents/gitmcp/gitmcp.schema.d.ts.map +0 -1
  123. package/dist/agents/gitmcp/gitmcp.schema.js +0 -18
  124. package/dist/agents/gitmcp/gitmcp.schema.js.map +0 -1
  125. package/dist/agents/gitmcp/gitmcp.types.d.ts +0 -31
  126. package/dist/agents/gitmcp/gitmcp.types.d.ts.map +0 -1
  127. package/dist/agents/gitmcp/gitmcp.types.js +0 -6
  128. package/dist/agents/gitmcp/gitmcp.types.js.map +0 -1
  129. package/dist/agents/gitmcp/gitmcp.yaml +0 -71
  130. package/dist/agents/gitmcp/index.d.ts +0 -16
  131. package/dist/agents/gitmcp/index.d.ts.map +0 -1
  132. package/dist/agents/gitmcp/index.js +0 -21
  133. package/dist/agents/gitmcp/index.js.map +0 -1
  134. package/dist/agents/image/image.handler.d.ts +0 -8
  135. package/dist/agents/image/image.handler.d.ts.map +0 -1
  136. package/dist/agents/image/image.handler.js +0 -66
  137. package/dist/agents/image/image.handler.js.map +0 -1
  138. package/dist/agents/image/image.schema.d.ts +0 -29
  139. package/dist/agents/image/image.schema.d.ts.map +0 -1
  140. package/dist/agents/image/image.schema.js +0 -26
  141. package/dist/agents/image/image.schema.js.map +0 -1
  142. package/dist/agents/image/image.types.d.ts +0 -42
  143. package/dist/agents/image/image.types.d.ts.map +0 -1
  144. package/dist/agents/image/image.types.js +0 -6
  145. package/dist/agents/image/image.types.js.map +0 -1
  146. package/dist/agents/image/image.yaml +0 -86
  147. package/dist/agents/image/index.d.ts +0 -14
  148. package/dist/agents/image/index.d.ts.map +0 -1
  149. package/dist/agents/image/index.js +0 -19
  150. package/dist/agents/image/index.js.map +0 -1
  151. package/dist/agents/index.d.ts +0 -95
  152. package/dist/agents/index.d.ts.map +0 -1
  153. package/dist/agents/index.js +0 -76
  154. package/dist/agents/index.js.map +0 -1
  155. package/dist/agents/joker/index.d.ts +0 -14
  156. package/dist/agents/joker/index.d.ts.map +0 -1
  157. package/dist/agents/joker/index.js +0 -19
  158. package/dist/agents/joker/index.js.map +0 -1
  159. package/dist/agents/joker/joker.handler.d.ts +0 -8
  160. package/dist/agents/joker/joker.handler.d.ts.map +0 -1
  161. package/dist/agents/joker/joker.handler.js +0 -48
  162. package/dist/agents/joker/joker.handler.js.map +0 -1
  163. package/dist/agents/joker/joker.schema.d.ts +0 -12
  164. package/dist/agents/joker/joker.schema.d.ts.map +0 -1
  165. package/dist/agents/joker/joker.schema.js +0 -13
  166. package/dist/agents/joker/joker.schema.js.map +0 -1
  167. package/dist/agents/joker/joker.types.d.ts +0 -35
  168. package/dist/agents/joker/joker.types.d.ts.map +0 -1
  169. package/dist/agents/joker/joker.types.js +0 -6
  170. package/dist/agents/joker/joker.types.js.map +0 -1
  171. package/dist/agents/joker/joker.yaml +0 -47
  172. package/dist/agents/mcp-tool/index.d.ts +0 -14
  173. package/dist/agents/mcp-tool/index.d.ts.map +0 -1
  174. package/dist/agents/mcp-tool/index.js +0 -19
  175. package/dist/agents/mcp-tool/index.js.map +0 -1
  176. package/dist/agents/mcp-tool/mcp-tool.handler.d.ts +0 -12
  177. package/dist/agents/mcp-tool/mcp-tool.handler.d.ts.map +0 -1
  178. package/dist/agents/mcp-tool/mcp-tool.handler.js +0 -116
  179. package/dist/agents/mcp-tool/mcp-tool.handler.js.map +0 -1
  180. package/dist/agents/mcp-tool/mcp-tool.schema.d.ts +0 -19
  181. package/dist/agents/mcp-tool/mcp-tool.schema.d.ts.map +0 -1
  182. package/dist/agents/mcp-tool/mcp-tool.schema.js +0 -20
  183. package/dist/agents/mcp-tool/mcp-tool.schema.js.map +0 -1
  184. package/dist/agents/mcp-tool/mcp-tool.types.d.ts +0 -31
  185. package/dist/agents/mcp-tool/mcp-tool.types.d.ts.map +0 -1
  186. package/dist/agents/mcp-tool/mcp-tool.types.js +0 -6
  187. package/dist/agents/mcp-tool/mcp-tool.types.js.map +0 -1
  188. package/dist/agents/mcp-tool/mcp-tool.yaml +0 -71
  189. package/dist/agents/rag/index.d.ts +0 -15
  190. package/dist/agents/rag/index.d.ts.map +0 -1
  191. package/dist/agents/rag/index.js +0 -20
  192. package/dist/agents/rag/index.js.map +0 -1
  193. package/dist/agents/rag/rag.handler.d.ts +0 -8
  194. package/dist/agents/rag/rag.handler.d.ts.map +0 -1
  195. package/dist/agents/rag/rag.handler.js +0 -101
  196. package/dist/agents/rag/rag.handler.js.map +0 -1
  197. package/dist/agents/rag/rag.schema.d.ts +0 -27
  198. package/dist/agents/rag/rag.schema.d.ts.map +0 -1
  199. package/dist/agents/rag/rag.schema.js +0 -24
  200. package/dist/agents/rag/rag.schema.js.map +0 -1
  201. package/dist/agents/rag/rag.types.d.ts +0 -47
  202. package/dist/agents/rag/rag.types.d.ts.map +0 -1
  203. package/dist/agents/rag/rag.types.js +0 -6
  204. package/dist/agents/rag/rag.types.js.map +0 -1
  205. package/dist/agents/rag/rag.yaml +0 -89
  206. package/dist/agents/registry/agentRegistry.d.ts +0 -117
  207. package/dist/agents/registry/agentRegistry.d.ts.map +0 -1
  208. package/dist/agents/registry/agentRegistry.js +0 -551
  209. package/dist/agents/registry/agentRegistry.js.map +0 -1
  210. package/dist/agents/registry/index.d.ts +0 -6
  211. package/dist/agents/registry/index.d.ts.map +0 -1
  212. package/dist/agents/registry/index.js +0 -10
  213. package/dist/agents/registry/index.js.map +0 -1
  214. package/dist/agents/translator/index.d.ts +0 -14
  215. package/dist/agents/translator/index.d.ts.map +0 -1
  216. package/dist/agents/translator/index.js +0 -19
  217. package/dist/agents/translator/index.js.map +0 -1
  218. package/dist/agents/translator/translator.handler.d.ts +0 -8
  219. package/dist/agents/translator/translator.handler.d.ts.map +0 -1
  220. package/dist/agents/translator/translator.handler.js +0 -83
  221. package/dist/agents/translator/translator.handler.js.map +0 -1
  222. package/dist/agents/translator/translator.schema.d.ts +0 -27
  223. package/dist/agents/translator/translator.schema.d.ts.map +0 -1
  224. package/dist/agents/translator/translator.schema.js +0 -28
  225. package/dist/agents/translator/translator.schema.js.map +0 -1
  226. package/dist/agents/translator/translator.types.d.ts +0 -40
  227. package/dist/agents/translator/translator.types.d.ts.map +0 -1
  228. package/dist/agents/translator/translator.types.js +0 -6
  229. package/dist/agents/translator/translator.types.js.map +0 -1
  230. package/dist/agents/translator/translator.yaml +0 -80
  231. package/dist/audit/auditTrail.d.ts +0 -55
  232. package/dist/audit/auditTrail.d.ts.map +0 -1
  233. package/dist/audit/auditTrail.js +0 -93
  234. package/dist/audit/auditTrail.js.map +0 -1
  235. package/dist/client/index.d.ts +0 -89
  236. package/dist/client/index.d.ts.map +0 -1
  237. package/dist/client/index.js +0 -93
  238. package/dist/client/index.js.map +0 -1
  239. package/dist/client/types.d.ts +0 -17
  240. package/dist/client/types.d.ts.map +0 -1
  241. package/dist/client/types.js +0 -7
  242. package/dist/client/types.js.map +0 -1
  243. package/dist/compliance/gdprEngine.d.ts +0 -44
  244. package/dist/compliance/gdprEngine.d.ts.map +0 -1
  245. package/dist/compliance/gdprEngine.js +0 -178
  246. package/dist/compliance/gdprEngine.js.map +0 -1
  247. package/dist/compliance/lgpdEngine.d.ts +0 -51
  248. package/dist/compliance/lgpdEngine.d.ts.map +0 -1
  249. package/dist/compliance/lgpdEngine.js +0 -221
  250. package/dist/compliance/lgpdEngine.js.map +0 -1
  251. package/dist/config.d.ts +0 -78
  252. package/dist/config.d.ts.map +0 -1
  253. package/dist/config.js +0 -77
  254. package/dist/config.js.map +0 -1
  255. package/dist/errors.d.ts +0 -17
  256. package/dist/errors.d.ts.map +0 -1
  257. package/dist/errors.js +0 -40
  258. package/dist/errors.js.map +0 -1
  259. package/dist/firebase/tenantManager.d.ts +0 -116
  260. package/dist/firebase/tenantManager.d.ts.map +0 -1
  261. package/dist/firebase/tenantManager.js +0 -444
  262. package/dist/firebase/tenantManager.js.map +0 -1
  263. package/dist/index.js.map +0 -1
  264. package/dist/integration/secure-yaml-runtime.d.ts +0 -68
  265. package/dist/integration/secure-yaml-runtime.d.ts.map +0 -1
  266. package/dist/integration/secure-yaml-runtime.js +0 -245
  267. package/dist/integration/secure-yaml-runtime.js.map +0 -1
  268. package/dist/parser/secure-yaml-parser.d.ts +0 -62
  269. package/dist/parser/secure-yaml-parser.d.ts.map +0 -1
  270. package/dist/parser/secure-yaml-parser.js +0 -234
  271. package/dist/parser/secure-yaml-parser.js.map +0 -1
  272. package/dist/performance/autoscaling.d.ts +0 -100
  273. package/dist/performance/autoscaling.d.ts.map +0 -1
  274. package/dist/performance/autoscaling.js +0 -339
  275. package/dist/performance/autoscaling.js.map +0 -1
  276. package/dist/performance/benchmark.d.ts +0 -104
  277. package/dist/performance/benchmark.d.ts.map +0 -1
  278. package/dist/performance/benchmark.js +0 -514
  279. package/dist/performance/benchmark.js.map +0 -1
  280. package/dist/performance/index.d.ts +0 -14
  281. package/dist/performance/index.d.ts.map +0 -1
  282. package/dist/performance/index.js +0 -35
  283. package/dist/performance/index.js.map +0 -1
  284. package/dist/performance/monitor.d.ts +0 -126
  285. package/dist/performance/monitor.d.ts.map +0 -1
  286. package/dist/performance/monitor.js +0 -324
  287. package/dist/performance/monitor.js.map +0 -1
  288. package/dist/performance/streaming.d.ts +0 -82
  289. package/dist/performance/streaming.d.ts.map +0 -1
  290. package/dist/performance/streaming.js +0 -287
  291. package/dist/performance/streaming.js.map +0 -1
  292. package/dist/runtime/audit.d.ts +0 -240
  293. package/dist/runtime/audit.d.ts.map +0 -1
  294. package/dist/runtime/audit.js +0 -641
  295. package/dist/runtime/audit.js.map +0 -1
  296. package/dist/runtime/declarativeAgentRuntime.d.ts +0 -92
  297. package/dist/runtime/declarativeAgentRuntime.d.ts.map +0 -1
  298. package/dist/runtime/declarativeAgentRuntime.js +0 -512
  299. package/dist/runtime/declarativeAgentRuntime.js.map +0 -1
  300. package/dist/runtime/index.d.ts +0 -12
  301. package/dist/runtime/index.d.ts.map +0 -1
  302. package/dist/runtime/index.js +0 -33
  303. package/dist/runtime/index.js.map +0 -1
  304. package/dist/runtime/isolatedRuntime.d.ts +0 -119
  305. package/dist/runtime/isolatedRuntime.d.ts.map +0 -1
  306. package/dist/runtime/isolatedRuntime.js +0 -425
  307. package/dist/runtime/isolatedRuntime.js.map +0 -1
  308. package/dist/runtime/schemaCompiler.d.ts +0 -35
  309. package/dist/runtime/schemaCompiler.d.ts.map +0 -1
  310. package/dist/runtime/schemaCompiler.js +0 -152
  311. package/dist/runtime/schemaCompiler.js.map +0 -1
  312. package/dist/runtime/simpleRuntime.d.ts +0 -57
  313. package/dist/runtime/simpleRuntime.d.ts.map +0 -1
  314. package/dist/runtime/simpleRuntime.js +0 -187
  315. package/dist/runtime/simpleRuntime.js.map +0 -1
  316. package/dist/runtime/workflowExecutor.d.ts +0 -30
  317. package/dist/runtime/workflowExecutor.d.ts.map +0 -1
  318. package/dist/runtime/workflowExecutor.js +0 -70
  319. package/dist/runtime/workflowExecutor.js.map +0 -1
  320. package/dist/security/dashboard.d.ts +0 -89
  321. package/dist/security/dashboard.d.ts.map +0 -1
  322. package/dist/security/dashboard.js +0 -300
  323. package/dist/security/dashboard.js.map +0 -1
  324. package/dist/security/hardening.d.ts +0 -130
  325. package/dist/security/hardening.d.ts.map +0 -1
  326. package/dist/security/hardening.js +0 -414
  327. package/dist/security/hardening.js.map +0 -1
  328. package/dist/security/index.d.ts +0 -128
  329. package/dist/security/index.d.ts.map +0 -1
  330. package/dist/security/index.js +0 -353
  331. package/dist/security/index.js.map +0 -1
  332. package/dist/security/monitor.d.ts +0 -88
  333. package/dist/security/monitor.d.ts.map +0 -1
  334. package/dist/security/monitor.js +0 -356
  335. package/dist/security/monitor.js.map +0 -1
  336. package/dist/security/scanner.d.ts +0 -104
  337. package/dist/security/scanner.d.ts.map +0 -1
  338. package/dist/security/scanner.js +0 -298
  339. package/dist/security/scanner.js.map +0 -1
  340. package/dist/security/score.d.ts +0 -150
  341. package/dist/security/score.d.ts.map +0 -1
  342. package/dist/security/score.js +0 -983
  343. package/dist/security/score.js.map +0 -1
  344. package/dist/security/threatDetector.d.ts +0 -39
  345. package/dist/security/threatDetector.d.ts.map +0 -1
  346. package/dist/security/threatDetector.js +0 -354
  347. package/dist/security/threatDetector.js.map +0 -1
  348. package/dist/security/validation.d.ts +0 -69
  349. package/dist/security/validation.d.ts.map +0 -1
  350. package/dist/security/validation.js +0 -286
  351. package/dist/security/validation.js.map +0 -1
  352. package/dist/server/api/clientsRoute.d.ts +0 -9
  353. package/dist/server/api/clientsRoute.d.ts.map +0 -1
  354. package/dist/server/api/clientsRoute.js +0 -71
  355. package/dist/server/api/clientsRoute.js.map +0 -1
  356. package/dist/server/api/endpointsRoute.d.ts +0 -8
  357. package/dist/server/api/endpointsRoute.d.ts.map +0 -1
  358. package/dist/server/api/endpointsRoute.js +0 -76
  359. package/dist/server/api/endpointsRoute.js.map +0 -1
  360. package/dist/server/api/graphql.d.ts +0 -9
  361. package/dist/server/api/graphql.d.ts.map +0 -1
  362. package/dist/server/api/graphql.js +0 -222
  363. package/dist/server/api/graphql.js.map +0 -1
  364. package/dist/server/errors.d.ts +0 -19
  365. package/dist/server/errors.d.ts.map +0 -1
  366. package/dist/server/errors.js +0 -42
  367. package/dist/server/errors.js.map +0 -1
  368. package/dist/server/index.d.ts +0 -7
  369. package/dist/server/index.d.ts.map +0 -1
  370. package/dist/server/index.js +0 -24
  371. package/dist/server/index.js.map +0 -1
  372. package/dist/server/kvStore.d.ts +0 -27
  373. package/dist/server/kvStore.d.ts.map +0 -1
  374. package/dist/server/kvStore.js +0 -128
  375. package/dist/server/kvStore.js.map +0 -1
  376. package/dist/server/runtimeSecurity.d.ts +0 -28
  377. package/dist/server/runtimeSecurity.d.ts.map +0 -1
  378. package/dist/server/runtimeSecurity.js +0 -85
  379. package/dist/server/runtimeSecurity.js.map +0 -1
  380. package/dist/server/types.d.ts +0 -53
  381. package/dist/server/types.d.ts.map +0 -1
  382. package/dist/server/types.js +0 -8
  383. package/dist/server/types.js.map +0 -1
  384. package/dist/shared/index.d.ts +0 -7
  385. package/dist/shared/index.d.ts.map +0 -1
  386. package/dist/shared/index.js +0 -23
  387. package/dist/shared/index.js.map +0 -1
  388. package/dist/shared/types/agent.types.d.ts +0 -50
  389. package/dist/shared/types/agent.types.d.ts.map +0 -1
  390. package/dist/shared/types/agent.types.js +0 -7
  391. package/dist/shared/types/agent.types.js.map +0 -1
  392. package/dist/shared/types/execution.types.d.ts +0 -42
  393. package/dist/shared/types/execution.types.d.ts.map +0 -1
  394. package/dist/shared/types/execution.types.js +0 -7
  395. package/dist/shared/types/execution.types.js.map +0 -1
  396. package/dist/shared/types/index.d.ts +0 -7
  397. package/dist/shared/types/index.d.ts.map +0 -1
  398. package/dist/shared/types/index.js +0 -23
  399. package/dist/shared/types/index.js.map +0 -1
  400. package/dist/shared/types/schema.types.d.ts +0 -52
  401. package/dist/shared/types/schema.types.d.ts.map +0 -1
  402. package/dist/shared/types/schema.types.js +0 -7
  403. package/dist/shared/types/schema.types.js.map +0 -1
  404. package/dist/shared/utils/index.d.ts +0 -5
  405. package/dist/shared/utils/index.d.ts.map +0 -1
  406. package/dist/shared/utils/index.js +0 -21
  407. package/dist/shared/utils/index.js.map +0 -1
  408. package/dist/shared/utils/validation.d.ts +0 -42
  409. package/dist/shared/utils/validation.d.ts.map +0 -1
  410. package/dist/shared/utils/validation.js +0 -93
  411. package/dist/shared/utils/validation.js.map +0 -1
  412. package/dist/tenant/TenantManager.d.ts +0 -152
  413. package/dist/tenant/TenantManager.d.ts.map +0 -1
  414. package/dist/tenant/TenantManager.js +0 -392
  415. package/dist/tenant/TenantManager.js.map +0 -1
  416. package/dist/tenant/index.d.ts +0 -47
  417. package/dist/tenant/index.d.ts.map +0 -1
  418. package/dist/tenant/index.js +0 -74
  419. package/dist/tenant/index.js.map +0 -1
  420. package/dist/tenant/interfaces.d.ts +0 -170
  421. package/dist/tenant/interfaces.d.ts.map +0 -1
  422. package/dist/tenant/interfaces.js +0 -67
  423. package/dist/tenant/interfaces.js.map +0 -1
  424. package/dist/tenant/providerFactory.d.ts +0 -43
  425. package/dist/tenant/providerFactory.d.ts.map +0 -1
  426. package/dist/tenant/providerFactory.js +0 -70
  427. package/dist/tenant/providerFactory.js.map +0 -1
  428. package/dist/tenant/providerRegistry.d.ts +0 -47
  429. package/dist/tenant/providerRegistry.d.ts.map +0 -1
  430. package/dist/tenant/providerRegistry.js +0 -79
  431. package/dist/tenant/providerRegistry.js.map +0 -1
  432. package/dist/tenant/providers/FirebaseTenantProvider.d.ts +0 -41
  433. package/dist/tenant/providers/FirebaseTenantProvider.d.ts.map +0 -1
  434. package/dist/tenant/providers/FirebaseTenantProvider.js +0 -290
  435. package/dist/tenant/providers/FirebaseTenantProvider.js.map +0 -1
  436. package/dist/tenant/providers/InMemoryTenantProvider.d.ts +0 -18
  437. package/dist/tenant/providers/InMemoryTenantProvider.d.ts.map +0 -1
  438. package/dist/tenant/providers/InMemoryTenantProvider.js +0 -137
  439. package/dist/tenant/providers/InMemoryTenantProvider.js.map +0 -1
  440. package/dist/types/executionContext.d.ts +0 -16
  441. package/dist/types/executionContext.d.ts.map +0 -1
  442. package/dist/types/executionContext.js +0 -3
  443. package/dist/types/executionContext.js.map +0 -1
  444. package/src/agents/chat/chat.handler.ts +0 -209
  445. package/src/agents/chat/chat.schema.ts +0 -33
  446. package/src/agents/chat/chat.types.ts +0 -46
  447. package/src/agents/chat/chat.yaml +0 -150
  448. package/src/agents/chat/index.ts +0 -21
  449. package/src/agents/chromadb/chromadb.handler.ts +0 -130
  450. package/src/agents/chromadb/chromadb.schema.ts +0 -35
  451. package/src/agents/chromadb/chromadb.types.ts +0 -52
  452. package/src/agents/chromadb/chromadb.yaml +0 -128
  453. package/src/agents/chromadb/index.ts +0 -20
  454. package/src/agents/gemini-vectorize/gemini-vectorize.handler.ts +0 -72
  455. package/src/agents/gemini-vectorize/gemini-vectorize.schema.ts +0 -22
  456. package/src/agents/gemini-vectorize/gemini-vectorize.types.ts +0 -34
  457. package/src/agents/gemini-vectorize/gemini-vectorize.yaml +0 -84
  458. package/src/agents/gemini-vectorize/index.ts +0 -20
  459. package/src/agents/gitmcp/gitmcp.handler.ts +0 -122
  460. package/src/agents/gitmcp/gitmcp.schema.ts +0 -20
  461. package/src/agents/gitmcp/gitmcp.types.ts +0 -33
  462. package/src/agents/gitmcp/gitmcp.yaml +0 -71
  463. package/src/agents/gitmcp/index.ts +0 -21
  464. package/src/agents/image/image.handler.ts +0 -82
  465. package/src/agents/image/image.schema.ts +0 -28
  466. package/src/agents/image/image.types.ts +0 -45
  467. package/src/agents/image/image.yaml +0 -86
  468. package/src/agents/image/index.ts +0 -19
  469. package/src/agents/index.ts +0 -59
  470. package/src/agents/joker/index.ts +0 -19
  471. package/src/agents/joker/joker.handler.ts +0 -60
  472. package/src/agents/joker/joker.schema.ts +0 -15
  473. package/src/agents/joker/joker.types.ts +0 -37
  474. package/src/agents/joker/joker.yaml +0 -47
  475. package/src/agents/mcp-tool/index.ts +0 -19
  476. package/src/agents/mcp-tool/mcp-tool.handler.ts +0 -112
  477. package/src/agents/mcp-tool/mcp-tool.schema.ts +0 -22
  478. package/src/agents/mcp-tool/mcp-tool.types.ts +0 -33
  479. package/src/agents/mcp-tool/mcp-tool.yaml +0 -71
  480. package/src/agents/rag/index.ts +0 -20
  481. package/src/agents/rag/rag.handler.ts +0 -119
  482. package/src/agents/rag/rag.schema.ts +0 -26
  483. package/src/agents/rag/rag.types.ts +0 -51
  484. package/src/agents/rag/rag.yaml +0 -89
  485. package/src/agents/registry/agentRegistry.ts +0 -598
  486. package/src/agents/registry/index.ts +0 -6
  487. package/src/agents/translator/index.ts +0 -19
  488. package/src/agents/translator/translator.handler.ts +0 -99
  489. package/src/agents/translator/translator.schema.ts +0 -30
  490. package/src/agents/translator/translator.types.ts +0 -42
  491. package/src/agents/translator/translator.yaml +0 -80
  492. package/src/audit/auditTrail.ts +0 -134
  493. package/src/client/index.ts +0 -53
  494. package/src/client/types.ts +0 -38
  495. package/src/compliance/gdprEngine.ts +0 -209
  496. package/src/compliance/lgpdEngine.ts +0 -268
  497. package/src/config.ts +0 -179
  498. package/src/errors.ts +0 -35
  499. package/src/integration/secure-yaml-runtime.ts +0 -341
  500. package/src/parser/secure-yaml-parser.ts +0 -273
  501. package/src/performance/autoscaling.ts +0 -495
  502. package/src/performance/benchmark.ts +0 -644
  503. package/src/performance/index.ts +0 -34
  504. package/src/performance/monitor.ts +0 -469
  505. package/src/performance/streaming.ts +0 -317
  506. package/src/runtime/audit.ts +0 -907
  507. package/src/runtime/declarativeAgentRuntime.ts +0 -772
  508. package/src/runtime/index.ts +0 -31
  509. package/src/runtime/isolatedRuntime.ts +0 -572
  510. package/src/runtime/schemaCompiler.ts +0 -228
  511. package/src/runtime/simpleRuntime.ts +0 -201
  512. package/src/runtime/workflowExecutor.ts +0 -94
  513. package/src/security/dashboard.ts +0 -462
  514. package/src/security/hardening.ts +0 -560
  515. package/src/security/index.ts +0 -439
  516. package/src/security/monitor.ts +0 -490
  517. package/src/security/scanner.ts +0 -368
  518. package/src/security/score.ts +0 -1138
  519. package/src/security/threatDetector.ts +0 -481
  520. package/src/security/validation.ts +0 -365
  521. package/src/server/api/clientsRoute.ts +0 -92
  522. package/src/server/api/endpointsRoute.ts +0 -97
  523. package/src/server/api/graphql.ts +0 -284
  524. package/src/server/errors.ts +0 -38
  525. package/src/server/index.ts +0 -6
  526. package/src/server/kvStore.ts +0 -152
  527. package/src/server/runtimeSecurity.ts +0 -102
  528. package/src/server/types.ts +0 -60
  529. package/src/shared/index.ts +0 -7
  530. package/src/shared/types/agent.types.ts +0 -80
  531. package/src/shared/types/execution.types.ts +0 -45
  532. package/src/shared/types/index.ts +0 -7
  533. package/src/shared/types/schema.types.ts +0 -55
  534. package/src/shared/utils/index.ts +0 -5
  535. package/src/shared/utils/validation.ts +0 -100
  536. package/src/tenant/TenantManager.ts +0 -488
  537. package/src/tenant/index.ts +0 -101
  538. package/src/tenant/interfaces.ts +0 -231
  539. package/src/tenant/providerFactory.ts +0 -75
  540. package/src/tenant/providerRegistry.ts +0 -86
  541. package/src/tenant/providers/InMemoryTenantProvider.ts +0 -168
  542. package/src/types/executionContext.ts +0 -16
@@ -1,209 +0,0 @@
1
- import 'server-only';
2
-
3
- /**
4
- * Chat Agent Handler - Server-only execution logic
5
- * Orchestrates RAG pipeline or simple chat based on mode
6
- */
7
-
8
- import type { ExecutionContext } from '../../types/executionContext';
9
- import type { ExecutionStep } from '../../shared/types/agent.types';
10
- import type { ChatHandlerParams, ChatHandlerResult, ChatMode } from './chat.types';
11
- import { executeVectorizeHandler } from '../gemini-vectorize/gemini-vectorize.handler';
12
- import { executeChromaDBHandler } from '../chromadb/chromadb.handler';
13
- import { executeRagHandler } from '../rag/rag.handler';
14
-
15
- const KNOWLEDGE_COLLECTION = 'beddel_knowledge';
16
-
17
- /**
18
- * Execute simple chat mode - direct LLM with conversation history
19
- */
20
- async function executeSimpleChat(
21
- query: string,
22
- messages: ChatHandlerParams['messages'],
23
- props: Record<string, string>,
24
- context: ExecutionContext,
25
- executionSteps: ExecutionStep[]
26
- ): Promise<ChatHandlerResult> {
27
- const startTime = Date.now();
28
-
29
- context.log(`[Chat:Simple] Processing query: "${query.substring(0, 50)}..."`);
30
-
31
- const chatStep: ExecutionStep = {
32
- agent: 'rag',
33
- action: 'chat',
34
- status: 'running',
35
- startTime: Date.now(),
36
- phase: 'generation',
37
- };
38
- executionSteps.push(chatStep);
39
-
40
- const result = await executeRagHandler(
41
- { query, history: messages, mode: 'simple' },
42
- props,
43
- context
44
- );
45
-
46
- chatStep.status = result.error ? 'error' : 'success';
47
- chatStep.endTime = Date.now();
48
- chatStep.duration = chatStep.endTime - chatStep.startTime;
49
- if (result.error) chatStep.error = result.error;
50
-
51
- return {
52
- response: result.response,
53
- timestamp: result.timestamp,
54
- execution_steps: executionSteps,
55
- total_duration: Date.now() - startTime,
56
- };
57
- }
58
-
59
- /**
60
- * Execute RAG chat mode - full pipeline with knowledge base
61
- */
62
- async function executeRagChat(
63
- query: string,
64
- messages: ChatHandlerParams['messages'],
65
- props: Record<string, string>,
66
- context: ExecutionContext,
67
- executionSteps: ExecutionStep[]
68
- ): Promise<ChatHandlerResult> {
69
- const startTime = Date.now();
70
-
71
- context.log(`[Chat:RAG] Processing query: "${query.substring(0, 50)}..."`);
72
-
73
- // Step 1: Vectorize user query
74
- const vectorizeStep: ExecutionStep = {
75
- agent: 'gemini-vectorize',
76
- action: 'embedSingle',
77
- status: 'running',
78
- startTime: Date.now(),
79
- phase: 'vectorization',
80
- };
81
- executionSteps.push(vectorizeStep);
82
-
83
- const vectorResult = await executeVectorizeHandler(
84
- { action: 'embedSingle', text: query },
85
- props,
86
- context
87
- );
88
-
89
- vectorizeStep.status = vectorResult.success ? 'success' : 'error';
90
- vectorizeStep.endTime = Date.now();
91
- vectorizeStep.duration = vectorizeStep.endTime - vectorizeStep.startTime;
92
-
93
- if (!vectorResult.success || !vectorResult.vector) {
94
- throw new Error(`Vectorization failed: ${vectorResult.error}`);
95
- }
96
-
97
- // Step 2: Check if knowledge base has data
98
- const checkStep: ExecutionStep = {
99
- agent: 'chromadb',
100
- action: 'hasData',
101
- status: 'running',
102
- startTime: Date.now(),
103
- phase: 'retrieval',
104
- };
105
- executionSteps.push(checkStep);
106
-
107
- const hasDataResult = await executeChromaDBHandler(
108
- { action: 'hasData', collection_name: KNOWLEDGE_COLLECTION, min_count: 5 },
109
- props,
110
- context
111
- );
112
-
113
- checkStep.status = hasDataResult.success ? 'success' : 'error';
114
- checkStep.endTime = Date.now();
115
- checkStep.duration = checkStep.endTime - checkStep.startTime;
116
-
117
- // Step 3: Search knowledge base
118
- const searchStep: ExecutionStep = {
119
- agent: 'chromadb',
120
- action: 'search',
121
- status: 'running',
122
- startTime: Date.now(),
123
- phase: 'retrieval',
124
- };
125
- executionSteps.push(searchStep);
126
-
127
- const searchResult = await executeChromaDBHandler(
128
- {
129
- action: 'search',
130
- collection_name: KNOWLEDGE_COLLECTION,
131
- query_vector: vectorResult.vector,
132
- limit: 5,
133
- },
134
- props,
135
- context
136
- );
137
-
138
- searchStep.status = searchResult.success ? 'success' : 'error';
139
- searchStep.endTime = Date.now();
140
- searchStep.duration = searchStep.endTime - searchStep.startTime;
141
-
142
- // Step 4: Generate answer
143
- const ragStep: ExecutionStep = {
144
- agent: 'rag',
145
- action: 'generate',
146
- status: 'running',
147
- startTime: Date.now(),
148
- phase: 'generation',
149
- };
150
- executionSteps.push(ragStep);
151
-
152
- const hasDocuments = searchResult.documents && searchResult.documents.trim().length > 0;
153
-
154
- const ragResult = hasDocuments
155
- ? await executeRagHandler({ query, documents: searchResult.documents, history: messages }, props, context)
156
- : await executeRagHandler(
157
- { query, documents: 'No specific documentation available. Answer based on general knowledge.', history: messages },
158
- props,
159
- context
160
- );
161
-
162
- ragStep.status = ragResult.error ? 'error' : 'success';
163
- ragStep.endTime = Date.now();
164
- ragStep.duration = ragStep.endTime - ragStep.startTime;
165
- if (ragResult.error) ragStep.error = ragResult.error;
166
-
167
- return {
168
- response: ragResult.response,
169
- timestamp: ragResult.timestamp,
170
- execution_steps: executionSteps,
171
- total_duration: Date.now() - startTime,
172
- };
173
- }
174
-
175
- /**
176
- * Execute chat orchestration
177
- */
178
- export async function executeChatHandler(
179
- params: ChatHandlerParams,
180
- props: Record<string, string>,
181
- context: ExecutionContext
182
- ): Promise<ChatHandlerResult> {
183
- const executionSteps: ExecutionStep[] = [];
184
- const messages = params.messages || [];
185
- const lastUserMessage = [...messages].reverse().find((m) => m.role === 'user');
186
- const query = params.query || lastUserMessage?.content || '';
187
- const mode: ChatMode = params.mode || 'rag';
188
-
189
- if (!query) {
190
- throw new Error('No query found in messages or query parameter');
191
- }
192
-
193
- try {
194
- return mode === 'simple'
195
- ? await executeSimpleChat(query, messages, props, context, executionSteps)
196
- : await executeRagChat(query, messages, props, context, executionSteps);
197
- } catch (error: unknown) {
198
- const message = error instanceof Error ? error.message : String(error);
199
- context.log(`[Chat] Error: ${message}`);
200
- context.setError(message);
201
-
202
- return {
203
- response: `Error processing your request: ${message}`,
204
- timestamp: new Date().toISOString(),
205
- execution_steps: executionSteps,
206
- total_duration: 0,
207
- };
208
- }
209
- }
@@ -1,33 +0,0 @@
1
- /**
2
- * Chat Agent Schema - Zod validation schemas
3
- * Safe for both client and server
4
- */
5
-
6
- import { z } from 'zod';
7
-
8
- export const ChatInputSchema = z.object({
9
- messages: z.array(z.object({
10
- role: z.enum(['user', 'assistant', 'system']),
11
- content: z.string(),
12
- })),
13
- query: z.string().optional(),
14
- knowledge_sources: z.array(z.string()).optional(),
15
- });
16
-
17
- export const ChatOutputSchema = z.object({
18
- response: z.string(),
19
- timestamp: z.string(),
20
- execution_steps: z.array(z.object({
21
- agent: z.string(),
22
- action: z.string(),
23
- status: z.enum(['running', 'success', 'error']),
24
- startTime: z.number(),
25
- endTime: z.number().optional(),
26
- duration: z.number().optional(),
27
- error: z.string().optional(),
28
- })).optional(),
29
- total_duration: z.number().optional(),
30
- });
31
-
32
- export type ChatInput = z.infer<typeof ChatInputSchema>;
33
- export type ChatOutput = z.infer<typeof ChatOutputSchema>;
@@ -1,46 +0,0 @@
1
- /**
2
- * Chat Agent Types - Shared between client and server
3
- */
4
-
5
- import type { ConversationMessage } from '../rag/rag.types';
6
- import type { ExecutionStep } from '../../shared/types/agent.types';
7
-
8
- /**
9
- * Chat mode determines the execution flow
10
- * - 'rag': Full RAG pipeline with knowledge base (default)
11
- * - 'simple': Direct LLM chat maintaining conversation context only
12
- */
13
- export type ChatMode = 'rag' | 'simple';
14
-
15
- /**
16
- * Parameters for chat orchestration
17
- */
18
- export interface ChatHandlerParams {
19
- messages: ConversationMessage[];
20
- query?: string;
21
- mode?: ChatMode;
22
- knowledge_sources?: string[];
23
- }
24
-
25
- /**
26
- * Result from chat orchestration
27
- */
28
- export interface ChatHandlerResult {
29
- response: string;
30
- timestamp: string;
31
- execution_steps?: ExecutionStep[];
32
- total_duration?: number;
33
- }
34
-
35
- /**
36
- * Chat agent metadata
37
- */
38
- export interface ChatMetadata {
39
- id: 'chat';
40
- name: string;
41
- description: string;
42
- category: 'chat';
43
- route: '/agents/chat';
44
- knowledge_sources: string[];
45
- tags: string[];
46
- }
@@ -1,150 +0,0 @@
1
- # Chat Agent - Native Builtin Orchestrator Agent for Beddel Runtime
2
- # Route: /agents/chat
3
- # Method: chat.execute
4
-
5
- agent:
6
- id: chat
7
- version: 1.0.0
8
- protocol: beddel-declarative-protocol/v2.0
9
-
10
- metadata:
11
- name: "Q&A Context Chat Agent"
12
- description: "Orchestrates RAG pipeline or simple chat based on mode selection"
13
- category: "chat"
14
- route: "/agents/chat"
15
- knowledge_sources:
16
- - "gitmcp-agent"
17
- tags:
18
- - "chat"
19
- - "orchestrator"
20
- - "rag"
21
- - "qa"
22
- - "simple"
23
-
24
- schema:
25
- input:
26
- type: "object"
27
- properties:
28
- messages:
29
- type: "array"
30
- items:
31
- type: "object"
32
- properties:
33
- role:
34
- type: "string"
35
- enum: ["user", "assistant", "system"]
36
- content:
37
- type: "string"
38
- required: ["role", "content"]
39
- description: "Conversation messages"
40
- query:
41
- type: "string"
42
- description: "Direct query (alternative to messages)"
43
- mode:
44
- type: "string"
45
- enum: ["rag", "simple"]
46
- default: "rag"
47
- description: "Chat mode: 'rag' for knowledge-based answers, 'simple' for direct LLM chat"
48
- knowledge_sources:
49
- type: "array"
50
- items:
51
- type: "string"
52
- description: "GitMCP URLs to use as knowledge sources"
53
- required: ["messages"]
54
-
55
- output:
56
- type: "object"
57
- properties:
58
- response:
59
- type: "string"
60
- description: "Generated answer"
61
- timestamp:
62
- type: "string"
63
- description: "ISO timestamp"
64
- execution_steps:
65
- type: "array"
66
- description: "Detailed execution steps for observability"
67
- total_duration:
68
- type: "number"
69
- description: "Total execution time in milliseconds"
70
- required: ["response", "timestamp"]
71
-
72
- logic:
73
- variables:
74
- - name: "userQuery"
75
- type: "string"
76
- init: '""'
77
- - name: "allDocuments"
78
- type: "string"
79
- init: '""'
80
-
81
- workflow:
82
- # Step 1: Extract user query from messages
83
- - name: "extract-query"
84
- type: "output-generator"
85
- action:
86
- type: "generate"
87
- output:
88
- _extracted: true
89
-
90
- # Step 2: Mode branch - Simple chat or RAG pipeline
91
- - name: "mode-check"
92
- type: "conditional"
93
- condition: "$input.mode == 'simple'"
94
- then:
95
- # Simple mode: Direct LLM chat with conversation history
96
- - name: "simple-chat"
97
- type: "rag"
98
- action:
99
- query: "$input.query"
100
- history: "$input.messages"
101
- mode: "simple"
102
- result: "ragResult"
103
- else:
104
- # RAG mode: Full pipeline with knowledge base
105
- - name: "vectorize-query"
106
- type: "gemini-vectorize"
107
- action:
108
- action: "embedSingle"
109
- text: "$input.query"
110
- result: "queryVector"
111
-
112
- - name: "check-knowledge"
113
- type: "chromadb"
114
- action:
115
- action: "hasData"
116
- collection_name: "beddel_knowledge"
117
- min_count: 5
118
- result: "hasDataResult"
119
-
120
- - name: "search-knowledge"
121
- type: "chromadb"
122
- action:
123
- action: "search"
124
- collection_name: "beddel_knowledge"
125
- query_vector: "$queryVector.vector"
126
- limit: 5
127
- result: "searchResult"
128
-
129
- - name: "generate-answer"
130
- type: "rag"
131
- action:
132
- query: "$input.query"
133
- documents: "$searchResult.documents"
134
- history: "$input.messages"
135
- mode: "rag"
136
- result: "ragResult"
137
-
138
- # Step 3: Deliver final response
139
- - name: "deliver-response"
140
- type: "output-generator"
141
- action:
142
- type: "generate"
143
- output:
144
- response: "$ragResult.response"
145
- timestamp: "$ragResult.timestamp"
146
-
147
- output:
148
- schema:
149
- response: "$ragResult.response"
150
- timestamp: "$ragResult.timestamp"
@@ -1,21 +0,0 @@
1
- /**
2
- * Chat Agent - Public exports (client-safe)
3
- */
4
-
5
- // Schema exports (client-safe)
6
- export { ChatInputSchema, ChatOutputSchema } from './chat.schema';
7
- export type { ChatInput, ChatOutput } from './chat.schema';
8
-
9
- // Type exports (client-safe)
10
- export type { ChatHandlerParams, ChatHandlerResult, ChatMetadata } from './chat.types';
11
-
12
- // Metadata (client-safe)
13
- export const chatMetadata = {
14
- id: 'chat',
15
- name: 'Q&A Context Chat Agent',
16
- description: 'Orchestrates RAG pipeline: vectorization, storage, retrieval and answer generation',
17
- category: 'chat',
18
- route: '/agents/chat',
19
- knowledge_sources: ['gitmcp-agent'],
20
- tags: ['chat', 'orchestrator', 'rag', 'qa'],
21
- } as const;
@@ -1,130 +0,0 @@
1
- import 'server-only';
2
-
3
- /**
4
- * ChromaDB Agent Handler - Server-only execution logic
5
- * Vector storage and retrieval using ChromaDB
6
- */
7
-
8
- import type { ExecutionContext } from '../../types/executionContext';
9
- import type { ChromaDBHandlerParams, ChromaDBHandlerResult, ChromaDBSearchResult } from './chromadb.types';
10
-
11
- // ChromaDB imports (lazy loaded)
12
- let chromaClient: any = null;
13
-
14
- /**
15
- * Execute ChromaDB operations
16
- */
17
- export async function executeChromaDBHandler(
18
- params: ChromaDBHandlerParams,
19
- _props: Record<string, string>,
20
- context: ExecutionContext
21
- ): Promise<ChromaDBHandlerResult> {
22
- const action = params.action;
23
- const collectionName = params.collection_name;
24
-
25
- if (!collectionName) {
26
- throw new Error('Missing required ChromaDB input: collection_name');
27
- }
28
-
29
- try {
30
- // Lazy load ChromaDB
31
- if (!chromaClient) {
32
- const chromaModule = await import('chromadb');
33
-
34
- if (process.env.CHROMADB_API_KEY) {
35
- context.log('[ChromaDB] Initializing CloudClient...');
36
- chromaClient = new chromaModule.CloudClient({
37
- apiKey: process.env.CHROMADB_API_KEY,
38
- tenant: process.env.CHROMADB_TENANT || 'default_tenant',
39
- database: process.env.CHROMADB_DATABASE || 'dev',
40
- });
41
- } else {
42
- context.log('[ChromaDB] Initializing Local ChromaClient...');
43
- chromaClient = new chromaModule.ChromaClient({
44
- path: process.env.CHROMADB_URL || 'http://localhost:8000',
45
- });
46
- }
47
- }
48
-
49
- if (action === 'hasData') {
50
- const minCount = params.min_count || 1;
51
- context.log(`[ChromaDB] Checking data for collection: ${collectionName}`);
52
-
53
- try {
54
- const collection = await chromaClient.getCollection({
55
- name: collectionName,
56
- embeddingFunction: undefined,
57
- });
58
- const count = await collection.count();
59
- const hasEnoughData = count >= minCount;
60
-
61
- return { success: true, has_data: hasEnoughData, count };
62
- } catch {
63
- return { success: true, has_data: false, count: 0 };
64
- }
65
-
66
- } else if (action === 'store') {
67
- const ids = params.ids;
68
- const vectors = params.vectors;
69
- const documents = params.documents;
70
- const metadatas = params.metadatas;
71
-
72
- context.log(`[ChromaDB] Storing ${ids?.length || 0} items in ${collectionName}...`);
73
-
74
- const collection = await chromaClient.getOrCreateCollection({
75
- name: collectionName,
76
- embeddingFunction: undefined,
77
- });
78
-
79
- await collection.add({
80
- ids,
81
- embeddings: vectors,
82
- documents,
83
- metadatas,
84
- });
85
-
86
- return { success: true, stored_count: ids?.length || 0 };
87
-
88
- } else if (action === 'search') {
89
- const queryVector = params.query_vector;
90
- const limit = params.limit || 5;
91
-
92
- context.log(`[ChromaDB] Searching ${collectionName}...`);
93
-
94
- try {
95
- const collection = await chromaClient.getCollection({
96
- name: collectionName,
97
- embeddingFunction: undefined,
98
- });
99
-
100
- const results = await collection.query({
101
- queryEmbeddings: [queryVector],
102
- nResults: limit,
103
- });
104
-
105
- const flatResults: ChromaDBSearchResult[] = (results.documents[0] || []).map(
106
- (doc: string | null, idx: number) => ({
107
- text: doc,
108
- metadata: results.metadatas[0]?.[idx] || null,
109
- distance: results.distances?.[0]?.[idx] || null,
110
- })
111
- );
112
-
113
- const documentsString = flatResults.map((r) => r.text).join('\n\n---\n\n');
114
-
115
- return { success: true, results: flatResults, documents: documentsString };
116
- } catch {
117
- // Collection doesn't exist - return empty results
118
- context.log(`[ChromaDB] Collection ${collectionName} not found, returning empty results`);
119
- return { success: true, results: [], documents: '' };
120
- }
121
-
122
- } else {
123
- throw new Error(`Unknown ChromaDB action: ${action}`);
124
- }
125
- } catch (error: unknown) {
126
- const message = error instanceof Error ? error.message : String(error);
127
- context.log(`[ChromaDB] Error: ${message}`);
128
- return { success: false, error: message };
129
- }
130
- }
@@ -1,35 +0,0 @@
1
- /**
2
- * ChromaDB Agent Schema - Zod validation schemas
3
- * Safe for both client and server
4
- */
5
-
6
- import { z } from 'zod';
7
-
8
- export const ChromaDBInputSchema = z.object({
9
- action: z.enum(['hasData', 'store', 'search']),
10
- collection_name: z.string().min(1),
11
- min_count: z.number().optional(),
12
- ids: z.array(z.string()).optional(),
13
- vectors: z.array(z.array(z.number())).optional(),
14
- documents: z.array(z.string()).optional(),
15
- metadatas: z.array(z.record(z.string(), z.unknown())).optional(),
16
- query_vector: z.array(z.number()).optional(),
17
- limit: z.number().optional(),
18
- });
19
-
20
- export const ChromaDBOutputSchema = z.object({
21
- success: z.boolean(),
22
- has_data: z.boolean().optional(),
23
- count: z.number().optional(),
24
- stored_count: z.number().optional(),
25
- results: z.array(z.object({
26
- text: z.string().nullable(),
27
- metadata: z.record(z.string(), z.unknown()).nullable(),
28
- distance: z.number().nullable(),
29
- })).optional(),
30
- documents: z.string().optional(),
31
- error: z.string().optional(),
32
- });
33
-
34
- export type ChromaDBInput = z.infer<typeof ChromaDBInputSchema>;
35
- export type ChromaDBOutput = z.infer<typeof ChromaDBOutputSchema>;
@@ -1,52 +0,0 @@
1
- /**
2
- * ChromaDB Agent Types - Shared between client and server
3
- */
4
-
5
- /**
6
- * Parameters for ChromaDB operations
7
- */
8
- export interface ChromaDBHandlerParams {
9
- action: 'hasData' | 'store' | 'search';
10
- collection_name: string;
11
- min_count?: number;
12
- ids?: string[];
13
- vectors?: number[][];
14
- documents?: string[];
15
- metadatas?: Record<string, unknown>[];
16
- query_vector?: number[];
17
- limit?: number;
18
- }
19
-
20
- /**
21
- * Search result item
22
- */
23
- export interface ChromaDBSearchResult {
24
- text: string | null;
25
- metadata: Record<string, unknown> | null;
26
- distance: number | null;
27
- }
28
-
29
- /**
30
- * Result from ChromaDB operations
31
- */
32
- export interface ChromaDBHandlerResult {
33
- success: boolean;
34
- has_data?: boolean;
35
- count?: number;
36
- stored_count?: number;
37
- results?: ChromaDBSearchResult[];
38
- documents?: string;
39
- error?: string;
40
- }
41
-
42
- /**
43
- * ChromaDB agent metadata
44
- */
45
- export interface ChromaDBMetadata {
46
- id: 'chromadb';
47
- name: string;
48
- description: string;
49
- category: 'database';
50
- route: '/agents/chromadb';
51
- tags: string[];
52
- }