@hotmeshio/long-tail 0.4.18 → 0.4.20

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 (354) hide show
  1. package/README.md +0 -2
  2. package/build/api/auth-sso.d.ts +12 -0
  3. package/build/api/auth-sso.js +54 -0
  4. package/build/api/escalations/bulk.js +2 -2
  5. package/build/api/escalations/claim.js +3 -13
  6. package/build/api/escalations/create.js +3 -2
  7. package/build/api/escalations/helpers.d.ts +1 -0
  8. package/build/api/escalations/helpers.js +12 -9
  9. package/build/api/escalations/list.d.ts +1 -0
  10. package/build/api/escalations/list.js +1 -0
  11. package/build/api/escalations/metadata.d.ts +7 -24
  12. package/build/api/escalations/metadata.js +31 -65
  13. package/build/api/escalations/single.js +3 -2
  14. package/build/api/settings.js +5 -0
  15. package/build/api/topics.d.ts +9 -0
  16. package/build/api/topics.js +31 -2
  17. package/build/lib/events/index.d.ts +1 -0
  18. package/build/lib/events/index.js +4 -0
  19. package/build/lib/events/publish.d.ts +12 -9
  20. package/build/lib/events/publish.js +27 -17
  21. package/build/modules/auth.d.ts +7 -0
  22. package/build/modules/auth.js +104 -2
  23. package/build/modules/sso.d.ts +6 -0
  24. package/build/modules/sso.js +20 -0
  25. package/build/routes/auth-sso.d.ts +2 -0
  26. package/build/routes/auth-sso.js +51 -0
  27. package/build/routes/bot-accounts.js +1 -1
  28. package/build/routes/controlplane.js +6 -6
  29. package/build/routes/escalations/list.js +1 -0
  30. package/build/routes/index.js +2 -0
  31. package/build/routes/mcp-endpoint.d.ts +17 -0
  32. package/build/routes/mcp-endpoint.js +70 -0
  33. package/build/routes/roles.js +5 -5
  34. package/build/routes/topics.js +2 -0
  35. package/build/routes/users.js +31 -5
  36. package/build/sdk/index.d.ts +1 -0
  37. package/build/services/agent/input-mapper.js +17 -1
  38. package/build/services/escalation/crud.d.ts +17 -1
  39. package/build/services/escalation/crud.js +62 -13
  40. package/build/services/escalation/queries.d.ts +1 -0
  41. package/build/services/escalation/queries.js +7 -0
  42. package/build/services/escalation/sql.d.ts +14 -5
  43. package/build/services/escalation/sql.js +53 -16
  44. package/build/services/mcp/exposure.d.ts +15 -0
  45. package/build/services/mcp/exposure.js +18 -0
  46. package/build/services/mcp/external-server.d.ts +15 -0
  47. package/build/services/mcp/external-server.js +125 -0
  48. package/build/services/mcp/seed-service-account.d.ts +11 -0
  49. package/build/services/mcp/seed-service-account.js +77 -0
  50. package/build/services/role/index.d.ts +1 -1
  51. package/build/services/role/index.js +2 -2
  52. package/build/services/topics/system-topics.js +29 -25
  53. package/build/services/user/index.d.ts +1 -1
  54. package/build/services/user/index.js +3 -1
  55. package/build/services/user/rbac.d.ts +16 -0
  56. package/build/services/user/rbac.js +31 -0
  57. package/build/services/user/sso-provision.d.ts +19 -0
  58. package/build/services/user/sso-provision.js +62 -0
  59. package/build/services/workflow-invocation.js +5 -3
  60. package/build/start/config.js +6 -0
  61. package/build/start/server.js +2 -0
  62. package/build/start/workers.js +15 -0
  63. package/build/system/index.js +53 -35
  64. package/build/system/mcp-servers/admin/agent-subscriptions.d.ts +5 -0
  65. package/build/system/mcp-servers/admin/agent-subscriptions.js +78 -0
  66. package/build/system/mcp-servers/admin/agents.d.ts +5 -0
  67. package/build/system/mcp-servers/admin/agents.js +103 -0
  68. package/build/system/mcp-servers/admin/bot-accounts.d.ts +5 -0
  69. package/build/system/mcp-servers/admin/bot-accounts.js +126 -0
  70. package/build/system/mcp-servers/admin/controlplane.d.ts +5 -0
  71. package/build/system/mcp-servers/admin/controlplane.js +107 -0
  72. package/build/system/mcp-servers/admin/escalations.js +88 -0
  73. package/build/system/mcp-servers/admin/exports.d.ts +5 -0
  74. package/build/system/mcp-servers/admin/exports.js +101 -0
  75. package/build/system/mcp-servers/admin/index.d.ts +16 -8
  76. package/build/system/mcp-servers/admin/index.js +36 -21
  77. package/build/system/mcp-servers/admin/pipelines.d.ts +5 -0
  78. package/build/system/mcp-servers/admin/pipelines.js +96 -0
  79. package/build/system/mcp-servers/admin/schemas.d.ts +614 -6
  80. package/build/system/mcp-servers/admin/schemas.js +239 -1
  81. package/build/system/mcp-servers/admin/settings.d.ts +5 -0
  82. package/build/system/mcp-servers/admin/settings.js +53 -0
  83. package/build/system/mcp-servers/admin/topics.d.ts +5 -0
  84. package/build/system/mcp-servers/admin/topics.js +101 -0
  85. package/build/system/seed/tool-manifests-admin.d.ts +5077 -188
  86. package/build/system/seed/tool-manifests-admin.js +79 -30
  87. package/build/system/seed/tool-manifests-data.d.ts +20 -0
  88. package/build/system/seed/tool-manifests-data.js +24 -6
  89. package/build/system/seed/tool-manifests-escalation.d.ts +5 -0
  90. package/build/system/seed/tool-manifests-escalation.js +5 -0
  91. package/build/system/seed/tool-manifests-events.d.ts +4 -0
  92. package/build/system/seed/tool-manifests-events.js +4 -0
  93. package/build/system/seed/tool-manifests-knowledge.d.ts +6 -0
  94. package/build/system/seed/tool-manifests-knowledge.js +7 -0
  95. package/build/system/seed/tool-manifests-workflows.d.ts +8 -0
  96. package/build/system/seed/tool-manifests-workflows.js +8 -0
  97. package/build/tsconfig.tsbuildinfo +1 -1
  98. package/build/types/auth.d.ts +71 -0
  99. package/build/types/events.d.ts +17 -6
  100. package/build/types/index.d.ts +1 -1
  101. package/build/types/startup.d.ts +22 -1
  102. package/dashboard/dist/assets/{AdminDashboard-Cfo0mwL2.js → AdminDashboard-BwUGcCxQ.js} +2 -2
  103. package/dashboard/dist/assets/{AdminDashboard-Cfo0mwL2.js.map → AdminDashboard-BwUGcCxQ.js.map} +1 -1
  104. package/dashboard/dist/assets/AgentConfigPage-DgrYzLwq.js +16 -0
  105. package/dashboard/dist/assets/AgentConfigPage-DgrYzLwq.js.map +1 -0
  106. package/dashboard/dist/assets/{AgentDetailPage-3mZA7SOb.js → AgentDetailPage-XJpl7wfJ.js} +4 -4
  107. package/dashboard/dist/assets/AgentDetailPage-XJpl7wfJ.js.map +1 -0
  108. package/dashboard/dist/assets/{AgentsPage-CTVocfBb.js → AgentsPage-CGpVG6r8.js} +2 -2
  109. package/dashboard/dist/assets/{AgentsPage-CTVocfBb.js.map → AgentsPage-CGpVG6r8.js.map} +1 -1
  110. package/dashboard/dist/assets/AvailableEscalationsPage-DR1e0TQZ.js +2 -0
  111. package/dashboard/dist/assets/{AvailableEscalationsPage-CA9x9o5s.js.map → AvailableEscalationsPage-DR1e0TQZ.js.map} +1 -1
  112. package/dashboard/dist/assets/BotPicker-BKtjl6IL.js +2 -0
  113. package/dashboard/dist/assets/{BotPicker-BQp_Vs73.js.map → BotPicker-BKtjl6IL.js.map} +1 -1
  114. package/dashboard/dist/assets/{CapabilitiesPage-wpVtkGeU.js → CapabilitiesPage-kCB8fyOj.js} +2 -2
  115. package/dashboard/dist/assets/{CapabilitiesPage-wpVtkGeU.js.map → CapabilitiesPage-kCB8fyOj.js.map} +1 -1
  116. package/dashboard/dist/assets/{CollapsibleSection-2eZMMZiG.js → CollapsibleSection-C3tU61hB.js} +2 -2
  117. package/dashboard/dist/assets/{CollapsibleSection-2eZMMZiG.js.map → CollapsibleSection-C3tU61hB.js.map} +1 -1
  118. package/dashboard/dist/assets/{CredentialsPage-DJGLssm0.js → CredentialsPage-Dt4nJs_B.js} +2 -2
  119. package/dashboard/dist/assets/{CredentialsPage-DJGLssm0.js.map → CredentialsPage-Dt4nJs_B.js.map} +1 -1
  120. package/dashboard/dist/assets/CronLabel-BdE6mHyA.js +2 -0
  121. package/dashboard/dist/assets/CronLabel-BdE6mHyA.js.map +1 -0
  122. package/dashboard/dist/assets/{CustomDurationPicker-DbyqfK35.js → CustomDurationPicker-B_Yxfb-u.js} +2 -2
  123. package/dashboard/dist/assets/{CustomDurationPicker-DbyqfK35.js.map → CustomDurationPicker-B_Yxfb-u.js.map} +1 -1
  124. package/dashboard/dist/assets/{DropZone-BkfRoUcm.js → DropZone-CptiQ0wc.js} +2 -2
  125. package/dashboard/dist/assets/{DropZone-BkfRoUcm.js.map → DropZone-CptiQ0wc.js.map} +1 -1
  126. package/dashboard/dist/assets/ElapsedCell-tcGx5PFI.js +2 -0
  127. package/dashboard/dist/assets/{ElapsedCell-BPYm8RA7.js.map → ElapsedCell-tcGx5PFI.js.map} +1 -1
  128. package/dashboard/dist/assets/{EscalationsOverview-kYGHfnLf.js → EscalationsOverview-1KO5dXzk.js} +2 -2
  129. package/dashboard/dist/assets/{EscalationsOverview-kYGHfnLf.js.map → EscalationsOverview-1KO5dXzk.js.map} +1 -1
  130. package/dashboard/dist/assets/{EventTable-DSDzJMer.js → EventTable-DnpsQ6Ew.js} +2 -2
  131. package/dashboard/dist/assets/{EventTable-DSDzJMer.js.map → EventTable-DnpsQ6Ew.js.map} +1 -1
  132. package/dashboard/dist/assets/HomePage-B2Jgo1J1.js +2 -0
  133. package/dashboard/dist/assets/HomePage-B2Jgo1J1.js.map +1 -0
  134. package/dashboard/dist/assets/ListToolbar-jrVba7QN.js +2 -0
  135. package/dashboard/dist/assets/{ListToolbar-DEef1_-T.js.map → ListToolbar-jrVba7QN.js.map} +1 -1
  136. package/dashboard/dist/assets/{McpOverview-CZFW5qMb.js → McpOverview-BzyxJyc9.js} +2 -2
  137. package/dashboard/dist/assets/{McpOverview-CZFW5qMb.js.map → McpOverview-BzyxJyc9.js.map} +1 -1
  138. package/dashboard/dist/assets/{McpQueryDetailPage-q9xH-QRo.js → McpQueryDetailPage-DXNseeKl.js} +2 -2
  139. package/dashboard/dist/assets/{McpQueryDetailPage-q9xH-QRo.js.map → McpQueryDetailPage-DXNseeKl.js.map} +1 -1
  140. package/dashboard/dist/assets/{McpQueryPage-D14466yi.js → McpQueryPage-WZfTY43_.js} +2 -2
  141. package/dashboard/dist/assets/{McpQueryPage-D14466yi.js.map → McpQueryPage-WZfTY43_.js.map} +1 -1
  142. package/dashboard/dist/assets/McpRunDetailPage-DKZp-p7S.js +2 -0
  143. package/dashboard/dist/assets/McpRunDetailPage-DKZp-p7S.js.map +1 -0
  144. package/dashboard/dist/assets/McpRunsPage-SXyiwc0d.js +2 -0
  145. package/dashboard/dist/assets/{McpRunsPage-aZg057y3.js.map → McpRunsPage-SXyiwc0d.js.map} +1 -1
  146. package/dashboard/dist/assets/OperatorDashboard-Cy7ySMXj.js +2 -0
  147. package/dashboard/dist/assets/OperatorDashboard-Cy7ySMXj.js.map +1 -0
  148. package/dashboard/dist/assets/{PageHeader-CR6TpJG_.js → PageHeader-BuJpMxyu.js} +2 -2
  149. package/dashboard/dist/assets/{PageHeader-CR6TpJG_.js.map → PageHeader-BuJpMxyu.js.map} +1 -1
  150. package/dashboard/dist/assets/{PageHeaderWithStats-CRcQEAO1.js → PageHeaderWithStats-yD_PTbOl.js} +2 -2
  151. package/dashboard/dist/assets/{PageHeaderWithStats-CRcQEAO1.js.map → PageHeaderWithStats-yD_PTbOl.js.map} +1 -1
  152. package/dashboard/dist/assets/{ProcessDetailPage-DyzNjwu8.js → ProcessDetailPage-DYIfvWyc.js} +2 -2
  153. package/dashboard/dist/assets/{ProcessDetailPage-DyzNjwu8.js.map → ProcessDetailPage-DYIfvWyc.js.map} +1 -1
  154. package/dashboard/dist/assets/{ProcessesListPage-CT_3b5Wt.js → ProcessesListPage-DR1RGaMl.js} +2 -2
  155. package/dashboard/dist/assets/{ProcessesListPage-CT_3b5Wt.js.map → ProcessesListPage-DR1RGaMl.js.map} +1 -1
  156. package/dashboard/dist/assets/{RolePill-BC54Vn-U.js → RolePill-SasQKc_B.js} +2 -2
  157. package/dashboard/dist/assets/{RolePill-BC54Vn-U.js.map → RolePill-SasQKc_B.js.map} +1 -1
  158. package/dashboard/dist/assets/{RolesPage-CpRJq-sg.js → RolesPage-pMERxj15.js} +2 -2
  159. package/dashboard/dist/assets/{RolesPage-CpRJq-sg.js.map → RolesPage-pMERxj15.js.map} +1 -1
  160. package/dashboard/dist/assets/{RunAsSelector-C20rdNsC.js → RunAsSelector-B-ksMoEj.js} +2 -2
  161. package/dashboard/dist/assets/{RunAsSelector-C20rdNsC.js.map → RunAsSelector-B-ksMoEj.js.map} +1 -1
  162. package/dashboard/dist/assets/ServerName-CHspudaC.js +2 -0
  163. package/dashboard/dist/assets/{ServerName-Q6okiv4f.js.map → ServerName-CHspudaC.js.map} +1 -1
  164. package/dashboard/dist/assets/{SwimlaneTimeline-CbFaU4bq.js → SwimlaneTimeline-Cr_K5qpu.js} +2 -2
  165. package/dashboard/dist/assets/{SwimlaneTimeline-CbFaU4bq.js.map → SwimlaneTimeline-Cr_K5qpu.js.map} +1 -1
  166. package/dashboard/dist/assets/{TagInput-D6l1SPWd.js → TagInput-DvF3j8MA.js} +2 -2
  167. package/dashboard/dist/assets/{TagInput-D6l1SPWd.js.map → TagInput-DvF3j8MA.js.map} +1 -1
  168. package/dashboard/dist/assets/{TaskDetailPage-22cJsFmM.js → TaskDetailPage-BO5p7AEe.js} +2 -2
  169. package/dashboard/dist/assets/{TaskDetailPage-22cJsFmM.js.map → TaskDetailPage-BO5p7AEe.js.map} +1 -1
  170. package/dashboard/dist/assets/{TaskQueuePill-iDBVCEQQ.js → TaskQueuePill-BCQrS2oK.js} +2 -2
  171. package/dashboard/dist/assets/{TaskQueuePill-iDBVCEQQ.js.map → TaskQueuePill-BCQrS2oK.js.map} +1 -1
  172. package/dashboard/dist/assets/{TasksListPage-BDmaUIKu.js → TasksListPage-BRg-uFtF.js} +2 -2
  173. package/dashboard/dist/assets/{TasksListPage-BDmaUIKu.js.map → TasksListPage-BRg-uFtF.js.map} +1 -1
  174. package/dashboard/dist/assets/{TimeAgo-7wqEp87-.js → TimeAgo-BSzN6rAH.js} +2 -2
  175. package/dashboard/dist/assets/{TimeAgo-7wqEp87-.js.map → TimeAgo-BSzN6rAH.js.map} +1 -1
  176. package/dashboard/dist/assets/{TimestampCell-BBCf8zsN.js → TimestampCell-DL6zMNEQ.js} +2 -2
  177. package/dashboard/dist/assets/{TimestampCell-BBCf8zsN.js.map → TimestampCell-DL6zMNEQ.js.map} +1 -1
  178. package/dashboard/dist/assets/{ToolPill-HcRTggHo.js → ToolPill-1aTqYtzp.js} +2 -2
  179. package/dashboard/dist/assets/{ToolPill-HcRTggHo.js.map → ToolPill-1aTqYtzp.js.map} +1 -1
  180. package/dashboard/dist/assets/{ToolTestPanel-Dosq1cqG.js → ToolTestPanel-fLzNp79U.js} +2 -2
  181. package/dashboard/dist/assets/{ToolTestPanel-Dosq1cqG.js.map → ToolTestPanel-fLzNp79U.js.map} +1 -1
  182. package/dashboard/dist/assets/TopicDetailPage-D7gCsPKB.js +9 -0
  183. package/dashboard/dist/assets/TopicDetailPage-D7gCsPKB.js.map +1 -0
  184. package/dashboard/dist/assets/{TopicsPage-tVPdz-k0.js → TopicsPage-B3Aa8Haz.js} +2 -2
  185. package/dashboard/dist/assets/{TopicsPage-tVPdz-k0.js.map → TopicsPage-B3Aa8Haz.js.map} +1 -1
  186. package/dashboard/dist/assets/{UserName-DX7IBjFn.js → UserName-BjHIJWgh.js} +2 -2
  187. package/dashboard/dist/assets/{UserName-DX7IBjFn.js.map → UserName-BjHIJWgh.js.map} +1 -1
  188. package/dashboard/dist/assets/{WorkflowExecutionPage-BjC0j9_L.js → WorkflowExecutionPage-BQ7AYlQA.js} +2 -2
  189. package/dashboard/dist/assets/{WorkflowExecutionPage-BjC0j9_L.js.map → WorkflowExecutionPage-BQ7AYlQA.js.map} +1 -1
  190. package/dashboard/dist/assets/{WorkflowPill-54px0YiY.js → WorkflowPill-Z-zHRKOK.js} +2 -2
  191. package/dashboard/dist/assets/{WorkflowPill-54px0YiY.js.map → WorkflowPill-Z-zHRKOK.js.map} +1 -1
  192. package/dashboard/dist/assets/WorkflowsDashboard-D-G8Xudz.js +2 -0
  193. package/dashboard/dist/assets/WorkflowsDashboard-D-G8Xudz.js.map +1 -0
  194. package/dashboard/dist/assets/{WorkflowsOverview-DaJRDkNy.js → WorkflowsOverview-B4DUcVxs.js} +2 -2
  195. package/dashboard/dist/assets/{WorkflowsOverview-DaJRDkNy.js.map → WorkflowsOverview-B4DUcVxs.js.map} +1 -1
  196. package/dashboard/dist/assets/{YamlWorkflowsPage-CkpQaUmz.js → YamlWorkflowsPage-CnTNOku0.js} +2 -2
  197. package/dashboard/dist/assets/{YamlWorkflowsPage-CkpQaUmz.js.map → YamlWorkflowsPage-CnTNOku0.js.map} +1 -1
  198. package/dashboard/dist/assets/{agents-B-P5MlEx.js → agents-CkvQDr9b.js} +2 -2
  199. package/dashboard/dist/assets/{agents-B-P5MlEx.js.map → agents-CkvQDr9b.js.map} +1 -1
  200. package/dashboard/dist/assets/{bots-CZz9iVys.js → bots-CzuMCVgU.js} +2 -2
  201. package/dashboard/dist/assets/{bots-CZz9iVys.js.map → bots-CzuMCVgU.js.map} +1 -1
  202. package/dashboard/dist/assets/{capabilities-DrZ8Vw_v.js → capabilities-CbGmS0ty.js} +2 -2
  203. package/dashboard/dist/assets/{capabilities-DrZ8Vw_v.js.map → capabilities-CbGmS0ty.js.map} +1 -1
  204. package/dashboard/dist/assets/{controlplane-cj-1c-1C.js → controlplane-DGvwkuYx.js} +2 -2
  205. package/dashboard/dist/assets/{controlplane-cj-1c-1C.js.map → controlplane-DGvwkuYx.js.map} +1 -1
  206. package/dashboard/dist/assets/{escalation-BEVFyQnE.js → escalation-B7ysVToF.js} +2 -2
  207. package/dashboard/dist/assets/{escalation-BEVFyQnE.js.map → escalation-B7ysVToF.js.map} +1 -1
  208. package/dashboard/dist/assets/{escalation-columns-Beox3TXH.js → escalation-columns-CHQEJU1j.js} +2 -2
  209. package/dashboard/dist/assets/{escalation-columns-Beox3TXH.js.map → escalation-columns-CHQEJU1j.js.map} +1 -1
  210. package/dashboard/dist/assets/{helpers-B4gzNq9h.js → helpers-BFOjXa4r.js} +2 -2
  211. package/dashboard/dist/assets/{helpers-B4gzNq9h.js.map → helpers-BFOjXa4r.js.map} +1 -1
  212. package/dashboard/dist/assets/index-B9_1AZaG.js +2 -0
  213. package/dashboard/dist/assets/{index-3n5VREXN.js.map → index-B9_1AZaG.js.map} +1 -1
  214. package/dashboard/dist/assets/{index-BCQ65lNu.js → index-BFaDxPxA.js} +2 -2
  215. package/dashboard/dist/assets/{index-BCQ65lNu.js.map → index-BFaDxPxA.js.map} +1 -1
  216. package/dashboard/dist/assets/index-BduDiGcw.js +15 -0
  217. package/dashboard/dist/assets/{index-UtAfnStw.js.map → index-BduDiGcw.js.map} +1 -1
  218. package/dashboard/dist/assets/{index-Bh-PnP17.js → index-BeLphL59.js} +2 -2
  219. package/dashboard/dist/assets/{index-Bh-PnP17.js.map → index-BeLphL59.js.map} +1 -1
  220. package/dashboard/dist/assets/index-C--SEsU7.css +1 -0
  221. package/dashboard/dist/assets/{index-_DfbFHXk.js → index-CRiBkHPb.js} +2 -2
  222. package/dashboard/dist/assets/{index-_DfbFHXk.js.map → index-CRiBkHPb.js.map} +1 -1
  223. package/dashboard/dist/assets/{index-DdKbIZNE.js → index-CbrMW-gM.js} +2 -2
  224. package/dashboard/dist/assets/{index-DdKbIZNE.js.map → index-CbrMW-gM.js.map} +1 -1
  225. package/dashboard/dist/assets/{index-aJRDh4zW.js → index-CvOGgvzP.js} +2 -2
  226. package/dashboard/dist/assets/{index-aJRDh4zW.js.map → index-CvOGgvzP.js.map} +1 -1
  227. package/dashboard/dist/assets/{index-D1MywQ2z.js → index-DDlrQeTj.js} +2 -2
  228. package/dashboard/dist/assets/{index-D1MywQ2z.js.map → index-DDlrQeTj.js.map} +1 -1
  229. package/dashboard/dist/assets/{index-BYXiz05a.js → index-DQHmfTPo.js} +2 -2
  230. package/dashboard/dist/assets/{index-BYXiz05a.js.map → index-DQHmfTPo.js.map} +1 -1
  231. package/dashboard/dist/assets/{index-BpN31nuC.js → index-_BRA9uFL.js} +25 -25
  232. package/dashboard/dist/assets/index-_BRA9uFL.js.map +1 -0
  233. package/dashboard/dist/assets/index-a98qWLB-.js +2 -0
  234. package/dashboard/dist/assets/index-a98qWLB-.js.map +1 -0
  235. package/dashboard/dist/assets/index-l_8R6U4r.js +6 -0
  236. package/dashboard/dist/assets/index-l_8R6U4r.js.map +1 -0
  237. package/dashboard/dist/assets/{index-D4KGadbW.js → index-v0OQpgXS.js} +2 -2
  238. package/dashboard/dist/assets/{index-D4KGadbW.js.map → index-v0OQpgXS.js.map} +1 -1
  239. package/dashboard/dist/assets/{knowledge-DhtKWMON.js → knowledge-BlF8UMrk.js} +2 -2
  240. package/dashboard/dist/assets/{knowledge-DhtKWMON.js.map → knowledge-BlF8UMrk.js.map} +1 -1
  241. package/dashboard/dist/assets/{mcp-BXN7-wGF.js → mcp-MtXuky8q.js} +2 -2
  242. package/dashboard/dist/assets/{mcp-BXN7-wGF.js.map → mcp-MtXuky8q.js.map} +1 -1
  243. package/dashboard/dist/assets/{mcp-query-BIJP4mQJ.js → mcp-query-DQ-J1Q0K.js} +2 -2
  244. package/dashboard/dist/assets/{mcp-query-BIJP4mQJ.js.map → mcp-query-DQ-J1Q0K.js.map} +1 -1
  245. package/dashboard/dist/assets/{namespaces-ne_yDQZX.js → namespaces-DtsT_GoV.js} +2 -2
  246. package/dashboard/dist/assets/{namespaces-ne_yDQZX.js.map → namespaces-DtsT_GoV.js.map} +1 -1
  247. package/dashboard/dist/assets/{pipelines-Bcz62DoS.js → pipelines-BjlCm9VH.js} +2 -2
  248. package/dashboard/dist/assets/{pipelines-Bcz62DoS.js.map → pipelines-BjlCm9VH.js.map} +1 -1
  249. package/dashboard/dist/assets/{roles-De2CzGCy.js → roles-D-LhJ82d.js} +2 -2
  250. package/dashboard/dist/assets/{roles-De2CzGCy.js.map → roles-D-LhJ82d.js.map} +1 -1
  251. package/dashboard/dist/assets/{tasks-4yL5EfxI.js → tasks-BrP_8uEN.js} +2 -2
  252. package/dashboard/dist/assets/{tasks-4yL5EfxI.js.map → tasks-BrP_8uEN.js.map} +1 -1
  253. package/dashboard/dist/assets/topics-DUk-zX5D.js +2 -0
  254. package/dashboard/dist/assets/{topics-DDKHpRwP.js.map → topics-DUk-zX5D.js.map} +1 -1
  255. package/dashboard/dist/assets/useEventHooks-XNNzwADV.js +2 -0
  256. package/dashboard/dist/assets/useEventHooks-XNNzwADV.js.map +1 -0
  257. package/dashboard/dist/assets/{useYamlActivityEvents-Dv6GhDkh.js → useYamlActivityEvents-DANQ5jIY.js} +2 -2
  258. package/dashboard/dist/assets/{useYamlActivityEvents-Dv6GhDkh.js.map → useYamlActivityEvents-DANQ5jIY.js.map} +1 -1
  259. package/dashboard/dist/assets/{users-pSMWP58G.js → users-vj0JgOkA.js} +2 -2
  260. package/dashboard/dist/assets/{users-pSMWP58G.js.map → users-vj0JgOkA.js.map} +1 -1
  261. package/dashboard/dist/assets/{vendor-icons-CrrAvF2g.js → vendor-icons-Doy0g69_.js} +116 -111
  262. package/dashboard/dist/assets/vendor-icons-Doy0g69_.js.map +1 -0
  263. package/dashboard/dist/assets/{workflows-COYPOe2I.js → workflows-CmqgGPzI.js} +2 -2
  264. package/dashboard/dist/assets/{workflows-COYPOe2I.js.map → workflows-CmqgGPzI.js.map} +1 -1
  265. package/dashboard/dist/assets/{yaml-workflows-1dF3ig6u.js → yaml-workflows-DNFyjBXH.js} +2 -2
  266. package/dashboard/dist/assets/{yaml-workflows-1dF3ig6u.js.map → yaml-workflows-DNFyjBXH.js.map} +1 -1
  267. package/dashboard/dist/index.html +3 -3
  268. package/docs/api/http/controlplane.md +1 -1
  269. package/docs/api/http/mcp-endpoint.md +133 -0
  270. package/docs/api/http/roles.md +46 -0
  271. package/docs/api/http/service-accounts.md +15 -0
  272. package/docs/api/http/settings.md +6 -0
  273. package/docs/api/mcp/admin.md +1187 -0
  274. package/docs/api/mcp/claude-code.md +47 -0
  275. package/docs/api/mcp/docs.md +54 -0
  276. package/docs/api/mcp/events.md +80 -0
  277. package/docs/api/mcp/file-storage.md +76 -0
  278. package/docs/api/mcp/http-fetch.md +64 -0
  279. package/docs/api/mcp/human-queue.md +101 -0
  280. package/docs/api/mcp/index.md +52 -0
  281. package/docs/api/mcp/knowledge.md +125 -0
  282. package/docs/api/mcp/oauth.md +62 -0
  283. package/docs/api/mcp/schema-exchange.md +56 -0
  284. package/docs/api/mcp/translation.md +28 -0
  285. package/docs/api/mcp/vision.md +46 -0
  286. package/docs/api/sdk/settings.md +3 -1
  287. package/docs/auth.md +109 -0
  288. package/docs/dashboard.md +1 -1
  289. package/package.json +1 -1
  290. package/build/system/mcp-servers/playwright/browser-lifecycle.d.ts +0 -26
  291. package/build/system/mcp-servers/playwright/browser-lifecycle.js +0 -125
  292. package/build/system/mcp-servers/playwright/index.d.ts +0 -25
  293. package/build/system/mcp-servers/playwright/index.js +0 -42
  294. package/build/system/mcp-servers/playwright/schemas.d.ts +0 -394
  295. package/build/system/mcp-servers/playwright/schemas.js +0 -90
  296. package/build/system/mcp-servers/playwright/tools-atomic.d.ts +0 -2
  297. package/build/system/mcp-servers/playwright/tools-atomic.js +0 -9
  298. package/build/system/mcp-servers/playwright/tools-navigation.d.ts +0 -2
  299. package/build/system/mcp-servers/playwright/tools-navigation.js +0 -153
  300. package/build/system/mcp-servers/playwright/tools-page-interaction.d.ts +0 -2
  301. package/build/system/mcp-servers/playwright/tools-page-interaction.js +0 -162
  302. package/build/system/mcp-servers/playwright/tools-run-script.d.ts +0 -2
  303. package/build/system/mcp-servers/playwright/tools-run-script.js +0 -207
  304. package/build/system/mcp-servers/playwright/types.d.ts +0 -8
  305. package/build/system/mcp-servers/playwright/types.js +0 -30
  306. package/build/system/mcp-servers/playwright/vision-helper.d.ts +0 -12
  307. package/build/system/mcp-servers/playwright/vision-helper.js +0 -81
  308. package/build/system/mcp-servers/playwright-cli/helpers.d.ts +0 -11
  309. package/build/system/mcp-servers/playwright-cli/helpers.js +0 -20
  310. package/build/system/mcp-servers/playwright-cli/index.d.ts +0 -4
  311. package/build/system/mcp-servers/playwright-cli/index.js +0 -15
  312. package/build/system/mcp-servers/playwright-cli/schemas.d.ts +0 -219
  313. package/build/system/mcp-servers/playwright-cli/schemas.js +0 -75
  314. package/build/system/mcp-servers/playwright-cli/tools-auth.d.ts +0 -2
  315. package/build/system/mcp-servers/playwright-cli/tools-auth.js +0 -183
  316. package/build/system/mcp-servers/playwright-cli/tools-capture.d.ts +0 -2
  317. package/build/system/mcp-servers/playwright-cli/tools-capture.js +0 -273
  318. package/build/system/seed/tool-manifests-browser.d.ts +0 -577
  319. package/build/system/seed/tool-manifests-browser.js +0 -158
  320. package/dashboard/dist/assets/AgentConfigPage-DBtvb2x5.js +0 -16
  321. package/dashboard/dist/assets/AgentConfigPage-DBtvb2x5.js.map +0 -1
  322. package/dashboard/dist/assets/AgentDetailPage-3mZA7SOb.js.map +0 -1
  323. package/dashboard/dist/assets/AvailableEscalationsPage-CA9x9o5s.js +0 -2
  324. package/dashboard/dist/assets/BotPicker-BQp_Vs73.js +0 -2
  325. package/dashboard/dist/assets/CronLabel-DY8VdTS9.js +0 -2
  326. package/dashboard/dist/assets/CronLabel-DY8VdTS9.js.map +0 -1
  327. package/dashboard/dist/assets/ElapsedCell-BPYm8RA7.js +0 -2
  328. package/dashboard/dist/assets/EventTopicPill-CCWCs07y.js +0 -2
  329. package/dashboard/dist/assets/EventTopicPill-CCWCs07y.js.map +0 -1
  330. package/dashboard/dist/assets/HomePage-CwRebzmO.js +0 -2
  331. package/dashboard/dist/assets/HomePage-CwRebzmO.js.map +0 -1
  332. package/dashboard/dist/assets/ListToolbar-DEef1_-T.js +0 -2
  333. package/dashboard/dist/assets/McpRunDetailPage-X0sfRFTk.js +0 -2
  334. package/dashboard/dist/assets/McpRunDetailPage-X0sfRFTk.js.map +0 -1
  335. package/dashboard/dist/assets/McpRunsPage-aZg057y3.js +0 -2
  336. package/dashboard/dist/assets/OperatorDashboard-iZEHnndU.js +0 -2
  337. package/dashboard/dist/assets/OperatorDashboard-iZEHnndU.js.map +0 -1
  338. package/dashboard/dist/assets/ServerName-Q6okiv4f.js +0 -2
  339. package/dashboard/dist/assets/TopicDetailPage-DW97-YHQ.js +0 -9
  340. package/dashboard/dist/assets/TopicDetailPage-DW97-YHQ.js.map +0 -1
  341. package/dashboard/dist/assets/WorkflowsDashboard-eCH4gpAk.js +0 -2
  342. package/dashboard/dist/assets/WorkflowsDashboard-eCH4gpAk.js.map +0 -1
  343. package/dashboard/dist/assets/index-3n5VREXN.js +0 -2
  344. package/dashboard/dist/assets/index-BAXzN-QB.js +0 -6
  345. package/dashboard/dist/assets/index-BAXzN-QB.js.map +0 -1
  346. package/dashboard/dist/assets/index-BpN31nuC.js.map +0 -1
  347. package/dashboard/dist/assets/index-C37LMzJa.css +0 -1
  348. package/dashboard/dist/assets/index-C5dHozmW.js +0 -2
  349. package/dashboard/dist/assets/index-C5dHozmW.js.map +0 -1
  350. package/dashboard/dist/assets/index-UtAfnStw.js +0 -15
  351. package/dashboard/dist/assets/topics-DDKHpRwP.js +0 -2
  352. package/dashboard/dist/assets/useEventHooks-NzIyvoGY.js +0 -2
  353. package/dashboard/dist/assets/useEventHooks-NzIyvoGY.js.map +0 -1
  354. package/dashboard/dist/assets/vendor-icons-CrrAvF2g.js.map +0 -1
@@ -19,7 +19,7 @@ function objectSchema(properties) {
19
19
  const SYSTEM_TOPICS = [
20
20
  // Task lifecycle
21
21
  {
22
- topic: 'task.created',
22
+ topic: 'system.task.*.created',
23
23
  description: 'A new task has been created and queued for execution.',
24
24
  category: 'task',
25
25
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string', description: 'Task ID' }, status: STATUS_FIELD, data: { type: 'object', description: 'Task input data' } }),
@@ -27,7 +27,7 @@ const SYSTEM_TOPICS = [
27
27
  tags: ['lifecycle', 'core'],
28
28
  },
29
29
  {
30
- topic: 'task.started',
30
+ topic: 'system.task.*.started',
31
31
  description: 'A task has begun execution.',
32
32
  category: 'task',
33
33
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD }),
@@ -35,7 +35,7 @@ const SYSTEM_TOPICS = [
35
35
  tags: ['lifecycle', 'core'],
36
36
  },
37
37
  {
38
- topic: 'task.completed',
38
+ topic: 'system.task.*.completed',
39
39
  description: 'A task has finished successfully.',
40
40
  category: 'task',
41
41
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD, milestones: { type: 'array', items: { type: 'object' }, description: 'Milestones reported' }, data: { type: 'object', description: 'Task result data' } }),
@@ -43,7 +43,7 @@ const SYSTEM_TOPICS = [
43
43
  tags: ['lifecycle', 'core'],
44
44
  },
45
45
  {
46
- topic: 'task.escalated',
46
+ topic: 'system.task.*.escalated',
47
47
  description: 'A task has been escalated for human review.',
48
48
  category: 'task',
49
49
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object' } }),
@@ -51,7 +51,7 @@ const SYSTEM_TOPICS = [
51
51
  tags: ['lifecycle', 'escalation'],
52
52
  },
53
53
  {
54
- topic: 'task.failed',
54
+ topic: 'system.task.*.failed',
55
55
  description: 'A task has failed execution.',
56
56
  category: 'task',
57
57
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object', description: 'Error details' } }),
@@ -60,7 +60,7 @@ const SYSTEM_TOPICS = [
60
60
  },
61
61
  // Workflow lifecycle
62
62
  {
63
- topic: 'workflow.started',
63
+ topic: 'system.workflow.*.started',
64
64
  description: 'A workflow execution has started.',
65
65
  category: 'workflow',
66
66
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD }),
@@ -68,7 +68,7 @@ const SYSTEM_TOPICS = [
68
68
  tags: ['lifecycle', 'core'],
69
69
  },
70
70
  {
71
- topic: 'workflow.completed',
71
+ topic: 'system.workflow.*.completed',
72
72
  description: 'A workflow execution has completed successfully.',
73
73
  category: 'workflow',
74
74
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object' } }),
@@ -76,7 +76,7 @@ const SYSTEM_TOPICS = [
76
76
  tags: ['lifecycle', 'core'],
77
77
  },
78
78
  {
79
- topic: 'workflow.failed',
79
+ topic: 'system.workflow.*.failed',
80
80
  description: 'A workflow execution has failed.',
81
81
  category: 'workflow',
82
82
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, taskId: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object', description: 'Error details' } }),
@@ -85,7 +85,7 @@ const SYSTEM_TOPICS = [
85
85
  },
86
86
  // Escalation lifecycle
87
87
  {
88
- topic: 'escalation.created',
88
+ topic: 'system.escalation.*.created',
89
89
  description: 'A new escalation has been created for human review.',
90
90
  category: 'escalation',
91
91
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, escalationId: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object' } }),
@@ -93,7 +93,7 @@ const SYSTEM_TOPICS = [
93
93
  tags: ['lifecycle', 'hitl'],
94
94
  },
95
95
  {
96
- topic: 'escalation.resolved',
96
+ topic: 'system.escalation.*.resolved',
97
97
  description: 'An escalation has been resolved by a human operator.',
98
98
  category: 'escalation',
99
99
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, escalationId: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object' } }),
@@ -101,7 +101,7 @@ const SYSTEM_TOPICS = [
101
101
  tags: ['lifecycle', 'hitl'],
102
102
  },
103
103
  {
104
- topic: 'escalation.claimed',
104
+ topic: 'system.escalation.*.claimed',
105
105
  description: 'An escalation has been claimed by an operator.',
106
106
  category: 'escalation',
107
107
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, escalationId: { type: 'string' }, status: STATUS_FIELD }),
@@ -109,7 +109,7 @@ const SYSTEM_TOPICS = [
109
109
  tags: ['lifecycle', 'hitl'],
110
110
  },
111
111
  {
112
- topic: 'escalation.released',
112
+ topic: 'system.escalation.*.released',
113
113
  description: 'An escalation has been released back to the queue.',
114
114
  category: 'escalation',
115
115
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, escalationId: { type: 'string' }, status: STATUS_FIELD }),
@@ -118,7 +118,7 @@ const SYSTEM_TOPICS = [
118
118
  },
119
119
  // Activity lifecycle
120
120
  {
121
- topic: 'activity.started',
121
+ topic: 'system.activity.*.*.started',
122
122
  description: 'A YAML workflow activity step has started.',
123
123
  category: 'activity',
124
124
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, activityName: { type: 'string', description: 'Activity step name' } }),
@@ -126,7 +126,7 @@ const SYSTEM_TOPICS = [
126
126
  tags: ['lifecycle', 'yaml'],
127
127
  },
128
128
  {
129
- topic: 'activity.completed',
129
+ topic: 'system.activity.*.*.completed',
130
130
  description: 'A YAML workflow activity step has completed.',
131
131
  category: 'activity',
132
132
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, activityName: { type: 'string' }, data: { type: 'object' } }),
@@ -134,7 +134,7 @@ const SYSTEM_TOPICS = [
134
134
  tags: ['lifecycle', 'yaml'],
135
135
  },
136
136
  {
137
- topic: 'activity.failed',
137
+ topic: 'system.activity.*.*.failed',
138
138
  description: 'A YAML workflow activity step has failed.',
139
139
  category: 'activity',
140
140
  payload_schema: objectSchema({ ...WORKFLOW_CONTEXT_PROPS, activityName: { type: 'string' }, data: { type: 'object', description: 'Error details' } }),
@@ -143,7 +143,7 @@ const SYSTEM_TOPICS = [
143
143
  },
144
144
  // Knowledge lifecycle
145
145
  {
146
- topic: 'knowledge.stored',
146
+ topic: 'system.knowledge.*.stored',
147
147
  description: 'A knowledge entry has been written to the knowledge store.',
148
148
  category: 'knowledge',
149
149
  payload_schema: objectSchema({ domain: { type: 'string', description: 'Knowledge domain' }, key: { type: 'string', description: 'Knowledge entry key' } }),
@@ -151,7 +151,7 @@ const SYSTEM_TOPICS = [
151
151
  tags: ['lifecycle', 'knowledge'],
152
152
  },
153
153
  {
154
- topic: 'knowledge.deleted',
154
+ topic: 'system.knowledge.*.deleted',
155
155
  description: 'A knowledge entry has been removed from the knowledge store.',
156
156
  category: 'knowledge',
157
157
  payload_schema: objectSchema({ domain: { type: 'string', description: 'Knowledge domain' }, key: { type: 'string', description: 'Knowledge entry key' } }),
@@ -160,7 +160,7 @@ const SYSTEM_TOPICS = [
160
160
  },
161
161
  // File storage
162
162
  {
163
- topic: 'file.stored',
163
+ topic: 'system.file.stored',
164
164
  description: 'A file has been written to storage.',
165
165
  category: 'file',
166
166
  payload_schema: objectSchema({
@@ -175,7 +175,7 @@ const SYSTEM_TOPICS = [
175
175
  tags: ['lifecycle', 'file', 'storage'],
176
176
  },
177
177
  {
178
- topic: 'file.deleted',
178
+ topic: 'system.file.deleted',
179
179
  description: 'A file has been removed from storage.',
180
180
  category: 'file',
181
181
  payload_schema: objectSchema({
@@ -189,7 +189,7 @@ const SYSTEM_TOPICS = [
189
189
  },
190
190
  // Agent lifecycle
191
191
  {
192
- topic: 'agent.started',
192
+ topic: 'system.agent.*.started',
193
193
  description: 'An agent reaction workflow has started in response to an event.',
194
194
  category: 'agent',
195
195
  payload_schema: objectSchema({ agentId: { type: 'string', description: 'Agent ID' }, agentName: { type: 'string', description: 'Agent name' }, status: STATUS_FIELD, data: { type: 'object', description: 'Trigger context' } }),
@@ -197,7 +197,7 @@ const SYSTEM_TOPICS = [
197
197
  tags: ['lifecycle', 'agent'],
198
198
  },
199
199
  {
200
- topic: 'agent.completed',
200
+ topic: 'system.agent.*.completed',
201
201
  description: 'An agent reaction workflow has completed successfully.',
202
202
  category: 'agent',
203
203
  payload_schema: objectSchema({ agentId: { type: 'string' }, agentName: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object' } }),
@@ -205,7 +205,7 @@ const SYSTEM_TOPICS = [
205
205
  tags: ['lifecycle', 'agent'],
206
206
  },
207
207
  {
208
- topic: 'agent.failed',
208
+ topic: 'system.agent.*.failed',
209
209
  description: 'An agent reaction workflow has failed.',
210
210
  category: 'agent',
211
211
  payload_schema: objectSchema({ agentId: { type: 'string' }, agentName: { type: 'string' }, status: STATUS_FIELD, data: { type: 'object', description: 'Error details' } }),
@@ -213,7 +213,7 @@ const SYSTEM_TOPICS = [
213
213
  tags: ['lifecycle', 'agent', 'error'],
214
214
  },
215
215
  {
216
- topic: 'agent.status_changed',
216
+ topic: 'system.agent.*.status_changed',
217
217
  description: 'An agent\'s status has changed (activated, paused, errored).',
218
218
  category: 'agent',
219
219
  payload_schema: objectSchema({ agentId: { type: 'string' }, agentName: { type: 'string' }, status: STATUS_FIELD }),
@@ -222,7 +222,7 @@ const SYSTEM_TOPICS = [
222
222
  },
223
223
  // Milestone
224
224
  {
225
- topic: 'milestone',
225
+ topic: 'system.milestone.*',
226
226
  description: 'A workflow or activity has reported progress milestones.',
227
227
  category: 'milestone',
228
228
  payload_schema: objectSchema({
@@ -240,7 +240,11 @@ const SYSTEM_TOPICS = [
240
240
  * `app.*` → 'app', everything else → first segment.
241
241
  */
242
242
  function inferCategory(topic) {
243
- return topic.startsWith('app.') ? 'app' : topic.split('.')[0];
243
+ if (topic.startsWith('app.'))
244
+ return 'app';
245
+ if (topic.startsWith('system.'))
246
+ return topic.split('.')[1]; // system.workflow.* → 'workflow'
247
+ return topic.split('.')[0];
244
248
  }
245
249
  /**
246
250
  * Seed all 22 built-in system topics into the catalog.
@@ -1,6 +1,6 @@
1
1
  export { CreateUserInput, UpdateUserInput, VALID_ROLE_TYPES } from './types';
2
2
  export { createUser, getUser, getUserByExternalId, getUserByEmail, updateUser, deleteUser, listUsers, } from './crud';
3
3
  export { isValidRoleType, addUserRole, removeUserRole, getUserRoles, hasRole, hasRoleType, } from './roles';
4
- export { isSuperAdmin, isGroupAdmin, canManageRole } from './rbac';
4
+ export { isSuperAdmin, isGroupAdmin, canManageRole, hasGlobalEscalationAccess, hasRolesAsAdmin } from './rbac';
5
5
  export { verifyPassword } from './auth';
6
6
  export { seedAdmin } from './seed-admin';
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.seedAdmin = exports.verifyPassword = exports.canManageRole = exports.isGroupAdmin = exports.isSuperAdmin = exports.hasRoleType = exports.hasRole = exports.getUserRoles = exports.removeUserRole = exports.addUserRole = exports.isValidRoleType = exports.listUsers = exports.deleteUser = exports.updateUser = exports.getUserByEmail = exports.getUserByExternalId = exports.getUser = exports.createUser = exports.VALID_ROLE_TYPES = void 0;
3
+ exports.seedAdmin = exports.verifyPassword = exports.hasRolesAsAdmin = exports.hasGlobalEscalationAccess = exports.canManageRole = exports.isGroupAdmin = exports.isSuperAdmin = exports.hasRoleType = exports.hasRole = exports.getUserRoles = exports.removeUserRole = exports.addUserRole = exports.isValidRoleType = exports.listUsers = exports.deleteUser = exports.updateUser = exports.getUserByEmail = exports.getUserByExternalId = exports.getUser = exports.createUser = exports.VALID_ROLE_TYPES = void 0;
4
4
  var types_1 = require("./types");
5
5
  Object.defineProperty(exports, "VALID_ROLE_TYPES", { enumerable: true, get: function () { return types_1.VALID_ROLE_TYPES; } });
6
6
  var crud_1 = require("./crud");
@@ -22,6 +22,8 @@ var rbac_1 = require("./rbac");
22
22
  Object.defineProperty(exports, "isSuperAdmin", { enumerable: true, get: function () { return rbac_1.isSuperAdmin; } });
23
23
  Object.defineProperty(exports, "isGroupAdmin", { enumerable: true, get: function () { return rbac_1.isGroupAdmin; } });
24
24
  Object.defineProperty(exports, "canManageRole", { enumerable: true, get: function () { return rbac_1.canManageRole; } });
25
+ Object.defineProperty(exports, "hasGlobalEscalationAccess", { enumerable: true, get: function () { return rbac_1.hasGlobalEscalationAccess; } });
26
+ Object.defineProperty(exports, "hasRolesAsAdmin", { enumerable: true, get: function () { return rbac_1.hasRolesAsAdmin; } });
25
27
  var auth_1 = require("./auth");
26
28
  Object.defineProperty(exports, "verifyPassword", { enumerable: true, get: function () { return auth_1.verifyPassword; } });
27
29
  var seed_admin_1 = require("./seed-admin");
@@ -13,3 +13,19 @@ export declare function isGroupAdmin(userId: string, role: string): Promise<bool
13
13
  * Superadmins can manage any role. Admins can manage roles they belong to.
14
14
  */
15
15
  export declare function canManageRole(actorId: string, role: string): Promise<boolean>;
16
+ /**
17
+ * Can this user act on escalations across all roles?
18
+ *
19
+ * True for:
20
+ * - superadmin (any role with type 'superadmin')
21
+ * - admin/admin (the named 'admin' role with type 'admin')
22
+ *
23
+ * These users see all escalations, can claim/resolve/escalate across
24
+ * all roles, and can perform bulk actions.
25
+ */
26
+ export declare function hasGlobalEscalationAccess(userId: string): Promise<boolean>;
27
+ /**
28
+ * Batch check: does the user have admin type for ALL specified roles?
29
+ * Single query — replaces the N+1 loop in checkBulkPermission.
30
+ */
31
+ export declare function hasRolesAsAdmin(userId: string, roles: string[]): Promise<boolean>;
@@ -3,6 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.isSuperAdmin = isSuperAdmin;
4
4
  exports.isGroupAdmin = isGroupAdmin;
5
5
  exports.canManageRole = canManageRole;
6
+ exports.hasGlobalEscalationAccess = hasGlobalEscalationAccess;
7
+ exports.hasRolesAsAdmin = hasRolesAsAdmin;
6
8
  const db_1 = require("../../lib/db");
7
9
  const roles_1 = require("./roles");
8
10
  const sql_1 = require("./sql");
@@ -30,3 +32,32 @@ async function isGroupAdmin(userId, role) {
30
32
  async function canManageRole(actorId, role) {
31
33
  return isGroupAdmin(actorId, role);
32
34
  }
35
+ /**
36
+ * Can this user act on escalations across all roles?
37
+ *
38
+ * True for:
39
+ * - superadmin (any role with type 'superadmin')
40
+ * - admin/admin (the named 'admin' role with type 'admin')
41
+ *
42
+ * These users see all escalations, can claim/resolve/escalate across
43
+ * all roles, and can perform bulk actions.
44
+ */
45
+ async function hasGlobalEscalationAccess(userId) {
46
+ if (await isSuperAdmin(userId))
47
+ return true;
48
+ const roles = await (0, roles_1.getUserRoles)(userId);
49
+ return roles.some((r) => r.role === 'admin' && r.type === 'admin');
50
+ }
51
+ /**
52
+ * Batch check: does the user have admin type for ALL specified roles?
53
+ * Single query — replaces the N+1 loop in checkBulkPermission.
54
+ */
55
+ async function hasRolesAsAdmin(userId, roles) {
56
+ if (!roles.length)
57
+ return true;
58
+ const pool = (0, db_1.getPool)();
59
+ const { rows } = await pool.query(`SELECT COUNT(DISTINCT role)::int AS cnt
60
+ FROM lt_user_roles
61
+ WHERE user_id = $1 AND role = ANY($2::text[]) AND type IN ('admin', 'superadmin')`, [userId, roles]);
62
+ return (rows[0]?.cnt ?? 0) >= roles.length;
63
+ }
@@ -0,0 +1,19 @@
1
+ import type { SSOIdentity, LTSSOConfig } from '../../types/auth';
2
+ export interface ProvisionedUser {
3
+ userId: string;
4
+ roles: Array<{
5
+ role: string;
6
+ type: string;
7
+ }>;
8
+ created: boolean;
9
+ }
10
+ /**
11
+ * JIT provision or sync an SSO identity to lt_users.
12
+ *
13
+ * Lookup by `external_id`. If not found, create with resolved roles.
14
+ * If found, sync any new roles from the identity.
15
+ *
16
+ * Returns the internal `lt_users.id` (UUID) that all RBAC and
17
+ * escalation queries use.
18
+ */
19
+ export declare function ssoProvision(identity: SSOIdentity, ssoConfig: LTSSOConfig): Promise<ProvisionedUser>;
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ssoProvision = ssoProvision;
4
+ const logger_1 = require("../../lib/logger");
5
+ const crud_1 = require("./crud");
6
+ const roles_1 = require("./roles");
7
+ /**
8
+ * JIT provision or sync an SSO identity to lt_users.
9
+ *
10
+ * Lookup by `external_id`. If not found, create with resolved roles.
11
+ * If found, sync any new roles from the identity.
12
+ *
13
+ * Returns the internal `lt_users.id` (UUID) that all RBAC and
14
+ * escalation queries use.
15
+ */
16
+ async function ssoProvision(identity, ssoConfig) {
17
+ const defaultRoleType = ssoConfig.defaultRoleType || 'member';
18
+ const ltRoles = resolveRoles(identity.roles || [], defaultRoleType, ssoConfig.roleMap);
19
+ const existing = await (0, crud_1.getUserByExternalId)(identity.externalId);
20
+ if (existing) {
21
+ // Sync roles: ensure all resolved roles exist on the user
22
+ const currentRoles = await (0, roles_1.getUserRoles)(existing.id);
23
+ for (const lr of ltRoles) {
24
+ const has = currentRoles.some((r) => r.role === lr.role);
25
+ if (!has) {
26
+ await (0, roles_1.addUserRole)(existing.id, lr.role, lr.type);
27
+ }
28
+ }
29
+ const updatedRoles = await (0, roles_1.getUserRoles)(existing.id);
30
+ return {
31
+ userId: existing.id,
32
+ roles: updatedRoles.map((r) => ({ role: r.role, type: r.type })),
33
+ created: false,
34
+ };
35
+ }
36
+ // Create new user
37
+ const user = await (0, crud_1.createUser)({
38
+ external_id: identity.externalId,
39
+ email: identity.email || undefined,
40
+ display_name: identity.displayName || identity.externalId,
41
+ roles: ltRoles.map((r) => ({ role: r.role, type: r.type })),
42
+ metadata: identity.metadata,
43
+ });
44
+ logger_1.loggerRegistry.info(`[lt-sso] provisioned user: ${identity.externalId} → ${user.id}`);
45
+ return {
46
+ userId: user.id,
47
+ roles: (user.roles || []).map((r) => ({ role: r.role, type: r.type })),
48
+ created: true,
49
+ };
50
+ }
51
+ function resolveRoles(hostRoles, defaultRoleType, roleMap) {
52
+ const mapped = roleMap
53
+ ? hostRoles.filter((r) => roleMap[r]).map((r) => roleMap[r])
54
+ : hostRoles;
55
+ if (mapped.length === 0) {
56
+ return [{ role: defaultRoleType, type: defaultRoleType }];
57
+ }
58
+ return mapped.map((role) => ({
59
+ role,
60
+ type: role === 'superadmin' ? 'superadmin' : role === 'admin' ? 'admin' : 'member',
61
+ }));
62
+ }
@@ -148,15 +148,17 @@ async function checkInvocationRoles(workflowType, userId, authRole) {
148
148
  // Superadmin from JWT bypasses all invocation role checks
149
149
  if (authRole === 'superadmin')
150
150
  return;
151
- const user = await userService.getUserByExternalId(userId);
151
+ const user = await userService.getUser(userId);
152
152
  if (!user) {
153
153
  throw new InvocationError('User not registered', 403);
154
154
  }
155
155
  const userRoles = user.roles.map((r) => r.role);
156
156
  const hasInvocationRole = wfConfig.invocation_roles.some((r) => userRoles.includes(r));
157
157
  if (!hasInvocationRole) {
158
- const isSuperAdmin = user.roles.some((r) => r.type === 'superadmin');
159
- if (!isSuperAdmin) {
158
+ // superadmin and admin/admin bypass role checks
159
+ const hasGlobalAccess = user.roles.some((r) => r.type === 'superadmin')
160
+ || user.roles.some((r) => r.role === 'admin' && r.type === 'admin');
161
+ if (!hasGlobalAccess) {
160
162
  throw new InvocationError('Insufficient role for invocation', 403);
161
163
  }
162
164
  }
@@ -100,4 +100,10 @@ async function applyServerAuthConfig(startConfig) {
100
100
  baseUrl: startConfig.auth.oauth.baseUrl,
101
101
  });
102
102
  }
103
+ // SSO — store config for requireAuth fallback and /api/auth/sso exchange
104
+ if (startConfig.auth?.sso) {
105
+ const { setSSOConfig } = await Promise.resolve().then(() => __importStar(require('../modules/sso')));
106
+ setSSOConfig(startConfig.auth.sso);
107
+ logger_1.loggerRegistry.info('[long-tail] SSO enabled — host auth will be trusted');
108
+ }
103
109
  }
@@ -10,6 +10,7 @@ const express_1 = __importDefault(require("express"));
10
10
  const config_1 = require("../modules/config");
11
11
  const logger_1 = require("../lib/logger");
12
12
  const routes_1 = __importDefault(require("../routes"));
13
+ const mcp_endpoint_1 = __importDefault(require("../routes/mcp-endpoint"));
13
14
  /**
14
15
  * Create and start the embedded Express server with health check,
15
16
  * API routes, and optional dashboard static assets.
@@ -24,6 +25,7 @@ function startServer() {
24
25
  res.json({ status: 'ok', timestamp: new Date().toISOString() });
25
26
  });
26
27
  app.use('/api', routes_1.default);
28
+ app.use('/mcp', mcp_endpoint_1.default);
27
29
  // Serve dashboard static assets
28
30
  // Resolves correctly in both dev (ts-node from root) and prod (node build/)
29
31
  const devDist = path_1.default.join(__dirname, '..', 'dashboard', 'dist');
@@ -111,6 +111,9 @@ async function startWorkers(startConfig, workers, builtinMcpServerFactories) {
111
111
  return undefined;
112
112
  });
113
113
  }
114
+ // Seed MCP service account (idempotent)
115
+ const { seedMcpServiceAccount } = await Promise.resolve().then(() => __importStar(require('../services/mcp/seed-service-account')));
116
+ await seedMcpServiceAccount();
114
117
  const connection = buildConnection();
115
118
  // Readonly mode: all user-provided workers are observers — skip crons, triggers, and agent seeding.
116
119
  // System workers (mcpQuery, etc.) are always added by collectWorkers, so check the original config.
@@ -217,6 +220,9 @@ async function startWorkers(startConfig, workers, builtinMcpServerFactories) {
217
220
  registerBuiltinServer(name, entry.factory);
218
221
  }
219
222
  logger_1.loggerRegistry.info(`[long-tail] ${Object.keys(allFactories).length} MCP server factories registered`);
223
+ // Set exposure config for the /mcp endpoint
224
+ const { setExposureConfig } = await Promise.resolve().then(() => __importStar(require('../services/mcp/exposure')));
225
+ setExposureConfig(startConfig.mcp?.exposure);
220
226
  // 2. Seed MCP server configs (insert-if-absent + drift log)
221
227
  for (const [name, entry] of Object.entries(allFactories)) {
222
228
  if (entry.config) {
@@ -240,6 +246,15 @@ async function startWorkers(startConfig, workers, builtinMcpServerFactories) {
240
246
  await seedSystemTopics();
241
247
  if (startConfig.topics?.length)
242
248
  await seedConfigTopics(startConfig.topics);
249
+ // Seed example topics when examples are enabled
250
+ if (startConfig.examples) {
251
+ try {
252
+ const { EXAMPLE_TOPICS } = await Promise.resolve().then(() => __importStar(require('../examples')));
253
+ if (EXAMPLE_TOPICS?.length)
254
+ await seedConfigTopics(EXAMPLE_TOPICS);
255
+ }
256
+ catch { /* examples not available */ }
257
+ }
243
258
  // Seed agents (from startConfig + example system agents when enabled)
244
259
  const systemAgents = startConfig.examples
245
260
  ? (await Promise.resolve().then(() => __importStar(require('../system')))).getSystemAgents()
@@ -45,7 +45,17 @@ exports.getSystemAgents = getSystemAgents;
45
45
  // ── Tool manifests (static JSON schema data) ────────────────────────────────
46
46
  const tool_manifests_escalation_1 = require("./seed/tool-manifests-escalation");
47
47
  const tool_manifests_data_1 = require("./seed/tool-manifests-data");
48
- const tool_manifests_browser_1 = require("./seed/tool-manifests-browser");
48
+ // Playwright is an example connector — loaded conditionally (not in npm package)
49
+ let PLAYWRIGHT_TOOLS = [];
50
+ try {
51
+ PLAYWRIGHT_TOOLS = require('../examples/seed/tool-manifests-browser').PLAYWRIGHT_TOOLS;
52
+ }
53
+ catch { /* not available */ }
54
+ let PLAYWRIGHT_CLI_TOOLS = [];
55
+ try {
56
+ PLAYWRIGHT_CLI_TOOLS = require('../examples/seed/tool-manifests-browser').PLAYWRIGHT_CLI_TOOLS;
57
+ }
58
+ catch { /* not available */ }
49
59
  const tool_manifests_workflows_1 = require("./seed/tool-manifests-workflows");
50
60
  const tool_manifests_admin_1 = require("./seed/tool-manifests-admin");
51
61
  const tool_manifests_knowledge_1 = require("./seed/tool-manifests-knowledge");
@@ -173,6 +183,7 @@ exports.builtinMcpServerFactories = {
173
183
  description: 'Text translation using LLM. Translates content between languages with automatic source language detection.',
174
184
  tags: ['translation', 'language', 'text-processing'],
175
185
  category: 'Analysis',
186
+ aiRequired: true,
176
187
  credentialProviders: ['anthropic'],
177
188
  toolManifest: tool_manifests_data_1.TRANSLATION_TOOLS,
178
189
  },
@@ -183,6 +194,7 @@ exports.builtinMcpServerFactories = {
183
194
  description: 'Image analysis and description using LLM vision. Analyzes images to extract structured data, text content, and descriptions.',
184
195
  tags: ['vision', 'image-analysis', 'multimodal'],
185
196
  category: 'Analysis',
197
+ aiRequired: true,
186
198
  compileHints: [
187
199
  'Vision tools process one image at a time.',
188
200
  'The argument name is `image` (NOT `image_path`). It accepts a storage path, data URI, or https:// URL.',
@@ -193,34 +205,6 @@ exports.builtinMcpServerFactories = {
193
205
  toolManifest: tool_manifests_data_1.VISION_ANALYSIS_TOOLS,
194
206
  },
195
207
  },
196
- 'long-tail-playwright': {
197
- factory: () => Promise.resolve().then(() => __importStar(require('./mcp-servers/playwright'))).then((m) => m.createPlaywrightServer()),
198
- config: {
199
- description: 'Low-level browser automation via Playwright. Fine-grained control: navigate, click, fill, wait_for, evaluate, run_script.',
200
- tags: ['browser-automation', 'testing', 'screenshots'],
201
- category: 'Automation',
202
- compileHints: [
203
- 'Session fields (_handle, page_id) MUST be threaded from the step that created them to EVERY subsequent browser step.',
204
- 'run_script accepts a `steps` array — fixed implementation detail, never a dynamic input.',
205
- 'run_script exposes `screenshots` (array) and `last_screenshot_path` (string) as output fields.',
206
- ].join(' '),
207
- toolManifest: tool_manifests_browser_1.PLAYWRIGHT_TOOLS,
208
- },
209
- },
210
- 'long-tail-playwright-cli': {
211
- factory: () => Promise.resolve().then(() => __importStar(require('./mcp-servers/playwright-cli'))).then((m) => m.createPlaywrightCliServer()),
212
- config: {
213
- description: 'High-level browser automation. Intent-based tools that handle session management, timing, and error recovery internally.',
214
- tags: ['browser-automation', 'screenshots', 'scraping', 'forms'],
215
- category: 'Automation',
216
- compileHints: [
217
- 'Session fields (_handle, page_id) MUST be threaded from producing step to ALL subsequent browser steps.',
218
- 'extract_content returns `links` (structured array) and `script_result` (raw). Use `links` as the source field.',
219
- 'capture_page screenshot_path MUST include a file extension (.png).',
220
- ].join(' '),
221
- toolManifest: tool_manifests_browser_1.PLAYWRIGHT_CLI_TOOLS,
222
- },
223
- },
224
208
  'long-tail-docs': {
225
209
  factory: () => Promise.resolve().then(() => __importStar(require('./mcp-servers/docs'))).then((m) => m.createDocsServer()),
226
210
  config: {
@@ -265,6 +249,7 @@ exports.builtinMcpServerFactories = {
265
249
  description: 'Agentic coding assistant via Claude Code CLI. Execute development tasks: code generation, refactoring, file analysis, and multi-step workflows.',
266
250
  tags: ['development', 'coding', 'ai-agent', 'terminal', 'code-generation'],
267
251
  category: 'Development',
252
+ aiRequired: true,
268
253
  compileHints: 'execute_task runs Claude Code as a subprocess. The `prompt` parameter is ALWAYS a dynamic trigger input. ' +
269
254
  'Keep prompts self-contained. For read-only analysis, restrict with allowed_tools: ["Read", "Grep", "Glob"].',
270
255
  credentialProviders: ['anthropic'],
@@ -274,8 +259,8 @@ exports.builtinMcpServerFactories = {
274
259
  'long-tail-admin': {
275
260
  factory: () => Promise.resolve().then(() => __importStar(require('./mcp-servers/admin'))).then((m) => m.createAdminServer()),
276
261
  config: {
277
- description: 'System administration tools for reflexive self-management. Certify workflows, update server tags, manage roles.',
278
- tags: ['admin', 'system', 'configuration'],
262
+ description: 'Unified system management tasks, escalations, workflows, agents, bot accounts, control plane, pipelines, topics, users, roles, and settings.',
263
+ tags: ['admin', 'system', 'configuration', 'agents', 'bot-accounts', 'controlplane', 'pipelines', 'topics'],
279
264
  category: 'System',
280
265
  compileHints: 'Admin tools modify system configuration. certify_workflow and decertify_workflow change interceptor behavior.',
281
266
  toolManifest: tool_manifests_admin_1.ADMIN_TOOLS,
@@ -318,6 +303,39 @@ exports.builtinMcpServerFactories = {
318
303
  },
319
304
  },
320
305
  };
306
+ // Playwright is an example connector — only register when available (not in npm package)
307
+ if (PLAYWRIGHT_TOOLS.length > 0) {
308
+ exports.builtinMcpServerFactories['long-tail-playwright'] = {
309
+ factory: () => Promise.resolve().then(() => __importStar(require('../examples/mcp-servers/playwright'))).then((m) => m.createPlaywrightServer()),
310
+ config: {
311
+ description: 'Low-level browser automation via Playwright. Fine-grained control: navigate, click, fill, wait_for, evaluate, run_script.',
312
+ tags: ['browser-automation', 'testing', 'screenshots'],
313
+ category: 'Automation',
314
+ compileHints: [
315
+ 'Session fields (_handle, page_id) MUST be threaded from the step that created them to EVERY subsequent browser step.',
316
+ 'run_script accepts a `steps` array — fixed implementation detail, never a dynamic input.',
317
+ 'run_script exposes `screenshots` (array) and `last_screenshot_path` (string) as output fields.',
318
+ ].join(' '),
319
+ toolManifest: PLAYWRIGHT_TOOLS,
320
+ },
321
+ };
322
+ }
323
+ if (PLAYWRIGHT_CLI_TOOLS.length > 0) {
324
+ exports.builtinMcpServerFactories['long-tail-playwright-cli'] = {
325
+ factory: () => Promise.resolve().then(() => __importStar(require('../examples/mcp-servers/playwright-cli'))).then((m) => m.createPlaywrightCliServer()),
326
+ config: {
327
+ description: 'High-level browser automation. Intent-based tools that handle session management, timing, and error recovery internally.',
328
+ tags: ['browser-automation', 'screenshots', 'scraping', 'forms'],
329
+ category: 'Automation',
330
+ compileHints: [
331
+ 'Session fields (_handle, page_id) MUST be threaded from producing step to ALL subsequent browser steps.',
332
+ 'extract_content returns `links` (structured array) and `script_result` (raw). Use `links` as the source field.',
333
+ 'capture_page screenshot_path MUST include a file extension (.png).',
334
+ ].join(' '),
335
+ toolManifest: PLAYWRIGHT_CLI_TOOLS,
336
+ },
337
+ };
338
+ }
321
339
  // Gmail is an example connector — only register when available (not in npm package)
322
340
  if (GMAIL_TOOLS.length > 0) {
323
341
  exports.builtinMcpServerFactories['long-tail-gmail'] = {
@@ -360,8 +378,8 @@ function getSystemAgents() {
360
378
  { cron: '0 * * * *', workflow_type: 'basicEcho' },
361
379
  ],
362
380
  subscriptions: [
363
- { topic: 'workflow.failed', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { error: '{event.status}', workflowId: '{event.workflowId}' } } },
364
- { topic: 'activity.failed', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { activity: '{event.activityName}', workflowId: '{event.workflowId}' } } },
381
+ { topic: 'system.workflow.*.failed', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { error: '{event.status}', workflowId: '{event.workflowId}' } } },
382
+ { topic: 'system.activity.*.*.failed', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { activity: '{event.activityName}', workflowId: '{event.workflowId}' } } },
365
383
  { topic: 'app.*.*.error', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { error: '{event.data}', source: '{event.source}' } } },
366
384
  ],
367
385
  },
@@ -374,7 +392,7 @@ function getSystemAgents() {
374
392
  knowledge_domain: 'event-routing',
375
393
  subscriptions: [
376
394
  { topic: 'app.>', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { topic: '{event.type}', source: '{event.source}', payload: '{event.data}' } } },
377
- { topic: 'knowledge.stored', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { domain: '{event.data.domain}', key: '{event.data.key}' } } },
395
+ { topic: 'system.knowledge.*.stored', reaction_type: 'durable', workflow_type: 'basicEcho', input_mapping: { data: { domain: '{event.data.domain}', key: '{event.data.key}' } } },
378
396
  ],
379
397
  },
380
398
  {
@@ -388,7 +406,7 @@ function getSystemAgents() {
388
406
  { cron: '*/15 * * * *', workflow_type: 'reviewContent' },
389
407
  ],
390
408
  subscriptions: [
391
- { topic: 'escalation.created', reaction_type: 'durable', workflow_type: 'reviewContent', filter: { workflowName: 'reviewContent' }, input_mapping: { data: { escalationId: '{event.escalationId}', workflowId: '{event.workflowId}' } } },
409
+ { topic: 'system.escalation.*.created', reaction_type: 'durable', workflow_type: 'reviewContent', filter: { workflowName: 'reviewContent' }, input_mapping: { data: { escalationId: '{event.escalationId}', workflowId: '{event.workflowId}' } } },
392
410
  ],
393
411
  },
394
412
  ];
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Agent subscription tools — mirrors routes/agents.ts subscription routes
3
+ */
4
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
5
+ export declare function registerAgentSubscriptionTools(server: McpServer): void;