@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.
Files changed (349) hide show
  1. package/README.md +15 -0
  2. package/build/api/escalations/bulk.d.ts +78 -0
  3. package/build/api/escalations/bulk.js +279 -0
  4. package/build/api/escalations/claim.d.ts +30 -0
  5. package/build/api/escalations/claim.js +121 -0
  6. package/build/api/escalations/create.d.ts +29 -0
  7. package/build/api/escalations/create.js +101 -0
  8. package/build/api/escalations/helpers.d.ts +10 -0
  9. package/build/api/escalations/helpers.js +80 -0
  10. package/build/api/escalations/index.d.ts +6 -0
  11. package/build/api/escalations/index.js +26 -0
  12. package/build/api/escalations/list.d.ts +75 -0
  13. package/build/api/escalations/list.js +170 -0
  14. package/build/api/escalations/resolve.d.ts +18 -0
  15. package/build/api/escalations/resolve.js +243 -0
  16. package/build/api/escalations/single.d.ts +37 -0
  17. package/build/api/escalations/single.js +123 -0
  18. package/build/api/files.d.ts +3 -0
  19. package/build/api/files.js +18 -1
  20. package/build/api/knowledge.d.ts +36 -0
  21. package/build/api/knowledge.js +112 -0
  22. package/build/api/mcp/index.d.ts +2 -0
  23. package/build/api/mcp/index.js +16 -0
  24. package/build/api/{mcp.d.ts → mcp/servers.d.ts} +1 -33
  25. package/build/api/{mcp.js → mcp/servers.js} +4 -65
  26. package/build/api/mcp/tools.d.ts +33 -0
  27. package/build/api/mcp/tools.js +64 -0
  28. package/build/api/settings.js +9 -1
  29. package/build/api/workflows/config.d.ts +64 -0
  30. package/build/api/workflows/config.js +142 -0
  31. package/build/api/workflows/discovery.d.ts +29 -0
  32. package/build/api/workflows/discovery.js +153 -0
  33. package/build/api/workflows/index.d.ts +3 -0
  34. package/build/api/workflows/index.js +18 -0
  35. package/build/api/workflows/invocation.d.ts +67 -0
  36. package/build/api/workflows/invocation.js +188 -0
  37. package/build/api/yaml-workflows/cron.d.ts +39 -0
  38. package/build/api/yaml-workflows/cron.js +127 -0
  39. package/build/api/{yaml-workflows.d.ts → yaml-workflows/crud.d.ts} +22 -146
  40. package/build/api/{yaml-workflows.js → yaml-workflows/crud.js} +77 -378
  41. package/build/api/yaml-workflows/deploy.d.ts +71 -0
  42. package/build/api/yaml-workflows/deploy.js +223 -0
  43. package/build/api/yaml-workflows/helpers.d.ts +2 -0
  44. package/build/api/yaml-workflows/helpers.js +8 -0
  45. package/build/api/yaml-workflows/index.d.ts +4 -0
  46. package/build/api/yaml-workflows/index.js +27 -0
  47. package/build/api/yaml-workflows/versions.d.ts +43 -0
  48. package/build/api/yaml-workflows/versions.js +124 -0
  49. package/build/bin/ltc.d.ts +2 -0
  50. package/build/bin/ltc.js +220 -0
  51. package/build/examples/seed-data.d.ts +55 -0
  52. package/build/examples/seed-data.js +161 -0
  53. package/build/examples/seed.js +7 -164
  54. package/build/lib/cli/auth.d.ts +23 -0
  55. package/build/lib/cli/auth.js +167 -0
  56. package/build/lib/cli/client.d.ts +6 -0
  57. package/build/lib/cli/client.js +31 -0
  58. package/build/lib/cli/commands/escalations.d.ts +19 -0
  59. package/build/lib/cli/commands/escalations.js +69 -0
  60. package/build/lib/cli/commands/knowledge.d.ts +18 -0
  61. package/build/lib/cli/commands/knowledge.js +87 -0
  62. package/build/lib/cli/commands/mcp.d.ts +8 -0
  63. package/build/lib/cli/commands/mcp.js +33 -0
  64. package/build/lib/cli/commands/pipelines.d.ts +16 -0
  65. package/build/lib/cli/commands/pipelines.js +67 -0
  66. package/build/lib/cli/commands/status.d.ts +1 -0
  67. package/build/lib/cli/commands/status.js +28 -0
  68. package/build/lib/cli/commands/users.d.ts +7 -0
  69. package/build/lib/cli/commands/users.js +25 -0
  70. package/build/lib/cli/commands/workflows.d.ts +16 -0
  71. package/build/lib/cli/commands/workflows.js +104 -0
  72. package/build/lib/cli/compile.d.ts +2 -0
  73. package/build/lib/cli/compile.js +165 -0
  74. package/build/lib/cli/format.d.ts +23 -0
  75. package/build/lib/cli/format.js +94 -0
  76. package/build/lib/cli/init.d.ts +1 -0
  77. package/build/lib/cli/init.js +61 -0
  78. package/build/lib/cli/output.d.ts +27 -0
  79. package/build/lib/cli/output.js +126 -0
  80. package/build/lib/cli/scanner.d.ts +10 -0
  81. package/build/lib/cli/scanner.js +164 -0
  82. package/build/lib/cli/types.d.ts +16 -0
  83. package/build/lib/cli/types.js +2 -0
  84. package/build/lib/logger/index.d.ts +0 -9
  85. package/build/lib/logger/index.js +9 -4
  86. package/build/lib/storage/index.js +2 -2
  87. package/build/routes/file-browser.js +14 -0
  88. package/build/routes/index.js +2 -0
  89. package/build/routes/knowledge.d.ts +2 -0
  90. package/build/routes/knowledge.js +141 -0
  91. package/build/routes/yaml-workflows/crud.js +9 -0
  92. package/build/sdk/index.d.ts +17 -0
  93. package/build/sdk/index.js +19 -0
  94. package/build/services/mcp/client/connection-dispatch.d.ts +18 -0
  95. package/build/services/mcp/client/connection-dispatch.js +78 -0
  96. package/build/services/mcp/client/connection-lifecycle.d.ts +48 -0
  97. package/build/services/mcp/client/connection-lifecycle.js +296 -0
  98. package/build/services/mcp/client/connection-test.d.ts +10 -0
  99. package/build/services/mcp/client/connection-test.js +49 -0
  100. package/build/services/mcp/client/connection.d.ts +3 -68
  101. package/build/services/mcp/client/connection.js +15 -393
  102. package/build/services/mcp/server-lifecycle.d.ts +27 -0
  103. package/build/services/mcp/server-lifecycle.js +49 -0
  104. package/build/services/mcp/server-tools.d.ts +13 -0
  105. package/build/services/mcp/server-tools.js +287 -0
  106. package/build/services/mcp/server.d.ts +2 -26
  107. package/build/services/mcp/server.js +7 -315
  108. package/build/services/yaml-workflow/builder-regenerate.d.ts +25 -0
  109. package/build/services/yaml-workflow/builder-regenerate.js +111 -0
  110. package/build/services/yaml-workflow/db-versions.d.ts +17 -0
  111. package/build/services/yaml-workflow/db-versions.js +76 -0
  112. package/build/services/yaml-workflow/db.d.ts +3 -13
  113. package/build/services/yaml-workflow/db.js +15 -71
  114. package/build/services/yaml-workflow/deployer-helpers.js +48 -17
  115. package/build/services/yaml-workflow/durable-compiler/index.d.ts +22 -0
  116. package/build/services/yaml-workflow/durable-compiler/index.js +168 -0
  117. package/build/services/yaml-workflow/durable-compiler/parser.d.ts +12 -0
  118. package/build/services/yaml-workflow/durable-compiler/parser.js +110 -0
  119. package/build/services/yaml-workflow/durable-compiler/prompts.d.ts +18 -0
  120. package/build/services/yaml-workflow/durable-compiler/prompts.js +570 -0
  121. package/build/services/yaml-workflow/durable-compiler/types.d.ts +51 -0
  122. package/build/services/yaml-workflow/durable-compiler/types.js +5 -0
  123. package/build/services/yaml-workflow/pipeline/build/dag-assembly.d.ts +17 -0
  124. package/build/services/yaml-workflow/pipeline/build/dag-assembly.js +192 -0
  125. package/build/services/yaml-workflow/pipeline/build/dag.d.ts +4 -13
  126. package/build/services/yaml-workflow/pipeline/build/dag.js +9 -185
  127. package/build/services/yaml-workflow/pipeline/prompt-templates.d.ts +10 -0
  128. package/build/services/yaml-workflow/pipeline/prompt-templates.js +270 -0
  129. package/build/services/yaml-workflow/pipeline/prompts.d.ts +3 -6
  130. package/build/services/yaml-workflow/pipeline/prompts.js +8 -263
  131. package/build/start/workers.js +6 -5
  132. package/build/system/activities/file-storage.d.ts +4 -0
  133. package/build/system/activities/file-storage.js +7 -1
  134. package/build/system/activities/knowledge.d.ts +23 -0
  135. package/build/system/activities/knowledge.js +50 -10
  136. package/build/system/activities/sql.d.ts +3 -0
  137. package/build/system/activities/sql.js +25 -1
  138. package/build/system/mcp-servers/file-storage.js +3 -1
  139. package/build/system/mcp-servers/human-queue-schemas.d.ts +91 -0
  140. package/build/system/mcp-servers/human-queue-schemas.js +42 -0
  141. package/build/system/mcp-servers/human-queue.d.ts +2 -6
  142. package/build/system/mcp-servers/human-queue.js +9 -51
  143. package/build/system/mcp-servers/knowledge.js +43 -9
  144. package/build/system/mcp-servers/workflow-compiler.js +54 -0
  145. package/build/system/workflows/mcp-triage/activities-proxy.d.ts +21 -0
  146. package/build/system/workflows/mcp-triage/activities-proxy.js +70 -0
  147. package/build/system/workflows/mcp-triage/index.js +17 -75
  148. package/build/system/workflows/mcp-workflow-planner/activities/persist.d.ts +1 -0
  149. package/build/system/workflows/mcp-workflow-planner/activities/persist.js +1 -0
  150. package/build/system/workflows/mcp-workflow-planner/index.js +2 -0
  151. package/build/tsconfig.tsbuildinfo +1 -1
  152. package/dashboard/dist/assets/{AdminDashboard-Cngijp4Q.js → AdminDashboard-NLryl1_B.js} +2 -2
  153. package/dashboard/dist/assets/{AdminDashboard-Cngijp4Q.js.map → AdminDashboard-NLryl1_B.js.map} +1 -1
  154. package/dashboard/dist/assets/AvailableEscalationsPage-6vexlrk3.js +2 -0
  155. package/dashboard/dist/assets/AvailableEscalationsPage-6vexlrk3.js.map +1 -0
  156. package/dashboard/dist/assets/{BotPicker-B8Uvw9Si.js → BotPicker-DWhn0tr1.js} +2 -2
  157. package/dashboard/dist/assets/{BotPicker-B8Uvw9Si.js.map → BotPicker-DWhn0tr1.js.map} +1 -1
  158. package/dashboard/dist/assets/{CollapsibleSection-DiFPuWOY.js → CollapsibleSection-CgYgQiOc.js} +2 -2
  159. package/dashboard/dist/assets/{CollapsibleSection-DiFPuWOY.js.map → CollapsibleSection-CgYgQiOc.js.map} +1 -1
  160. package/dashboard/dist/assets/{ConfirmDeleteModal-CpXG9uyu.js → ConfirmDeleteModal-DCKAPXD3.js} +2 -2
  161. package/dashboard/dist/assets/{ConfirmDeleteModal-CpXG9uyu.js.map → ConfirmDeleteModal-DCKAPXD3.js.map} +1 -1
  162. package/dashboard/dist/assets/{CopyableId-DKsTR9lK.js → CopyableId-DXkaAOYk.js} +2 -2
  163. package/dashboard/dist/assets/{CopyableId-DKsTR9lK.js.map → CopyableId-DXkaAOYk.js.map} +1 -1
  164. package/dashboard/dist/assets/{CredentialsPage-DlS7Kf40.js → CredentialsPage-B361BOfU.js} +2 -2
  165. package/dashboard/dist/assets/{CredentialsPage-DlS7Kf40.js.map → CredentialsPage-B361BOfU.js.map} +1 -1
  166. package/dashboard/dist/assets/{CustomDurationPicker-B-9eW3pm.js → CustomDurationPicker-D2G1ldiF.js} +2 -2
  167. package/dashboard/dist/assets/{CustomDurationPicker-B-9eW3pm.js.map → CustomDurationPicker-D2G1ldiF.js.map} +1 -1
  168. package/dashboard/dist/assets/{DataTable-DkOokbtL.js → DataTable-DXSUbA26.js} +2 -2
  169. package/dashboard/dist/assets/{DataTable-DkOokbtL.js.map → DataTable-DXSUbA26.js.map} +1 -1
  170. package/dashboard/dist/assets/{ElapsedCell-DVtHqM-5.js → ElapsedCell-CQGqkXP_.js} +2 -2
  171. package/dashboard/dist/assets/{ElapsedCell-DVtHqM-5.js.map → ElapsedCell-CQGqkXP_.js.map} +1 -1
  172. package/dashboard/dist/assets/{EmptyState-C7KIMIbE.js → EmptyState-Dep92Wkg.js} +2 -2
  173. package/dashboard/dist/assets/{EmptyState-C7KIMIbE.js.map → EmptyState-Dep92Wkg.js.map} +1 -1
  174. package/dashboard/dist/assets/{EscalationsOverview-BMKBlkPx.js → EscalationsOverview-DVEFVjs7.js} +2 -2
  175. package/dashboard/dist/assets/{EscalationsOverview-BMKBlkPx.js.map → EscalationsOverview-DVEFVjs7.js.map} +1 -1
  176. package/dashboard/dist/assets/{EventTable-BYZ5OVdQ.js → EventTable-BMJAPkMi.js} +2 -2
  177. package/dashboard/dist/assets/{EventTable-BYZ5OVdQ.js.map → EventTable-BMJAPkMi.js.map} +1 -1
  178. package/dashboard/dist/assets/{FilterBar-C5r3n6YO.js → FilterBar-DbVbCzH2.js} +2 -2
  179. package/dashboard/dist/assets/{FilterBar-C5r3n6YO.js.map → FilterBar-DbVbCzH2.js.map} +1 -1
  180. package/dashboard/dist/assets/{ListToolbar-BGUajIsW.js → ListToolbar-0XNuXj0M.js} +2 -2
  181. package/dashboard/dist/assets/{ListToolbar-BGUajIsW.js.map → ListToolbar-0XNuXj0M.js.map} +1 -1
  182. package/dashboard/dist/assets/{McpOverview-B_kJYHea.js → McpOverview-CeYnCzBN.js} +2 -2
  183. package/dashboard/dist/assets/{McpOverview-B_kJYHea.js.map → McpOverview-CeYnCzBN.js.map} +1 -1
  184. package/dashboard/dist/assets/McpQueryDetailPage-t3qW3QNa.js +5 -0
  185. package/dashboard/dist/assets/McpQueryDetailPage-t3qW3QNa.js.map +1 -0
  186. package/dashboard/dist/assets/{McpQueryPage-BgAq_bQg.js → McpQueryPage-CfUcdzaj.js} +2 -2
  187. package/dashboard/dist/assets/{McpQueryPage-BgAq_bQg.js.map → McpQueryPage-CfUcdzaj.js.map} +1 -1
  188. package/dashboard/dist/assets/{McpRunDetailPage-B8c0OszR.js → McpRunDetailPage-CZtodW_Z.js} +2 -2
  189. package/dashboard/dist/assets/{McpRunDetailPage-B8c0OszR.js.map → McpRunDetailPage-CZtodW_Z.js.map} +1 -1
  190. package/dashboard/dist/assets/{McpRunsPage-BY8C6k78.js → McpRunsPage-Dzgq7HGt.js} +2 -2
  191. package/dashboard/dist/assets/{McpRunsPage-BY8C6k78.js.map → McpRunsPage-Dzgq7HGt.js.map} +1 -1
  192. package/dashboard/dist/assets/{Modal-E1yRnCeW.js → Modal-yyhUeKoA.js} +2 -2
  193. package/dashboard/dist/assets/{Modal-E1yRnCeW.js.map → Modal-yyhUeKoA.js.map} +1 -1
  194. package/dashboard/dist/assets/{OperatorDashboard-C8MSTzey.js → OperatorDashboard-Ceh7OQtZ.js} +2 -2
  195. package/dashboard/dist/assets/{OperatorDashboard-C8MSTzey.js.map → OperatorDashboard-Ceh7OQtZ.js.map} +1 -1
  196. package/dashboard/dist/assets/{PageHeader-Cm5HBQF_.js → PageHeader-CZ9a8cpr.js} +2 -2
  197. package/dashboard/dist/assets/{PageHeader-Cm5HBQF_.js.map → PageHeader-CZ9a8cpr.js.map} +1 -1
  198. package/dashboard/dist/assets/{PageHeaderWithStats-CNmWJFSN.js → PageHeaderWithStats-BJuNs5NM.js} +2 -2
  199. package/dashboard/dist/assets/{PageHeaderWithStats-CNmWJFSN.js.map → PageHeaderWithStats-BJuNs5NM.js.map} +1 -1
  200. package/dashboard/dist/assets/{PriorityBadge-HSI4RVhs.js → PriorityBadge-BrPikMFy.js} +2 -2
  201. package/dashboard/dist/assets/{PriorityBadge-HSI4RVhs.js.map → PriorityBadge-BrPikMFy.js.map} +1 -1
  202. package/dashboard/dist/assets/{ProcessDetailPage-Dln8622H.js → ProcessDetailPage-2miaYd8G.js} +2 -2
  203. package/dashboard/dist/assets/{ProcessDetailPage-Dln8622H.js.map → ProcessDetailPage-2miaYd8G.js.map} +1 -1
  204. package/dashboard/dist/assets/{ProcessesListPage-bIsd9N_h.js → ProcessesListPage-DqpRDqjk.js} +2 -2
  205. package/dashboard/dist/assets/{ProcessesListPage-bIsd9N_h.js.map → ProcessesListPage-DqpRDqjk.js.map} +1 -1
  206. package/dashboard/dist/assets/{RolePill-BVUp2bF0.js → RolePill-DxbJMfJu.js} +2 -2
  207. package/dashboard/dist/assets/{RolePill-BVUp2bF0.js.map → RolePill-DxbJMfJu.js.map} +1 -1
  208. package/dashboard/dist/assets/RolesPage-CYHRo21-.js +2 -0
  209. package/dashboard/dist/assets/{RolesPage-kH-Njt25.js.map → RolesPage-CYHRo21-.js.map} +1 -1
  210. package/dashboard/dist/assets/{RowActions-DbUJPfaW.js → RowActions-DurFwIwe.js} +2 -2
  211. package/dashboard/dist/assets/{RowActions-DbUJPfaW.js.map → RowActions-DurFwIwe.js.map} +1 -1
  212. package/dashboard/dist/assets/RunAsSelector-CNKraP6u.js +2 -0
  213. package/dashboard/dist/assets/RunAsSelector-CNKraP6u.js.map +1 -0
  214. package/dashboard/dist/assets/{StatCard-Bs3JbyAz.js → StatCard-CKplpK3w.js} +2 -2
  215. package/dashboard/dist/assets/{StatCard-Bs3JbyAz.js.map → StatCard-CKplpK3w.js.map} +1 -1
  216. package/dashboard/dist/assets/{StatusBadge-CakDdsCw.js → StatusBadge-Dm0V1dNN.js} +2 -2
  217. package/dashboard/dist/assets/{StatusBadge-CakDdsCw.js.map → StatusBadge-Dm0V1dNN.js.map} +1 -1
  218. package/dashboard/dist/assets/{StepIndicator-Cd_SG_yA.js → StepIndicator-Dicx0WTZ.js} +2 -2
  219. package/dashboard/dist/assets/{StepIndicator-Cd_SG_yA.js.map → StepIndicator-Dicx0WTZ.js.map} +1 -1
  220. package/dashboard/dist/assets/{StickyPagination-Bz0C18nC.js → StickyPagination-B2jYvU3-.js} +2 -2
  221. package/dashboard/dist/assets/{StickyPagination-Bz0C18nC.js.map → StickyPagination-B2jYvU3-.js.map} +1 -1
  222. package/dashboard/dist/assets/SwimlaneTimeline-ClwumkT1.js +2 -0
  223. package/dashboard/dist/assets/SwimlaneTimeline-ClwumkT1.js.map +1 -0
  224. package/dashboard/dist/assets/{TagInput-ClFhXG-U.js → TagInput-CypDZ6Kl.js} +2 -2
  225. package/dashboard/dist/assets/{TagInput-ClFhXG-U.js.map → TagInput-CypDZ6Kl.js.map} +1 -1
  226. package/dashboard/dist/assets/{TaskDetailPage-SuMBdARt.js → TaskDetailPage-DooDNJGT.js} +2 -2
  227. package/dashboard/dist/assets/{TaskDetailPage-SuMBdARt.js.map → TaskDetailPage-DooDNJGT.js.map} +1 -1
  228. package/dashboard/dist/assets/{TaskQueuePill-lJR1JW_W.js → TaskQueuePill-C1hZ-j31.js} +2 -2
  229. package/dashboard/dist/assets/{TaskQueuePill-lJR1JW_W.js.map → TaskQueuePill-C1hZ-j31.js.map} +1 -1
  230. package/dashboard/dist/assets/{TasksListPage-Dkq1Vtbt.js → TasksListPage-D7CdkAeg.js} +2 -2
  231. package/dashboard/dist/assets/{TasksListPage-Dkq1Vtbt.js.map → TasksListPage-D7CdkAeg.js.map} +1 -1
  232. package/dashboard/dist/assets/{TimeAgo-DgfDZ1pl.js → TimeAgo-B5LXB2aj.js} +2 -2
  233. package/dashboard/dist/assets/{TimeAgo-DgfDZ1pl.js.map → TimeAgo-B5LXB2aj.js.map} +1 -1
  234. package/dashboard/dist/assets/{TimestampCell-MpHZ1hMD.js → TimestampCell-Crb9b0Gw.js} +2 -2
  235. package/dashboard/dist/assets/{TimestampCell-MpHZ1hMD.js.map → TimestampCell-Crb9b0Gw.js.map} +1 -1
  236. package/dashboard/dist/assets/{UserName-DqsosA4B.js → UserName-OPg-nkRa.js} +2 -2
  237. package/dashboard/dist/assets/{UserName-DqsosA4B.js.map → UserName-OPg-nkRa.js.map} +1 -1
  238. package/dashboard/dist/assets/{WorkflowExecutionPage-CVlg38C3.js → WorkflowExecutionPage-CcLVrs9b.js} +2 -2
  239. package/dashboard/dist/assets/{WorkflowExecutionPage-CVlg38C3.js.map → WorkflowExecutionPage-CcLVrs9b.js.map} +1 -1
  240. package/dashboard/dist/assets/{WorkflowPill-CRpZhjGR.js → WorkflowPill-CCV4MMj7.js} +2 -2
  241. package/dashboard/dist/assets/{WorkflowPill-CRpZhjGR.js.map → WorkflowPill-CCV4MMj7.js.map} +1 -1
  242. package/dashboard/dist/assets/{WorkflowsDashboard-Ugzbs8mV.js → WorkflowsDashboard-DB1SncBi.js} +2 -2
  243. package/dashboard/dist/assets/{WorkflowsDashboard-Ugzbs8mV.js.map → WorkflowsDashboard-DB1SncBi.js.map} +1 -1
  244. package/dashboard/dist/assets/{WorkflowsOverview-CIp_lTNl.js → WorkflowsOverview-DvShiYJV.js} +2 -2
  245. package/dashboard/dist/assets/{WorkflowsOverview-CIp_lTNl.js.map → WorkflowsOverview-DvShiYJV.js.map} +1 -1
  246. package/dashboard/dist/assets/YamlWorkflowsPage-DCBoMeGI.js +2 -0
  247. package/dashboard/dist/assets/YamlWorkflowsPage-DCBoMeGI.js.map +1 -0
  248. package/dashboard/dist/assets/{bots-DPfUpVqI.js → bots-Dqos20NE.js} +2 -2
  249. package/dashboard/dist/assets/{bots-DPfUpVqI.js.map → bots-Dqos20NE.js.map} +1 -1
  250. package/dashboard/dist/assets/{escalation-RrCDbMC3.js → escalation-A0CsbvNV.js} +2 -2
  251. package/dashboard/dist/assets/{escalation-RrCDbMC3.js.map → escalation-A0CsbvNV.js.map} +1 -1
  252. package/dashboard/dist/assets/{escalation-columns-CDGa9wsD.js → escalation-columns-BpBJN6k4.js} +2 -2
  253. package/dashboard/dist/assets/{escalation-columns-CDGa9wsD.js.map → escalation-columns-BpBJN6k4.js.map} +1 -1
  254. package/dashboard/dist/assets/{helpers-ZSKqdkdS.js → helpers-CmznCuAx.js} +2 -2
  255. package/dashboard/dist/assets/{helpers-ZSKqdkdS.js.map → helpers-CmznCuAx.js.map} +1 -1
  256. package/dashboard/dist/assets/index-BIeYV5QK.js +2 -0
  257. package/dashboard/dist/assets/index-BIeYV5QK.js.map +1 -0
  258. package/dashboard/dist/assets/index-BYwD3kHN.js +5 -0
  259. package/dashboard/dist/assets/index-BYwD3kHN.js.map +1 -0
  260. package/dashboard/dist/assets/index-C5TUqJu0.css +1 -0
  261. package/dashboard/dist/assets/{index-DX6zxr6t.js → index-C8-UaN4N.js} +2 -2
  262. package/dashboard/dist/assets/{index-DX6zxr6t.js.map → index-C8-UaN4N.js.map} +1 -1
  263. package/dashboard/dist/assets/index-CAj5LT9H.js +15 -0
  264. package/dashboard/dist/assets/index-CAj5LT9H.js.map +1 -0
  265. package/dashboard/dist/assets/index-CjxHCVxl.js +2 -0
  266. package/dashboard/dist/assets/{index-C90ZPzXk.js.map → index-CjxHCVxl.js.map} +1 -1
  267. package/dashboard/dist/assets/index-Cr0Rqsj7.js +2 -0
  268. package/dashboard/dist/assets/index-Cr0Rqsj7.js.map +1 -0
  269. package/dashboard/dist/assets/index-DZHNte4o.js +2 -0
  270. package/dashboard/dist/assets/{index-K40Qw1tk.js.map → index-DZHNte4o.js.map} +1 -1
  271. package/dashboard/dist/assets/{index-DNytWfSZ.js → index-VnYkWW8r.js} +2 -2
  272. package/dashboard/dist/assets/{index-DNytWfSZ.js.map → index-VnYkWW8r.js.map} +1 -1
  273. package/dashboard/dist/assets/{index-BbI2dzhJ.js → index-XGOmZ117.js} +2 -2
  274. package/dashboard/dist/assets/{index-BbI2dzhJ.js.map → index-XGOmZ117.js.map} +1 -1
  275. package/dashboard/dist/assets/index-ZjOUzWhc.js +2 -0
  276. package/dashboard/dist/assets/index-ZjOUzWhc.js.map +1 -0
  277. package/dashboard/dist/assets/{index-Cmgrk7PQ.js → index-puKKZ5l8.js} +71 -71
  278. package/dashboard/dist/assets/index-puKKZ5l8.js.map +1 -0
  279. package/dashboard/dist/assets/{index-BmVCyB6C.js → index-t5frSddy.js} +2 -2
  280. package/dashboard/dist/assets/{index-BmVCyB6C.js.map → index-t5frSddy.js.map} +1 -1
  281. package/dashboard/dist/assets/{mcp-CNE44TSp.js → mcp-DrWymhSu.js} +2 -2
  282. package/dashboard/dist/assets/{mcp-CNE44TSp.js.map → mcp-DrWymhSu.js.map} +1 -1
  283. package/dashboard/dist/assets/{mcp-query-RQX0uN-5.js → mcp-query-BhUxVEMS.js} +2 -2
  284. package/dashboard/dist/assets/{mcp-query-RQX0uN-5.js.map → mcp-query-BhUxVEMS.js.map} +1 -1
  285. package/dashboard/dist/assets/{mcp-runs-0w40bdz-.js → mcp-runs-DUfz4mLd.js} +2 -2
  286. package/dashboard/dist/assets/{mcp-runs-0w40bdz-.js.map → mcp-runs-DUfz4mLd.js.map} +1 -1
  287. package/dashboard/dist/assets/{namespaces-BbmdXuPp.js → namespaces-Cm6AY5sh.js} +2 -2
  288. package/dashboard/dist/assets/{namespaces-BbmdXuPp.js.map → namespaces-Cm6AY5sh.js.map} +1 -1
  289. package/dashboard/dist/assets/{roles-DoHYlhWH.js → roles-2v1Kc7BJ.js} +2 -2
  290. package/dashboard/dist/assets/{roles-DoHYlhWH.js.map → roles-2v1Kc7BJ.js.map} +1 -1
  291. package/dashboard/dist/assets/{settings-BAiJiCHS.js → settings-DTQNp6tH.js} +2 -2
  292. package/dashboard/dist/assets/{settings-BAiJiCHS.js.map → settings-DTQNp6tH.js.map} +1 -1
  293. package/dashboard/dist/assets/{tasks-CvroqHtm.js → tasks-CS1rgG1s.js} +2 -2
  294. package/dashboard/dist/assets/{tasks-CvroqHtm.js.map → tasks-CS1rgG1s.js.map} +1 -1
  295. package/dashboard/dist/assets/useEventHooks-BjXX8x3a.js +2 -0
  296. package/dashboard/dist/assets/{useEventHooks-BHMbzR_y.js.map → useEventHooks-BjXX8x3a.js.map} +1 -1
  297. package/dashboard/dist/assets/useYamlActivityEvents-BeR-nVWQ.js +2 -0
  298. package/dashboard/dist/assets/{useYamlActivityEvents-D56KV14X.js.map → useYamlActivityEvents-BeR-nVWQ.js.map} +1 -1
  299. package/dashboard/dist/assets/{users-CxIMy_xw.js → users-DYsdQ7Md.js} +2 -2
  300. package/dashboard/dist/assets/{users-CxIMy_xw.js.map → users-DYsdQ7Md.js.map} +1 -1
  301. package/dashboard/dist/assets/{vendor-icons-AFGxSeQS.js → vendor-icons-CWl44VA6.js} +77 -77
  302. package/dashboard/dist/assets/vendor-icons-CWl44VA6.js.map +1 -0
  303. package/dashboard/dist/assets/{workflows-yR9yais7.js → workflows-2QAXh3UD.js} +2 -2
  304. package/dashboard/dist/assets/{workflows-yR9yais7.js.map → workflows-2QAXh3UD.js.map} +1 -1
  305. package/dashboard/dist/assets/{yaml-workflows-QVF2MZ0l.js → yaml-workflows-sx8-UEE3.js} +2 -2
  306. package/dashboard/dist/assets/{yaml-workflows-QVF2MZ0l.js.map → yaml-workflows-sx8-UEE3.js.map} +1 -1
  307. package/dashboard/dist/index.html +3 -3
  308. package/docs/api/http/file-browser.md +101 -0
  309. package/docs/api/http/knowledge.md +203 -0
  310. package/docs/api/http/settings.md +6 -4
  311. package/docs/api/sdk/files.md +68 -0
  312. package/docs/api/sdk/knowledge.md +126 -0
  313. package/docs/api/sdk/settings.md +3 -2
  314. package/docs/cli.md +171 -0
  315. package/docs/compilation.md +16 -0
  316. package/docs/compiler.md +311 -0
  317. package/docs/events.md +19 -0
  318. package/docs/workflows.md +19 -0
  319. package/package.json +13 -2
  320. package/build/api/escalations.d.ts +0 -271
  321. package/build/api/escalations.js +0 -932
  322. package/build/api/workflows.d.ts +0 -158
  323. package/build/api/workflows.js +0 -414
  324. package/dashboard/dist/assets/AvailableEscalationsPage-CpBfGV1h.js +0 -2
  325. package/dashboard/dist/assets/AvailableEscalationsPage-CpBfGV1h.js.map +0 -1
  326. package/dashboard/dist/assets/McpQueryDetailPage-Czsmovqw.js +0 -5
  327. package/dashboard/dist/assets/McpQueryDetailPage-Czsmovqw.js.map +0 -1
  328. package/dashboard/dist/assets/RolesPage-kH-Njt25.js +0 -2
  329. package/dashboard/dist/assets/SwimlaneTimeline-Cfe-xQRX.js +0 -2
  330. package/dashboard/dist/assets/SwimlaneTimeline-Cfe-xQRX.js.map +0 -1
  331. package/dashboard/dist/assets/YamlWorkflowsPage-BICF0fRO.js +0 -2
  332. package/dashboard/dist/assets/YamlWorkflowsPage-BICF0fRO.js.map +0 -1
  333. package/dashboard/dist/assets/helpers-rMEcLwKs.js +0 -2
  334. package/dashboard/dist/assets/helpers-rMEcLwKs.js.map +0 -1
  335. package/dashboard/dist/assets/index-ABcJHHlN.js +0 -5
  336. package/dashboard/dist/assets/index-ABcJHHlN.js.map +0 -1
  337. package/dashboard/dist/assets/index-B91h_jZ0.js +0 -15
  338. package/dashboard/dist/assets/index-B91h_jZ0.js.map +0 -1
  339. package/dashboard/dist/assets/index-C1E5GTs9.js +0 -2
  340. package/dashboard/dist/assets/index-C1E5GTs9.js.map +0 -1
  341. package/dashboard/dist/assets/index-C90ZPzXk.js +0 -2
  342. package/dashboard/dist/assets/index-Cmgrk7PQ.js.map +0 -1
  343. package/dashboard/dist/assets/index-DeX-ezqf.css +0 -1
  344. package/dashboard/dist/assets/index-K40Qw1tk.js +0 -2
  345. package/dashboard/dist/assets/index-lCyNr5Xk.js +0 -2
  346. package/dashboard/dist/assets/index-lCyNr5Xk.js.map +0 -1
  347. package/dashboard/dist/assets/useEventHooks-BHMbzR_y.js +0 -2
  348. package/dashboard/dist/assets/useYamlActivityEvents-D56KV14X.js +0 -2
  349. 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.deployYamlWorkflow = deployYamlWorkflow;
45
- exports.activateYamlWorkflow = activateYamlWorkflow;
46
- exports.invokeYamlWorkflow = invokeYamlWorkflow;
47
- exports.archiveYamlWorkflow = archiveYamlWorkflow;
48
- exports.restoreYamlWorkflow = restoreYamlWorkflow;
49
- exports.getVersionHistory = getVersionHistory;
50
- exports.getVersionSnapshot = getVersionSnapshot;
51
- exports.getYamlContent = getYamlContent;
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
- // Look up task queue from the source task record, or use input override
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
- * Invoke an active YAML workflow, executing its DAG pipeline.
428
+ * Compile a durable TypeScript workflow into a YAML DAG.
513
429
  *
514
- * The workflow must be in "active" status. Delegates to the invoke service which
515
- * starts the HotMesh execution. Supports both synchronous (wait for result) and
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.idUUID of the workflow to invoke
519
- * @param input.datainput payload passed to the workflow's entry point
520
- * @param input.syncwhen true, block until the workflow completes and return its output
521
- * @param input.timeoutmax milliseconds to wait when sync is true
522
- * @param input.execute_asoverride identity for the execution context
523
- * @param authauthenticated user context; userId is forwarded to the invoke service
524
- * @returns `{ status: 200, data: ... }` workflow execution result (sync) or job metadata (async)
433
+ * @param input.sourceTypeScript source code or file path
434
+ * @param input.is_file_pathwhether source is a file path (default: false)
435
+ * @param input.workflow_namename of the exported workflow function
436
+ * @param input.namename for the generated YAML workflow
437
+ * @param input.descriptionoptional description
438
+ * @param input.app_idtarget 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 invokeYamlWorkflow(input, auth) {
443
+ async function createYamlWorkflowFromDurable(input) {
527
444
  try {
528
- const wf = await yamlDb.getYamlWorkflow(input.id);
529
- if (!wf) {
530
- return { status: 404, error: 'YAML workflow not found' };
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
- if (wf.status !== 'active') {
533
- return { status: 400, error: 'Workflow must be active to invoke' };
534
- }
535
- const result = await (0, invoke_1.invokeYamlWorkflow)(wf, {
536
- data: input.data,
537
- sync: input.sync,
538
- timeout: input.timeout,
539
- execute_as: input.execute_as,
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
- return { status: 200, data: result };
543
- }
544
- catch (err) {
545
- if (isNotFoundError(err)) {
546
- return { status: 404, error: 'YAML workflow not found' };
547
- }
548
- return { status: 500, error: err.message };
549
- }
550
- }
551
- /**
552
- * Archive a YAML workflow, removing it from active service.
553
- *
554
- * If the workflow is currently active, its HotMesh engine is stopped before
555
- * transitioning the status to "archived". Archived workflows cannot be invoked
556
- * or regenerated but can still be viewed or deleted.
557
- *
558
- * @param input.id UUID of the workflow to archive
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>;