@hotmeshio/long-tail 0.1.6 → 0.1.7

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 (335) hide show
  1. package/README.md +44 -4
  2. package/build/api/auth.d.ts +5 -0
  3. package/build/api/auth.js +42 -0
  4. package/build/api/bot-accounts.d.ts +50 -0
  5. package/build/api/bot-accounts.js +215 -0
  6. package/build/api/controlplane.d.ts +20 -0
  7. package/build/api/controlplane.js +110 -0
  8. package/build/api/dba.d.ts +15 -0
  9. package/build/api/dba.js +68 -0
  10. package/build/api/escalations.d.ts +70 -0
  11. package/build/api/escalations.js +656 -0
  12. package/build/api/exports.d.ts +32 -0
  13. package/build/api/exports.js +146 -0
  14. package/build/api/index.d.ts +18 -0
  15. package/build/api/index.js +54 -0
  16. package/build/api/insight.d.ts +29 -0
  17. package/build/api/insight.js +90 -0
  18. package/build/api/maintenance.d.ts +7 -0
  19. package/build/api/maintenance.js +28 -0
  20. package/build/api/mcp-runs.d.ts +16 -0
  21. package/build/api/mcp-runs.js +62 -0
  22. package/build/api/mcp.d.ts +52 -0
  23. package/build/api/mcp.js +212 -0
  24. package/build/api/namespaces.d.ts +7 -0
  25. package/build/{routes/escalations/helpers.js → api/namespaces.js} +24 -12
  26. package/build/api/roles.d.ts +25 -0
  27. package/build/api/roles.js +159 -0
  28. package/build/api/settings.d.ts +2 -0
  29. package/build/api/settings.js +35 -0
  30. package/build/api/tasks.d.ts +27 -0
  31. package/build/api/tasks.js +96 -0
  32. package/build/api/users.d.ts +44 -0
  33. package/build/api/users.js +162 -0
  34. package/build/api/workflow-sets.d.ts +26 -0
  35. package/build/api/workflow-sets.js +119 -0
  36. package/build/api/workflows.d.ts +48 -0
  37. package/build/api/workflows.js +298 -0
  38. package/build/api/yaml-workflows.d.ts +87 -0
  39. package/build/api/yaml-workflows.js +556 -0
  40. package/build/index.d.ts +4 -0
  41. package/build/index.js +6 -1
  42. package/build/lib/db/schemas/004_workflow_sets.sql +29 -0
  43. package/build/lib/db/schemas/005_unique_graph_topic.sql +7 -0
  44. package/build/lib/db/schemas/011_system_workflow_configs.sql +7 -0
  45. package/build/lib/events/callback.d.ts +41 -0
  46. package/build/lib/events/callback.js +98 -0
  47. package/build/modules/config.js +1 -1
  48. package/build/routes/auth.js +37 -36
  49. package/build/routes/bot-accounts.js +34 -164
  50. package/build/routes/controlplane.js +20 -60
  51. package/build/routes/dba.js +18 -28
  52. package/build/routes/escalations/bulk.js +17 -192
  53. package/build/routes/escalations/list.js +29 -75
  54. package/build/routes/escalations/resolve.js +3 -193
  55. package/build/routes/escalations/single.js +13 -122
  56. package/build/routes/exports.js +44 -95
  57. package/build/routes/index.js +2 -0
  58. package/build/routes/insight.js +46 -88
  59. package/build/routes/maintenance.js +41 -17
  60. package/build/routes/mcp-runs.js +52 -60
  61. package/build/routes/mcp.js +49 -177
  62. package/build/routes/namespaces.js +9 -20
  63. package/build/routes/roles.js +23 -97
  64. package/build/routes/settings.js +37 -25
  65. package/build/routes/tasks.js +28 -64
  66. package/build/routes/users.js +24 -113
  67. package/build/routes/workflow-sets.d.ts +2 -0
  68. package/build/routes/workflow-sets.js +98 -0
  69. package/build/routes/workflows/config.js +23 -57
  70. package/build/routes/workflows/discovery.js +11 -85
  71. package/build/routes/workflows/invocation.js +16 -84
  72. package/build/routes/yaml-workflows/cron.js +12 -61
  73. package/build/routes/yaml-workflows/crud.js +30 -223
  74. package/build/routes/yaml-workflows/deployment.js +15 -115
  75. package/build/routes/yaml-workflows/versions.js +20 -58
  76. package/build/sdk/index.d.ts +327 -0
  77. package/build/sdk/index.js +298 -0
  78. package/build/services/controlplane/index.d.ts +1 -2
  79. package/build/services/controlplane/index.js +3 -3
  80. package/build/services/controlplane/sql.d.ts +2 -2
  81. package/build/services/controlplane/sql.js +4 -5
  82. package/build/services/controlplane/types.d.ts +1 -0
  83. package/build/services/export/index.js +6 -1
  84. package/build/services/hotmesh-utils.js +2 -4
  85. package/build/services/insight/index.d.ts +7 -0
  86. package/build/services/insight/index.js +30 -0
  87. package/build/services/mcp/client/tools.js +13 -1
  88. package/build/services/mcp-runs/sql.js +1 -1
  89. package/build/services/workflow-sets/db.d.ts +16 -0
  90. package/build/services/workflow-sets/db.js +78 -0
  91. package/build/services/workflow-sets/index.d.ts +1 -0
  92. package/build/services/workflow-sets/index.js +11 -0
  93. package/build/services/workflow-sets/sql.d.ts +6 -0
  94. package/build/services/workflow-sets/sql.js +24 -0
  95. package/build/services/yaml-workflow/db-utils.d.ts +1 -0
  96. package/build/services/yaml-workflow/db-utils.js +4 -0
  97. package/build/services/yaml-workflow/db.d.ts +5 -0
  98. package/build/services/yaml-workflow/db.js +17 -0
  99. package/build/services/yaml-workflow/pipeline/build/wiring.js +14 -1
  100. package/build/services/yaml-workflow/pipeline/prompts.d.ts +1 -1
  101. package/build/services/yaml-workflow/pipeline/prompts.js +1 -1
  102. package/build/services/yaml-workflow/sql.d.ts +2 -1
  103. package/build/services/yaml-workflow/sql.js +8 -3
  104. package/build/services/yaml-workflow/types.d.ts +3 -0
  105. package/build/services/yaml-workflow/workers/callbacks.js +7 -1
  106. package/build/services/yaml-workflow/workers/register.js +7 -0
  107. package/build/start/adapters.js +4 -0
  108. package/build/system/index.js +6 -0
  109. package/build/system/mcp-servers/knowledge.js +1 -1
  110. package/build/system/seed/server-definitions.js +2 -1
  111. package/build/system/workflows/mcp-workflow-builder/activities/index.d.ts +1 -1
  112. package/build/system/workflows/mcp-workflow-builder/activities/index.js +2 -1
  113. package/build/system/workflows/mcp-workflow-builder/activities/tool-loader.d.ts +6 -0
  114. package/build/system/workflows/mcp-workflow-builder/activities/tool-loader.js +26 -0
  115. package/build/system/workflows/mcp-workflow-builder/index.js +26 -2
  116. package/build/system/workflows/mcp-workflow-builder/prompts.js +104 -35
  117. package/build/system/workflows/mcp-workflow-planner/activities/analyze.d.ts +11 -0
  118. package/build/system/workflows/mcp-workflow-planner/activities/analyze.js +36 -0
  119. package/build/system/workflows/mcp-workflow-planner/activities/index.d.ts +3 -0
  120. package/build/system/workflows/mcp-workflow-planner/activities/index.js +12 -0
  121. package/build/system/workflows/mcp-workflow-planner/activities/persist.d.ts +19 -0
  122. package/build/system/workflows/mcp-workflow-planner/activities/persist.js +55 -0
  123. package/build/system/workflows/mcp-workflow-planner/activities/plan.d.ts +10 -0
  124. package/build/system/workflows/mcp-workflow-planner/activities/plan.js +43 -0
  125. package/build/system/workflows/mcp-workflow-planner/index.d.ts +7 -0
  126. package/build/system/workflows/mcp-workflow-planner/index.js +152 -0
  127. package/build/system/workflows/mcp-workflow-planner/prompts.d.ts +7 -0
  128. package/build/system/workflows/mcp-workflow-planner/prompts.js +77 -0
  129. package/build/tsconfig.tsbuildinfo +1 -1
  130. package/build/types/index.d.ts +1 -0
  131. package/build/types/sdk.d.ts +27 -0
  132. package/build/types/sdk.js +2 -0
  133. package/build/types/workflow-set.d.ts +44 -0
  134. package/build/types/workflow-set.js +5 -0
  135. package/dashboard/dist/assets/{AdminDashboard-BXkKGkb5.js → AdminDashboard-DRjkRSjJ.js} +2 -2
  136. package/dashboard/dist/assets/{AdminDashboard-BXkKGkb5.js.map → AdminDashboard-DRjkRSjJ.js.map} +1 -1
  137. package/dashboard/dist/assets/{AvailableEscalationsPage-DcH592mc.js → AvailableEscalationsPage-CnivX4Tz.js} +2 -2
  138. package/dashboard/dist/assets/{AvailableEscalationsPage-DcH592mc.js.map → AvailableEscalationsPage-CnivX4Tz.js.map} +1 -1
  139. package/dashboard/dist/assets/BotPicker-DwwaBhTH.js +2 -0
  140. package/dashboard/dist/assets/{BotPicker-A6LtzyuO.js.map → BotPicker-DwwaBhTH.js.map} +1 -1
  141. package/dashboard/dist/assets/{CollapsibleSection-C7nL2_mv.js → CollapsibleSection-DQpaVA0M.js} +2 -2
  142. package/dashboard/dist/assets/{CollapsibleSection-C7nL2_mv.js.map → CollapsibleSection-DQpaVA0M.js.map} +1 -1
  143. package/dashboard/dist/assets/{ConfirmDeleteModal-CWFwJrSl.js → ConfirmDeleteModal-B7JoDNvt.js} +2 -2
  144. package/dashboard/dist/assets/{ConfirmDeleteModal-CWFwJrSl.js.map → ConfirmDeleteModal-B7JoDNvt.js.map} +1 -1
  145. package/dashboard/dist/assets/{CopyableId-DbZ5c3jh.js → CopyableId-AqoZayBG.js} +2 -2
  146. package/dashboard/dist/assets/{CopyableId-DbZ5c3jh.js.map → CopyableId-AqoZayBG.js.map} +1 -1
  147. package/dashboard/dist/assets/{CredentialsPage-ClWkmLPu.js → CredentialsPage-qGw1kQzi.js} +2 -2
  148. package/dashboard/dist/assets/{CredentialsPage-ClWkmLPu.js.map → CredentialsPage-qGw1kQzi.js.map} +1 -1
  149. package/dashboard/dist/assets/{CustomDurationPicker-CtH2hReF.js → CustomDurationPicker-D1HUQcd0.js} +2 -2
  150. package/dashboard/dist/assets/{CustomDurationPicker-CtH2hReF.js.map → CustomDurationPicker-D1HUQcd0.js.map} +1 -1
  151. package/dashboard/dist/assets/{DataTable-CM5ZcpPi.js → DataTable-DKvSKoVG.js} +2 -2
  152. package/dashboard/dist/assets/{DataTable-CM5ZcpPi.js.map → DataTable-DKvSKoVG.js.map} +1 -1
  153. package/dashboard/dist/assets/{ElapsedCell-CwqavyeC.js → ElapsedCell-B0yrReGQ.js} +2 -2
  154. package/dashboard/dist/assets/{ElapsedCell-CwqavyeC.js.map → ElapsedCell-B0yrReGQ.js.map} +1 -1
  155. package/dashboard/dist/assets/{EmptyState-BBn78pmm.js → EmptyState-X0fIzYID.js} +2 -2
  156. package/dashboard/dist/assets/{EmptyState-BBn78pmm.js.map → EmptyState-X0fIzYID.js.map} +1 -1
  157. package/dashboard/dist/assets/{EscalationsOverview-BcJ2E3X7.js → EscalationsOverview-BQAT9W7r.js} +2 -2
  158. package/dashboard/dist/assets/{EscalationsOverview-BcJ2E3X7.js.map → EscalationsOverview-BQAT9W7r.js.map} +1 -1
  159. package/dashboard/dist/assets/{EventTable-C1en_KZ0.js → EventTable-CX1KNLhZ.js} +2 -2
  160. package/dashboard/dist/assets/{EventTable-C1en_KZ0.js.map → EventTable-CX1KNLhZ.js.map} +1 -1
  161. package/dashboard/dist/assets/{FilterBar-CZTlrLQT.js → FilterBar-DMTvuQy-.js} +2 -2
  162. package/dashboard/dist/assets/{FilterBar-CZTlrLQT.js.map → FilterBar-DMTvuQy-.js.map} +1 -1
  163. package/dashboard/dist/assets/{ListToolbar-Cdbsapig.js → ListToolbar-DTOSxoEy.js} +2 -2
  164. package/dashboard/dist/assets/{ListToolbar-Cdbsapig.js.map → ListToolbar-DTOSxoEy.js.map} +1 -1
  165. package/dashboard/dist/assets/{McpOverview-CSpEJxKa.js → McpOverview-BaKTIWrG.js} +2 -2
  166. package/dashboard/dist/assets/{McpOverview-CSpEJxKa.js.map → McpOverview-BaKTIWrG.js.map} +1 -1
  167. package/dashboard/dist/assets/McpQueryDetailPage-CC08T5k8.js +5 -0
  168. package/dashboard/dist/assets/McpQueryDetailPage-CC08T5k8.js.map +1 -0
  169. package/dashboard/dist/assets/McpQueryPage-CVfF9dYg.js +2 -0
  170. package/dashboard/dist/assets/McpQueryPage-CVfF9dYg.js.map +1 -0
  171. package/dashboard/dist/assets/{McpRunDetailPage-9xdxgG4d.js → McpRunDetailPage-CKs1RWeV.js} +2 -2
  172. package/dashboard/dist/assets/{McpRunDetailPage-9xdxgG4d.js.map → McpRunDetailPage-CKs1RWeV.js.map} +1 -1
  173. package/dashboard/dist/assets/{McpRunsPage-wWLqHsd4.js → McpRunsPage-CcPD_tY1.js} +2 -2
  174. package/dashboard/dist/assets/{McpRunsPage-wWLqHsd4.js.map → McpRunsPage-CcPD_tY1.js.map} +1 -1
  175. package/dashboard/dist/assets/{Modal-kB_P7ZOr.js → Modal-_2AbWxJT.js} +2 -2
  176. package/dashboard/dist/assets/{Modal-kB_P7ZOr.js.map → Modal-_2AbWxJT.js.map} +1 -1
  177. package/dashboard/dist/assets/OperatorDashboard-BGiRaRDr.js +2 -0
  178. package/dashboard/dist/assets/{OperatorDashboard-jc0vrgDI.js.map → OperatorDashboard-BGiRaRDr.js.map} +1 -1
  179. package/dashboard/dist/assets/{PageHeader-NkOeBR05.js → PageHeader-DVr5Qyzm.js} +2 -2
  180. package/dashboard/dist/assets/{PageHeader-NkOeBR05.js.map → PageHeader-DVr5Qyzm.js.map} +1 -1
  181. package/dashboard/dist/assets/{PageHeaderWithStats-ywNhrmFK.js → PageHeaderWithStats-D0KRASML.js} +2 -2
  182. package/dashboard/dist/assets/{PageHeaderWithStats-ywNhrmFK.js.map → PageHeaderWithStats-D0KRASML.js.map} +1 -1
  183. package/dashboard/dist/assets/{PriorityBadge-B2MQbSxy.js → PriorityBadge-Bx2559OU.js} +2 -2
  184. package/dashboard/dist/assets/{PriorityBadge-B2MQbSxy.js.map → PriorityBadge-Bx2559OU.js.map} +1 -1
  185. package/dashboard/dist/assets/{ProcessDetailPage-B7z7IdqE.js → ProcessDetailPage-69I--sry.js} +2 -2
  186. package/dashboard/dist/assets/{ProcessDetailPage-B7z7IdqE.js.map → ProcessDetailPage-69I--sry.js.map} +1 -1
  187. package/dashboard/dist/assets/{ProcessesListPage-C-uHadO6.js → ProcessesListPage-BDpUbua2.js} +2 -2
  188. package/dashboard/dist/assets/{ProcessesListPage-C-uHadO6.js.map → ProcessesListPage-BDpUbua2.js.map} +1 -1
  189. package/dashboard/dist/assets/{RolePill-C1dgC-fK.js → RolePill-CcAqEaSt.js} +2 -2
  190. package/dashboard/dist/assets/{RolePill-C1dgC-fK.js.map → RolePill-CcAqEaSt.js.map} +1 -1
  191. package/dashboard/dist/assets/{RolesPage-BSxrD1vm.js → RolesPage-Cl23Hjet.js} +2 -2
  192. package/dashboard/dist/assets/{RolesPage-BSxrD1vm.js.map → RolesPage-Cl23Hjet.js.map} +1 -1
  193. package/dashboard/dist/assets/{RowActions-lYaHGI-v.js → RowActions-B4mqIt3Z.js} +2 -2
  194. package/dashboard/dist/assets/{RowActions-lYaHGI-v.js.map → RowActions-B4mqIt3Z.js.map} +1 -1
  195. package/dashboard/dist/assets/{StatCard-v2TiITVr.js → StatCard-Cz_2OjAZ.js} +2 -2
  196. package/dashboard/dist/assets/{StatCard-v2TiITVr.js.map → StatCard-Cz_2OjAZ.js.map} +1 -1
  197. package/dashboard/dist/assets/{StatusBadge-DWlxevgG.js → StatusBadge-Wi2FJZsn.js} +2 -2
  198. package/dashboard/dist/assets/{StatusBadge-DWlxevgG.js.map → StatusBadge-Wi2FJZsn.js.map} +1 -1
  199. package/dashboard/dist/assets/{StepIndicator-CRM4ft28.js → StepIndicator-PW5NRDMb.js} +2 -2
  200. package/dashboard/dist/assets/{StepIndicator-CRM4ft28.js.map → StepIndicator-PW5NRDMb.js.map} +1 -1
  201. package/dashboard/dist/assets/{StickyPagination-CF0EToEU.js → StickyPagination-Bl2Uzz65.js} +2 -2
  202. package/dashboard/dist/assets/{StickyPagination-CF0EToEU.js.map → StickyPagination-Bl2Uzz65.js.map} +1 -1
  203. package/dashboard/dist/assets/{SwimlaneTimeline-CNlj7fgg.js → SwimlaneTimeline-CUPqMd0z.js} +2 -2
  204. package/dashboard/dist/assets/{SwimlaneTimeline-CNlj7fgg.js.map → SwimlaneTimeline-CUPqMd0z.js.map} +1 -1
  205. package/dashboard/dist/assets/{TagInput-CH8qMGhC.js → TagInput-BLtf86Ly.js} +2 -2
  206. package/dashboard/dist/assets/{TagInput-CH8qMGhC.js.map → TagInput-BLtf86Ly.js.map} +1 -1
  207. package/dashboard/dist/assets/{TaskDetailPage-CdWo-6mu.js → TaskDetailPage-BXJFX74D.js} +2 -2
  208. package/dashboard/dist/assets/{TaskDetailPage-CdWo-6mu.js.map → TaskDetailPage-BXJFX74D.js.map} +1 -1
  209. package/dashboard/dist/assets/{TaskQueuePill-BPj4ogVG.js → TaskQueuePill-CWYj3xKe.js} +2 -2
  210. package/dashboard/dist/assets/{TaskQueuePill-BPj4ogVG.js.map → TaskQueuePill-CWYj3xKe.js.map} +1 -1
  211. package/dashboard/dist/assets/{TasksListPage-CtRkMpKU.js → TasksListPage-C3cX94Mw.js} +2 -2
  212. package/dashboard/dist/assets/{TasksListPage-CtRkMpKU.js.map → TasksListPage-C3cX94Mw.js.map} +1 -1
  213. package/dashboard/dist/assets/{TimeAgo-Di1a3X5P.js → TimeAgo-B_5yDDHV.js} +2 -2
  214. package/dashboard/dist/assets/{TimeAgo-Di1a3X5P.js.map → TimeAgo-B_5yDDHV.js.map} +1 -1
  215. package/dashboard/dist/assets/{TimestampCell-CqrXql-S.js → TimestampCell-DRX724uU.js} +2 -2
  216. package/dashboard/dist/assets/{TimestampCell-CqrXql-S.js.map → TimestampCell-DRX724uU.js.map} +1 -1
  217. package/dashboard/dist/assets/{UserName-BUFYCnRa.js → UserName-Ca8FA469.js} +2 -2
  218. package/dashboard/dist/assets/{UserName-BUFYCnRa.js.map → UserName-Ca8FA469.js.map} +1 -1
  219. package/dashboard/dist/assets/{WorkflowExecutionPage-25iusMml.js → WorkflowExecutionPage-BBYWEV2P.js} +2 -2
  220. package/dashboard/dist/assets/{WorkflowExecutionPage-25iusMml.js.map → WorkflowExecutionPage-BBYWEV2P.js.map} +1 -1
  221. package/dashboard/dist/assets/WorkflowPill-BXifAuLi.js +2 -0
  222. package/dashboard/dist/assets/{WorkflowPill-DPKOcbf4.js.map → WorkflowPill-BXifAuLi.js.map} +1 -1
  223. package/dashboard/dist/assets/{WorkflowsDashboard-BgxslssH.js → WorkflowsDashboard-Drl3juz9.js} +2 -2
  224. package/dashboard/dist/assets/{WorkflowsDashboard-BgxslssH.js.map → WorkflowsDashboard-Drl3juz9.js.map} +1 -1
  225. package/dashboard/dist/assets/{WorkflowsOverview-Doe5L-Re.js → WorkflowsOverview-03IRrDLg.js} +2 -2
  226. package/dashboard/dist/assets/{WorkflowsOverview-Doe5L-Re.js.map → WorkflowsOverview-03IRrDLg.js.map} +1 -1
  227. package/dashboard/dist/assets/YamlWorkflowsPage-DC2cLxVi.js +2 -0
  228. package/dashboard/dist/assets/YamlWorkflowsPage-DC2cLxVi.js.map +1 -0
  229. package/dashboard/dist/assets/{bots-Bi2_O1Ts.js → bots-DZEXcgiJ.js} +2 -2
  230. package/dashboard/dist/assets/{bots-Bi2_O1Ts.js.map → bots-DZEXcgiJ.js.map} +1 -1
  231. package/dashboard/dist/assets/{escalation-Ck1KlLkT.js → escalation-Cw48lNaF.js} +2 -2
  232. package/dashboard/dist/assets/{escalation-Ck1KlLkT.js.map → escalation-Cw48lNaF.js.map} +1 -1
  233. package/dashboard/dist/assets/{escalation-columns-ohDsj2eJ.js → escalation-columns-NINpo3qf.js} +2 -2
  234. package/dashboard/dist/assets/{escalation-columns-ohDsj2eJ.js.map → escalation-columns-NINpo3qf.js.map} +1 -1
  235. package/dashboard/dist/assets/helpers-Cuu3xKfr.js +2 -0
  236. package/dashboard/dist/assets/helpers-Cuu3xKfr.js.map +1 -0
  237. package/dashboard/dist/assets/{helpers-BoD2SgUY.js → helpers-fk_qr729.js} +2 -2
  238. package/dashboard/dist/assets/{helpers-BoD2SgUY.js.map → helpers-fk_qr729.js.map} +1 -1
  239. package/dashboard/dist/assets/index-B98ipWxE.js +2 -0
  240. package/dashboard/dist/assets/{index-D7zYZOnH.js.map → index-B98ipWxE.js.map} +1 -1
  241. package/dashboard/dist/assets/{index-BEtLIsML.js → index-BIG3KooI.js} +2 -2
  242. package/dashboard/dist/assets/{index-BEtLIsML.js.map → index-BIG3KooI.js.map} +1 -1
  243. package/dashboard/dist/assets/{index-DYyLF-Qb.js → index-BwN3KP_L.js} +5 -5
  244. package/dashboard/dist/assets/{index-DYyLF-Qb.js.map → index-BwN3KP_L.js.map} +1 -1
  245. package/dashboard/dist/assets/index-Bxe8h1x4.js +17 -0
  246. package/dashboard/dist/assets/{index-DOkHXmyf.js.map → index-Bxe8h1x4.js.map} +1 -1
  247. package/dashboard/dist/assets/{index-FuohTtaM.js → index-CNI7k7oB.js} +3 -3
  248. package/dashboard/dist/assets/{index-FuohTtaM.js.map → index-CNI7k7oB.js.map} +1 -1
  249. package/dashboard/dist/assets/{index-CZrJ09p-.js → index-CORHB0WC.js} +2 -2
  250. package/dashboard/dist/assets/{index-CZrJ09p-.js.map → index-CORHB0WC.js.map} +1 -1
  251. package/dashboard/dist/assets/{index-PyCTS05D.css → index-DcIKW-cZ.css} +1 -1
  252. package/dashboard/dist/assets/{index-D3NyVADW.js → index-Dj-z-x8M.js} +2 -2
  253. package/dashboard/dist/assets/index-Dj-z-x8M.js.map +1 -0
  254. package/dashboard/dist/assets/{index-Bn2xHDr8.js → index-DwRytW9O.js} +3 -3
  255. package/dashboard/dist/assets/{index-Bn2xHDr8.js.map → index-DwRytW9O.js.map} +1 -1
  256. package/dashboard/dist/assets/index-aRvL-dXp.js +2 -0
  257. package/dashboard/dist/assets/{index-Dk2Q51o0.js.map → index-aRvL-dXp.js.map} +1 -1
  258. package/dashboard/dist/assets/index-b03HlbnH.js +2 -0
  259. package/dashboard/dist/assets/{index-BpT-6WgJ.js.map → index-b03HlbnH.js.map} +1 -1
  260. package/dashboard/dist/assets/{mcp-CJtYjA7A.js → mcp-BZoFryNc.js} +2 -2
  261. package/dashboard/dist/assets/{mcp-CJtYjA7A.js.map → mcp-BZoFryNc.js.map} +1 -1
  262. package/dashboard/dist/assets/mcp-query-wiw1kwm8.js +2 -0
  263. package/dashboard/dist/assets/mcp-query-wiw1kwm8.js.map +1 -0
  264. package/dashboard/dist/assets/{mcp-runs-DUWm9Z4V.js → mcp-runs-BaEKnf5v.js} +2 -2
  265. package/dashboard/dist/assets/{mcp-runs-DUWm9Z4V.js.map → mcp-runs-BaEKnf5v.js.map} +1 -1
  266. package/dashboard/dist/assets/{namespaces-BM5P2qmL.js → namespaces-BwnZI4_A.js} +2 -2
  267. package/dashboard/dist/assets/{namespaces-BM5P2qmL.js.map → namespaces-BwnZI4_A.js.map} +1 -1
  268. package/dashboard/dist/assets/{roles-lv0shpjJ.js → roles-Bgn1K8zU.js} +2 -2
  269. package/dashboard/dist/assets/{roles-lv0shpjJ.js.map → roles-Bgn1K8zU.js.map} +1 -1
  270. package/dashboard/dist/assets/{settings-Wlq92mRo.js → settings-CizYiutL.js} +2 -2
  271. package/dashboard/dist/assets/{settings-Wlq92mRo.js.map → settings-CizYiutL.js.map} +1 -1
  272. package/dashboard/dist/assets/{tasks-BFGm4PuE.js → tasks-Bmte_hc4.js} +2 -2
  273. package/dashboard/dist/assets/{tasks-BFGm4PuE.js.map → tasks-Bmte_hc4.js.map} +1 -1
  274. package/dashboard/dist/assets/{useEventHooks-DIE6ue4x.js → useEventHooks-CUCxpiI2.js} +2 -2
  275. package/dashboard/dist/assets/{useEventHooks-DIE6ue4x.js.map → useEventHooks-CUCxpiI2.js.map} +1 -1
  276. package/dashboard/dist/assets/{useYamlActivityEvents-DCwSO73t.js → useYamlActivityEvents-Cum02Ej9.js} +2 -2
  277. package/dashboard/dist/assets/{useYamlActivityEvents-DCwSO73t.js.map → useYamlActivityEvents-Cum02Ej9.js.map} +1 -1
  278. package/dashboard/dist/assets/{users-tA5-K0wA.js → users-NSDgTt-z.js} +2 -2
  279. package/dashboard/dist/assets/{users-tA5-K0wA.js.map → users-NSDgTt-z.js.map} +1 -1
  280. package/dashboard/dist/assets/{vendor-icons-BiIug1SK.js → vendor-icons-D1DdudfH.js} +93 -73
  281. package/dashboard/dist/assets/vendor-icons-D1DdudfH.js.map +1 -0
  282. package/dashboard/dist/assets/{workflows-CfLc15Wr.js → workflows-k0XRdGXx.js} +2 -2
  283. package/dashboard/dist/assets/{workflows-CfLc15Wr.js.map → workflows-k0XRdGXx.js.map} +1 -1
  284. package/dashboard/dist/assets/yaml-workflows-DAre8I78.js +2 -0
  285. package/dashboard/dist/assets/yaml-workflows-DAre8I78.js.map +1 -0
  286. package/dashboard/dist/index.html +3 -3
  287. package/docs/epic-integration.md +224 -0
  288. package/docs/events.md +28 -0
  289. package/docs/sdk.md +177 -0
  290. package/docs/story.md +157 -0
  291. package/docs/workflow-builder.md +371 -0
  292. package/package.json +3 -2
  293. package/build/routes/escalations/helpers.d.ts +0 -5
  294. package/build/routes/resolve.d.ts +0 -9
  295. package/build/routes/resolve.js +0 -19
  296. package/build/routes/yaml-workflows/helpers.d.ts +0 -2
  297. package/build/routes/yaml-workflows/helpers.js +0 -8
  298. package/dashboard/dist/assets/BotPicker-A6LtzyuO.js +0 -2
  299. package/dashboard/dist/assets/McpQueryDetailPage-DhqEI180.js +0 -5
  300. package/dashboard/dist/assets/McpQueryDetailPage-DhqEI180.js.map +0 -1
  301. package/dashboard/dist/assets/McpQueryPage-CIiVMlqo.js +0 -2
  302. package/dashboard/dist/assets/McpQueryPage-CIiVMlqo.js.map +0 -1
  303. package/dashboard/dist/assets/OperatorDashboard-jc0vrgDI.js +0 -2
  304. package/dashboard/dist/assets/RunAsSelector-CJDnyp93.js +0 -2
  305. package/dashboard/dist/assets/RunAsSelector-CJDnyp93.js.map +0 -1
  306. package/dashboard/dist/assets/WorkflowPill-DPKOcbf4.js +0 -2
  307. package/dashboard/dist/assets/YamlWorkflowsPage-BliAckJ6.js +0 -2
  308. package/dashboard/dist/assets/YamlWorkflowsPage-BliAckJ6.js.map +0 -1
  309. package/dashboard/dist/assets/index-BpT-6WgJ.js +0 -2
  310. package/dashboard/dist/assets/index-D3NyVADW.js.map +0 -1
  311. package/dashboard/dist/assets/index-D7zYZOnH.js +0 -2
  312. package/dashboard/dist/assets/index-DOkHXmyf.js +0 -17
  313. package/dashboard/dist/assets/index-Dk2Q51o0.js +0 -2
  314. package/dashboard/dist/assets/mcp-query-jQJQrs_7.js +0 -2
  315. package/dashboard/dist/assets/mcp-query-jQJQrs_7.js.map +0 -1
  316. package/dashboard/dist/assets/vendor-icons-BiIug1SK.js.map +0 -1
  317. package/dashboard/dist/assets/yaml-workflows-D7JXNqbM.js +0 -2
  318. package/dashboard/dist/assets/yaml-workflows-D7JXNqbM.js.map +0 -1
  319. package/docs/img/01-login.png +0 -0
  320. package/docs/img/02-dashboard-home.png +0 -0
  321. package/docs/img/03-processes-list.png +0 -0
  322. package/docs/img/04-escalations-list.png +0 -0
  323. package/docs/img/05-mcp-servers.png +0 -0
  324. package/docs/img/06-mcp-pipelines.png +0 -0
  325. package/docs/img/07-workflows-list.png +0 -0
  326. package/docs/img/compilation/01-query-submit.png +0 -0
  327. package/docs/img/compilation/02-mcp-servers.png +0 -0
  328. package/docs/img/compilation/03-query-completed.png +0 -0
  329. package/docs/img/compilation/04-wizard-original.png +0 -0
  330. package/docs/img/compilation/05-wizard-timeline.png +0 -0
  331. package/docs/img/compilation/06-wizard-profile.png +0 -0
  332. package/docs/img/compilation/07-wizard-deploy.png +0 -0
  333. package/docs/img/compilation/08-wizard-test-modal.png +0 -0
  334. package/docs/img/compilation/09-wizard-test-compare.png +0 -0
  335. package/docs/img/compilation/10-wizard-verify.png +0 -0
@@ -0,0 +1,162 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.listUsers = listUsers;
37
+ exports.getUser = getUser;
38
+ exports.createUser = createUser;
39
+ exports.updateUser = updateUser;
40
+ exports.deleteUser = deleteUser;
41
+ exports.getUserRoles = getUserRoles;
42
+ exports.addUserRole = addUserRole;
43
+ exports.removeUserRole = removeUserRole;
44
+ const userService = __importStar(require("../services/user"));
45
+ async function listUsers(input) {
46
+ try {
47
+ const result = await userService.listUsers(input);
48
+ return { status: 200, data: result };
49
+ }
50
+ catch (err) {
51
+ return { status: 500, error: err.message };
52
+ }
53
+ }
54
+ async function getUser(input) {
55
+ try {
56
+ const user = await userService.getUser(input.id);
57
+ if (!user) {
58
+ return { status: 404, error: 'User not found' };
59
+ }
60
+ return { status: 200, data: user };
61
+ }
62
+ catch (err) {
63
+ return { status: 500, error: err.message };
64
+ }
65
+ }
66
+ // Admin-required
67
+ async function createUser(input) {
68
+ try {
69
+ if (!input.external_id) {
70
+ return { status: 400, error: 'external_id is required' };
71
+ }
72
+ if (input.roles) {
73
+ for (const r of input.roles) {
74
+ if (!r.role || !r.type || !userService.isValidRoleType(r.type)) {
75
+ return {
76
+ status: 400,
77
+ error: 'Each role must have a role name and type (superadmin, admin, member)',
78
+ };
79
+ }
80
+ }
81
+ }
82
+ const user = await userService.createUser({
83
+ external_id: input.external_id,
84
+ email: input.email,
85
+ display_name: input.display_name,
86
+ roles: input.roles,
87
+ metadata: input.metadata,
88
+ });
89
+ return { status: 201, data: user };
90
+ }
91
+ catch (err) {
92
+ if (err.code === '23505') {
93
+ return { status: 409, error: 'User with this external_id already exists' };
94
+ }
95
+ return { status: 500, error: err.message };
96
+ }
97
+ }
98
+ // Admin-required
99
+ async function updateUser(input) {
100
+ try {
101
+ const { id, ...fields } = input;
102
+ const user = await userService.updateUser(id, fields);
103
+ if (!user) {
104
+ return { status: 404, error: 'User not found' };
105
+ }
106
+ return { status: 200, data: user };
107
+ }
108
+ catch (err) {
109
+ return { status: 500, error: err.message };
110
+ }
111
+ }
112
+ // Admin-required
113
+ async function deleteUser(input) {
114
+ try {
115
+ const deleted = await userService.deleteUser(input.id);
116
+ if (!deleted) {
117
+ return { status: 404, error: 'User not found' };
118
+ }
119
+ return { status: 200, data: { deleted: true } };
120
+ }
121
+ catch (err) {
122
+ return { status: 500, error: err.message };
123
+ }
124
+ }
125
+ async function getUserRoles(input) {
126
+ try {
127
+ const roles = await userService.getUserRoles(input.id);
128
+ return { status: 200, data: { roles } };
129
+ }
130
+ catch (err) {
131
+ return { status: 500, error: err.message };
132
+ }
133
+ }
134
+ // Admin-required
135
+ async function addUserRole(input) {
136
+ try {
137
+ if (!input.role || !input.type) {
138
+ return { status: 400, error: 'role and type are required' };
139
+ }
140
+ if (!userService.isValidRoleType(input.type)) {
141
+ return { status: 400, error: 'type must be superadmin, admin, or member' };
142
+ }
143
+ const result = await userService.addUserRole(input.id, input.role, input.type);
144
+ return { status: 201, data: result };
145
+ }
146
+ catch (err) {
147
+ return { status: 500, error: err.message };
148
+ }
149
+ }
150
+ // Admin-required
151
+ async function removeUserRole(input) {
152
+ try {
153
+ const removed = await userService.removeUserRole(input.id, input.role);
154
+ if (!removed) {
155
+ return { status: 404, error: 'Role not found' };
156
+ }
157
+ return { status: 200, data: { removed: true } };
158
+ }
159
+ catch (err) {
160
+ return { status: 500, error: err.message };
161
+ }
162
+ }
@@ -0,0 +1,26 @@
1
+ import type { LTApiResult, LTApiAuth } from '../types/sdk';
2
+ export declare function createWorkflowSet(input: {
3
+ name: string;
4
+ description?: string;
5
+ specification: string;
6
+ }, auth?: LTApiAuth): Promise<LTApiResult>;
7
+ export declare function listWorkflowSets(input: {
8
+ status?: string;
9
+ search?: string;
10
+ limit?: number;
11
+ offset?: number;
12
+ }): Promise<LTApiResult>;
13
+ export declare function getWorkflowSet(input: {
14
+ id: string;
15
+ }): Promise<LTApiResult>;
16
+ export declare function updateWorkflowSetPlanApi(input: {
17
+ id: string;
18
+ plan: any[];
19
+ namespaces?: any[];
20
+ }): Promise<LTApiResult>;
21
+ export declare function buildWorkflowSet(input: {
22
+ id: string;
23
+ }): Promise<LTApiResult>;
24
+ export declare function deployWorkflowSet(input: {
25
+ id: string;
26
+ }): Promise<LTApiResult>;
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createWorkflowSet = createWorkflowSet;
4
+ exports.listWorkflowSets = listWorkflowSets;
5
+ exports.getWorkflowSet = getWorkflowSet;
6
+ exports.updateWorkflowSetPlanApi = updateWorkflowSetPlanApi;
7
+ exports.buildWorkflowSet = buildWorkflowSet;
8
+ exports.deployWorkflowSet = deployWorkflowSet;
9
+ const workflow_sets_1 = require("../services/workflow-sets");
10
+ const insight_1 = require("../services/insight");
11
+ async function createWorkflowSet(input, auth) {
12
+ try {
13
+ if (!input.specification || typeof input.specification !== 'string') {
14
+ return { status: 400, error: 'specification is required' };
15
+ }
16
+ if (!input.name || typeof input.name !== 'string') {
17
+ return { status: 400, error: 'name is required' };
18
+ }
19
+ if (!process.env.OPENAI_API_KEY && !process.env.ANTHROPIC_API_KEY) {
20
+ return { status: 503, error: 'Workflow planner requires an LLM API key' };
21
+ }
22
+ const set = await (0, workflow_sets_1.createWorkflowSet)({
23
+ name: input.name,
24
+ description: input.description,
25
+ specification: input.specification,
26
+ });
27
+ const plannerResult = await (0, insight_1.startWorkflowPlanner)({
28
+ specification: input.specification,
29
+ setId: set.id,
30
+ wait: false,
31
+ userId: auth?.userId,
32
+ });
33
+ await (0, workflow_sets_1.updateWorkflowSetSourceWorkflow)(set.id, plannerResult.workflow_id);
34
+ return {
35
+ status: 201,
36
+ data: {
37
+ ...set,
38
+ source_workflow_id: plannerResult.workflow_id,
39
+ planner_workflow_id: plannerResult.workflow_id,
40
+ },
41
+ };
42
+ }
43
+ catch (err) {
44
+ if (err.code === '23505') {
45
+ return { status: 409, error: 'A workflow set with this name already exists' };
46
+ }
47
+ return { status: 500, error: err.message };
48
+ }
49
+ }
50
+ async function listWorkflowSets(input) {
51
+ try {
52
+ const result = await (0, workflow_sets_1.listWorkflowSets)({
53
+ status: input.status,
54
+ search: input.search,
55
+ limit: input.limit,
56
+ offset: input.offset,
57
+ });
58
+ return { status: 200, data: result };
59
+ }
60
+ catch (err) {
61
+ return { status: 500, error: err.message };
62
+ }
63
+ }
64
+ async function getWorkflowSet(input) {
65
+ try {
66
+ const set = await (0, workflow_sets_1.getWorkflowSet)(input.id);
67
+ if (!set) {
68
+ return { status: 404, error: 'Workflow set not found' };
69
+ }
70
+ return { status: 200, data: set };
71
+ }
72
+ catch (err) {
73
+ return { status: 500, error: err.message };
74
+ }
75
+ }
76
+ async function updateWorkflowSetPlanApi(input) {
77
+ try {
78
+ if (!Array.isArray(input.plan)) {
79
+ return { status: 400, error: 'plan must be an array' };
80
+ }
81
+ const updated = await (0, workflow_sets_1.updateWorkflowSetPlan)(input.id, input.plan, input.namespaces || []);
82
+ if (!updated) {
83
+ return { status: 404, error: 'Workflow set not found' };
84
+ }
85
+ return { status: 200, data: updated };
86
+ }
87
+ catch (err) {
88
+ return { status: 500, error: err.message };
89
+ }
90
+ }
91
+ async function buildWorkflowSet(input) {
92
+ try {
93
+ const set = await (0, workflow_sets_1.getWorkflowSet)(input.id);
94
+ if (!set) {
95
+ return { status: 404, error: 'Workflow set not found' };
96
+ }
97
+ if (set.status !== 'planned') {
98
+ return { status: 409, error: `Cannot build set in '${set.status}' status` };
99
+ }
100
+ await (0, workflow_sets_1.updateWorkflowSetStatus)(input.id, 'building');
101
+ return { status: 200, data: { status: 'building', id: input.id } };
102
+ }
103
+ catch (err) {
104
+ return { status: 500, error: err.message };
105
+ }
106
+ }
107
+ async function deployWorkflowSet(input) {
108
+ try {
109
+ const set = await (0, workflow_sets_1.getWorkflowSet)(input.id);
110
+ if (!set) {
111
+ return { status: 404, error: 'Workflow set not found' };
112
+ }
113
+ await (0, workflow_sets_1.updateWorkflowSetStatus)(input.id, 'deploying');
114
+ return { status: 200, data: { status: 'deploying', id: input.id } };
115
+ }
116
+ catch (err) {
117
+ return { status: 500, error: err.message };
118
+ }
119
+ }
@@ -0,0 +1,48 @@
1
+ import type { LTApiResult, LTApiAuth } from '../types/sdk';
2
+ export declare function invokeWorkflow(input: {
3
+ type: string;
4
+ data?: Record<string, any>;
5
+ metadata?: Record<string, any>;
6
+ execute_as?: string;
7
+ }, auth: LTApiAuth): Promise<LTApiResult>;
8
+ export declare function getWorkflowStatus(input: {
9
+ workflowId: string;
10
+ }): Promise<LTApiResult>;
11
+ export declare function getWorkflowResult(input: {
12
+ workflowId: string;
13
+ }): Promise<LTApiResult>;
14
+ export declare function terminateWorkflow(input: {
15
+ workflowId: string;
16
+ }): Promise<LTApiResult>;
17
+ export declare function exportWorkflow(input: {
18
+ workflowId: string;
19
+ }): Promise<LTApiResult>;
20
+ export declare function listWorkers(input: {
21
+ include_system?: boolean;
22
+ }): Promise<LTApiResult>;
23
+ export declare function listDiscoveredWorkflows(input: {
24
+ include_system?: boolean;
25
+ }): Promise<LTApiResult>;
26
+ export declare function getCronStatus(): Promise<LTApiResult>;
27
+ export declare function listWorkflowConfigs(): Promise<LTApiResult>;
28
+ export declare function getWorkflowConfig(input: {
29
+ type: string;
30
+ }): Promise<LTApiResult>;
31
+ export declare function upsertWorkflowConfig(input: {
32
+ type: string;
33
+ invocable?: boolean;
34
+ task_queue?: string | null;
35
+ default_role?: string;
36
+ description?: string | null;
37
+ execute_as?: string | null;
38
+ roles?: string[];
39
+ invocation_roles?: string[];
40
+ consumes?: string[];
41
+ tool_tags?: string[];
42
+ envelope_schema?: any;
43
+ resolver_schema?: any;
44
+ cron_schedule?: string | null;
45
+ }): Promise<LTApiResult>;
46
+ export declare function deleteWorkflowConfig(input: {
47
+ type: string;
48
+ }): Promise<LTApiResult>;
@@ -0,0 +1,298 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.invokeWorkflow = invokeWorkflow;
37
+ exports.getWorkflowStatus = getWorkflowStatus;
38
+ exports.getWorkflowResult = getWorkflowResult;
39
+ exports.terminateWorkflow = terminateWorkflow;
40
+ exports.exportWorkflow = exportWorkflow;
41
+ exports.listWorkers = listWorkers;
42
+ exports.listDiscoveredWorkflows = listDiscoveredWorkflows;
43
+ exports.getCronStatus = getCronStatus;
44
+ exports.listWorkflowConfigs = listWorkflowConfigs;
45
+ exports.getWorkflowConfig = getWorkflowConfig;
46
+ exports.upsertWorkflowConfig = upsertWorkflowConfig;
47
+ exports.deleteWorkflowConfig = deleteWorkflowConfig;
48
+ const workers_1 = require("../workers");
49
+ const exportService = __importStar(require("../services/export"));
50
+ const configService = __importStar(require("../services/config"));
51
+ const cron_1 = require("../services/cron");
52
+ const db_1 = require("../lib/db");
53
+ const registry_1 = require("../services/workers/registry");
54
+ const sql_1 = require("../services/mcp-runs/sql");
55
+ const task_1 = require("../services/task");
56
+ const workflow_invocation_1 = require("../services/workflow-invocation");
57
+ const ltconfig_1 = require("../modules/ltconfig");
58
+ function isResolveError(err) {
59
+ return err?.message?.includes('Cannot resolve workflow');
60
+ }
61
+ // ── Invocation ──────────────────────────────────────────────────────────────
62
+ async function invokeWorkflow(input, auth) {
63
+ try {
64
+ await (0, workflow_invocation_1.checkInvocationRoles)(input.type, auth.userId);
65
+ const result = await (0, workflow_invocation_1.invokeWorkflow)({
66
+ workflowType: input.type,
67
+ data: input.data || {},
68
+ metadata: input.metadata,
69
+ executeAs: input.execute_as,
70
+ auth: {
71
+ userId: auth.userId,
72
+ },
73
+ });
74
+ return {
75
+ status: 202,
76
+ data: { workflowId: result.workflowId, message: 'Workflow started' },
77
+ };
78
+ }
79
+ catch (err) {
80
+ const status = err instanceof workflow_invocation_1.InvocationError ? err.statusCode : 500;
81
+ return { status, error: err.message };
82
+ }
83
+ }
84
+ async function getWorkflowStatus(input) {
85
+ try {
86
+ const resolved = await (0, task_1.resolveWorkflowHandle)(input.workflowId);
87
+ const client = (0, workers_1.createClient)();
88
+ const handle = await client.workflow.getHandle(resolved.taskQueue, resolved.workflowName, input.workflowId);
89
+ const status = await handle.status();
90
+ return {
91
+ status: 200,
92
+ data: { workflowId: input.workflowId, status },
93
+ };
94
+ }
95
+ catch (err) {
96
+ if (isResolveError(err))
97
+ return { status: 404, error: err.message };
98
+ return { status: 500, error: err.message };
99
+ }
100
+ }
101
+ async function getWorkflowResult(input) {
102
+ try {
103
+ const resolved = await (0, task_1.resolveWorkflowHandle)(input.workflowId);
104
+ const client = (0, workers_1.createClient)();
105
+ const handle = await client.workflow.getHandle(resolved.taskQueue, resolved.workflowName, input.workflowId);
106
+ const status = await handle.status();
107
+ if (status !== 0) {
108
+ return {
109
+ status: 202,
110
+ data: { workflowId: input.workflowId, status: 'running' },
111
+ };
112
+ }
113
+ const result = await handle.result();
114
+ return {
115
+ status: 200,
116
+ data: { workflowId: input.workflowId, result },
117
+ };
118
+ }
119
+ catch (err) {
120
+ if (isResolveError(err))
121
+ return { status: 404, error: err.message };
122
+ return { status: 500, error: err.message };
123
+ }
124
+ }
125
+ async function terminateWorkflow(input) {
126
+ try {
127
+ const resolved = await (0, task_1.resolveWorkflowHandle)(input.workflowId);
128
+ const client = (0, workers_1.createClient)();
129
+ const handle = await client.workflow.getHandle(resolved.taskQueue, resolved.workflowName, input.workflowId);
130
+ await handle.terminate();
131
+ return {
132
+ status: 200,
133
+ data: { terminated: true, workflowId: input.workflowId },
134
+ };
135
+ }
136
+ catch (err) {
137
+ if (isResolveError(err))
138
+ return { status: 404, error: err.message };
139
+ return { status: 500, error: err.message };
140
+ }
141
+ }
142
+ async function exportWorkflow(input) {
143
+ try {
144
+ const resolved = await (0, task_1.resolveWorkflowHandle)(input.workflowId);
145
+ const exported = await exportService.exportWorkflow(input.workflowId, resolved.taskQueue, resolved.workflowName);
146
+ return { status: 200, data: exported };
147
+ }
148
+ catch (err) {
149
+ if (isResolveError(err))
150
+ return { status: 404, error: err.message };
151
+ return { status: 500, error: err.message };
152
+ }
153
+ }
154
+ // ── Discovery ───────────────────────────────────────────────────────────────
155
+ async function listWorkers(input) {
156
+ try {
157
+ const activeWorkers = (0, registry_1.getRegisteredWorkers)();
158
+ const configs = await configService.listWorkflowConfigs();
159
+ const registeredTypes = new Set(configs.map((c) => c.workflow_type));
160
+ const workers = [...activeWorkers.entries()]
161
+ .filter(([name]) => input.include_system || !registry_1.SYSTEM_WORKFLOWS.has(name))
162
+ .sort(([a], [b]) => a.localeCompare(b))
163
+ .map(([name, { taskQueue }]) => ({
164
+ name,
165
+ task_queue: taskQueue,
166
+ registered: registeredTypes.has(name),
167
+ system: registry_1.SYSTEM_WORKFLOWS.has(name),
168
+ }));
169
+ return { status: 200, data: { workers } };
170
+ }
171
+ catch (err) {
172
+ return { status: 500, error: err.message };
173
+ }
174
+ }
175
+ async function listDiscoveredWorkflows(input) {
176
+ try {
177
+ // 1. Active workers from in-memory registry
178
+ const activeWorkers = (0, registry_1.getRegisteredWorkers)();
179
+ // 2. Historical entities from durable.jobs
180
+ const pool = (0, db_1.getPool)();
181
+ const { rows: entityRows } = await pool.query(sql_1.DISTINCT_ENTITIES_DURABLE);
182
+ const historicalEntities = new Set(entityRows.map((r) => r.entity));
183
+ // 3. Registered configs
184
+ const configs = await configService.listWorkflowConfigs();
185
+ const configMap = new Map(configs.map((c) => [c.workflow_type, c]));
186
+ // Build unified set of all workflow types
187
+ const allTypes = new Set();
188
+ for (const [name] of activeWorkers)
189
+ allTypes.add(name);
190
+ for (const entity of historicalEntities)
191
+ allTypes.add(entity);
192
+ for (const c of configs)
193
+ allTypes.add(c.workflow_type);
194
+ const workflows = [...allTypes]
195
+ .filter((t) => input.include_system || !registry_1.SYSTEM_WORKFLOWS.has(t))
196
+ .sort()
197
+ .map((workflowType) => {
198
+ const config = configMap.get(workflowType);
199
+ const worker = activeWorkers.get(workflowType);
200
+ return {
201
+ workflow_type: workflowType,
202
+ task_queue: config?.task_queue ?? worker?.taskQueue ?? null,
203
+ registered: !!config,
204
+ active: !!worker,
205
+ invocable: config?.invocable ?? !!worker,
206
+ system: registry_1.SYSTEM_WORKFLOWS.has(workflowType),
207
+ description: config?.description ?? null,
208
+ roles: config?.roles ?? [],
209
+ invocation_roles: config?.invocation_roles ?? [],
210
+ execute_as: config?.execute_as ?? null,
211
+ };
212
+ });
213
+ return { status: 200, data: { workflows } };
214
+ }
215
+ catch (err) {
216
+ return { status: 500, error: err.message };
217
+ }
218
+ }
219
+ async function getCronStatus() {
220
+ try {
221
+ const configs = await configService.listWorkflowConfigs();
222
+ const cronConfigs = configs.filter((c) => c.cron_schedule);
223
+ const activeTypes = cron_1.cronRegistry.activeWorkflowTypes;
224
+ const schedules = cronConfigs.map((c) => ({
225
+ workflow_type: c.workflow_type,
226
+ cron_schedule: c.cron_schedule,
227
+ description: c.description,
228
+ task_queue: c.task_queue,
229
+ invocable: c.invocable,
230
+ active: activeTypes.includes(c.workflow_type),
231
+ envelope_schema: c.envelope_schema,
232
+ }));
233
+ return { status: 200, data: { schedules } };
234
+ }
235
+ catch (err) {
236
+ return { status: 500, error: err.message };
237
+ }
238
+ }
239
+ // ── Configuration ───────────────────────────────────────────────────────────
240
+ async function listWorkflowConfigs() {
241
+ try {
242
+ const configs = await configService.listWorkflowConfigs();
243
+ return { status: 200, data: { workflows: configs } };
244
+ }
245
+ catch (err) {
246
+ return { status: 500, error: err.message };
247
+ }
248
+ }
249
+ async function getWorkflowConfig(input) {
250
+ try {
251
+ const config = await configService.getWorkflowConfig(input.type);
252
+ if (!config) {
253
+ return { status: 404, error: 'Workflow config not found' };
254
+ }
255
+ return { status: 200, data: config };
256
+ }
257
+ catch (err) {
258
+ return { status: 500, error: err.message };
259
+ }
260
+ }
261
+ async function upsertWorkflowConfig(input) {
262
+ try {
263
+ const config = await configService.upsertWorkflowConfig({
264
+ workflow_type: input.type,
265
+ invocable: input.invocable ?? false,
266
+ task_queue: input.task_queue ?? null,
267
+ default_role: input.default_role ?? 'reviewer',
268
+ description: input.description ?? null,
269
+ execute_as: input.execute_as ?? null,
270
+ roles: input.roles ?? [],
271
+ invocation_roles: input.invocation_roles ?? [],
272
+ consumes: input.consumes ?? [],
273
+ tool_tags: input.tool_tags ?? [],
274
+ envelope_schema: input.envelope_schema ?? null,
275
+ resolver_schema: input.resolver_schema ?? null,
276
+ cron_schedule: input.cron_schedule ?? null,
277
+ });
278
+ ltconfig_1.ltConfig.invalidate();
279
+ await cron_1.cronRegistry.restartCron(config);
280
+ return { status: 200, data: config };
281
+ }
282
+ catch (err) {
283
+ return { status: 500, error: err.message };
284
+ }
285
+ }
286
+ async function deleteWorkflowConfig(input) {
287
+ try {
288
+ const deleted = await configService.deleteWorkflowConfig(input.type);
289
+ if (!deleted) {
290
+ return { status: 404, error: 'Workflow config not found' };
291
+ }
292
+ ltconfig_1.ltConfig.invalidate();
293
+ return { status: 200, data: { deleted: true, workflow_type: input.type } };
294
+ }
295
+ catch (err) {
296
+ return { status: 500, error: err.message };
297
+ }
298
+ }