@hotmeshio/long-tail 0.1.14 → 0.1.15
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 +15 -0
- package/build/api/escalations/bulk.d.ts +78 -0
- package/build/api/escalations/bulk.js +279 -0
- package/build/api/escalations/claim.d.ts +30 -0
- package/build/api/escalations/claim.js +121 -0
- package/build/api/escalations/create.d.ts +29 -0
- package/build/api/escalations/create.js +101 -0
- package/build/api/escalations/helpers.d.ts +10 -0
- package/build/api/escalations/helpers.js +80 -0
- package/build/api/escalations/index.d.ts +6 -0
- package/build/api/escalations/index.js +26 -0
- package/build/api/escalations/list.d.ts +75 -0
- package/build/api/escalations/list.js +170 -0
- package/build/api/escalations/resolve.d.ts +18 -0
- package/build/api/escalations/resolve.js +243 -0
- package/build/api/escalations/single.d.ts +37 -0
- package/build/api/escalations/single.js +123 -0
- package/build/api/files.d.ts +3 -0
- package/build/api/files.js +18 -1
- package/build/api/knowledge.d.ts +36 -0
- package/build/api/knowledge.js +112 -0
- package/build/api/mcp/index.d.ts +2 -0
- package/build/api/mcp/index.js +16 -0
- package/build/api/{mcp.d.ts → mcp/servers.d.ts} +1 -33
- package/build/api/{mcp.js → mcp/servers.js} +4 -65
- package/build/api/mcp/tools.d.ts +33 -0
- package/build/api/mcp/tools.js +64 -0
- package/build/api/settings.js +9 -1
- package/build/api/workflows/config.d.ts +64 -0
- package/build/api/workflows/config.js +142 -0
- package/build/api/workflows/discovery.d.ts +29 -0
- package/build/api/workflows/discovery.js +153 -0
- package/build/api/workflows/index.d.ts +3 -0
- package/build/api/workflows/index.js +18 -0
- package/build/api/workflows/invocation.d.ts +67 -0
- package/build/api/workflows/invocation.js +188 -0
- package/build/api/yaml-workflows/cron.d.ts +39 -0
- package/build/api/yaml-workflows/cron.js +127 -0
- package/build/api/{yaml-workflows.d.ts → yaml-workflows/crud.d.ts} +22 -146
- package/build/api/{yaml-workflows.js → yaml-workflows/crud.js} +77 -378
- package/build/api/yaml-workflows/deploy.d.ts +71 -0
- package/build/api/yaml-workflows/deploy.js +223 -0
- package/build/api/yaml-workflows/helpers.d.ts +2 -0
- package/build/api/yaml-workflows/helpers.js +8 -0
- package/build/api/yaml-workflows/index.d.ts +4 -0
- package/build/api/yaml-workflows/index.js +27 -0
- package/build/api/yaml-workflows/versions.d.ts +43 -0
- package/build/api/yaml-workflows/versions.js +124 -0
- package/build/bin/ltc.d.ts +2 -0
- package/build/bin/ltc.js +220 -0
- package/build/examples/seed-data.d.ts +55 -0
- package/build/examples/seed-data.js +161 -0
- package/build/examples/seed.js +7 -164
- package/build/lib/cli/auth.d.ts +23 -0
- package/build/lib/cli/auth.js +167 -0
- package/build/lib/cli/client.d.ts +6 -0
- package/build/lib/cli/client.js +31 -0
- package/build/lib/cli/commands/escalations.d.ts +19 -0
- package/build/lib/cli/commands/escalations.js +69 -0
- package/build/lib/cli/commands/knowledge.d.ts +18 -0
- package/build/lib/cli/commands/knowledge.js +87 -0
- package/build/lib/cli/commands/mcp.d.ts +8 -0
- package/build/lib/cli/commands/mcp.js +33 -0
- package/build/lib/cli/commands/pipelines.d.ts +16 -0
- package/build/lib/cli/commands/pipelines.js +67 -0
- package/build/lib/cli/commands/status.d.ts +1 -0
- package/build/lib/cli/commands/status.js +28 -0
- package/build/lib/cli/commands/users.d.ts +7 -0
- package/build/lib/cli/commands/users.js +25 -0
- package/build/lib/cli/commands/workflows.d.ts +16 -0
- package/build/lib/cli/commands/workflows.js +104 -0
- package/build/lib/cli/compile.d.ts +2 -0
- package/build/lib/cli/compile.js +165 -0
- package/build/lib/cli/format.d.ts +23 -0
- package/build/lib/cli/format.js +94 -0
- package/build/lib/cli/init.d.ts +1 -0
- package/build/lib/cli/init.js +61 -0
- package/build/lib/cli/output.d.ts +27 -0
- package/build/lib/cli/output.js +126 -0
- package/build/lib/cli/scanner.d.ts +10 -0
- package/build/lib/cli/scanner.js +164 -0
- package/build/lib/cli/types.d.ts +16 -0
- package/build/lib/cli/types.js +2 -0
- package/build/lib/logger/index.d.ts +0 -9
- package/build/lib/logger/index.js +9 -4
- package/build/lib/storage/index.js +2 -2
- package/build/routes/file-browser.js +14 -0
- package/build/routes/index.js +2 -0
- package/build/routes/knowledge.d.ts +2 -0
- package/build/routes/knowledge.js +141 -0
- package/build/routes/yaml-workflows/crud.js +9 -0
- package/build/sdk/index.d.ts +17 -0
- package/build/sdk/index.js +19 -0
- package/build/services/mcp/client/connection-dispatch.d.ts +18 -0
- package/build/services/mcp/client/connection-dispatch.js +78 -0
- package/build/services/mcp/client/connection-lifecycle.d.ts +48 -0
- package/build/services/mcp/client/connection-lifecycle.js +296 -0
- package/build/services/mcp/client/connection-test.d.ts +10 -0
- package/build/services/mcp/client/connection-test.js +49 -0
- package/build/services/mcp/client/connection.d.ts +3 -68
- package/build/services/mcp/client/connection.js +15 -393
- package/build/services/mcp/server-lifecycle.d.ts +27 -0
- package/build/services/mcp/server-lifecycle.js +49 -0
- package/build/services/mcp/server-tools.d.ts +13 -0
- package/build/services/mcp/server-tools.js +287 -0
- package/build/services/mcp/server.d.ts +2 -26
- package/build/services/mcp/server.js +7 -315
- package/build/services/yaml-workflow/builder-regenerate.d.ts +25 -0
- package/build/services/yaml-workflow/builder-regenerate.js +111 -0
- package/build/services/yaml-workflow/db-versions.d.ts +17 -0
- package/build/services/yaml-workflow/db-versions.js +76 -0
- package/build/services/yaml-workflow/db.d.ts +3 -13
- package/build/services/yaml-workflow/db.js +15 -71
- package/build/services/yaml-workflow/deployer-helpers.js +48 -17
- package/build/services/yaml-workflow/durable-compiler/index.d.ts +22 -0
- package/build/services/yaml-workflow/durable-compiler/index.js +168 -0
- package/build/services/yaml-workflow/durable-compiler/parser.d.ts +12 -0
- package/build/services/yaml-workflow/durable-compiler/parser.js +110 -0
- package/build/services/yaml-workflow/durable-compiler/prompts.d.ts +18 -0
- package/build/services/yaml-workflow/durable-compiler/prompts.js +570 -0
- package/build/services/yaml-workflow/durable-compiler/types.d.ts +51 -0
- package/build/services/yaml-workflow/durable-compiler/types.js +5 -0
- package/build/services/yaml-workflow/pipeline/build/dag-assembly.d.ts +17 -0
- package/build/services/yaml-workflow/pipeline/build/dag-assembly.js +192 -0
- package/build/services/yaml-workflow/pipeline/build/dag.d.ts +4 -13
- package/build/services/yaml-workflow/pipeline/build/dag.js +9 -185
- package/build/services/yaml-workflow/pipeline/prompt-templates.d.ts +10 -0
- package/build/services/yaml-workflow/pipeline/prompt-templates.js +270 -0
- package/build/services/yaml-workflow/pipeline/prompts.d.ts +3 -6
- package/build/services/yaml-workflow/pipeline/prompts.js +8 -263
- package/build/start/workers.js +6 -5
- package/build/system/activities/file-storage.d.ts +4 -0
- package/build/system/activities/file-storage.js +7 -1
- package/build/system/activities/knowledge.d.ts +23 -0
- package/build/system/activities/knowledge.js +50 -10
- package/build/system/activities/sql.d.ts +3 -0
- package/build/system/activities/sql.js +25 -1
- package/build/system/mcp-servers/file-storage.js +3 -1
- package/build/system/mcp-servers/human-queue-schemas.d.ts +91 -0
- package/build/system/mcp-servers/human-queue-schemas.js +42 -0
- package/build/system/mcp-servers/human-queue.d.ts +2 -6
- package/build/system/mcp-servers/human-queue.js +9 -51
- package/build/system/mcp-servers/knowledge.js +43 -9
- package/build/system/mcp-servers/workflow-compiler.js +54 -0
- package/build/system/workflows/mcp-triage/activities-proxy.d.ts +21 -0
- package/build/system/workflows/mcp-triage/activities-proxy.js +70 -0
- package/build/system/workflows/mcp-triage/index.js +17 -75
- package/build/system/workflows/mcp-workflow-planner/activities/persist.d.ts +1 -0
- package/build/system/workflows/mcp-workflow-planner/activities/persist.js +1 -0
- package/build/system/workflows/mcp-workflow-planner/index.js +2 -0
- package/build/tsconfig.tsbuildinfo +1 -1
- package/dashboard/dist/assets/{AdminDashboard-Cngijp4Q.js → AdminDashboard-NLryl1_B.js} +2 -2
- package/dashboard/dist/assets/{AdminDashboard-Cngijp4Q.js.map → AdminDashboard-NLryl1_B.js.map} +1 -1
- package/dashboard/dist/assets/AvailableEscalationsPage-6vexlrk3.js +2 -0
- package/dashboard/dist/assets/AvailableEscalationsPage-6vexlrk3.js.map +1 -0
- package/dashboard/dist/assets/{BotPicker-B8Uvw9Si.js → BotPicker-DWhn0tr1.js} +2 -2
- package/dashboard/dist/assets/{BotPicker-B8Uvw9Si.js.map → BotPicker-DWhn0tr1.js.map} +1 -1
- package/dashboard/dist/assets/{CollapsibleSection-DiFPuWOY.js → CollapsibleSection-CgYgQiOc.js} +2 -2
- package/dashboard/dist/assets/{CollapsibleSection-DiFPuWOY.js.map → CollapsibleSection-CgYgQiOc.js.map} +1 -1
- package/dashboard/dist/assets/{ConfirmDeleteModal-CpXG9uyu.js → ConfirmDeleteModal-DCKAPXD3.js} +2 -2
- package/dashboard/dist/assets/{ConfirmDeleteModal-CpXG9uyu.js.map → ConfirmDeleteModal-DCKAPXD3.js.map} +1 -1
- package/dashboard/dist/assets/{CopyableId-DKsTR9lK.js → CopyableId-DXkaAOYk.js} +2 -2
- package/dashboard/dist/assets/{CopyableId-DKsTR9lK.js.map → CopyableId-DXkaAOYk.js.map} +1 -1
- package/dashboard/dist/assets/{CredentialsPage-DlS7Kf40.js → CredentialsPage-B361BOfU.js} +2 -2
- package/dashboard/dist/assets/{CredentialsPage-DlS7Kf40.js.map → CredentialsPage-B361BOfU.js.map} +1 -1
- package/dashboard/dist/assets/{CustomDurationPicker-B-9eW3pm.js → CustomDurationPicker-D2G1ldiF.js} +2 -2
- package/dashboard/dist/assets/{CustomDurationPicker-B-9eW3pm.js.map → CustomDurationPicker-D2G1ldiF.js.map} +1 -1
- package/dashboard/dist/assets/{DataTable-DkOokbtL.js → DataTable-DXSUbA26.js} +2 -2
- package/dashboard/dist/assets/{DataTable-DkOokbtL.js.map → DataTable-DXSUbA26.js.map} +1 -1
- package/dashboard/dist/assets/{ElapsedCell-DVtHqM-5.js → ElapsedCell-CQGqkXP_.js} +2 -2
- package/dashboard/dist/assets/{ElapsedCell-DVtHqM-5.js.map → ElapsedCell-CQGqkXP_.js.map} +1 -1
- package/dashboard/dist/assets/{EmptyState-C7KIMIbE.js → EmptyState-Dep92Wkg.js} +2 -2
- package/dashboard/dist/assets/{EmptyState-C7KIMIbE.js.map → EmptyState-Dep92Wkg.js.map} +1 -1
- package/dashboard/dist/assets/{EscalationsOverview-BMKBlkPx.js → EscalationsOverview-DVEFVjs7.js} +2 -2
- package/dashboard/dist/assets/{EscalationsOverview-BMKBlkPx.js.map → EscalationsOverview-DVEFVjs7.js.map} +1 -1
- package/dashboard/dist/assets/{EventTable-BYZ5OVdQ.js → EventTable-BMJAPkMi.js} +2 -2
- package/dashboard/dist/assets/{EventTable-BYZ5OVdQ.js.map → EventTable-BMJAPkMi.js.map} +1 -1
- package/dashboard/dist/assets/{FilterBar-C5r3n6YO.js → FilterBar-DbVbCzH2.js} +2 -2
- package/dashboard/dist/assets/{FilterBar-C5r3n6YO.js.map → FilterBar-DbVbCzH2.js.map} +1 -1
- package/dashboard/dist/assets/{ListToolbar-BGUajIsW.js → ListToolbar-0XNuXj0M.js} +2 -2
- package/dashboard/dist/assets/{ListToolbar-BGUajIsW.js.map → ListToolbar-0XNuXj0M.js.map} +1 -1
- package/dashboard/dist/assets/{McpOverview-B_kJYHea.js → McpOverview-CeYnCzBN.js} +2 -2
- package/dashboard/dist/assets/{McpOverview-B_kJYHea.js.map → McpOverview-CeYnCzBN.js.map} +1 -1
- package/dashboard/dist/assets/McpQueryDetailPage-t3qW3QNa.js +5 -0
- package/dashboard/dist/assets/McpQueryDetailPage-t3qW3QNa.js.map +1 -0
- package/dashboard/dist/assets/{McpQueryPage-BgAq_bQg.js → McpQueryPage-CfUcdzaj.js} +2 -2
- package/dashboard/dist/assets/{McpQueryPage-BgAq_bQg.js.map → McpQueryPage-CfUcdzaj.js.map} +1 -1
- package/dashboard/dist/assets/{McpRunDetailPage-B8c0OszR.js → McpRunDetailPage-CZtodW_Z.js} +2 -2
- package/dashboard/dist/assets/{McpRunDetailPage-B8c0OszR.js.map → McpRunDetailPage-CZtodW_Z.js.map} +1 -1
- package/dashboard/dist/assets/{McpRunsPage-BY8C6k78.js → McpRunsPage-Dzgq7HGt.js} +2 -2
- package/dashboard/dist/assets/{McpRunsPage-BY8C6k78.js.map → McpRunsPage-Dzgq7HGt.js.map} +1 -1
- package/dashboard/dist/assets/{Modal-E1yRnCeW.js → Modal-yyhUeKoA.js} +2 -2
- package/dashboard/dist/assets/{Modal-E1yRnCeW.js.map → Modal-yyhUeKoA.js.map} +1 -1
- package/dashboard/dist/assets/{OperatorDashboard-C8MSTzey.js → OperatorDashboard-Ceh7OQtZ.js} +2 -2
- package/dashboard/dist/assets/{OperatorDashboard-C8MSTzey.js.map → OperatorDashboard-Ceh7OQtZ.js.map} +1 -1
- package/dashboard/dist/assets/{PageHeader-Cm5HBQF_.js → PageHeader-CZ9a8cpr.js} +2 -2
- package/dashboard/dist/assets/{PageHeader-Cm5HBQF_.js.map → PageHeader-CZ9a8cpr.js.map} +1 -1
- package/dashboard/dist/assets/{PageHeaderWithStats-CNmWJFSN.js → PageHeaderWithStats-BJuNs5NM.js} +2 -2
- package/dashboard/dist/assets/{PageHeaderWithStats-CNmWJFSN.js.map → PageHeaderWithStats-BJuNs5NM.js.map} +1 -1
- package/dashboard/dist/assets/{PriorityBadge-HSI4RVhs.js → PriorityBadge-BrPikMFy.js} +2 -2
- package/dashboard/dist/assets/{PriorityBadge-HSI4RVhs.js.map → PriorityBadge-BrPikMFy.js.map} +1 -1
- package/dashboard/dist/assets/{ProcessDetailPage-Dln8622H.js → ProcessDetailPage-2miaYd8G.js} +2 -2
- package/dashboard/dist/assets/{ProcessDetailPage-Dln8622H.js.map → ProcessDetailPage-2miaYd8G.js.map} +1 -1
- package/dashboard/dist/assets/{ProcessesListPage-bIsd9N_h.js → ProcessesListPage-DqpRDqjk.js} +2 -2
- package/dashboard/dist/assets/{ProcessesListPage-bIsd9N_h.js.map → ProcessesListPage-DqpRDqjk.js.map} +1 -1
- package/dashboard/dist/assets/{RolePill-BVUp2bF0.js → RolePill-DxbJMfJu.js} +2 -2
- package/dashboard/dist/assets/{RolePill-BVUp2bF0.js.map → RolePill-DxbJMfJu.js.map} +1 -1
- package/dashboard/dist/assets/RolesPage-CYHRo21-.js +2 -0
- package/dashboard/dist/assets/{RolesPage-kH-Njt25.js.map → RolesPage-CYHRo21-.js.map} +1 -1
- package/dashboard/dist/assets/{RowActions-DbUJPfaW.js → RowActions-DurFwIwe.js} +2 -2
- package/dashboard/dist/assets/{RowActions-DbUJPfaW.js.map → RowActions-DurFwIwe.js.map} +1 -1
- package/dashboard/dist/assets/RunAsSelector-CNKraP6u.js +2 -0
- package/dashboard/dist/assets/RunAsSelector-CNKraP6u.js.map +1 -0
- package/dashboard/dist/assets/{StatCard-Bs3JbyAz.js → StatCard-CKplpK3w.js} +2 -2
- package/dashboard/dist/assets/{StatCard-Bs3JbyAz.js.map → StatCard-CKplpK3w.js.map} +1 -1
- package/dashboard/dist/assets/{StatusBadge-CakDdsCw.js → StatusBadge-Dm0V1dNN.js} +2 -2
- package/dashboard/dist/assets/{StatusBadge-CakDdsCw.js.map → StatusBadge-Dm0V1dNN.js.map} +1 -1
- package/dashboard/dist/assets/{StepIndicator-Cd_SG_yA.js → StepIndicator-Dicx0WTZ.js} +2 -2
- package/dashboard/dist/assets/{StepIndicator-Cd_SG_yA.js.map → StepIndicator-Dicx0WTZ.js.map} +1 -1
- package/dashboard/dist/assets/{StickyPagination-Bz0C18nC.js → StickyPagination-B2jYvU3-.js} +2 -2
- package/dashboard/dist/assets/{StickyPagination-Bz0C18nC.js.map → StickyPagination-B2jYvU3-.js.map} +1 -1
- package/dashboard/dist/assets/SwimlaneTimeline-ClwumkT1.js +2 -0
- package/dashboard/dist/assets/SwimlaneTimeline-ClwumkT1.js.map +1 -0
- package/dashboard/dist/assets/{TagInput-ClFhXG-U.js → TagInput-CypDZ6Kl.js} +2 -2
- package/dashboard/dist/assets/{TagInput-ClFhXG-U.js.map → TagInput-CypDZ6Kl.js.map} +1 -1
- package/dashboard/dist/assets/{TaskDetailPage-SuMBdARt.js → TaskDetailPage-DooDNJGT.js} +2 -2
- package/dashboard/dist/assets/{TaskDetailPage-SuMBdARt.js.map → TaskDetailPage-DooDNJGT.js.map} +1 -1
- package/dashboard/dist/assets/{TaskQueuePill-lJR1JW_W.js → TaskQueuePill-C1hZ-j31.js} +2 -2
- package/dashboard/dist/assets/{TaskQueuePill-lJR1JW_W.js.map → TaskQueuePill-C1hZ-j31.js.map} +1 -1
- package/dashboard/dist/assets/{TasksListPage-Dkq1Vtbt.js → TasksListPage-D7CdkAeg.js} +2 -2
- package/dashboard/dist/assets/{TasksListPage-Dkq1Vtbt.js.map → TasksListPage-D7CdkAeg.js.map} +1 -1
- package/dashboard/dist/assets/{TimeAgo-DgfDZ1pl.js → TimeAgo-B5LXB2aj.js} +2 -2
- package/dashboard/dist/assets/{TimeAgo-DgfDZ1pl.js.map → TimeAgo-B5LXB2aj.js.map} +1 -1
- package/dashboard/dist/assets/{TimestampCell-MpHZ1hMD.js → TimestampCell-Crb9b0Gw.js} +2 -2
- package/dashboard/dist/assets/{TimestampCell-MpHZ1hMD.js.map → TimestampCell-Crb9b0Gw.js.map} +1 -1
- package/dashboard/dist/assets/{UserName-DqsosA4B.js → UserName-OPg-nkRa.js} +2 -2
- package/dashboard/dist/assets/{UserName-DqsosA4B.js.map → UserName-OPg-nkRa.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowExecutionPage-CVlg38C3.js → WorkflowExecutionPage-CcLVrs9b.js} +2 -2
- package/dashboard/dist/assets/{WorkflowExecutionPage-CVlg38C3.js.map → WorkflowExecutionPage-CcLVrs9b.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowPill-CRpZhjGR.js → WorkflowPill-CCV4MMj7.js} +2 -2
- package/dashboard/dist/assets/{WorkflowPill-CRpZhjGR.js.map → WorkflowPill-CCV4MMj7.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowsDashboard-Ugzbs8mV.js → WorkflowsDashboard-DB1SncBi.js} +2 -2
- package/dashboard/dist/assets/{WorkflowsDashboard-Ugzbs8mV.js.map → WorkflowsDashboard-DB1SncBi.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowsOverview-CIp_lTNl.js → WorkflowsOverview-DvShiYJV.js} +2 -2
- package/dashboard/dist/assets/{WorkflowsOverview-CIp_lTNl.js.map → WorkflowsOverview-DvShiYJV.js.map} +1 -1
- package/dashboard/dist/assets/YamlWorkflowsPage-DCBoMeGI.js +2 -0
- package/dashboard/dist/assets/YamlWorkflowsPage-DCBoMeGI.js.map +1 -0
- package/dashboard/dist/assets/{bots-DPfUpVqI.js → bots-Dqos20NE.js} +2 -2
- package/dashboard/dist/assets/{bots-DPfUpVqI.js.map → bots-Dqos20NE.js.map} +1 -1
- package/dashboard/dist/assets/{escalation-RrCDbMC3.js → escalation-A0CsbvNV.js} +2 -2
- package/dashboard/dist/assets/{escalation-RrCDbMC3.js.map → escalation-A0CsbvNV.js.map} +1 -1
- package/dashboard/dist/assets/{escalation-columns-CDGa9wsD.js → escalation-columns-BpBJN6k4.js} +2 -2
- package/dashboard/dist/assets/{escalation-columns-CDGa9wsD.js.map → escalation-columns-BpBJN6k4.js.map} +1 -1
- package/dashboard/dist/assets/{helpers-ZSKqdkdS.js → helpers-CmznCuAx.js} +2 -2
- package/dashboard/dist/assets/{helpers-ZSKqdkdS.js.map → helpers-CmznCuAx.js.map} +1 -1
- package/dashboard/dist/assets/index-BIeYV5QK.js +2 -0
- package/dashboard/dist/assets/index-BIeYV5QK.js.map +1 -0
- package/dashboard/dist/assets/index-BYwD3kHN.js +5 -0
- package/dashboard/dist/assets/index-BYwD3kHN.js.map +1 -0
- package/dashboard/dist/assets/index-C5TUqJu0.css +1 -0
- package/dashboard/dist/assets/{index-DX6zxr6t.js → index-C8-UaN4N.js} +2 -2
- package/dashboard/dist/assets/{index-DX6zxr6t.js.map → index-C8-UaN4N.js.map} +1 -1
- package/dashboard/dist/assets/index-CAj5LT9H.js +15 -0
- package/dashboard/dist/assets/index-CAj5LT9H.js.map +1 -0
- package/dashboard/dist/assets/index-CjxHCVxl.js +2 -0
- package/dashboard/dist/assets/{index-C90ZPzXk.js.map → index-CjxHCVxl.js.map} +1 -1
- package/dashboard/dist/assets/index-Cr0Rqsj7.js +2 -0
- package/dashboard/dist/assets/index-Cr0Rqsj7.js.map +1 -0
- package/dashboard/dist/assets/index-DZHNte4o.js +2 -0
- package/dashboard/dist/assets/{index-K40Qw1tk.js.map → index-DZHNte4o.js.map} +1 -1
- package/dashboard/dist/assets/{index-DNytWfSZ.js → index-VnYkWW8r.js} +2 -2
- package/dashboard/dist/assets/{index-DNytWfSZ.js.map → index-VnYkWW8r.js.map} +1 -1
- package/dashboard/dist/assets/{index-BbI2dzhJ.js → index-XGOmZ117.js} +2 -2
- package/dashboard/dist/assets/{index-BbI2dzhJ.js.map → index-XGOmZ117.js.map} +1 -1
- package/dashboard/dist/assets/index-ZjOUzWhc.js +2 -0
- package/dashboard/dist/assets/index-ZjOUzWhc.js.map +1 -0
- package/dashboard/dist/assets/{index-Cmgrk7PQ.js → index-puKKZ5l8.js} +71 -71
- package/dashboard/dist/assets/index-puKKZ5l8.js.map +1 -0
- package/dashboard/dist/assets/{index-BmVCyB6C.js → index-t5frSddy.js} +2 -2
- package/dashboard/dist/assets/{index-BmVCyB6C.js.map → index-t5frSddy.js.map} +1 -1
- package/dashboard/dist/assets/{mcp-CNE44TSp.js → mcp-DrWymhSu.js} +2 -2
- package/dashboard/dist/assets/{mcp-CNE44TSp.js.map → mcp-DrWymhSu.js.map} +1 -1
- package/dashboard/dist/assets/{mcp-query-RQX0uN-5.js → mcp-query-BhUxVEMS.js} +2 -2
- package/dashboard/dist/assets/{mcp-query-RQX0uN-5.js.map → mcp-query-BhUxVEMS.js.map} +1 -1
- package/dashboard/dist/assets/{mcp-runs-0w40bdz-.js → mcp-runs-DUfz4mLd.js} +2 -2
- package/dashboard/dist/assets/{mcp-runs-0w40bdz-.js.map → mcp-runs-DUfz4mLd.js.map} +1 -1
- package/dashboard/dist/assets/{namespaces-BbmdXuPp.js → namespaces-Cm6AY5sh.js} +2 -2
- package/dashboard/dist/assets/{namespaces-BbmdXuPp.js.map → namespaces-Cm6AY5sh.js.map} +1 -1
- package/dashboard/dist/assets/{roles-DoHYlhWH.js → roles-2v1Kc7BJ.js} +2 -2
- package/dashboard/dist/assets/{roles-DoHYlhWH.js.map → roles-2v1Kc7BJ.js.map} +1 -1
- package/dashboard/dist/assets/{settings-BAiJiCHS.js → settings-DTQNp6tH.js} +2 -2
- package/dashboard/dist/assets/{settings-BAiJiCHS.js.map → settings-DTQNp6tH.js.map} +1 -1
- package/dashboard/dist/assets/{tasks-CvroqHtm.js → tasks-CS1rgG1s.js} +2 -2
- package/dashboard/dist/assets/{tasks-CvroqHtm.js.map → tasks-CS1rgG1s.js.map} +1 -1
- package/dashboard/dist/assets/useEventHooks-BjXX8x3a.js +2 -0
- package/dashboard/dist/assets/{useEventHooks-BHMbzR_y.js.map → useEventHooks-BjXX8x3a.js.map} +1 -1
- package/dashboard/dist/assets/useYamlActivityEvents-BeR-nVWQ.js +2 -0
- package/dashboard/dist/assets/{useYamlActivityEvents-D56KV14X.js.map → useYamlActivityEvents-BeR-nVWQ.js.map} +1 -1
- package/dashboard/dist/assets/{users-CxIMy_xw.js → users-DYsdQ7Md.js} +2 -2
- package/dashboard/dist/assets/{users-CxIMy_xw.js.map → users-DYsdQ7Md.js.map} +1 -1
- package/dashboard/dist/assets/{vendor-icons-AFGxSeQS.js → vendor-icons-CWl44VA6.js} +77 -77
- package/dashboard/dist/assets/vendor-icons-CWl44VA6.js.map +1 -0
- package/dashboard/dist/assets/{workflows-yR9yais7.js → workflows-2QAXh3UD.js} +2 -2
- package/dashboard/dist/assets/{workflows-yR9yais7.js.map → workflows-2QAXh3UD.js.map} +1 -1
- package/dashboard/dist/assets/{yaml-workflows-QVF2MZ0l.js → yaml-workflows-sx8-UEE3.js} +2 -2
- package/dashboard/dist/assets/{yaml-workflows-QVF2MZ0l.js.map → yaml-workflows-sx8-UEE3.js.map} +1 -1
- package/dashboard/dist/index.html +3 -3
- package/docs/api/http/file-browser.md +101 -0
- package/docs/api/http/knowledge.md +203 -0
- package/docs/api/http/settings.md +6 -4
- package/docs/api/sdk/files.md +68 -0
- package/docs/api/sdk/knowledge.md +126 -0
- package/docs/api/sdk/settings.md +3 -2
- package/docs/cli.md +171 -0
- package/docs/compilation.md +16 -0
- package/docs/compiler.md +311 -0
- package/docs/events.md +19 -0
- package/docs/workflows.md +19 -0
- package/package.json +13 -2
- package/build/api/escalations.d.ts +0 -271
- package/build/api/escalations.js +0 -932
- package/build/api/workflows.d.ts +0 -158
- package/build/api/workflows.js +0 -414
- package/dashboard/dist/assets/AvailableEscalationsPage-CpBfGV1h.js +0 -2
- package/dashboard/dist/assets/AvailableEscalationsPage-CpBfGV1h.js.map +0 -1
- package/dashboard/dist/assets/McpQueryDetailPage-Czsmovqw.js +0 -5
- package/dashboard/dist/assets/McpQueryDetailPage-Czsmovqw.js.map +0 -1
- package/dashboard/dist/assets/RolesPage-kH-Njt25.js +0 -2
- package/dashboard/dist/assets/SwimlaneTimeline-Cfe-xQRX.js +0 -2
- package/dashboard/dist/assets/SwimlaneTimeline-Cfe-xQRX.js.map +0 -1
- package/dashboard/dist/assets/YamlWorkflowsPage-BICF0fRO.js +0 -2
- package/dashboard/dist/assets/YamlWorkflowsPage-BICF0fRO.js.map +0 -1
- package/dashboard/dist/assets/helpers-rMEcLwKs.js +0 -2
- package/dashboard/dist/assets/helpers-rMEcLwKs.js.map +0 -1
- package/dashboard/dist/assets/index-ABcJHHlN.js +0 -5
- package/dashboard/dist/assets/index-ABcJHHlN.js.map +0 -1
- package/dashboard/dist/assets/index-B91h_jZ0.js +0 -15
- package/dashboard/dist/assets/index-B91h_jZ0.js.map +0 -1
- package/dashboard/dist/assets/index-C1E5GTs9.js +0 -2
- package/dashboard/dist/assets/index-C1E5GTs9.js.map +0 -1
- package/dashboard/dist/assets/index-C90ZPzXk.js +0 -2
- package/dashboard/dist/assets/index-Cmgrk7PQ.js.map +0 -1
- package/dashboard/dist/assets/index-DeX-ezqf.css +0 -1
- package/dashboard/dist/assets/index-K40Qw1tk.js +0 -2
- package/dashboard/dist/assets/index-lCyNr5Xk.js +0 -2
- package/dashboard/dist/assets/index-lCyNr5Xk.js.map +0 -1
- package/dashboard/dist/assets/useEventHooks-BHMbzR_y.js +0 -2
- package/dashboard/dist/assets/useYamlActivityEvents-D56KV14X.js +0 -2
- package/dashboard/dist/assets/vendor-icons-AFGxSeQS.js.map +0 -1
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const express_1 = require("express");
|
|
37
|
+
const api = __importStar(require("../api/knowledge"));
|
|
38
|
+
const router = (0, express_1.Router)();
|
|
39
|
+
/**
|
|
40
|
+
* GET /api/knowledge/domains
|
|
41
|
+
* List all knowledge domains with entry counts.
|
|
42
|
+
*/
|
|
43
|
+
router.get('/domains', async (_req, res) => {
|
|
44
|
+
const result = await api.listDomains();
|
|
45
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
46
|
+
});
|
|
47
|
+
/**
|
|
48
|
+
* GET /api/knowledge/entries
|
|
49
|
+
* List entries within a domain.
|
|
50
|
+
* Query: ?domain=...&tags=a,b&limit=50&offset=0
|
|
51
|
+
*/
|
|
52
|
+
router.get('/entries', async (req, res) => {
|
|
53
|
+
const domain = req.query.domain;
|
|
54
|
+
if (!domain) {
|
|
55
|
+
res.status(400).json({ error: 'domain is required' });
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
const tags = req.query.tags
|
|
59
|
+
? req.query.tags.split(',').map((t) => t.trim()).filter(Boolean)
|
|
60
|
+
: undefined;
|
|
61
|
+
const search = req.query.search || undefined;
|
|
62
|
+
const limit = req.query.limit ? parseInt(req.query.limit, 10) : undefined;
|
|
63
|
+
const offset = req.query.offset ? parseInt(req.query.offset, 10) : undefined;
|
|
64
|
+
const result = await api.listEntries({ domain, tags, search, limit, offset });
|
|
65
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
66
|
+
});
|
|
67
|
+
/**
|
|
68
|
+
* GET /api/knowledge/entry
|
|
69
|
+
* Get a single knowledge entry.
|
|
70
|
+
* Query: ?domain=...&key=...
|
|
71
|
+
*/
|
|
72
|
+
router.get('/entry', async (req, res) => {
|
|
73
|
+
const domain = req.query.domain;
|
|
74
|
+
const key = req.query.key;
|
|
75
|
+
if (!domain || !key) {
|
|
76
|
+
res.status(400).json({ error: 'domain and key are required' });
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
const result = await api.getEntry({ domain, key });
|
|
80
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
81
|
+
});
|
|
82
|
+
/**
|
|
83
|
+
* POST /api/knowledge/entry
|
|
84
|
+
* Create or update a knowledge entry.
|
|
85
|
+
* Body: { domain, key, data, tags? }
|
|
86
|
+
*/
|
|
87
|
+
router.post('/entry', async (req, res) => {
|
|
88
|
+
const { domain, key, data, tags, replace } = req.body;
|
|
89
|
+
if (!domain || !key || !data) {
|
|
90
|
+
res.status(400).json({ error: 'domain, key, and data are required' });
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
const result = await api.storeEntry({ domain, key, data, tags, replace: !!replace });
|
|
94
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
95
|
+
});
|
|
96
|
+
/**
|
|
97
|
+
* DELETE /api/knowledge/entry
|
|
98
|
+
* Delete a knowledge entry.
|
|
99
|
+
* Query: ?domain=...&key=...
|
|
100
|
+
*/
|
|
101
|
+
router.delete('/entry', async (req, res) => {
|
|
102
|
+
const domain = req.query.domain;
|
|
103
|
+
const key = req.query.key;
|
|
104
|
+
if (!domain || !key) {
|
|
105
|
+
res.status(400).json({ error: 'domain and key are required' });
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
const result = await api.deleteEntry({ domain, key });
|
|
109
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
110
|
+
});
|
|
111
|
+
/**
|
|
112
|
+
* PUT /api/knowledge/field
|
|
113
|
+
* Set a value at a specific JSONB path without clobbering siblings.
|
|
114
|
+
* Body: { domain, key, path, value, tags? }
|
|
115
|
+
*/
|
|
116
|
+
router.put('/field', async (req, res) => {
|
|
117
|
+
const { domain, key, path, value, tags } = req.body;
|
|
118
|
+
if (!domain || !key || !path || value === undefined) {
|
|
119
|
+
res.status(400).json({ error: 'domain, key, path, and value are required' });
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const result = await api.setField({ domain, key, path, value, tags });
|
|
123
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
124
|
+
});
|
|
125
|
+
/**
|
|
126
|
+
* DELETE /api/knowledge/field
|
|
127
|
+
* Remove a specific field at a JSONB path.
|
|
128
|
+
* Query: ?domain=...&key=...&path=...
|
|
129
|
+
*/
|
|
130
|
+
router.delete('/field', async (req, res) => {
|
|
131
|
+
const domain = req.query.domain;
|
|
132
|
+
const key = req.query.key;
|
|
133
|
+
const path = req.query.path;
|
|
134
|
+
if (!domain || !key || !path) {
|
|
135
|
+
res.status(400).json({ error: 'domain, key, and path are required' });
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
const result = await api.removeField({ domain, key, path });
|
|
139
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
140
|
+
});
|
|
141
|
+
exports.default = router;
|
|
@@ -80,6 +80,15 @@ router.post('/direct', async (req, res) => {
|
|
|
80
80
|
const result = await api.createYamlWorkflowDirect(req.body);
|
|
81
81
|
res.status(result.status).json(result.data ?? { error: result.error });
|
|
82
82
|
});
|
|
83
|
+
/**
|
|
84
|
+
* POST /api/yaml-workflows/from-durable
|
|
85
|
+
* Compile a durable TypeScript workflow into a YAML DAG.
|
|
86
|
+
* Body: { source, is_file_path?, workflow_name, name, description?, app_id?, subscribes?, tags? }
|
|
87
|
+
*/
|
|
88
|
+
router.post('/from-durable', async (req, res) => {
|
|
89
|
+
const result = await api.createYamlWorkflowFromDurable(req.body);
|
|
90
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
91
|
+
});
|
|
83
92
|
// -- Parameterized routes --
|
|
84
93
|
/**
|
|
85
94
|
* GET /api/yaml-workflows/:id
|
package/build/sdk/index.d.ts
CHANGED
|
@@ -16,6 +16,8 @@ import * as workflowSetsApi from '../api/workflow-sets';
|
|
|
16
16
|
import * as dbaApi from '../api/dba';
|
|
17
17
|
import * as namespacesApi from '../api/namespaces';
|
|
18
18
|
import * as maintenanceApi from '../api/maintenance';
|
|
19
|
+
import * as filesApi from '../api/files';
|
|
20
|
+
import * as knowledgeApi from '../api/knowledge';
|
|
19
21
|
import type { LTApiAuth, LTApiResult } from '../types/sdk';
|
|
20
22
|
import type { LTEvent, LTEventType } from '../types/events';
|
|
21
23
|
/**
|
|
@@ -330,6 +332,21 @@ export declare function createClient(options?: LTClientOptions): {
|
|
|
330
332
|
getConfig: typeof maintenanceApi.getMaintenanceConfig;
|
|
331
333
|
updateConfig: typeof maintenanceApi.updateMaintenanceConfig;
|
|
332
334
|
};
|
|
335
|
+
files: {
|
|
336
|
+
browse: typeof filesApi.browseFiles;
|
|
337
|
+
getMetadata: typeof filesApi.getFileMetadata;
|
|
338
|
+
delete: typeof filesApi.deleteFile;
|
|
339
|
+
generateSignedUrl: typeof filesApi.generateSignedUrl;
|
|
340
|
+
};
|
|
341
|
+
knowledge: {
|
|
342
|
+
listDomains: typeof knowledgeApi.listDomains;
|
|
343
|
+
listEntries: typeof knowledgeApi.listEntries;
|
|
344
|
+
getEntry: typeof knowledgeApi.getEntry;
|
|
345
|
+
storeEntry: typeof knowledgeApi.storeEntry;
|
|
346
|
+
setField: typeof knowledgeApi.setField;
|
|
347
|
+
removeField: typeof knowledgeApi.removeField;
|
|
348
|
+
deleteEntry: typeof knowledgeApi.deleteEntry;
|
|
349
|
+
};
|
|
333
350
|
events: {
|
|
334
351
|
/**
|
|
335
352
|
* Subscribe to Long Tail events.
|
package/build/sdk/index.js
CHANGED
|
@@ -52,6 +52,8 @@ const workflowSetsApi = __importStar(require("../api/workflow-sets"));
|
|
|
52
52
|
const dbaApi = __importStar(require("../api/dba"));
|
|
53
53
|
const namespacesApi = __importStar(require("../api/namespaces"));
|
|
54
54
|
const maintenanceApi = __importStar(require("../api/maintenance"));
|
|
55
|
+
const filesApi = __importStar(require("../api/files"));
|
|
56
|
+
const knowledgeApi = __importStar(require("../api/knowledge"));
|
|
55
57
|
const events_1 = require("../lib/events");
|
|
56
58
|
const callback_1 = require("../lib/events/callback");
|
|
57
59
|
/** Bind auth context to a function that expects it as the last argument. */
|
|
@@ -275,6 +277,23 @@ function createClient(options = {}) {
|
|
|
275
277
|
getConfig: maintenanceApi.getMaintenanceConfig,
|
|
276
278
|
updateConfig: maintenanceApi.updateMaintenanceConfig,
|
|
277
279
|
},
|
|
280
|
+
// ── Files ──────────────────────────────────────────────────────────────
|
|
281
|
+
files: {
|
|
282
|
+
browse: filesApi.browseFiles,
|
|
283
|
+
getMetadata: filesApi.getFileMetadata,
|
|
284
|
+
delete: filesApi.deleteFile,
|
|
285
|
+
generateSignedUrl: filesApi.generateSignedUrl,
|
|
286
|
+
},
|
|
287
|
+
// ── Knowledge ─────────────────────────────────────────────────────────
|
|
288
|
+
knowledge: {
|
|
289
|
+
listDomains: knowledgeApi.listDomains,
|
|
290
|
+
listEntries: knowledgeApi.listEntries,
|
|
291
|
+
getEntry: knowledgeApi.getEntry,
|
|
292
|
+
storeEntry: knowledgeApi.storeEntry,
|
|
293
|
+
setField: knowledgeApi.setField,
|
|
294
|
+
removeField: knowledgeApi.removeField,
|
|
295
|
+
deleteEntry: knowledgeApi.deleteEntry,
|
|
296
|
+
},
|
|
278
297
|
// ── Events ─────────────────────────────────────────────────────────────
|
|
279
298
|
events: {
|
|
280
299
|
/**
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { LTMcpToolManifest } from '../../../types';
|
|
2
|
+
/**
|
|
3
|
+
* Dispatch a tool call directly to a built-in server's handler,
|
|
4
|
+
* bypassing MCP Client/Transport entirely. Returns null if the server
|
|
5
|
+
* or tool is not a built-in — caller should fall through to MCP transport.
|
|
6
|
+
*
|
|
7
|
+
* Each built-in server is lazily instantiated once and cached. Tool handlers
|
|
8
|
+
* are called via server._registeredTools[toolName].handler(args). This
|
|
9
|
+
* eliminates the InMemoryTransport bottleneck under concurrent load.
|
|
10
|
+
*/
|
|
11
|
+
export declare function dispatchBuiltinTool(serverId: string, toolName: string, args: Record<string, any>): Promise<{
|
|
12
|
+
dispatched: true;
|
|
13
|
+
result: any;
|
|
14
|
+
} | null>;
|
|
15
|
+
/**
|
|
16
|
+
* List tools from a connected server.
|
|
17
|
+
*/
|
|
18
|
+
export declare function listServerTools(serverId: string): Promise<LTMcpToolManifest[]>;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.dispatchBuiltinTool = dispatchBuiltinTool;
|
|
4
|
+
exports.listServerTools = listServerTools;
|
|
5
|
+
const logger_1 = require("../../../lib/logger");
|
|
6
|
+
const connection_lifecycle_1 = require("./connection-lifecycle");
|
|
7
|
+
/**
|
|
8
|
+
* Dispatch a tool call directly to a built-in server's handler,
|
|
9
|
+
* bypassing MCP Client/Transport entirely. Returns null if the server
|
|
10
|
+
* or tool is not a built-in — caller should fall through to MCP transport.
|
|
11
|
+
*
|
|
12
|
+
* Each built-in server is lazily instantiated once and cached. Tool handlers
|
|
13
|
+
* are called via server._registeredTools[toolName].handler(args). This
|
|
14
|
+
* eliminates the InMemoryTransport bottleneck under concurrent load.
|
|
15
|
+
*/
|
|
16
|
+
async function dispatchBuiltinTool(serverId, toolName, args) {
|
|
17
|
+
const builtinFactories = (0, connection_lifecycle_1.getBuiltinFactories)();
|
|
18
|
+
const builtinServers = (0, connection_lifecycle_1.getBuiltinServers)();
|
|
19
|
+
// Normalize and match against builtin factories
|
|
20
|
+
const norm = (s) => s.replace(/[^a-zA-Z0-9]/g, '').toLowerCase();
|
|
21
|
+
const normId = norm(serverId);
|
|
22
|
+
let matchedName = null;
|
|
23
|
+
for (const [name] of builtinFactories) {
|
|
24
|
+
const normName = norm(name);
|
|
25
|
+
if (normName === normId || normName.includes(normId) || normId.includes(normName)) {
|
|
26
|
+
matchedName = name;
|
|
27
|
+
break;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
if (!matchedName)
|
|
31
|
+
return null;
|
|
32
|
+
// Lazily create and cache the server instance
|
|
33
|
+
if (!builtinServers.has(matchedName)) {
|
|
34
|
+
const factory = builtinFactories.get(matchedName);
|
|
35
|
+
const server = await factory();
|
|
36
|
+
builtinServers.set(matchedName, server);
|
|
37
|
+
logger_1.loggerRegistry.info(`[lt-mcp:builtin] ${matchedName} ready (direct dispatch)`);
|
|
38
|
+
}
|
|
39
|
+
const server = builtinServers.get(matchedName);
|
|
40
|
+
const tool = server._registeredTools?.[toolName];
|
|
41
|
+
if (!tool?.handler)
|
|
42
|
+
return null;
|
|
43
|
+
// Call the handler directly — no transport, no JSON-RPC.
|
|
44
|
+
// Tool handlers return MCP-shaped responses: { content: [{ type: 'text', text: '...' }] }
|
|
45
|
+
// Parse the text content the same way callServerTool does.
|
|
46
|
+
const mcpResponse = await tool.handler(args);
|
|
47
|
+
let parsed = mcpResponse;
|
|
48
|
+
if (mcpResponse && Array.isArray(mcpResponse.content)) {
|
|
49
|
+
const textContent = mcpResponse.content.find((c) => c.type === 'text');
|
|
50
|
+
if (textContent && 'text' in textContent) {
|
|
51
|
+
try {
|
|
52
|
+
parsed = JSON.parse(textContent.text);
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
parsed = mcpResponse.isError ? { error: textContent.text } : textContent.text;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
const isError = parsed && typeof parsed === 'object' && 'error' in parsed;
|
|
60
|
+
logger_1.loggerRegistry.debug(`[lt-mcp:builtin] ${matchedName}/${toolName} ok=${!isError} resultKeys=[${typeof parsed === 'object' && parsed ? Object.keys(parsed).join(',') : 'raw'}]`);
|
|
61
|
+
return { dispatched: true, result: parsed };
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* List tools from a connected server.
|
|
65
|
+
*/
|
|
66
|
+
async function listServerTools(serverId) {
|
|
67
|
+
const clients = (0, connection_lifecycle_1.getClients)();
|
|
68
|
+
const client = clients.get(serverId);
|
|
69
|
+
if (!client) {
|
|
70
|
+
throw new Error(`MCP server ${serverId} is not connected`);
|
|
71
|
+
}
|
|
72
|
+
const { tools } = await client.listTools();
|
|
73
|
+
return tools.map((t) => ({
|
|
74
|
+
name: t.name,
|
|
75
|
+
description: t.description || '',
|
|
76
|
+
inputSchema: t.inputSchema || {},
|
|
77
|
+
}));
|
|
78
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Client } from '@modelcontextprotocol/sdk/client/index.js';
|
|
2
|
+
import type { LTMcpServerRecord } from '../../../types';
|
|
3
|
+
/** Read-only access to the clients map for sibling modules. */
|
|
4
|
+
export declare function getClients(): Map<string, Client>;
|
|
5
|
+
/** Read-only access to the builtin factories map for sibling modules. */
|
|
6
|
+
export declare function getBuiltinFactories(): Map<string, () => Promise<any>>;
|
|
7
|
+
/** Read-only access to the builtin servers map for sibling modules. */
|
|
8
|
+
export declare function getBuiltinServers(): Map<string, any>;
|
|
9
|
+
/**
|
|
10
|
+
* Register a built-in server factory so it can be auto-connected
|
|
11
|
+
* when callServerTool is invoked with its name.
|
|
12
|
+
*/
|
|
13
|
+
export declare function registerBuiltinServer(name: string, factory: () => Promise<any>): void;
|
|
14
|
+
/**
|
|
15
|
+
* Connect to a registered MCP server.
|
|
16
|
+
* Creates the appropriate transport based on transport_type,
|
|
17
|
+
* connects, and caches tool manifest in DB.
|
|
18
|
+
*/
|
|
19
|
+
export declare function connectToServer(server: LTMcpServerRecord): Promise<Client>;
|
|
20
|
+
/**
|
|
21
|
+
* Disconnect from a specific server.
|
|
22
|
+
*/
|
|
23
|
+
export declare function disconnectFromServer(serverId: string): Promise<void>;
|
|
24
|
+
/**
|
|
25
|
+
* Resolve a server by ID or name, auto-connecting built-in servers if needed.
|
|
26
|
+
* Returns the client or null if not found.
|
|
27
|
+
*
|
|
28
|
+
* Built-in servers are connected once under their canonical factory name.
|
|
29
|
+
* Alias lookups (e.g. 'translation' matching 'long-tail-translation') reuse
|
|
30
|
+
* the same client instance to avoid double-connecting the singleton server.
|
|
31
|
+
*/
|
|
32
|
+
export declare function resolveClient(serverId: string): Promise<Client | null>;
|
|
33
|
+
/**
|
|
34
|
+
* Connect to all auto-connect servers.
|
|
35
|
+
*/
|
|
36
|
+
export declare function connectAutoServers(): Promise<void>;
|
|
37
|
+
/**
|
|
38
|
+
* Disconnect all clients.
|
|
39
|
+
*/
|
|
40
|
+
export declare function disconnectAll(): Promise<void>;
|
|
41
|
+
/**
|
|
42
|
+
* Check if a server is connected.
|
|
43
|
+
*/
|
|
44
|
+
export declare function isConnected(serverId: string): boolean;
|
|
45
|
+
/**
|
|
46
|
+
* Clear all state. Used in tests.
|
|
47
|
+
*/
|
|
48
|
+
export declare function clear(): void;
|
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.getClients = getClients;
|
|
37
|
+
exports.getBuiltinFactories = getBuiltinFactories;
|
|
38
|
+
exports.getBuiltinServers = getBuiltinServers;
|
|
39
|
+
exports.registerBuiltinServer = registerBuiltinServer;
|
|
40
|
+
exports.connectToServer = connectToServer;
|
|
41
|
+
exports.disconnectFromServer = disconnectFromServer;
|
|
42
|
+
exports.resolveClient = resolveClient;
|
|
43
|
+
exports.connectAutoServers = connectAutoServers;
|
|
44
|
+
exports.disconnectAll = disconnectAll;
|
|
45
|
+
exports.isConnected = isConnected;
|
|
46
|
+
exports.clear = clear;
|
|
47
|
+
const index_js_1 = require("@modelcontextprotocol/sdk/client/index.js");
|
|
48
|
+
const stdio_js_1 = require("@modelcontextprotocol/sdk/client/stdio.js");
|
|
49
|
+
const sse_js_1 = require("@modelcontextprotocol/sdk/client/sse.js");
|
|
50
|
+
const streamableHttp_js_1 = require("@modelcontextprotocol/sdk/client/streamableHttp.js");
|
|
51
|
+
const inMemory_js_1 = require("@modelcontextprotocol/sdk/inMemory.js");
|
|
52
|
+
const logger_1 = require("../../../lib/logger");
|
|
53
|
+
const mcpDbService = __importStar(require("../db"));
|
|
54
|
+
/** In-memory map of server ID/name to active MCP client */
|
|
55
|
+
const clients = new Map();
|
|
56
|
+
/**
|
|
57
|
+
* Built-in server factories -- keyed by server name.
|
|
58
|
+
* These are in-process MCP servers that connect via InMemoryTransport
|
|
59
|
+
* rather than external stdio/SSE connections.
|
|
60
|
+
*/
|
|
61
|
+
const builtinFactories = new Map();
|
|
62
|
+
/**
|
|
63
|
+
* Cached built-in McpServer instances -- keyed by canonical server name.
|
|
64
|
+
* Used by dispatchBuiltinTool() to call tool handlers directly without
|
|
65
|
+
* going through MCP Client/Transport. One instance per server.
|
|
66
|
+
*/
|
|
67
|
+
const builtinServers = new Map();
|
|
68
|
+
/** Read-only access to the clients map for sibling modules. */
|
|
69
|
+
function getClients() {
|
|
70
|
+
return clients;
|
|
71
|
+
}
|
|
72
|
+
/** Read-only access to the builtin factories map for sibling modules. */
|
|
73
|
+
function getBuiltinFactories() {
|
|
74
|
+
return builtinFactories;
|
|
75
|
+
}
|
|
76
|
+
/** Read-only access to the builtin servers map for sibling modules. */
|
|
77
|
+
function getBuiltinServers() {
|
|
78
|
+
return builtinServers;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Register a built-in server factory so it can be auto-connected
|
|
82
|
+
* when callServerTool is invoked with its name.
|
|
83
|
+
*/
|
|
84
|
+
function registerBuiltinServer(name, factory) {
|
|
85
|
+
builtinFactories.set(name, factory);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Connect to a registered MCP server.
|
|
89
|
+
* Creates the appropriate transport based on transport_type,
|
|
90
|
+
* connects, and caches tool manifest in DB.
|
|
91
|
+
*/
|
|
92
|
+
async function connectToServer(server) {
|
|
93
|
+
if (clients.has(server.id)) {
|
|
94
|
+
return clients.get(server.id);
|
|
95
|
+
}
|
|
96
|
+
// Built-in servers use InMemoryTransport via their registered factory
|
|
97
|
+
if (server.transport_config?.builtin) {
|
|
98
|
+
// Find matching factory by server name
|
|
99
|
+
for (const [name, factory] of builtinFactories) {
|
|
100
|
+
if (server.name === name || name.includes(server.name) || server.name.includes(name)) {
|
|
101
|
+
// Reuse existing client if factory was already connected
|
|
102
|
+
if (clients.has(name)) {
|
|
103
|
+
clients.set(server.id, clients.get(name));
|
|
104
|
+
await mcpDbService.updateMcpServerStatus(server.id, 'connected');
|
|
105
|
+
return clients.get(name);
|
|
106
|
+
}
|
|
107
|
+
const srv = await factory();
|
|
108
|
+
const [clientTransport, serverTransport] = inMemory_js_1.InMemoryTransport.createLinkedPair();
|
|
109
|
+
await srv.connect(serverTransport);
|
|
110
|
+
const client = new index_js_1.Client({ name: `builtin-${name}`, version: '1.0.0' });
|
|
111
|
+
await client.connect(clientTransport);
|
|
112
|
+
clients.set(name, client);
|
|
113
|
+
clients.set(server.id, client);
|
|
114
|
+
// Cache the tool manifest
|
|
115
|
+
const { tools } = await client.listTools();
|
|
116
|
+
const manifest = tools.map((t) => ({
|
|
117
|
+
name: t.name,
|
|
118
|
+
description: t.description || '',
|
|
119
|
+
inputSchema: t.inputSchema || {},
|
|
120
|
+
}));
|
|
121
|
+
await mcpDbService.updateMcpServerStatus(server.id, 'connected', manifest);
|
|
122
|
+
logger_1.loggerRegistry.info(`[lt-mcp:client] connected builtin server: ${name} (${manifest.length} tools)`);
|
|
123
|
+
return client;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
throw new Error(`No builtin factory registered for server: ${server.name}`);
|
|
127
|
+
}
|
|
128
|
+
const client = new index_js_1.Client({ name: 'long-tail', version: '1.0.0' });
|
|
129
|
+
let transport;
|
|
130
|
+
const ttype = server.transport_type;
|
|
131
|
+
if (ttype === 'stdio') {
|
|
132
|
+
transport = new stdio_js_1.StdioClientTransport({
|
|
133
|
+
command: server.transport_config.command,
|
|
134
|
+
args: server.transport_config.args || [],
|
|
135
|
+
env: server.transport_config.env,
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
else if (ttype === 'streamable-http') {
|
|
139
|
+
transport = new streamableHttp_js_1.StreamableHTTPClientTransport(new URL(server.transport_config.url));
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
transport = new sse_js_1.SSEClientTransport(new URL(server.transport_config.url));
|
|
143
|
+
}
|
|
144
|
+
await client.connect(transport);
|
|
145
|
+
clients.set(server.id, client);
|
|
146
|
+
// Cache the tool manifest
|
|
147
|
+
const { tools } = await client.listTools();
|
|
148
|
+
const manifest = tools.map((t) => ({
|
|
149
|
+
name: t.name,
|
|
150
|
+
description: t.description || '',
|
|
151
|
+
inputSchema: t.inputSchema || {},
|
|
152
|
+
}));
|
|
153
|
+
await mcpDbService.updateMcpServerStatus(server.id, 'connected', manifest);
|
|
154
|
+
logger_1.loggerRegistry.info(`[lt-mcp:client] connected to ${server.name} (${manifest.length} tools)`);
|
|
155
|
+
return client;
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Disconnect from a specific server.
|
|
159
|
+
*/
|
|
160
|
+
async function disconnectFromServer(serverId) {
|
|
161
|
+
const client = clients.get(serverId);
|
|
162
|
+
if (client) {
|
|
163
|
+
await client.close();
|
|
164
|
+
clients.delete(serverId);
|
|
165
|
+
await mcpDbService.updateMcpServerStatus(serverId, 'disconnected');
|
|
166
|
+
logger_1.loggerRegistry.info(`[lt-mcp:client] disconnected from ${serverId}`);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Resolve a server by ID or name, auto-connecting built-in servers if needed.
|
|
171
|
+
* Returns the client or null if not found.
|
|
172
|
+
*
|
|
173
|
+
* Built-in servers are connected once under their canonical factory name.
|
|
174
|
+
* Alias lookups (e.g. 'translation' matching 'long-tail-translation') reuse
|
|
175
|
+
* the same client instance to avoid double-connecting the singleton server.
|
|
176
|
+
*/
|
|
177
|
+
async function resolveClient(serverId) {
|
|
178
|
+
// 1. Direct lookup (by UUID or name)
|
|
179
|
+
if (clients.has(serverId))
|
|
180
|
+
return clients.get(serverId);
|
|
181
|
+
// 2. Check built-in server factories -- exact match first, then fuzzy
|
|
182
|
+
// Normalize strips non-alphanumeric chars so hyphens and underscores
|
|
183
|
+
// match (e.g., "long_tail_vision" matches "long-tail-vision").
|
|
184
|
+
const norm = (s) => s.replace(/[^a-zA-Z0-9]/g, '').toLowerCase();
|
|
185
|
+
let matchedName = null;
|
|
186
|
+
if (builtinFactories.has(serverId)) {
|
|
187
|
+
matchedName = serverId;
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
const normId = norm(serverId);
|
|
191
|
+
for (const [name] of builtinFactories) {
|
|
192
|
+
const normName = norm(name);
|
|
193
|
+
if (normName.includes(normId) || normId.includes(normName)) {
|
|
194
|
+
matchedName = name;
|
|
195
|
+
break;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
if (matchedName) {
|
|
200
|
+
const factory = builtinFactories.get(matchedName);
|
|
201
|
+
// Check if we already connected this factory under its canonical name
|
|
202
|
+
if (clients.has(matchedName)) {
|
|
203
|
+
// Alias the serverId to the existing client so future lookups are instant
|
|
204
|
+
clients.set(serverId, clients.get(matchedName));
|
|
205
|
+
return clients.get(matchedName);
|
|
206
|
+
}
|
|
207
|
+
const server = await factory();
|
|
208
|
+
const [clientTransport, serverTransport] = inMemory_js_1.InMemoryTransport.createLinkedPair();
|
|
209
|
+
await server.connect(serverTransport);
|
|
210
|
+
const client = new index_js_1.Client({ name: `builtin-${matchedName}`, version: '1.0.0' });
|
|
211
|
+
await client.connect(clientTransport);
|
|
212
|
+
// Cache under both the canonical name and the requested serverId
|
|
213
|
+
clients.set(matchedName, client);
|
|
214
|
+
if (serverId !== matchedName)
|
|
215
|
+
clients.set(serverId, client);
|
|
216
|
+
logger_1.loggerRegistry.info(`[lt-mcp:client] auto-connected built-in server: ${matchedName} (as '${serverId}')`);
|
|
217
|
+
return client;
|
|
218
|
+
}
|
|
219
|
+
// 3. Look up in DB by ID or name, then try to match a built-in factory
|
|
220
|
+
try {
|
|
221
|
+
const dbServer = (await mcpDbService.getMcpServer(serverId)) ||
|
|
222
|
+
(await mcpDbService.getMcpServerByName(serverId));
|
|
223
|
+
if (dbServer) {
|
|
224
|
+
// Already connected under its DB id?
|
|
225
|
+
if (clients.has(dbServer.id)) {
|
|
226
|
+
clients.set(serverId, clients.get(dbServer.id));
|
|
227
|
+
return clients.get(dbServer.id);
|
|
228
|
+
}
|
|
229
|
+
// Match DB server name to a built-in factory
|
|
230
|
+
for (const [name, factory] of builtinFactories) {
|
|
231
|
+
if (dbServer.name === name || name.includes(dbServer.name) || dbServer.name.includes(name)) {
|
|
232
|
+
if (clients.has(name)) {
|
|
233
|
+
clients.set(serverId, clients.get(name));
|
|
234
|
+
return clients.get(name);
|
|
235
|
+
}
|
|
236
|
+
const srv = await factory();
|
|
237
|
+
const [clientTransport, serverTransport] = inMemory_js_1.InMemoryTransport.createLinkedPair();
|
|
238
|
+
await srv.connect(serverTransport);
|
|
239
|
+
const client = new index_js_1.Client({ name: `builtin-${name}`, version: '1.0.0' });
|
|
240
|
+
await client.connect(clientTransport);
|
|
241
|
+
clients.set(name, client);
|
|
242
|
+
clients.set(dbServer.id, client);
|
|
243
|
+
if (serverId !== name && serverId !== dbServer.id)
|
|
244
|
+
clients.set(serverId, client);
|
|
245
|
+
logger_1.loggerRegistry.info(`[lt-mcp:client] auto-connected built-in server: ${name} (via DB id '${serverId}')`);
|
|
246
|
+
return client;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
catch {
|
|
252
|
+
// DB lookup failed -- not critical
|
|
253
|
+
}
|
|
254
|
+
return null;
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* Connect to all auto-connect servers.
|
|
258
|
+
*/
|
|
259
|
+
async function connectAutoServers() {
|
|
260
|
+
const servers = await mcpDbService.getAutoConnectServers();
|
|
261
|
+
for (const server of servers) {
|
|
262
|
+
// Skip built-in servers -- they auto-connect lazily via resolveClient()
|
|
263
|
+
// on first tool call using InMemoryTransport, not stdio/SSE.
|
|
264
|
+
if (server.transport_config?.builtin) {
|
|
265
|
+
continue;
|
|
266
|
+
}
|
|
267
|
+
try {
|
|
268
|
+
await connectToServer(server);
|
|
269
|
+
}
|
|
270
|
+
catch (err) {
|
|
271
|
+
logger_1.loggerRegistry.error(`[lt-mcp:client] failed to connect to ${server.name}: ${err.message}`);
|
|
272
|
+
await mcpDbService.updateMcpServerStatus(server.id, 'error');
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
/**
|
|
277
|
+
* Disconnect all clients.
|
|
278
|
+
*/
|
|
279
|
+
async function disconnectAll() {
|
|
280
|
+
for (const [serverId] of clients) {
|
|
281
|
+
await disconnectFromServer(serverId);
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
/**
|
|
285
|
+
* Check if a server is connected.
|
|
286
|
+
*/
|
|
287
|
+
function isConnected(serverId) {
|
|
288
|
+
return clients.has(serverId);
|
|
289
|
+
}
|
|
290
|
+
/**
|
|
291
|
+
* Clear all state. Used in tests.
|
|
292
|
+
*/
|
|
293
|
+
function clear() {
|
|
294
|
+
clients.clear();
|
|
295
|
+
builtinServers.clear();
|
|
296
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { LTMcpToolManifest } from '../../../types';
|
|
2
|
+
/**
|
|
3
|
+
* Test connectivity to an MCP server without persisting.
|
|
4
|
+
* Creates a temporary client, connects, lists tools, then disconnects.
|
|
5
|
+
*/
|
|
6
|
+
export declare function testConnection(transportType: 'stdio' | 'sse' | 'streamable-http', transportConfig: Record<string, any>): Promise<{
|
|
7
|
+
success: boolean;
|
|
8
|
+
tools: LTMcpToolManifest[];
|
|
9
|
+
error?: string;
|
|
10
|
+
}>;
|