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.
- package/README.md +138 -595
- package/dist/client.d.ts +10 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +9 -0
- package/dist/core/parser.d.ts +25 -0
- package/dist/core/parser.d.ts.map +1 -0
- package/dist/core/parser.js +31 -0
- package/dist/core/variable-resolver.d.ts +23 -0
- package/dist/core/variable-resolver.d.ts.map +1 -0
- package/dist/core/variable-resolver.js +98 -0
- package/dist/core/workflow.d.ts +39 -0
- package/dist/core/workflow.d.ts.map +1 -0
- package/dist/core/workflow.js +64 -0
- package/dist/index.d.ts +14 -36
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +15 -130
- package/dist/primitives/index.d.ts +37 -0
- package/dist/primitives/index.d.ts.map +1 -0
- package/dist/primitives/index.js +72 -0
- package/dist/primitives/llm.d.ts +56 -0
- package/dist/primitives/llm.d.ts.map +1 -0
- package/dist/primitives/llm.js +156 -0
- package/dist/primitives/output.d.ts +28 -0
- package/dist/primitives/output.d.ts.map +1 -0
- package/dist/primitives/output.js +39 -0
- package/dist/server/handler.d.ts +7 -0
- package/dist/server/handler.d.ts.map +1 -0
- package/dist/server/handler.js +55 -0
- package/dist/server.d.ts +10 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +9 -0
- package/dist/tools/index.d.ts +49 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +96 -0
- package/dist/types/index.d.ts +54 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +5 -0
- package/docs/architecture/api-reference.md +307 -0
- package/docs/architecture/components.md +246 -0
- package/docs/architecture/core-workflows.md +236 -0
- package/docs/architecture/high-level-architecture.md +76 -0
- package/docs/architecture/index.md +31 -0
- package/docs/architecture/source-tree.md +92 -0
- package/docs/architecture/tech-stack.md +25 -0
- package/docs/prd/epic-list.md +101 -0
- package/docs/prd/goals-context.md +23 -0
- package/docs/prd/index.md +21 -0
- package/docs/prd/requirements.md +25 -0
- package/docs/prd/technical-assumptions.md +35 -0
- package/package.json +31 -118
- package/src/client.ts +18 -0
- package/src/core/parser.ts +36 -0
- package/src/core/variable-resolver.ts +114 -0
- package/src/core/workflow.ts +77 -0
- package/src/index.ts +25 -159
- package/src/primitives/index.ts +83 -0
- package/src/primitives/llm.ts +210 -0
- package/src/primitives/output.ts +65 -0
- package/src/server/handler.ts +80 -0
- package/src/server.ts +10 -0
- package/src/tools/index.ts +118 -0
- package/src/types/index.ts +62 -0
- package/tsconfig.json +27 -0
- package/CHANGELOG.md +0 -78
- package/LICENSE +0 -21
- package/dist/agents/chat/chat.handler.d.ts +0 -12
- package/dist/agents/chat/chat.handler.d.ts.map +0 -1
- package/dist/agents/chat/chat.handler.js +0 -143
- package/dist/agents/chat/chat.handler.js.map +0 -1
- package/dist/agents/chat/chat.schema.d.ts +0 -38
- package/dist/agents/chat/chat.schema.d.ts.map +0 -1
- package/dist/agents/chat/chat.schema.js +0 -31
- package/dist/agents/chat/chat.schema.js.map +0 -1
- package/dist/agents/chat/chat.types.d.ts +0 -42
- package/dist/agents/chat/chat.types.d.ts.map +0 -1
- package/dist/agents/chat/chat.types.js +0 -6
- package/dist/agents/chat/chat.types.js.map +0 -1
- package/dist/agents/chat/chat.yaml +0 -150
- package/dist/agents/chat/index.d.ts +0 -16
- package/dist/agents/chat/index.d.ts.map +0 -1
- package/dist/agents/chat/index.js +0 -21
- package/dist/agents/chat/index.js.map +0 -1
- package/dist/agents/chromadb/chromadb.handler.d.ts +0 -12
- package/dist/agents/chromadb/chromadb.handler.d.ts.map +0 -1
- package/dist/agents/chromadb/chromadb.handler.js +0 -139
- package/dist/agents/chromadb/chromadb.handler.js.map +0 -1
- package/dist/agents/chromadb/chromadb.schema.d.ts +0 -36
- package/dist/agents/chromadb/chromadb.schema.d.ts.map +0 -1
- package/dist/agents/chromadb/chromadb.schema.js +0 -33
- package/dist/agents/chromadb/chromadb.schema.js.map +0 -1
- package/dist/agents/chromadb/chromadb.types.d.ts +0 -49
- package/dist/agents/chromadb/chromadb.types.d.ts.map +0 -1
- package/dist/agents/chromadb/chromadb.types.js +0 -6
- package/dist/agents/chromadb/chromadb.types.js.map +0 -1
- package/dist/agents/chromadb/chromadb.yaml +0 -128
- package/dist/agents/chromadb/index.d.ts +0 -15
- package/dist/agents/chromadb/index.d.ts.map +0 -1
- package/dist/agents/chromadb/index.js +0 -20
- package/dist/agents/chromadb/index.js.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.handler.d.ts +0 -8
- package/dist/agents/gemini-vectorize/gemini-vectorize.handler.d.ts.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.handler.js +0 -58
- package/dist/agents/gemini-vectorize/gemini-vectorize.handler.js.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.schema.d.ts +0 -22
- package/dist/agents/gemini-vectorize/gemini-vectorize.schema.d.ts.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.schema.js +0 -20
- package/dist/agents/gemini-vectorize/gemini-vectorize.schema.js.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.types.d.ts +0 -32
- package/dist/agents/gemini-vectorize/gemini-vectorize.types.d.ts.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.types.js +0 -6
- package/dist/agents/gemini-vectorize/gemini-vectorize.types.js.map +0 -1
- package/dist/agents/gemini-vectorize/gemini-vectorize.yaml +0 -84
- package/dist/agents/gemini-vectorize/index.d.ts +0 -15
- package/dist/agents/gemini-vectorize/index.d.ts.map +0 -1
- package/dist/agents/gemini-vectorize/index.js +0 -20
- package/dist/agents/gemini-vectorize/index.js.map +0 -1
- package/dist/agents/gitmcp/gitmcp.handler.d.ts +0 -12
- package/dist/agents/gitmcp/gitmcp.handler.d.ts.map +0 -1
- package/dist/agents/gitmcp/gitmcp.handler.js +0 -95
- package/dist/agents/gitmcp/gitmcp.handler.js.map +0 -1
- package/dist/agents/gitmcp/gitmcp.schema.d.ts +0 -17
- package/dist/agents/gitmcp/gitmcp.schema.d.ts.map +0 -1
- package/dist/agents/gitmcp/gitmcp.schema.js +0 -18
- package/dist/agents/gitmcp/gitmcp.schema.js.map +0 -1
- package/dist/agents/gitmcp/gitmcp.types.d.ts +0 -31
- package/dist/agents/gitmcp/gitmcp.types.d.ts.map +0 -1
- package/dist/agents/gitmcp/gitmcp.types.js +0 -6
- package/dist/agents/gitmcp/gitmcp.types.js.map +0 -1
- package/dist/agents/gitmcp/gitmcp.yaml +0 -71
- package/dist/agents/gitmcp/index.d.ts +0 -16
- package/dist/agents/gitmcp/index.d.ts.map +0 -1
- package/dist/agents/gitmcp/index.js +0 -21
- package/dist/agents/gitmcp/index.js.map +0 -1
- package/dist/agents/image/image.handler.d.ts +0 -8
- package/dist/agents/image/image.handler.d.ts.map +0 -1
- package/dist/agents/image/image.handler.js +0 -66
- package/dist/agents/image/image.handler.js.map +0 -1
- package/dist/agents/image/image.schema.d.ts +0 -29
- package/dist/agents/image/image.schema.d.ts.map +0 -1
- package/dist/agents/image/image.schema.js +0 -26
- package/dist/agents/image/image.schema.js.map +0 -1
- package/dist/agents/image/image.types.d.ts +0 -42
- package/dist/agents/image/image.types.d.ts.map +0 -1
- package/dist/agents/image/image.types.js +0 -6
- package/dist/agents/image/image.types.js.map +0 -1
- package/dist/agents/image/image.yaml +0 -86
- package/dist/agents/image/index.d.ts +0 -14
- package/dist/agents/image/index.d.ts.map +0 -1
- package/dist/agents/image/index.js +0 -19
- package/dist/agents/image/index.js.map +0 -1
- package/dist/agents/index.d.ts +0 -95
- package/dist/agents/index.d.ts.map +0 -1
- package/dist/agents/index.js +0 -76
- package/dist/agents/index.js.map +0 -1
- package/dist/agents/joker/index.d.ts +0 -14
- package/dist/agents/joker/index.d.ts.map +0 -1
- package/dist/agents/joker/index.js +0 -19
- package/dist/agents/joker/index.js.map +0 -1
- package/dist/agents/joker/joker.handler.d.ts +0 -8
- package/dist/agents/joker/joker.handler.d.ts.map +0 -1
- package/dist/agents/joker/joker.handler.js +0 -48
- package/dist/agents/joker/joker.handler.js.map +0 -1
- package/dist/agents/joker/joker.schema.d.ts +0 -12
- package/dist/agents/joker/joker.schema.d.ts.map +0 -1
- package/dist/agents/joker/joker.schema.js +0 -13
- package/dist/agents/joker/joker.schema.js.map +0 -1
- package/dist/agents/joker/joker.types.d.ts +0 -35
- package/dist/agents/joker/joker.types.d.ts.map +0 -1
- package/dist/agents/joker/joker.types.js +0 -6
- package/dist/agents/joker/joker.types.js.map +0 -1
- package/dist/agents/joker/joker.yaml +0 -47
- package/dist/agents/mcp-tool/index.d.ts +0 -14
- package/dist/agents/mcp-tool/index.d.ts.map +0 -1
- package/dist/agents/mcp-tool/index.js +0 -19
- package/dist/agents/mcp-tool/index.js.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.handler.d.ts +0 -12
- package/dist/agents/mcp-tool/mcp-tool.handler.d.ts.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.handler.js +0 -116
- package/dist/agents/mcp-tool/mcp-tool.handler.js.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.schema.d.ts +0 -19
- package/dist/agents/mcp-tool/mcp-tool.schema.d.ts.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.schema.js +0 -20
- package/dist/agents/mcp-tool/mcp-tool.schema.js.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.types.d.ts +0 -31
- package/dist/agents/mcp-tool/mcp-tool.types.d.ts.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.types.js +0 -6
- package/dist/agents/mcp-tool/mcp-tool.types.js.map +0 -1
- package/dist/agents/mcp-tool/mcp-tool.yaml +0 -71
- package/dist/agents/rag/index.d.ts +0 -15
- package/dist/agents/rag/index.d.ts.map +0 -1
- package/dist/agents/rag/index.js +0 -20
- package/dist/agents/rag/index.js.map +0 -1
- package/dist/agents/rag/rag.handler.d.ts +0 -8
- package/dist/agents/rag/rag.handler.d.ts.map +0 -1
- package/dist/agents/rag/rag.handler.js +0 -101
- package/dist/agents/rag/rag.handler.js.map +0 -1
- package/dist/agents/rag/rag.schema.d.ts +0 -27
- package/dist/agents/rag/rag.schema.d.ts.map +0 -1
- package/dist/agents/rag/rag.schema.js +0 -24
- package/dist/agents/rag/rag.schema.js.map +0 -1
- package/dist/agents/rag/rag.types.d.ts +0 -47
- package/dist/agents/rag/rag.types.d.ts.map +0 -1
- package/dist/agents/rag/rag.types.js +0 -6
- package/dist/agents/rag/rag.types.js.map +0 -1
- package/dist/agents/rag/rag.yaml +0 -89
- package/dist/agents/registry/agentRegistry.d.ts +0 -117
- package/dist/agents/registry/agentRegistry.d.ts.map +0 -1
- package/dist/agents/registry/agentRegistry.js +0 -551
- package/dist/agents/registry/agentRegistry.js.map +0 -1
- package/dist/agents/registry/index.d.ts +0 -6
- package/dist/agents/registry/index.d.ts.map +0 -1
- package/dist/agents/registry/index.js +0 -10
- package/dist/agents/registry/index.js.map +0 -1
- package/dist/agents/translator/index.d.ts +0 -14
- package/dist/agents/translator/index.d.ts.map +0 -1
- package/dist/agents/translator/index.js +0 -19
- package/dist/agents/translator/index.js.map +0 -1
- package/dist/agents/translator/translator.handler.d.ts +0 -8
- package/dist/agents/translator/translator.handler.d.ts.map +0 -1
- package/dist/agents/translator/translator.handler.js +0 -83
- package/dist/agents/translator/translator.handler.js.map +0 -1
- package/dist/agents/translator/translator.schema.d.ts +0 -27
- package/dist/agents/translator/translator.schema.d.ts.map +0 -1
- package/dist/agents/translator/translator.schema.js +0 -28
- package/dist/agents/translator/translator.schema.js.map +0 -1
- package/dist/agents/translator/translator.types.d.ts +0 -40
- package/dist/agents/translator/translator.types.d.ts.map +0 -1
- package/dist/agents/translator/translator.types.js +0 -6
- package/dist/agents/translator/translator.types.js.map +0 -1
- package/dist/agents/translator/translator.yaml +0 -80
- package/dist/audit/auditTrail.d.ts +0 -55
- package/dist/audit/auditTrail.d.ts.map +0 -1
- package/dist/audit/auditTrail.js +0 -93
- package/dist/audit/auditTrail.js.map +0 -1
- package/dist/client/index.d.ts +0 -89
- package/dist/client/index.d.ts.map +0 -1
- package/dist/client/index.js +0 -93
- package/dist/client/index.js.map +0 -1
- package/dist/client/types.d.ts +0 -17
- package/dist/client/types.d.ts.map +0 -1
- package/dist/client/types.js +0 -7
- package/dist/client/types.js.map +0 -1
- package/dist/compliance/gdprEngine.d.ts +0 -44
- package/dist/compliance/gdprEngine.d.ts.map +0 -1
- package/dist/compliance/gdprEngine.js +0 -178
- package/dist/compliance/gdprEngine.js.map +0 -1
- package/dist/compliance/lgpdEngine.d.ts +0 -51
- package/dist/compliance/lgpdEngine.d.ts.map +0 -1
- package/dist/compliance/lgpdEngine.js +0 -221
- package/dist/compliance/lgpdEngine.js.map +0 -1
- package/dist/config.d.ts +0 -78
- package/dist/config.d.ts.map +0 -1
- package/dist/config.js +0 -77
- package/dist/config.js.map +0 -1
- package/dist/errors.d.ts +0 -17
- package/dist/errors.d.ts.map +0 -1
- package/dist/errors.js +0 -40
- package/dist/errors.js.map +0 -1
- package/dist/firebase/tenantManager.d.ts +0 -116
- package/dist/firebase/tenantManager.d.ts.map +0 -1
- package/dist/firebase/tenantManager.js +0 -444
- package/dist/firebase/tenantManager.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/integration/secure-yaml-runtime.d.ts +0 -68
- package/dist/integration/secure-yaml-runtime.d.ts.map +0 -1
- package/dist/integration/secure-yaml-runtime.js +0 -245
- package/dist/integration/secure-yaml-runtime.js.map +0 -1
- package/dist/parser/secure-yaml-parser.d.ts +0 -62
- package/dist/parser/secure-yaml-parser.d.ts.map +0 -1
- package/dist/parser/secure-yaml-parser.js +0 -234
- package/dist/parser/secure-yaml-parser.js.map +0 -1
- package/dist/performance/autoscaling.d.ts +0 -100
- package/dist/performance/autoscaling.d.ts.map +0 -1
- package/dist/performance/autoscaling.js +0 -339
- package/dist/performance/autoscaling.js.map +0 -1
- package/dist/performance/benchmark.d.ts +0 -104
- package/dist/performance/benchmark.d.ts.map +0 -1
- package/dist/performance/benchmark.js +0 -514
- package/dist/performance/benchmark.js.map +0 -1
- package/dist/performance/index.d.ts +0 -14
- package/dist/performance/index.d.ts.map +0 -1
- package/dist/performance/index.js +0 -35
- package/dist/performance/index.js.map +0 -1
- package/dist/performance/monitor.d.ts +0 -126
- package/dist/performance/monitor.d.ts.map +0 -1
- package/dist/performance/monitor.js +0 -324
- package/dist/performance/monitor.js.map +0 -1
- package/dist/performance/streaming.d.ts +0 -82
- package/dist/performance/streaming.d.ts.map +0 -1
- package/dist/performance/streaming.js +0 -287
- package/dist/performance/streaming.js.map +0 -1
- package/dist/runtime/audit.d.ts +0 -240
- package/dist/runtime/audit.d.ts.map +0 -1
- package/dist/runtime/audit.js +0 -641
- package/dist/runtime/audit.js.map +0 -1
- package/dist/runtime/declarativeAgentRuntime.d.ts +0 -92
- package/dist/runtime/declarativeAgentRuntime.d.ts.map +0 -1
- package/dist/runtime/declarativeAgentRuntime.js +0 -512
- package/dist/runtime/declarativeAgentRuntime.js.map +0 -1
- package/dist/runtime/index.d.ts +0 -12
- package/dist/runtime/index.d.ts.map +0 -1
- package/dist/runtime/index.js +0 -33
- package/dist/runtime/index.js.map +0 -1
- package/dist/runtime/isolatedRuntime.d.ts +0 -119
- package/dist/runtime/isolatedRuntime.d.ts.map +0 -1
- package/dist/runtime/isolatedRuntime.js +0 -425
- package/dist/runtime/isolatedRuntime.js.map +0 -1
- package/dist/runtime/schemaCompiler.d.ts +0 -35
- package/dist/runtime/schemaCompiler.d.ts.map +0 -1
- package/dist/runtime/schemaCompiler.js +0 -152
- package/dist/runtime/schemaCompiler.js.map +0 -1
- package/dist/runtime/simpleRuntime.d.ts +0 -57
- package/dist/runtime/simpleRuntime.d.ts.map +0 -1
- package/dist/runtime/simpleRuntime.js +0 -187
- package/dist/runtime/simpleRuntime.js.map +0 -1
- package/dist/runtime/workflowExecutor.d.ts +0 -30
- package/dist/runtime/workflowExecutor.d.ts.map +0 -1
- package/dist/runtime/workflowExecutor.js +0 -70
- package/dist/runtime/workflowExecutor.js.map +0 -1
- package/dist/security/dashboard.d.ts +0 -89
- package/dist/security/dashboard.d.ts.map +0 -1
- package/dist/security/dashboard.js +0 -300
- package/dist/security/dashboard.js.map +0 -1
- package/dist/security/hardening.d.ts +0 -130
- package/dist/security/hardening.d.ts.map +0 -1
- package/dist/security/hardening.js +0 -414
- package/dist/security/hardening.js.map +0 -1
- package/dist/security/index.d.ts +0 -128
- package/dist/security/index.d.ts.map +0 -1
- package/dist/security/index.js +0 -353
- package/dist/security/index.js.map +0 -1
- package/dist/security/monitor.d.ts +0 -88
- package/dist/security/monitor.d.ts.map +0 -1
- package/dist/security/monitor.js +0 -356
- package/dist/security/monitor.js.map +0 -1
- package/dist/security/scanner.d.ts +0 -104
- package/dist/security/scanner.d.ts.map +0 -1
- package/dist/security/scanner.js +0 -298
- package/dist/security/scanner.js.map +0 -1
- package/dist/security/score.d.ts +0 -150
- package/dist/security/score.d.ts.map +0 -1
- package/dist/security/score.js +0 -983
- package/dist/security/score.js.map +0 -1
- package/dist/security/threatDetector.d.ts +0 -39
- package/dist/security/threatDetector.d.ts.map +0 -1
- package/dist/security/threatDetector.js +0 -354
- package/dist/security/threatDetector.js.map +0 -1
- package/dist/security/validation.d.ts +0 -69
- package/dist/security/validation.d.ts.map +0 -1
- package/dist/security/validation.js +0 -286
- package/dist/security/validation.js.map +0 -1
- package/dist/server/api/clientsRoute.d.ts +0 -9
- package/dist/server/api/clientsRoute.d.ts.map +0 -1
- package/dist/server/api/clientsRoute.js +0 -71
- package/dist/server/api/clientsRoute.js.map +0 -1
- package/dist/server/api/endpointsRoute.d.ts +0 -8
- package/dist/server/api/endpointsRoute.d.ts.map +0 -1
- package/dist/server/api/endpointsRoute.js +0 -76
- package/dist/server/api/endpointsRoute.js.map +0 -1
- package/dist/server/api/graphql.d.ts +0 -9
- package/dist/server/api/graphql.d.ts.map +0 -1
- package/dist/server/api/graphql.js +0 -222
- package/dist/server/api/graphql.js.map +0 -1
- package/dist/server/errors.d.ts +0 -19
- package/dist/server/errors.d.ts.map +0 -1
- package/dist/server/errors.js +0 -42
- package/dist/server/errors.js.map +0 -1
- package/dist/server/index.d.ts +0 -7
- package/dist/server/index.d.ts.map +0 -1
- package/dist/server/index.js +0 -24
- package/dist/server/index.js.map +0 -1
- package/dist/server/kvStore.d.ts +0 -27
- package/dist/server/kvStore.d.ts.map +0 -1
- package/dist/server/kvStore.js +0 -128
- package/dist/server/kvStore.js.map +0 -1
- package/dist/server/runtimeSecurity.d.ts +0 -28
- package/dist/server/runtimeSecurity.d.ts.map +0 -1
- package/dist/server/runtimeSecurity.js +0 -85
- package/dist/server/runtimeSecurity.js.map +0 -1
- package/dist/server/types.d.ts +0 -53
- package/dist/server/types.d.ts.map +0 -1
- package/dist/server/types.js +0 -8
- package/dist/server/types.js.map +0 -1
- package/dist/shared/index.d.ts +0 -7
- package/dist/shared/index.d.ts.map +0 -1
- package/dist/shared/index.js +0 -23
- package/dist/shared/index.js.map +0 -1
- package/dist/shared/types/agent.types.d.ts +0 -50
- package/dist/shared/types/agent.types.d.ts.map +0 -1
- package/dist/shared/types/agent.types.js +0 -7
- package/dist/shared/types/agent.types.js.map +0 -1
- package/dist/shared/types/execution.types.d.ts +0 -42
- package/dist/shared/types/execution.types.d.ts.map +0 -1
- package/dist/shared/types/execution.types.js +0 -7
- package/dist/shared/types/execution.types.js.map +0 -1
- package/dist/shared/types/index.d.ts +0 -7
- package/dist/shared/types/index.d.ts.map +0 -1
- package/dist/shared/types/index.js +0 -23
- package/dist/shared/types/index.js.map +0 -1
- package/dist/shared/types/schema.types.d.ts +0 -52
- package/dist/shared/types/schema.types.d.ts.map +0 -1
- package/dist/shared/types/schema.types.js +0 -7
- package/dist/shared/types/schema.types.js.map +0 -1
- package/dist/shared/utils/index.d.ts +0 -5
- package/dist/shared/utils/index.d.ts.map +0 -1
- package/dist/shared/utils/index.js +0 -21
- package/dist/shared/utils/index.js.map +0 -1
- package/dist/shared/utils/validation.d.ts +0 -42
- package/dist/shared/utils/validation.d.ts.map +0 -1
- package/dist/shared/utils/validation.js +0 -93
- package/dist/shared/utils/validation.js.map +0 -1
- package/dist/tenant/TenantManager.d.ts +0 -152
- package/dist/tenant/TenantManager.d.ts.map +0 -1
- package/dist/tenant/TenantManager.js +0 -392
- package/dist/tenant/TenantManager.js.map +0 -1
- package/dist/tenant/index.d.ts +0 -47
- package/dist/tenant/index.d.ts.map +0 -1
- package/dist/tenant/index.js +0 -74
- package/dist/tenant/index.js.map +0 -1
- package/dist/tenant/interfaces.d.ts +0 -170
- package/dist/tenant/interfaces.d.ts.map +0 -1
- package/dist/tenant/interfaces.js +0 -67
- package/dist/tenant/interfaces.js.map +0 -1
- package/dist/tenant/providerFactory.d.ts +0 -43
- package/dist/tenant/providerFactory.d.ts.map +0 -1
- package/dist/tenant/providerFactory.js +0 -70
- package/dist/tenant/providerFactory.js.map +0 -1
- package/dist/tenant/providerRegistry.d.ts +0 -47
- package/dist/tenant/providerRegistry.d.ts.map +0 -1
- package/dist/tenant/providerRegistry.js +0 -79
- package/dist/tenant/providerRegistry.js.map +0 -1
- package/dist/tenant/providers/FirebaseTenantProvider.d.ts +0 -41
- package/dist/tenant/providers/FirebaseTenantProvider.d.ts.map +0 -1
- package/dist/tenant/providers/FirebaseTenantProvider.js +0 -290
- package/dist/tenant/providers/FirebaseTenantProvider.js.map +0 -1
- package/dist/tenant/providers/InMemoryTenantProvider.d.ts +0 -18
- package/dist/tenant/providers/InMemoryTenantProvider.d.ts.map +0 -1
- package/dist/tenant/providers/InMemoryTenantProvider.js +0 -137
- package/dist/tenant/providers/InMemoryTenantProvider.js.map +0 -1
- package/dist/types/executionContext.d.ts +0 -16
- package/dist/types/executionContext.d.ts.map +0 -1
- package/dist/types/executionContext.js +0 -3
- package/dist/types/executionContext.js.map +0 -1
- package/src/agents/chat/chat.handler.ts +0 -209
- package/src/agents/chat/chat.schema.ts +0 -33
- package/src/agents/chat/chat.types.ts +0 -46
- package/src/agents/chat/chat.yaml +0 -150
- package/src/agents/chat/index.ts +0 -21
- package/src/agents/chromadb/chromadb.handler.ts +0 -130
- package/src/agents/chromadb/chromadb.schema.ts +0 -35
- package/src/agents/chromadb/chromadb.types.ts +0 -52
- package/src/agents/chromadb/chromadb.yaml +0 -128
- package/src/agents/chromadb/index.ts +0 -20
- package/src/agents/gemini-vectorize/gemini-vectorize.handler.ts +0 -72
- package/src/agents/gemini-vectorize/gemini-vectorize.schema.ts +0 -22
- package/src/agents/gemini-vectorize/gemini-vectorize.types.ts +0 -34
- package/src/agents/gemini-vectorize/gemini-vectorize.yaml +0 -84
- package/src/agents/gemini-vectorize/index.ts +0 -20
- package/src/agents/gitmcp/gitmcp.handler.ts +0 -122
- package/src/agents/gitmcp/gitmcp.schema.ts +0 -20
- package/src/agents/gitmcp/gitmcp.types.ts +0 -33
- package/src/agents/gitmcp/gitmcp.yaml +0 -71
- package/src/agents/gitmcp/index.ts +0 -21
- package/src/agents/image/image.handler.ts +0 -82
- package/src/agents/image/image.schema.ts +0 -28
- package/src/agents/image/image.types.ts +0 -45
- package/src/agents/image/image.yaml +0 -86
- package/src/agents/image/index.ts +0 -19
- package/src/agents/index.ts +0 -59
- package/src/agents/joker/index.ts +0 -19
- package/src/agents/joker/joker.handler.ts +0 -60
- package/src/agents/joker/joker.schema.ts +0 -15
- package/src/agents/joker/joker.types.ts +0 -37
- package/src/agents/joker/joker.yaml +0 -47
- package/src/agents/mcp-tool/index.ts +0 -19
- package/src/agents/mcp-tool/mcp-tool.handler.ts +0 -112
- package/src/agents/mcp-tool/mcp-tool.schema.ts +0 -22
- package/src/agents/mcp-tool/mcp-tool.types.ts +0 -33
- package/src/agents/mcp-tool/mcp-tool.yaml +0 -71
- package/src/agents/rag/index.ts +0 -20
- package/src/agents/rag/rag.handler.ts +0 -119
- package/src/agents/rag/rag.schema.ts +0 -26
- package/src/agents/rag/rag.types.ts +0 -51
- package/src/agents/rag/rag.yaml +0 -89
- package/src/agents/registry/agentRegistry.ts +0 -598
- package/src/agents/registry/index.ts +0 -6
- package/src/agents/translator/index.ts +0 -19
- package/src/agents/translator/translator.handler.ts +0 -99
- package/src/agents/translator/translator.schema.ts +0 -30
- package/src/agents/translator/translator.types.ts +0 -42
- package/src/agents/translator/translator.yaml +0 -80
- package/src/audit/auditTrail.ts +0 -134
- package/src/client/index.ts +0 -53
- package/src/client/types.ts +0 -38
- package/src/compliance/gdprEngine.ts +0 -209
- package/src/compliance/lgpdEngine.ts +0 -268
- package/src/config.ts +0 -179
- package/src/errors.ts +0 -35
- package/src/integration/secure-yaml-runtime.ts +0 -341
- package/src/parser/secure-yaml-parser.ts +0 -273
- package/src/performance/autoscaling.ts +0 -495
- package/src/performance/benchmark.ts +0 -644
- package/src/performance/index.ts +0 -34
- package/src/performance/monitor.ts +0 -469
- package/src/performance/streaming.ts +0 -317
- package/src/runtime/audit.ts +0 -907
- package/src/runtime/declarativeAgentRuntime.ts +0 -772
- package/src/runtime/index.ts +0 -31
- package/src/runtime/isolatedRuntime.ts +0 -572
- package/src/runtime/schemaCompiler.ts +0 -228
- package/src/runtime/simpleRuntime.ts +0 -201
- package/src/runtime/workflowExecutor.ts +0 -94
- package/src/security/dashboard.ts +0 -462
- package/src/security/hardening.ts +0 -560
- package/src/security/index.ts +0 -439
- package/src/security/monitor.ts +0 -490
- package/src/security/scanner.ts +0 -368
- package/src/security/score.ts +0 -1138
- package/src/security/threatDetector.ts +0 -481
- package/src/security/validation.ts +0 -365
- package/src/server/api/clientsRoute.ts +0 -92
- package/src/server/api/endpointsRoute.ts +0 -97
- package/src/server/api/graphql.ts +0 -284
- package/src/server/errors.ts +0 -38
- package/src/server/index.ts +0 -6
- package/src/server/kvStore.ts +0 -152
- package/src/server/runtimeSecurity.ts +0 -102
- package/src/server/types.ts +0 -60
- package/src/shared/index.ts +0 -7
- package/src/shared/types/agent.types.ts +0 -80
- package/src/shared/types/execution.types.ts +0 -45
- package/src/shared/types/index.ts +0 -7
- package/src/shared/types/schema.types.ts +0 -55
- package/src/shared/utils/index.ts +0 -5
- package/src/shared/utils/validation.ts +0 -100
- package/src/tenant/TenantManager.ts +0 -488
- package/src/tenant/index.ts +0 -101
- package/src/tenant/interfaces.ts +0 -231
- package/src/tenant/providerFactory.ts +0 -75
- package/src/tenant/providerRegistry.ts +0 -86
- package/src/tenant/providers/InMemoryTenantProvider.ts +0 -168
- 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"
|
package/src/agents/chat/index.ts
DELETED
|
@@ -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
|
-
}
|