@hotmeshio/long-tail 0.1.14 → 0.1.16
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 +6 -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} +99 -380
- 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/index.d.ts +1 -1
- 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/db/schemas/schemas/001_schema.sql +485 -0
- package/build/lib/db/schemas/schemas/002_seed.sql +92 -0
- package/build/lib/events/socketio.d.ts +12 -0
- package/build/lib/events/socketio.js +24 -1
- 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 +4 -0
- package/build/routes/knowledge.d.ts +2 -0
- package/build/routes/knowledge.js +141 -0
- package/build/routes/nats-credentials.d.ts +2 -0
- package/build/routes/nats-credentials.js +22 -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/services/yaml-workflow/workers/register.js +4 -2
- package/build/start/adapters.js +4 -1
- package/build/start/socket-auth.d.ts +13 -0
- package/build/start/socket-auth.js +32 -0
- 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-Bprul9Eb.js} +2 -2
- package/dashboard/dist/assets/{AdminDashboard-Cngijp4Q.js.map → AdminDashboard-Bprul9Eb.js.map} +1 -1
- package/dashboard/dist/assets/AvailableEscalationsPage-H_z5mC10.js +2 -0
- package/dashboard/dist/assets/AvailableEscalationsPage-H_z5mC10.js.map +1 -0
- package/dashboard/dist/assets/{BotPicker-B8Uvw9Si.js → BotPicker-DcvILNUf.js} +2 -2
- package/dashboard/dist/assets/{BotPicker-B8Uvw9Si.js.map → BotPicker-DcvILNUf.js.map} +1 -1
- package/dashboard/dist/assets/{CollapsibleSection-DiFPuWOY.js → CollapsibleSection-BWPbzgEe.js} +2 -2
- package/dashboard/dist/assets/{CollapsibleSection-DiFPuWOY.js.map → CollapsibleSection-BWPbzgEe.js.map} +1 -1
- package/dashboard/dist/assets/{ConfirmDeleteModal-CpXG9uyu.js → ConfirmDeleteModal-Cy6KVLfC.js} +2 -2
- package/dashboard/dist/assets/{ConfirmDeleteModal-CpXG9uyu.js.map → ConfirmDeleteModal-Cy6KVLfC.js.map} +1 -1
- package/dashboard/dist/assets/{CopyableId-DKsTR9lK.js → CopyableId-CRED8hvk.js} +2 -2
- package/dashboard/dist/assets/{CopyableId-DKsTR9lK.js.map → CopyableId-CRED8hvk.js.map} +1 -1
- package/dashboard/dist/assets/{CredentialsPage-DlS7Kf40.js → CredentialsPage-BUdvxiE3.js} +2 -2
- package/dashboard/dist/assets/{CredentialsPage-DlS7Kf40.js.map → CredentialsPage-BUdvxiE3.js.map} +1 -1
- package/dashboard/dist/assets/{CustomDurationPicker-B-9eW3pm.js → CustomDurationPicker-eOk2EqQ5.js} +2 -2
- package/dashboard/dist/assets/{CustomDurationPicker-B-9eW3pm.js.map → CustomDurationPicker-eOk2EqQ5.js.map} +1 -1
- package/dashboard/dist/assets/{DataTable-DkOokbtL.js → DataTable-bd2PTBJd.js} +2 -2
- package/dashboard/dist/assets/{DataTable-DkOokbtL.js.map → DataTable-bd2PTBJd.js.map} +1 -1
- package/dashboard/dist/assets/{ElapsedCell-DVtHqM-5.js → ElapsedCell-BGo8vyus.js} +2 -2
- package/dashboard/dist/assets/{ElapsedCell-DVtHqM-5.js.map → ElapsedCell-BGo8vyus.js.map} +1 -1
- package/dashboard/dist/assets/{EmptyState-C7KIMIbE.js → EmptyState-BygtU-Rh.js} +2 -2
- package/dashboard/dist/assets/{EmptyState-C7KIMIbE.js.map → EmptyState-BygtU-Rh.js.map} +1 -1
- package/dashboard/dist/assets/{EscalationsOverview-BMKBlkPx.js → EscalationsOverview-DUEcN5MP.js} +2 -2
- package/dashboard/dist/assets/{EscalationsOverview-BMKBlkPx.js.map → EscalationsOverview-DUEcN5MP.js.map} +1 -1
- package/dashboard/dist/assets/{EventTable-BYZ5OVdQ.js → EventTable-CmFhswLW.js} +2 -2
- package/dashboard/dist/assets/{EventTable-BYZ5OVdQ.js.map → EventTable-CmFhswLW.js.map} +1 -1
- package/dashboard/dist/assets/{FilterBar-C5r3n6YO.js → FilterBar-BQNzsd3A.js} +2 -2
- package/dashboard/dist/assets/{FilterBar-C5r3n6YO.js.map → FilterBar-BQNzsd3A.js.map} +1 -1
- package/dashboard/dist/assets/{ListToolbar-BGUajIsW.js → ListToolbar-OWOn-HiC.js} +2 -2
- package/dashboard/dist/assets/{ListToolbar-BGUajIsW.js.map → ListToolbar-OWOn-HiC.js.map} +1 -1
- package/dashboard/dist/assets/{McpOverview-B_kJYHea.js → McpOverview-OkEzvClD.js} +2 -2
- package/dashboard/dist/assets/{McpOverview-B_kJYHea.js.map → McpOverview-OkEzvClD.js.map} +1 -1
- package/dashboard/dist/assets/McpQueryDetailPage-C6Ih5sC_.js +5 -0
- package/dashboard/dist/assets/McpQueryDetailPage-C6Ih5sC_.js.map +1 -0
- package/dashboard/dist/assets/{McpQueryPage-BgAq_bQg.js → McpQueryPage-BAuOf5TL.js} +2 -2
- package/dashboard/dist/assets/{McpQueryPage-BgAq_bQg.js.map → McpQueryPage-BAuOf5TL.js.map} +1 -1
- package/dashboard/dist/assets/{McpRunDetailPage-B8c0OszR.js → McpRunDetailPage-DMeiG4i_.js} +2 -2
- package/dashboard/dist/assets/{McpRunDetailPage-B8c0OszR.js.map → McpRunDetailPage-DMeiG4i_.js.map} +1 -1
- package/dashboard/dist/assets/{McpRunsPage-BY8C6k78.js → McpRunsPage-CG3cNJh8.js} +2 -2
- package/dashboard/dist/assets/{McpRunsPage-BY8C6k78.js.map → McpRunsPage-CG3cNJh8.js.map} +1 -1
- package/dashboard/dist/assets/{Modal-E1yRnCeW.js → Modal-Dir9Rlnx.js} +2 -2
- package/dashboard/dist/assets/{Modal-E1yRnCeW.js.map → Modal-Dir9Rlnx.js.map} +1 -1
- package/dashboard/dist/assets/{OperatorDashboard-C8MSTzey.js → OperatorDashboard-OqWC6Azy.js} +2 -2
- package/dashboard/dist/assets/{OperatorDashboard-C8MSTzey.js.map → OperatorDashboard-OqWC6Azy.js.map} +1 -1
- package/dashboard/dist/assets/{PageHeader-Cm5HBQF_.js → PageHeader-FJIemmrC.js} +2 -2
- package/dashboard/dist/assets/{PageHeader-Cm5HBQF_.js.map → PageHeader-FJIemmrC.js.map} +1 -1
- package/dashboard/dist/assets/{PageHeaderWithStats-CNmWJFSN.js → PageHeaderWithStats-Br5y9qNO.js} +2 -2
- package/dashboard/dist/assets/{PageHeaderWithStats-CNmWJFSN.js.map → PageHeaderWithStats-Br5y9qNO.js.map} +1 -1
- package/dashboard/dist/assets/{PriorityBadge-HSI4RVhs.js → PriorityBadge-C7D5d_HY.js} +2 -2
- package/dashboard/dist/assets/{PriorityBadge-HSI4RVhs.js.map → PriorityBadge-C7D5d_HY.js.map} +1 -1
- package/dashboard/dist/assets/{ProcessDetailPage-Dln8622H.js → ProcessDetailPage-DZIP6grw.js} +2 -2
- package/dashboard/dist/assets/{ProcessDetailPage-Dln8622H.js.map → ProcessDetailPage-DZIP6grw.js.map} +1 -1
- package/dashboard/dist/assets/{ProcessesListPage-bIsd9N_h.js → ProcessesListPage-BQoPYkeB.js} +2 -2
- package/dashboard/dist/assets/{ProcessesListPage-bIsd9N_h.js.map → ProcessesListPage-BQoPYkeB.js.map} +1 -1
- package/dashboard/dist/assets/{RolePill-BVUp2bF0.js → RolePill-D6nMxMvp.js} +2 -2
- package/dashboard/dist/assets/{RolePill-BVUp2bF0.js.map → RolePill-D6nMxMvp.js.map} +1 -1
- package/dashboard/dist/assets/RolesPage-CwLnJFhy.js +2 -0
- package/dashboard/dist/assets/{RolesPage-kH-Njt25.js.map → RolesPage-CwLnJFhy.js.map} +1 -1
- package/dashboard/dist/assets/{RowActions-DbUJPfaW.js → RowActions-JqgAB0p3.js} +2 -2
- package/dashboard/dist/assets/{RowActions-DbUJPfaW.js.map → RowActions-JqgAB0p3.js.map} +1 -1
- package/dashboard/dist/assets/RunAsSelector-KAlKtitB.js +2 -0
- package/dashboard/dist/assets/RunAsSelector-KAlKtitB.js.map +1 -0
- package/dashboard/dist/assets/{StatCard-Bs3JbyAz.js → StatCard-B-WLhOaH.js} +2 -2
- package/dashboard/dist/assets/{StatCard-Bs3JbyAz.js.map → StatCard-B-WLhOaH.js.map} +1 -1
- package/dashboard/dist/assets/{StatusBadge-CakDdsCw.js → StatusBadge-DVCf2ncM.js} +2 -2
- package/dashboard/dist/assets/{StatusBadge-CakDdsCw.js.map → StatusBadge-DVCf2ncM.js.map} +1 -1
- package/dashboard/dist/assets/{StepIndicator-Cd_SG_yA.js → StepIndicator-D9Xvdf18.js} +2 -2
- package/dashboard/dist/assets/{StepIndicator-Cd_SG_yA.js.map → StepIndicator-D9Xvdf18.js.map} +1 -1
- package/dashboard/dist/assets/{StickyPagination-Bz0C18nC.js → StickyPagination-CJHMzYJj.js} +2 -2
- package/dashboard/dist/assets/{StickyPagination-Bz0C18nC.js.map → StickyPagination-CJHMzYJj.js.map} +1 -1
- package/dashboard/dist/assets/SwimlaneTimeline-YiXPDyEL.js +2 -0
- package/dashboard/dist/assets/SwimlaneTimeline-YiXPDyEL.js.map +1 -0
- package/dashboard/dist/assets/{TagInput-ClFhXG-U.js → TagInput-DcPnUnSJ.js} +2 -2
- package/dashboard/dist/assets/{TagInput-ClFhXG-U.js.map → TagInput-DcPnUnSJ.js.map} +1 -1
- package/dashboard/dist/assets/{TaskDetailPage-SuMBdARt.js → TaskDetailPage-DftmYWD7.js} +2 -2
- package/dashboard/dist/assets/{TaskDetailPage-SuMBdARt.js.map → TaskDetailPage-DftmYWD7.js.map} +1 -1
- package/dashboard/dist/assets/{TaskQueuePill-lJR1JW_W.js → TaskQueuePill-BzduBqwy.js} +2 -2
- package/dashboard/dist/assets/{TaskQueuePill-lJR1JW_W.js.map → TaskQueuePill-BzduBqwy.js.map} +1 -1
- package/dashboard/dist/assets/{TasksListPage-Dkq1Vtbt.js → TasksListPage-DeewV4Gp.js} +2 -2
- package/dashboard/dist/assets/{TasksListPage-Dkq1Vtbt.js.map → TasksListPage-DeewV4Gp.js.map} +1 -1
- package/dashboard/dist/assets/{TimeAgo-DgfDZ1pl.js → TimeAgo-DJZq-e4R.js} +2 -2
- package/dashboard/dist/assets/{TimeAgo-DgfDZ1pl.js.map → TimeAgo-DJZq-e4R.js.map} +1 -1
- package/dashboard/dist/assets/{TimestampCell-MpHZ1hMD.js → TimestampCell-Dx5uwGfS.js} +2 -2
- package/dashboard/dist/assets/{TimestampCell-MpHZ1hMD.js.map → TimestampCell-Dx5uwGfS.js.map} +1 -1
- package/dashboard/dist/assets/{UserName-DqsosA4B.js → UserName-CnGk7MgL.js} +2 -2
- package/dashboard/dist/assets/{UserName-DqsosA4B.js.map → UserName-CnGk7MgL.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowExecutionPage-CVlg38C3.js → WorkflowExecutionPage-CPQ0fIwf.js} +2 -2
- package/dashboard/dist/assets/{WorkflowExecutionPage-CVlg38C3.js.map → WorkflowExecutionPage-CPQ0fIwf.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowPill-CRpZhjGR.js → WorkflowPill-BrD5d1AG.js} +2 -2
- package/dashboard/dist/assets/{WorkflowPill-CRpZhjGR.js.map → WorkflowPill-BrD5d1AG.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowsDashboard-Ugzbs8mV.js → WorkflowsDashboard-BzjhABZP.js} +2 -2
- package/dashboard/dist/assets/{WorkflowsDashboard-Ugzbs8mV.js.map → WorkflowsDashboard-BzjhABZP.js.map} +1 -1
- package/dashboard/dist/assets/{WorkflowsOverview-CIp_lTNl.js → WorkflowsOverview-lBp2E6rN.js} +2 -2
- package/dashboard/dist/assets/{WorkflowsOverview-CIp_lTNl.js.map → WorkflowsOverview-lBp2E6rN.js.map} +1 -1
- package/dashboard/dist/assets/YamlWorkflowsPage-C_MkAp2i.js +2 -0
- package/dashboard/dist/assets/YamlWorkflowsPage-C_MkAp2i.js.map +1 -0
- package/dashboard/dist/assets/{bots-DPfUpVqI.js → bots-fc_O_YIq.js} +2 -2
- package/dashboard/dist/assets/{bots-DPfUpVqI.js.map → bots-fc_O_YIq.js.map} +1 -1
- package/dashboard/dist/assets/{escalation-RrCDbMC3.js → escalation-BYhLYHBz.js} +2 -2
- package/dashboard/dist/assets/{escalation-RrCDbMC3.js.map → escalation-BYhLYHBz.js.map} +1 -1
- package/dashboard/dist/assets/{escalation-columns-CDGa9wsD.js → escalation-columns-DjJyuC1g.js} +2 -2
- package/dashboard/dist/assets/{escalation-columns-CDGa9wsD.js.map → escalation-columns-DjJyuC1g.js.map} +1 -1
- package/dashboard/dist/assets/{helpers-ZSKqdkdS.js → helpers-CQG3Rh2y.js} +2 -2
- package/dashboard/dist/assets/{helpers-ZSKqdkdS.js.map → helpers-CQG3Rh2y.js.map} +1 -1
- package/dashboard/dist/assets/{index-DX6zxr6t.js → index-2nBhR7Dg.js} +2 -2
- package/dashboard/dist/assets/{index-DX6zxr6t.js.map → index-2nBhR7Dg.js.map} +1 -1
- package/dashboard/dist/assets/index-4IUoh_hd.js +2 -0
- package/dashboard/dist/assets/{index-K40Qw1tk.js.map → index-4IUoh_hd.js.map} +1 -1
- package/dashboard/dist/assets/index-B2CqPzLK.js +2 -0
- package/dashboard/dist/assets/index-B2CqPzLK.js.map +1 -0
- package/dashboard/dist/assets/index-B78xalb4.js +2 -0
- package/dashboard/dist/assets/index-B78xalb4.js.map +1 -0
- package/dashboard/dist/assets/index-BI8r69O_.js +2 -0
- package/dashboard/dist/assets/{index-C90ZPzXk.js.map → index-BI8r69O_.js.map} +1 -1
- package/dashboard/dist/assets/index-C5TUqJu0.css +1 -0
- package/dashboard/dist/assets/{index-BmVCyB6C.js → index-CUqCBBZG.js} +2 -2
- package/dashboard/dist/assets/{index-BmVCyB6C.js.map → index-CUqCBBZG.js.map} +1 -1
- package/dashboard/dist/assets/index-D51PaQZY.js +2 -0
- package/dashboard/dist/assets/index-D51PaQZY.js.map +1 -0
- package/dashboard/dist/assets/{index-BbI2dzhJ.js → index-DNtXXy1o.js} +2 -2
- package/dashboard/dist/assets/{index-BbI2dzhJ.js.map → index-DNtXXy1o.js.map} +1 -1
- package/dashboard/dist/assets/{index-DNytWfSZ.js → index-DR4qQvlW.js} +2 -2
- package/dashboard/dist/assets/{index-DNytWfSZ.js.map → index-DR4qQvlW.js.map} +1 -1
- package/dashboard/dist/assets/index-Dh0PCbR-.js +15 -0
- package/dashboard/dist/assets/index-Dh0PCbR-.js.map +1 -0
- package/dashboard/dist/assets/index-KYpLvJKB.js +5 -0
- package/dashboard/dist/assets/index-KYpLvJKB.js.map +1 -0
- package/dashboard/dist/assets/{index-Cmgrk7PQ.js → index-sNrqYt0Q.js} +73 -73
- package/dashboard/dist/assets/index-sNrqYt0Q.js.map +1 -0
- package/dashboard/dist/assets/{mcp-CNE44TSp.js → mcp-D2XfRh8v.js} +2 -2
- package/dashboard/dist/assets/{mcp-CNE44TSp.js.map → mcp-D2XfRh8v.js.map} +1 -1
- package/dashboard/dist/assets/{mcp-query-RQX0uN-5.js → mcp-query-CIx_mIC7.js} +2 -2
- package/dashboard/dist/assets/{mcp-query-RQX0uN-5.js.map → mcp-query-CIx_mIC7.js.map} +1 -1
- package/dashboard/dist/assets/{mcp-runs-0w40bdz-.js → mcp-runs-C9_J4LIH.js} +2 -2
- package/dashboard/dist/assets/{mcp-runs-0w40bdz-.js.map → mcp-runs-C9_J4LIH.js.map} +1 -1
- package/dashboard/dist/assets/{namespaces-BbmdXuPp.js → namespaces-BwMljx6f.js} +2 -2
- package/dashboard/dist/assets/{namespaces-BbmdXuPp.js.map → namespaces-BwMljx6f.js.map} +1 -1
- package/dashboard/dist/assets/{roles-DoHYlhWH.js → roles-Bd_sTV6I.js} +2 -2
- package/dashboard/dist/assets/{roles-DoHYlhWH.js.map → roles-Bd_sTV6I.js.map} +1 -1
- package/dashboard/dist/assets/{settings-BAiJiCHS.js → settings-BCb8eFyA.js} +2 -2
- package/dashboard/dist/assets/{settings-BAiJiCHS.js.map → settings-BCb8eFyA.js.map} +1 -1
- package/dashboard/dist/assets/{tasks-CvroqHtm.js → tasks-Bq54qGGq.js} +2 -2
- package/dashboard/dist/assets/{tasks-CvroqHtm.js.map → tasks-Bq54qGGq.js.map} +1 -1
- package/dashboard/dist/assets/useEventHooks-BTbGf536.js +2 -0
- package/dashboard/dist/assets/{useEventHooks-BHMbzR_y.js.map → useEventHooks-BTbGf536.js.map} +1 -1
- package/dashboard/dist/assets/useYamlActivityEvents-CsYP09W5.js +2 -0
- package/dashboard/dist/assets/{useYamlActivityEvents-D56KV14X.js.map → useYamlActivityEvents-CsYP09W5.js.map} +1 -1
- package/dashboard/dist/assets/{users-CxIMy_xw.js → users-BTBhafGc.js} +2 -2
- package/dashboard/dist/assets/{users-CxIMy_xw.js.map → users-BTBhafGc.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-BkzA4ahe.js} +2 -2
- package/dashboard/dist/assets/{workflows-yR9yais7.js.map → workflows-BkzA4ahe.js.map} +1 -1
- package/dashboard/dist/assets/{yaml-workflows-QVF2MZ0l.js → yaml-workflows-Cs0EYp0F.js} +2 -2
- package/dashboard/dist/assets/{yaml-workflows-QVF2MZ0l.js.map → yaml-workflows-Cs0EYp0F.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
|
@@ -10,6 +10,11 @@ exports.loggerRegistry = void 0;
|
|
|
10
10
|
*
|
|
11
11
|
* When no adapter is registered, all methods fall back to console.*.
|
|
12
12
|
*/
|
|
13
|
+
const LOG_LEVELS = { error: 0, warn: 1, info: 2, debug: 3 };
|
|
14
|
+
function shouldLog(level) {
|
|
15
|
+
const threshold = LOG_LEVELS[process.env.LOG_LEVEL || 'debug'] ?? 3;
|
|
16
|
+
return (LOG_LEVELS[level] ?? 3) <= threshold;
|
|
17
|
+
}
|
|
13
18
|
class LTLoggerRegistry {
|
|
14
19
|
constructor() {
|
|
15
20
|
this.adapter = null;
|
|
@@ -36,7 +41,7 @@ class LTLoggerRegistry {
|
|
|
36
41
|
if (this.adapter) {
|
|
37
42
|
this.adapter.info(msg, context);
|
|
38
43
|
}
|
|
39
|
-
else {
|
|
44
|
+
else if (shouldLog('info')) {
|
|
40
45
|
console.log(msg);
|
|
41
46
|
}
|
|
42
47
|
}
|
|
@@ -44,7 +49,7 @@ class LTLoggerRegistry {
|
|
|
44
49
|
if (this.adapter) {
|
|
45
50
|
this.adapter.warn(msg, context);
|
|
46
51
|
}
|
|
47
|
-
else {
|
|
52
|
+
else if (shouldLog('warn')) {
|
|
48
53
|
console.warn(msg);
|
|
49
54
|
}
|
|
50
55
|
}
|
|
@@ -52,7 +57,7 @@ class LTLoggerRegistry {
|
|
|
52
57
|
if (this.adapter) {
|
|
53
58
|
this.adapter.error(msg, context);
|
|
54
59
|
}
|
|
55
|
-
else {
|
|
60
|
+
else if (shouldLog('error')) {
|
|
56
61
|
console.error(msg);
|
|
57
62
|
}
|
|
58
63
|
}
|
|
@@ -60,7 +65,7 @@ class LTLoggerRegistry {
|
|
|
60
65
|
if (this.adapter) {
|
|
61
66
|
this.adapter.debug(msg, context);
|
|
62
67
|
}
|
|
63
|
-
else {
|
|
68
|
+
else if (shouldLog('debug')) {
|
|
64
69
|
console.debug(msg);
|
|
65
70
|
}
|
|
66
71
|
}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getStorageBackend = getStorageBackend;
|
|
4
4
|
exports.resetStorageBackend = resetStorageBackend;
|
|
5
|
+
const local_1 = require("./local");
|
|
5
6
|
let _backend = null;
|
|
6
7
|
/**
|
|
7
8
|
* Returns the singleton storage backend.
|
|
@@ -19,8 +20,7 @@ function getStorageBackend() {
|
|
|
19
20
|
_backend = new S3StorageBackend();
|
|
20
21
|
}
|
|
21
22
|
else {
|
|
22
|
-
|
|
23
|
-
_backend = new LocalStorageBackend();
|
|
23
|
+
_backend = new local_1.LocalStorageBackend();
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
return _backend;
|
|
@@ -86,6 +86,20 @@ router.post('/signed-url', async (req, res) => {
|
|
|
86
86
|
});
|
|
87
87
|
res.status(result.status).json(result.data ?? { error: result.error });
|
|
88
88
|
});
|
|
89
|
+
/**
|
|
90
|
+
* DELETE /api/file-browser/delete/*
|
|
91
|
+
* Permanently delete a file.
|
|
92
|
+
*/
|
|
93
|
+
router.delete('/delete/{*filePath}', async (req, res) => {
|
|
94
|
+
const raw = req.params.filePath;
|
|
95
|
+
const filePath = Array.isArray(raw) ? raw.join('/') : raw;
|
|
96
|
+
if (!filePath) {
|
|
97
|
+
res.status(400).json({ error: 'File path required' });
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
const result = await api.deleteFile({ filePath });
|
|
101
|
+
res.status(result.status).json(result.data ?? { error: result.error });
|
|
102
|
+
});
|
|
89
103
|
/**
|
|
90
104
|
* GET /api/file-browser/download/*
|
|
91
105
|
* Download a file with Content-Disposition: attachment.
|
package/build/routes/index.js
CHANGED
|
@@ -28,6 +28,8 @@ const controlplane_1 = __importDefault(require("./controlplane"));
|
|
|
28
28
|
const bot_accounts_1 = __importDefault(require("./bot-accounts"));
|
|
29
29
|
const docs_1 = __importDefault(require("./docs"));
|
|
30
30
|
const workflow_sets_1 = __importDefault(require("./workflow-sets"));
|
|
31
|
+
const knowledge_1 = __importDefault(require("./knowledge"));
|
|
32
|
+
const nats_credentials_1 = __importDefault(require("./nats-credentials"));
|
|
31
33
|
const router = (0, express_1.Router)();
|
|
32
34
|
// Public routes (no auth required — they handle their own auth)
|
|
33
35
|
router.use('/auth', auth_2.default);
|
|
@@ -37,6 +39,7 @@ router.use('/files', files_1.default);
|
|
|
37
39
|
router.use('/settings', settings_1.default);
|
|
38
40
|
// Apply auth to all API routes
|
|
39
41
|
router.use(auth_1.requireAuth);
|
|
42
|
+
router.use('/nats-credentials', nats_credentials_1.default);
|
|
40
43
|
router.use('/tasks', tasks_1.default);
|
|
41
44
|
router.use('/escalations', escalations_1.default);
|
|
42
45
|
router.use('/workflows', workflows_1.default);
|
|
@@ -55,4 +58,5 @@ router.use('/controlplane', controlplane_1.default);
|
|
|
55
58
|
router.use('/bot-accounts', bot_accounts_1.default);
|
|
56
59
|
router.use('/docs', docs_1.default);
|
|
57
60
|
router.use('/workflow-sets', workflow_sets_1.default);
|
|
61
|
+
router.use('/knowledge', knowledge_1.default);
|
|
58
62
|
exports.default = router;
|
|
@@ -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;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const express_1 = require("express");
|
|
4
|
+
const events_1 = require("../lib/events");
|
|
5
|
+
const nats_1 = require("../lib/events/nats");
|
|
6
|
+
const router = (0, express_1.Router)();
|
|
7
|
+
/**
|
|
8
|
+
* GET /api/nats-credentials
|
|
9
|
+
* Returns NATS WebSocket URL and auth token.
|
|
10
|
+
* Mounted behind requireAuth — only authenticated users receive the token.
|
|
11
|
+
*/
|
|
12
|
+
router.get('/', async (_req, res) => {
|
|
13
|
+
const hasNats = !!events_1.eventRegistry.getAdapter(nats_1.NatsEventAdapter);
|
|
14
|
+
if (!hasNats) {
|
|
15
|
+
return res.json({ natsWsUrl: null, natsToken: null });
|
|
16
|
+
}
|
|
17
|
+
res.json({
|
|
18
|
+
natsWsUrl: process.env.VITE_NATS_WS_URL || process.env.NATS_WS_URL || null,
|
|
19
|
+
natsToken: process.env.NATS_TOKEN || null,
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
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;
|