@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
|
@@ -41,33 +41,14 @@ exports.getYamlWorkflow = getYamlWorkflow;
|
|
|
41
41
|
exports.updateYamlWorkflow = updateYamlWorkflow;
|
|
42
42
|
exports.regenerateYamlWorkflow = regenerateYamlWorkflow;
|
|
43
43
|
exports.deleteYamlWorkflow = deleteYamlWorkflow;
|
|
44
|
-
exports.
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
exports.setCronSchedule = setCronSchedule;
|
|
53
|
-
exports.clearCronSchedule = clearCronSchedule;
|
|
54
|
-
exports.getCronStatus = getCronStatus;
|
|
55
|
-
const yamlDb = __importStar(require("../services/yaml-workflow/db"));
|
|
56
|
-
const yamlGenerator = __importStar(require("../services/yaml-workflow/generator"));
|
|
57
|
-
const yamlDeployer = __importStar(require("../services/yaml-workflow/deployer"));
|
|
58
|
-
const yamlWorkers = __importStar(require("../services/yaml-workflow/workers"));
|
|
59
|
-
const invoke_1 = require("../services/yaml-workflow/invoke");
|
|
60
|
-
const task_1 = require("../services/task");
|
|
61
|
-
const cron_1 = require("../services/cron");
|
|
62
|
-
const utils_1 = require("../modules/utils");
|
|
63
|
-
/** Return true if a Postgres error indicates an invalid/missing ID */
|
|
64
|
-
function isNotFoundError(err) {
|
|
65
|
-
const msg = err?.message ?? '';
|
|
66
|
-
return msg.includes('invalid input syntax for type uuid') || msg.includes('not found');
|
|
67
|
-
}
|
|
68
|
-
// ---------------------------------------------------------------------------
|
|
69
|
-
// CRUD
|
|
70
|
-
// ---------------------------------------------------------------------------
|
|
44
|
+
exports.createYamlWorkflowFromDurable = createYamlWorkflowFromDurable;
|
|
45
|
+
const yamlDb = __importStar(require("../../services/yaml-workflow/db"));
|
|
46
|
+
const yamlGenerator = __importStar(require("../../services/yaml-workflow/generator"));
|
|
47
|
+
const durable_compiler_1 = require("../../services/yaml-workflow/durable-compiler");
|
|
48
|
+
const builder_regenerate_1 = require("../../services/yaml-workflow/builder-regenerate");
|
|
49
|
+
const task_1 = require("../../services/task");
|
|
50
|
+
const utils_1 = require("../../modules/utils");
|
|
51
|
+
const helpers_1 = require("./helpers");
|
|
71
52
|
/**
|
|
72
53
|
* List YAML workflows with optional filtering and pagination.
|
|
73
54
|
*
|
|
@@ -98,7 +79,7 @@ async function listYamlWorkflows(input) {
|
|
|
98
79
|
return { status: 200, data: result };
|
|
99
80
|
}
|
|
100
81
|
catch (err) {
|
|
101
|
-
if (isNotFoundError(err)) {
|
|
82
|
+
if ((0, helpers_1.isNotFoundError)(err)) {
|
|
102
83
|
return { status: 404, error: 'YAML workflow not found' };
|
|
103
84
|
}
|
|
104
85
|
return { status: 500, error: err.message };
|
|
@@ -301,7 +282,7 @@ async function getYamlWorkflow(input) {
|
|
|
301
282
|
return { status: 200, data: wf };
|
|
302
283
|
}
|
|
303
284
|
catch (err) {
|
|
304
|
-
if (isNotFoundError(err)) {
|
|
285
|
+
if ((0, helpers_1.isNotFoundError)(err)) {
|
|
305
286
|
return { status: 404, error: 'YAML workflow not found' };
|
|
306
287
|
}
|
|
307
288
|
return { status: 500, error: err.message };
|
|
@@ -326,7 +307,7 @@ async function updateYamlWorkflow(input) {
|
|
|
326
307
|
return { status: 200, data: wf };
|
|
327
308
|
}
|
|
328
309
|
catch (err) {
|
|
329
|
-
if (isNotFoundError(err)) {
|
|
310
|
+
if ((0, helpers_1.isNotFoundError)(err)) {
|
|
330
311
|
return { status: 404, error: 'YAML workflow not found' };
|
|
331
312
|
}
|
|
332
313
|
return { status: 500, error: err.message };
|
|
@@ -354,10 +335,32 @@ async function regenerateYamlWorkflow(input) {
|
|
|
354
335
|
if (wf.status === 'archived') {
|
|
355
336
|
return { status: 400, error: 'Archived workflows cannot be regenerated' };
|
|
356
337
|
}
|
|
338
|
+
// Plan Build workflows: recompile from original prompt via builder LLM
|
|
339
|
+
if (!wf.source_workflow_id && wf.source_workflow_type === 'mcpWorkflowPlanner') {
|
|
340
|
+
if (!wf.original_prompt) {
|
|
341
|
+
return { status: 400, error: 'Cannot recompile: original prompt not stored. Re-run the plan to rebuild this workflow.' };
|
|
342
|
+
}
|
|
343
|
+
const feedback = input.compilation_feedback;
|
|
344
|
+
const result = await (0, builder_regenerate_1.rebuildFromPrompt)({
|
|
345
|
+
prompt: wf.original_prompt,
|
|
346
|
+
feedback: feedback || undefined,
|
|
347
|
+
priorYaml: feedback ? wf.yaml_content : undefined,
|
|
348
|
+
name: wf.name,
|
|
349
|
+
appId: wf.app_id,
|
|
350
|
+
});
|
|
351
|
+
const updated = await yamlDb.updateYamlWorkflow(wf.id, {
|
|
352
|
+
yaml_content: result.yaml,
|
|
353
|
+
input_schema: result.inputSchema,
|
|
354
|
+
output_schema: result.outputSchema,
|
|
355
|
+
activity_manifest: result.activityManifest,
|
|
356
|
+
tags: result.tags,
|
|
357
|
+
});
|
|
358
|
+
return { status: 200, data: updated };
|
|
359
|
+
}
|
|
357
360
|
if (!wf.source_workflow_id || !wf.source_workflow_type) {
|
|
358
361
|
return { status: 400, error: 'Missing source workflow reference — cannot regenerate' };
|
|
359
362
|
}
|
|
360
|
-
//
|
|
363
|
+
// Execution-trace workflows: recompile from source execution
|
|
361
364
|
let taskQueue = input.task_queue;
|
|
362
365
|
if (!taskQueue) {
|
|
363
366
|
const sourceTask = await (0, task_1.getTaskByWorkflowId)(wf.source_workflow_id);
|
|
@@ -387,7 +390,7 @@ async function regenerateYamlWorkflow(input) {
|
|
|
387
390
|
return { status: 200, data: updated };
|
|
388
391
|
}
|
|
389
392
|
catch (err) {
|
|
390
|
-
if (isNotFoundError(err)) {
|
|
393
|
+
if ((0, helpers_1.isNotFoundError)(err)) {
|
|
391
394
|
return { status: 404, error: 'YAML workflow not found' };
|
|
392
395
|
}
|
|
393
396
|
return { status: 500, error: err.message };
|
|
@@ -415,364 +418,60 @@ async function deleteYamlWorkflow(input) {
|
|
|
415
418
|
return { status: 200, data: { deleted: true } };
|
|
416
419
|
}
|
|
417
420
|
catch (err) {
|
|
418
|
-
if (isNotFoundError(err)) {
|
|
419
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
420
|
-
}
|
|
421
|
-
return { status: 500, error: err.message };
|
|
422
|
-
}
|
|
423
|
-
}
|
|
424
|
-
// ---------------------------------------------------------------------------
|
|
425
|
-
// Deployment
|
|
426
|
-
// ---------------------------------------------------------------------------
|
|
427
|
-
/**
|
|
428
|
-
* Deploy a YAML workflow and all sibling workflows sharing its app_id namespace.
|
|
429
|
-
*
|
|
430
|
-
* Merges and deploys the full app_id YAML, registers HotMesh workers for every
|
|
431
|
-
* non-archived sibling, transitions draft/deployed siblings to active, and marks
|
|
432
|
-
* the app_id content as deployed. Uses the app_version declared in the workflow record.
|
|
433
|
-
*
|
|
434
|
-
* @param input.id — UUID of the workflow to deploy
|
|
435
|
-
* @returns `{ status: 200, data: YamlWorkflow }` the refreshed workflow record after deployment
|
|
436
|
-
*/
|
|
437
|
-
async function deployYamlWorkflow(input) {
|
|
438
|
-
try {
|
|
439
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
440
|
-
if (!wf) {
|
|
441
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
442
|
-
}
|
|
443
|
-
// Compute the next app-level version for the namespace.
|
|
444
|
-
// Each deploy increments regardless of individual tool versions —
|
|
445
|
-
// adding a second tool (v1 of itself) to an app already at v1 produces app v2.
|
|
446
|
-
const deployVersion = await yamlDb.getNextAppVersion(wf.app_id);
|
|
447
|
-
// Deploy + activate merged YAML for the full app_id
|
|
448
|
-
const siblings = await yamlDb.listYamlWorkflowsByAppId(wf.app_id);
|
|
449
|
-
await yamlDeployer.deployAppId(wf.app_id, deployVersion);
|
|
450
|
-
// Register workers and mark all non-archived siblings as active
|
|
451
|
-
for (const sibling of siblings) {
|
|
452
|
-
await yamlDb.updateYamlWorkflowVersion(sibling.id, deployVersion);
|
|
453
|
-
await yamlWorkers.registerWorkersForWorkflow(sibling);
|
|
454
|
-
if (sibling.status === 'draft' || sibling.status === 'deployed') {
|
|
455
|
-
await yamlDb.updateYamlWorkflowStatus(sibling.id, 'active');
|
|
456
|
-
}
|
|
457
|
-
}
|
|
458
|
-
// Mark content as deployed for the entire app_id
|
|
459
|
-
await yamlDb.markAppIdContentDeployed(wf.app_id);
|
|
460
|
-
const updated = await yamlDb.getYamlWorkflow(input.id);
|
|
461
|
-
return { status: 200, data: updated };
|
|
462
|
-
}
|
|
463
|
-
catch (err) {
|
|
464
|
-
if (isNotFoundError(err)) {
|
|
465
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
466
|
-
}
|
|
467
|
-
return {
|
|
468
|
-
status: 500,
|
|
469
|
-
error: err.message,
|
|
470
|
-
};
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
/**
|
|
474
|
-
* Activate a previously deployed YAML workflow and its app_id siblings.
|
|
475
|
-
*
|
|
476
|
-
* Calls the deployer to activate the app_id at its current version, then registers
|
|
477
|
-
* HotMesh workers for all sibling workflows. Siblings in "deployed" status are
|
|
478
|
-
* transitioned to "active". The workflow must already be in deployed or active status.
|
|
479
|
-
*
|
|
480
|
-
* @param input.id — UUID of the workflow to activate
|
|
481
|
-
* @returns `{ status: 200, data: YamlWorkflow }` the refreshed workflow record after activation
|
|
482
|
-
*/
|
|
483
|
-
async function activateYamlWorkflow(input) {
|
|
484
|
-
try {
|
|
485
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
486
|
-
if (!wf) {
|
|
487
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
488
|
-
}
|
|
489
|
-
if (wf.status !== 'deployed' && wf.status !== 'active') {
|
|
490
|
-
return { status: 400, error: 'Workflow must be deployed before activation' };
|
|
491
|
-
}
|
|
492
|
-
await yamlDeployer.activateYamlWorkflow(wf.app_id, wf.app_version);
|
|
493
|
-
// Register workers for ALL workflows sharing this app_id
|
|
494
|
-
const siblings = await yamlDb.listYamlWorkflowsByAppId(wf.app_id);
|
|
495
|
-
for (const sibling of siblings) {
|
|
496
|
-
await yamlWorkers.registerWorkersForWorkflow(sibling);
|
|
497
|
-
if (sibling.status === 'deployed') {
|
|
498
|
-
await yamlDb.updateYamlWorkflowStatus(sibling.id, 'active');
|
|
499
|
-
}
|
|
500
|
-
}
|
|
501
|
-
const updated = await yamlDb.getYamlWorkflow(input.id);
|
|
502
|
-
return { status: 200, data: updated };
|
|
503
|
-
}
|
|
504
|
-
catch (err) {
|
|
505
|
-
if (isNotFoundError(err)) {
|
|
421
|
+
if ((0, helpers_1.isNotFoundError)(err)) {
|
|
506
422
|
return { status: 404, error: 'YAML workflow not found' };
|
|
507
423
|
}
|
|
508
424
|
return { status: 500, error: err.message };
|
|
509
425
|
}
|
|
510
426
|
}
|
|
511
427
|
/**
|
|
512
|
-
*
|
|
428
|
+
* Compile a durable TypeScript workflow into a YAML DAG.
|
|
513
429
|
*
|
|
514
|
-
*
|
|
515
|
-
*
|
|
516
|
-
* asynchronous (fire-and-forget) invocation modes.
|
|
430
|
+
* Accepts inline source code or a file path. The LLM translates the procedural
|
|
431
|
+
* orchestration into an equivalent HotMesh YAML DAG that runs without replay.
|
|
517
432
|
*
|
|
518
|
-
* @param input.
|
|
519
|
-
* @param input.
|
|
520
|
-
* @param input.
|
|
521
|
-
* @param input.
|
|
522
|
-
* @param input.
|
|
523
|
-
* @param
|
|
524
|
-
* @
|
|
433
|
+
* @param input.source — TypeScript source code or file path
|
|
434
|
+
* @param input.is_file_path — whether source is a file path (default: false)
|
|
435
|
+
* @param input.workflow_name — name of the exported workflow function
|
|
436
|
+
* @param input.name — name for the generated YAML workflow
|
|
437
|
+
* @param input.description — optional description
|
|
438
|
+
* @param input.app_id — target namespace (defaults to "longtail")
|
|
439
|
+
* @param input.subscribes — graph topic override
|
|
440
|
+
* @param input.tags — additional tags
|
|
441
|
+
* @returns `{ status: 201, data: YamlWorkflow }` the newly created draft record
|
|
525
442
|
*/
|
|
526
|
-
async function
|
|
443
|
+
async function createYamlWorkflowFromDurable(input) {
|
|
527
444
|
try {
|
|
528
|
-
const
|
|
529
|
-
if (!
|
|
530
|
-
return { status:
|
|
445
|
+
const { source, workflow_name, name, description, app_id, subscribes, tags: userTags } = input;
|
|
446
|
+
if (!source || !workflow_name || !name) {
|
|
447
|
+
return { status: 400, error: 'source, workflow_name, and name are required' };
|
|
531
448
|
}
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
userId: auth?.userId,
|
|
449
|
+
const result = await (0, durable_compiler_1.compileDurableToYaml)({
|
|
450
|
+
source,
|
|
451
|
+
isFilePath: !!input.is_file_path,
|
|
452
|
+
workflowName: workflow_name,
|
|
453
|
+
name,
|
|
454
|
+
description,
|
|
455
|
+
appId: app_id,
|
|
456
|
+
subscribes,
|
|
541
457
|
});
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
* @returns `{ status: 200, data: YamlWorkflow }` the updated record with status "archived"
|
|
560
|
-
*/
|
|
561
|
-
async function archiveYamlWorkflow(input) {
|
|
562
|
-
try {
|
|
563
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
564
|
-
if (!wf) {
|
|
565
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
566
|
-
}
|
|
567
|
-
if (wf.status === 'active') {
|
|
568
|
-
await yamlDeployer.stopEngine(wf.app_id);
|
|
569
|
-
}
|
|
570
|
-
const updated = await yamlDb.updateYamlWorkflowStatus(wf.id, 'archived');
|
|
571
|
-
return { status: 200, data: updated };
|
|
572
|
-
}
|
|
573
|
-
catch (err) {
|
|
574
|
-
if (isNotFoundError(err)) {
|
|
575
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
576
|
-
}
|
|
577
|
-
return { status: 500, error: err.message };
|
|
578
|
-
}
|
|
579
|
-
}
|
|
580
|
-
/**
|
|
581
|
-
* Restore an archived YAML workflow back to draft status.
|
|
582
|
-
*
|
|
583
|
-
* Transitions the workflow from "archived" to "draft" so it can be
|
|
584
|
-
* redeployed. The workflow must be in "archived" status.
|
|
585
|
-
*/
|
|
586
|
-
async function restoreYamlWorkflow(input) {
|
|
587
|
-
try {
|
|
588
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
589
|
-
if (!wf) {
|
|
590
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
591
|
-
}
|
|
592
|
-
if (wf.status !== 'archived') {
|
|
593
|
-
return { status: 400, error: 'Only archived workflows can be restored' };
|
|
594
|
-
}
|
|
595
|
-
const updated = await yamlDb.updateYamlWorkflowStatus(wf.id, 'draft');
|
|
596
|
-
return { status: 200, data: updated };
|
|
597
|
-
}
|
|
598
|
-
catch (err) {
|
|
599
|
-
if (isNotFoundError(err)) {
|
|
600
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
601
|
-
}
|
|
602
|
-
return { status: 500, error: err.message };
|
|
603
|
-
}
|
|
604
|
-
}
|
|
605
|
-
// ---------------------------------------------------------------------------
|
|
606
|
-
// Versions
|
|
607
|
-
// ---------------------------------------------------------------------------
|
|
608
|
-
/**
|
|
609
|
-
* Retrieve the version history for a YAML workflow.
|
|
610
|
-
*
|
|
611
|
-
* Returns a paginated list of version snapshots ordered by version number.
|
|
612
|
-
*
|
|
613
|
-
* @param input.id — UUID of the workflow
|
|
614
|
-
* @param input.limit — max versions to return (defaults to 20)
|
|
615
|
-
* @param input.offset — pagination offset (defaults to 0)
|
|
616
|
-
* @returns `{ status: 200, data: VersionSnapshot[] }` paginated version history
|
|
617
|
-
*/
|
|
618
|
-
async function getVersionHistory(input) {
|
|
619
|
-
try {
|
|
620
|
-
const limit = input.limit ?? 20;
|
|
621
|
-
const offset = input.offset ?? 0;
|
|
622
|
-
const result = await yamlDb.getVersionHistory(input.id, limit, offset);
|
|
623
|
-
return { status: 200, data: result };
|
|
624
|
-
}
|
|
625
|
-
catch (err) {
|
|
626
|
-
if (isNotFoundError(err)) {
|
|
627
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
628
|
-
}
|
|
629
|
-
return { status: 500, error: err.message };
|
|
630
|
-
}
|
|
631
|
-
}
|
|
632
|
-
/**
|
|
633
|
-
* Retrieve a specific version snapshot of a YAML workflow.
|
|
634
|
-
*
|
|
635
|
-
* Validates that the version number is a positive integer before querying.
|
|
636
|
-
*
|
|
637
|
-
* @param input.id — UUID of the workflow
|
|
638
|
-
* @param input.version — 1-based version number to retrieve
|
|
639
|
-
* @returns `{ status: 200, data: VersionSnapshot }` the snapshot at the requested version, or 404
|
|
640
|
-
*/
|
|
641
|
-
async function getVersionSnapshot(input) {
|
|
642
|
-
try {
|
|
643
|
-
const version = input.version;
|
|
644
|
-
if (isNaN(version) || version < 1) {
|
|
645
|
-
return { status: 400, error: 'Invalid version number' };
|
|
646
|
-
}
|
|
647
|
-
const snapshot = await yamlDb.getVersionSnapshot(input.id, version);
|
|
648
|
-
if (!snapshot) {
|
|
649
|
-
return { status: 404, error: `Version ${version} not found` };
|
|
650
|
-
}
|
|
651
|
-
return { status: 200, data: snapshot };
|
|
652
|
-
}
|
|
653
|
-
catch (err) {
|
|
654
|
-
if (isNotFoundError(err)) {
|
|
655
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
656
|
-
}
|
|
657
|
-
return { status: 500, error: err.message };
|
|
658
|
-
}
|
|
659
|
-
}
|
|
660
|
-
/**
|
|
661
|
-
* Retrieve the raw YAML content for a workflow, optionally at a specific version.
|
|
662
|
-
*
|
|
663
|
-
* When a version is provided, fetches from the version snapshot table. Otherwise
|
|
664
|
-
* returns the current yaml_content from the live workflow record.
|
|
665
|
-
*
|
|
666
|
-
* @param input.id — UUID of the workflow
|
|
667
|
-
* @param input.version — optional version number; when omitted, returns the current content
|
|
668
|
-
* @returns `{ status: 200, data: string }` the raw YAML string
|
|
669
|
-
*/
|
|
670
|
-
async function getYamlContent(input) {
|
|
671
|
-
try {
|
|
672
|
-
if (input.version) {
|
|
673
|
-
const snapshot = await yamlDb.getVersionSnapshot(input.id, input.version);
|
|
674
|
-
if (!snapshot) {
|
|
675
|
-
return { status: 404, error: `Version ${input.version} not found` };
|
|
676
|
-
}
|
|
677
|
-
return { status: 200, data: snapshot.yaml_content };
|
|
678
|
-
}
|
|
679
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
680
|
-
if (!wf) {
|
|
681
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
682
|
-
}
|
|
683
|
-
return { status: 200, data: wf.yaml_content };
|
|
684
|
-
}
|
|
685
|
-
catch (err) {
|
|
686
|
-
if (isNotFoundError(err)) {
|
|
687
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
688
|
-
}
|
|
689
|
-
return { status: 500, error: err.message };
|
|
690
|
-
}
|
|
691
|
-
}
|
|
692
|
-
// ---------------------------------------------------------------------------
|
|
693
|
-
// Cron
|
|
694
|
-
// ---------------------------------------------------------------------------
|
|
695
|
-
/**
|
|
696
|
-
* Set or update the cron schedule for a YAML workflow.
|
|
697
|
-
*
|
|
698
|
-
* Persists the schedule in the DB and restarts the in-process cron timer via the
|
|
699
|
-
* cron registry so the change takes effect immediately.
|
|
700
|
-
*
|
|
701
|
-
* @param input.id — UUID of the workflow to schedule
|
|
702
|
-
* @param input.cron_schedule — cron expression (e.g. "0 * * * *")
|
|
703
|
-
* @param input.cron_envelope — optional payload passed to each scheduled invocation
|
|
704
|
-
* @param input.execute_as — optional identity override for scheduled executions
|
|
705
|
-
* @returns `{ status: 200, data: YamlWorkflow }` the updated workflow record with cron fields set
|
|
706
|
-
*/
|
|
707
|
-
async function setCronSchedule(input) {
|
|
708
|
-
try {
|
|
709
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
710
|
-
if (!wf) {
|
|
711
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
712
|
-
}
|
|
713
|
-
if (!input.cron_schedule || typeof input.cron_schedule !== 'string') {
|
|
714
|
-
return { status: 400, error: 'cron_schedule is required' };
|
|
715
|
-
}
|
|
716
|
-
const updated = await yamlDb.updateCronSchedule(wf.id, input.cron_schedule.trim(), input.cron_envelope ?? null, input.execute_as ?? null);
|
|
717
|
-
if (updated) {
|
|
718
|
-
await cron_1.cronRegistry.restartYamlCron(updated);
|
|
719
|
-
}
|
|
720
|
-
return { status: 200, data: updated };
|
|
721
|
-
}
|
|
722
|
-
catch (err) {
|
|
723
|
-
if (isNotFoundError(err)) {
|
|
724
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
725
|
-
}
|
|
726
|
-
return { status: 500, error: err.message };
|
|
727
|
-
}
|
|
728
|
-
}
|
|
729
|
-
/**
|
|
730
|
-
* Remove the cron schedule from a YAML workflow.
|
|
731
|
-
*
|
|
732
|
-
* Stops the in-process cron timer first, then clears the schedule fields in the DB.
|
|
733
|
-
*
|
|
734
|
-
* @param input.id — UUID of the workflow to unschedule
|
|
735
|
-
* @returns `{ status: 200, data: YamlWorkflow }` the updated workflow record with cron fields cleared
|
|
736
|
-
*/
|
|
737
|
-
async function clearCronSchedule(input) {
|
|
738
|
-
try {
|
|
739
|
-
const wf = await yamlDb.getYamlWorkflow(input.id);
|
|
740
|
-
if (!wf) {
|
|
741
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
742
|
-
}
|
|
743
|
-
await cron_1.cronRegistry.stopYamlCron(wf.id);
|
|
744
|
-
const updated = await yamlDb.clearCronSchedule(wf.id);
|
|
745
|
-
return { status: 200, data: updated };
|
|
746
|
-
}
|
|
747
|
-
catch (err) {
|
|
748
|
-
if (isNotFoundError(err)) {
|
|
749
|
-
return { status: 404, error: 'YAML workflow not found' };
|
|
750
|
-
}
|
|
751
|
-
return { status: 500, error: err.message };
|
|
752
|
-
}
|
|
753
|
-
}
|
|
754
|
-
/**
|
|
755
|
-
* List all YAML workflows that have a cron schedule, with their live timer status.
|
|
756
|
-
*
|
|
757
|
-
* Fetches all cron-scheduled workflows from the DB and cross-references with the
|
|
758
|
-
* in-process cron registry to determine which timers are actually running.
|
|
759
|
-
*
|
|
760
|
-
* @returns `{ status: 200, data: { schedules: Array<{ id, name, graph_topic, app_id, cron_schedule, execute_as, active }> } }`
|
|
761
|
-
*/
|
|
762
|
-
async function getCronStatus() {
|
|
763
|
-
try {
|
|
764
|
-
const workflows = await yamlDb.getCronScheduledWorkflows();
|
|
765
|
-
const activeTypes = cron_1.cronRegistry.activeWorkflowTypes;
|
|
766
|
-
const schedules = workflows.map((wf) => ({
|
|
767
|
-
id: wf.id,
|
|
768
|
-
name: wf.name,
|
|
769
|
-
graph_topic: wf.graph_topic,
|
|
770
|
-
app_id: wf.app_id,
|
|
771
|
-
cron_schedule: wf.cron_schedule,
|
|
772
|
-
execute_as: wf.execute_as,
|
|
773
|
-
active: activeTypes.includes(`yaml:${wf.id}`),
|
|
774
|
-
}));
|
|
775
|
-
return { status: 200, data: { schedules } };
|
|
458
|
+
const mergedTags = [...new Set([...(result.tags || []), ...(Array.isArray(userTags) ? userTags : [])])];
|
|
459
|
+
const record = await yamlDb.createYamlWorkflow({
|
|
460
|
+
name,
|
|
461
|
+
description,
|
|
462
|
+
app_id: result.appId,
|
|
463
|
+
yaml_content: result.yaml,
|
|
464
|
+
graph_topic: result.graphTopic,
|
|
465
|
+
input_schema: result.inputSchema,
|
|
466
|
+
output_schema: result.outputSchema,
|
|
467
|
+
activity_manifest: result.activityManifest,
|
|
468
|
+
tags: mergedTags,
|
|
469
|
+
source_workflow_type: 'durable',
|
|
470
|
+
original_prompt: description,
|
|
471
|
+
category: result.category,
|
|
472
|
+
metadata: { durable_source: source.slice(0, 5000) },
|
|
473
|
+
});
|
|
474
|
+
return { status: 201, data: record };
|
|
776
475
|
}
|
|
777
476
|
catch (err) {
|
|
778
477
|
return { status: 500, error: err.message };
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import type { LTApiResult, LTApiAuth } from '../../types/sdk';
|
|
2
|
+
/**
|
|
3
|
+
* Deploy a YAML workflow and all sibling workflows sharing its app_id namespace.
|
|
4
|
+
*
|
|
5
|
+
* Merges and deploys the full app_id YAML, registers HotMesh workers for every
|
|
6
|
+
* non-archived sibling, transitions draft/deployed siblings to active, and marks
|
|
7
|
+
* the app_id content as deployed. Uses the app_version declared in the workflow record.
|
|
8
|
+
*
|
|
9
|
+
* @param input.id — UUID of the workflow to deploy
|
|
10
|
+
* @returns `{ status: 200, data: YamlWorkflow }` the refreshed workflow record after deployment
|
|
11
|
+
*/
|
|
12
|
+
export declare function deployYamlWorkflow(input: {
|
|
13
|
+
id: string;
|
|
14
|
+
}): Promise<LTApiResult>;
|
|
15
|
+
/**
|
|
16
|
+
* Activate a previously deployed YAML workflow and its app_id siblings.
|
|
17
|
+
*
|
|
18
|
+
* Calls the deployer to activate the app_id at its current version, then registers
|
|
19
|
+
* HotMesh workers for all sibling workflows. Siblings in "deployed" status are
|
|
20
|
+
* transitioned to "active". The workflow must already be in deployed or active status.
|
|
21
|
+
*
|
|
22
|
+
* @param input.id — UUID of the workflow to activate
|
|
23
|
+
* @returns `{ status: 200, data: YamlWorkflow }` the refreshed workflow record after activation
|
|
24
|
+
*/
|
|
25
|
+
export declare function activateYamlWorkflow(input: {
|
|
26
|
+
id: string;
|
|
27
|
+
}): Promise<LTApiResult>;
|
|
28
|
+
/**
|
|
29
|
+
* Invoke an active YAML workflow, executing its DAG pipeline.
|
|
30
|
+
*
|
|
31
|
+
* The workflow must be in "active" status. Delegates to the invoke service which
|
|
32
|
+
* starts the HotMesh execution. Supports both synchronous (wait for result) and
|
|
33
|
+
* asynchronous (fire-and-forget) invocation modes.
|
|
34
|
+
*
|
|
35
|
+
* @param input.id — UUID of the workflow to invoke
|
|
36
|
+
* @param input.data — input payload passed to the workflow's entry point
|
|
37
|
+
* @param input.sync — when true, block until the workflow completes and return its output
|
|
38
|
+
* @param input.timeout — max milliseconds to wait when sync is true
|
|
39
|
+
* @param input.execute_as — override identity for the execution context
|
|
40
|
+
* @param auth — authenticated user context; userId is forwarded to the invoke service
|
|
41
|
+
* @returns `{ status: 200, data: ... }` workflow execution result (sync) or job metadata (async)
|
|
42
|
+
*/
|
|
43
|
+
export declare function invokeYamlWorkflow(input: {
|
|
44
|
+
id: string;
|
|
45
|
+
data?: any;
|
|
46
|
+
sync?: boolean;
|
|
47
|
+
timeout?: number;
|
|
48
|
+
execute_as?: string;
|
|
49
|
+
}, auth?: LTApiAuth): Promise<LTApiResult>;
|
|
50
|
+
/**
|
|
51
|
+
* Archive a YAML workflow, removing it from active service.
|
|
52
|
+
*
|
|
53
|
+
* If the workflow is currently active, its HotMesh engine is stopped before
|
|
54
|
+
* transitioning the status to "archived". Archived workflows cannot be invoked
|
|
55
|
+
* or regenerated but can still be viewed or deleted.
|
|
56
|
+
*
|
|
57
|
+
* @param input.id — UUID of the workflow to archive
|
|
58
|
+
* @returns `{ status: 200, data: YamlWorkflow }` the updated record with status "archived"
|
|
59
|
+
*/
|
|
60
|
+
export declare function archiveYamlWorkflow(input: {
|
|
61
|
+
id: string;
|
|
62
|
+
}): Promise<LTApiResult>;
|
|
63
|
+
/**
|
|
64
|
+
* Restore an archived YAML workflow back to draft status.
|
|
65
|
+
*
|
|
66
|
+
* Transitions the workflow from "archived" to "draft" so it can be
|
|
67
|
+
* redeployed. The workflow must be in "archived" status.
|
|
68
|
+
*/
|
|
69
|
+
export declare function restoreYamlWorkflow(input: {
|
|
70
|
+
id: string;
|
|
71
|
+
}): Promise<LTApiResult>;
|