@invect/core 0.0.1

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 (1349) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +103 -0
  3. package/dist/_virtual/_rolldown/runtime.cjs +33 -0
  4. package/dist/_virtual/_rolldown/runtime.js +13 -0
  5. package/dist/actions/action-executor.cjs +166 -0
  6. package/dist/actions/action-executor.cjs.map +1 -0
  7. package/dist/actions/action-executor.d.cts +33 -0
  8. package/dist/actions/action-executor.d.cts.map +1 -0
  9. package/dist/actions/action-executor.d.ts +33 -0
  10. package/dist/actions/action-executor.d.ts.map +1 -0
  11. package/dist/actions/action-executor.js +164 -0
  12. package/dist/actions/action-executor.js.map +1 -0
  13. package/dist/actions/action-registry.cjs +236 -0
  14. package/dist/actions/action-registry.cjs.map +1 -0
  15. package/dist/actions/action-registry.d.cts +58 -0
  16. package/dist/actions/action-registry.d.cts.map +1 -0
  17. package/dist/actions/action-registry.d.ts +58 -0
  18. package/dist/actions/action-registry.d.ts.map +1 -0
  19. package/dist/actions/action-registry.js +233 -0
  20. package/dist/actions/action-registry.js.map +1 -0
  21. package/dist/actions/core/if-else.cjs +111 -0
  22. package/dist/actions/core/if-else.cjs.map +1 -0
  23. package/dist/actions/core/if-else.d.cts +1 -0
  24. package/dist/actions/core/if-else.d.ts +1 -0
  25. package/dist/actions/core/if-else.js +98 -0
  26. package/dist/actions/core/if-else.js.map +1 -0
  27. package/dist/actions/core/index.cjs +20 -0
  28. package/dist/actions/core/index.cjs.map +1 -0
  29. package/dist/actions/core/index.d.cts +7 -0
  30. package/dist/actions/core/index.d.cts.map +1 -0
  31. package/dist/actions/core/index.d.ts +7 -0
  32. package/dist/actions/core/index.d.ts.map +1 -0
  33. package/dist/actions/core/index.js +20 -0
  34. package/dist/actions/core/index.js.map +1 -0
  35. package/dist/actions/core/input.cjs +73 -0
  36. package/dist/actions/core/input.cjs.map +1 -0
  37. package/dist/actions/core/input.d.cts +1 -0
  38. package/dist/actions/core/input.d.ts +1 -0
  39. package/dist/actions/core/input.js +72 -0
  40. package/dist/actions/core/input.js.map +1 -0
  41. package/dist/actions/core/javascript.cjs +77 -0
  42. package/dist/actions/core/javascript.cjs.map +1 -0
  43. package/dist/actions/core/javascript.d.cts +1 -0
  44. package/dist/actions/core/javascript.d.ts +1 -0
  45. package/dist/actions/core/javascript.js +62 -0
  46. package/dist/actions/core/javascript.js.map +1 -0
  47. package/dist/actions/core/model.cjs +285 -0
  48. package/dist/actions/core/model.cjs.map +1 -0
  49. package/dist/actions/core/model.d.cts +1 -0
  50. package/dist/actions/core/model.d.ts +1 -0
  51. package/dist/actions/core/model.js +276 -0
  52. package/dist/actions/core/model.js.map +1 -0
  53. package/dist/actions/core/output.cjs +66 -0
  54. package/dist/actions/core/output.cjs.map +1 -0
  55. package/dist/actions/core/output.d.cts +1 -0
  56. package/dist/actions/core/output.d.ts +1 -0
  57. package/dist/actions/core/output.js +57 -0
  58. package/dist/actions/core/output.js.map +1 -0
  59. package/dist/actions/core/template-string.cjs +85 -0
  60. package/dist/actions/core/template-string.cjs.map +1 -0
  61. package/dist/actions/core/template-string.d.cts +1 -0
  62. package/dist/actions/core/template-string.d.ts +1 -0
  63. package/dist/actions/core/template-string.js +76 -0
  64. package/dist/actions/core/template-string.js.map +1 -0
  65. package/dist/actions/define-action.cjs +14 -0
  66. package/dist/actions/define-action.cjs.map +1 -0
  67. package/dist/actions/define-action.d.cts +13 -0
  68. package/dist/actions/define-action.d.cts.map +1 -0
  69. package/dist/actions/define-action.d.ts +13 -0
  70. package/dist/actions/define-action.d.ts.map +1 -0
  71. package/dist/actions/define-action.js +14 -0
  72. package/dist/actions/define-action.js.map +1 -0
  73. package/dist/actions/github/add-issue-comment.cjs +152 -0
  74. package/dist/actions/github/add-issue-comment.cjs.map +1 -0
  75. package/dist/actions/github/add-issue-comment.d.cts +1 -0
  76. package/dist/actions/github/add-issue-comment.d.ts +1 -0
  77. package/dist/actions/github/add-issue-comment.js +150 -0
  78. package/dist/actions/github/add-issue-comment.js.map +1 -0
  79. package/dist/actions/github/create-branch.cjs +201 -0
  80. package/dist/actions/github/create-branch.cjs.map +1 -0
  81. package/dist/actions/github/create-branch.d.cts +1 -0
  82. package/dist/actions/github/create-branch.d.ts +1 -0
  83. package/dist/actions/github/create-branch.js +199 -0
  84. package/dist/actions/github/create-branch.js.map +1 -0
  85. package/dist/actions/github/create-issue.cjs +190 -0
  86. package/dist/actions/github/create-issue.cjs.map +1 -0
  87. package/dist/actions/github/create-issue.d.cts +1 -0
  88. package/dist/actions/github/create-issue.d.ts +1 -0
  89. package/dist/actions/github/create-issue.js +188 -0
  90. package/dist/actions/github/create-issue.js.map +1 -0
  91. package/dist/actions/github/create-or-update-file.cjs +216 -0
  92. package/dist/actions/github/create-or-update-file.cjs.map +1 -0
  93. package/dist/actions/github/create-or-update-file.d.cts +1 -0
  94. package/dist/actions/github/create-or-update-file.d.ts +1 -0
  95. package/dist/actions/github/create-or-update-file.js +214 -0
  96. package/dist/actions/github/create-or-update-file.js.map +1 -0
  97. package/dist/actions/github/create-pull-request.cjs +206 -0
  98. package/dist/actions/github/create-pull-request.cjs.map +1 -0
  99. package/dist/actions/github/create-pull-request.d.cts +1 -0
  100. package/dist/actions/github/create-pull-request.d.ts +1 -0
  101. package/dist/actions/github/create-pull-request.js +204 -0
  102. package/dist/actions/github/create-pull-request.js.map +1 -0
  103. package/dist/actions/github/create-release.cjs +218 -0
  104. package/dist/actions/github/create-release.cjs.map +1 -0
  105. package/dist/actions/github/create-release.d.cts +1 -0
  106. package/dist/actions/github/create-release.d.ts +1 -0
  107. package/dist/actions/github/create-release.js +216 -0
  108. package/dist/actions/github/create-release.js.map +1 -0
  109. package/dist/actions/github/get-file-content.cjs +164 -0
  110. package/dist/actions/github/get-file-content.cjs.map +1 -0
  111. package/dist/actions/github/get-file-content.d.cts +1 -0
  112. package/dist/actions/github/get-file-content.d.ts +1 -0
  113. package/dist/actions/github/get-file-content.js +162 -0
  114. package/dist/actions/github/get-file-content.js.map +1 -0
  115. package/dist/actions/github/get-issue.cjs +149 -0
  116. package/dist/actions/github/get-issue.cjs.map +1 -0
  117. package/dist/actions/github/get-issue.d.cts +1 -0
  118. package/dist/actions/github/get-issue.d.ts +1 -0
  119. package/dist/actions/github/get-issue.js +147 -0
  120. package/dist/actions/github/get-issue.js.map +1 -0
  121. package/dist/actions/github/get-pull-request.cjs +160 -0
  122. package/dist/actions/github/get-pull-request.cjs.map +1 -0
  123. package/dist/actions/github/get-pull-request.d.cts +1 -0
  124. package/dist/actions/github/get-pull-request.d.ts +1 -0
  125. package/dist/actions/github/get-pull-request.js +158 -0
  126. package/dist/actions/github/get-pull-request.js.map +1 -0
  127. package/dist/actions/github/get-repo.cjs +144 -0
  128. package/dist/actions/github/get-repo.cjs.map +1 -0
  129. package/dist/actions/github/get-repo.d.cts +1 -0
  130. package/dist/actions/github/get-repo.d.ts +1 -0
  131. package/dist/actions/github/get-repo.js +142 -0
  132. package/dist/actions/github/get-repo.js.map +1 -0
  133. package/dist/actions/github/index.cjs +48 -0
  134. package/dist/actions/github/index.cjs.map +1 -0
  135. package/dist/actions/github/index.d.cts +7 -0
  136. package/dist/actions/github/index.d.cts.map +1 -0
  137. package/dist/actions/github/index.d.ts +7 -0
  138. package/dist/actions/github/index.d.ts.map +1 -0
  139. package/dist/actions/github/index.js +48 -0
  140. package/dist/actions/github/index.js.map +1 -0
  141. package/dist/actions/github/list-branches.cjs +149 -0
  142. package/dist/actions/github/list-branches.cjs.map +1 -0
  143. package/dist/actions/github/list-branches.d.cts +1 -0
  144. package/dist/actions/github/list-branches.d.ts +1 -0
  145. package/dist/actions/github/list-branches.js +147 -0
  146. package/dist/actions/github/list-branches.js.map +1 -0
  147. package/dist/actions/github/list-commits.cjs +200 -0
  148. package/dist/actions/github/list-commits.cjs.map +1 -0
  149. package/dist/actions/github/list-commits.d.cts +1 -0
  150. package/dist/actions/github/list-commits.d.ts +1 -0
  151. package/dist/actions/github/list-commits.js +198 -0
  152. package/dist/actions/github/list-commits.js.map +1 -0
  153. package/dist/actions/github/list-issue-comments.cjs +153 -0
  154. package/dist/actions/github/list-issue-comments.cjs.map +1 -0
  155. package/dist/actions/github/list-issue-comments.d.cts +1 -0
  156. package/dist/actions/github/list-issue-comments.d.ts +1 -0
  157. package/dist/actions/github/list-issue-comments.js +151 -0
  158. package/dist/actions/github/list-issue-comments.js.map +1 -0
  159. package/dist/actions/github/list-issues.cjs +244 -0
  160. package/dist/actions/github/list-issues.cjs.map +1 -0
  161. package/dist/actions/github/list-issues.d.cts +1 -0
  162. package/dist/actions/github/list-issues.d.ts +1 -0
  163. package/dist/actions/github/list-issues.js +242 -0
  164. package/dist/actions/github/list-issues.js.map +1 -0
  165. package/dist/actions/github/list-pull-requests.cjs +252 -0
  166. package/dist/actions/github/list-pull-requests.cjs.map +1 -0
  167. package/dist/actions/github/list-pull-requests.d.cts +1 -0
  168. package/dist/actions/github/list-pull-requests.d.ts +1 -0
  169. package/dist/actions/github/list-pull-requests.js +250 -0
  170. package/dist/actions/github/list-pull-requests.js.map +1 -0
  171. package/dist/actions/github/list-releases.cjs +152 -0
  172. package/dist/actions/github/list-releases.cjs.map +1 -0
  173. package/dist/actions/github/list-releases.d.cts +1 -0
  174. package/dist/actions/github/list-releases.d.ts +1 -0
  175. package/dist/actions/github/list-releases.js +150 -0
  176. package/dist/actions/github/list-releases.js.map +1 -0
  177. package/dist/actions/github/list-repos.cjs +227 -0
  178. package/dist/actions/github/list-repos.cjs.map +1 -0
  179. package/dist/actions/github/list-repos.d.cts +1 -0
  180. package/dist/actions/github/list-repos.d.ts +1 -0
  181. package/dist/actions/github/list-repos.js +225 -0
  182. package/dist/actions/github/list-repos.js.map +1 -0
  183. package/dist/actions/github/merge-pull-request.cjs +204 -0
  184. package/dist/actions/github/merge-pull-request.cjs.map +1 -0
  185. package/dist/actions/github/merge-pull-request.d.cts +1 -0
  186. package/dist/actions/github/merge-pull-request.d.ts +1 -0
  187. package/dist/actions/github/merge-pull-request.js +202 -0
  188. package/dist/actions/github/merge-pull-request.js.map +1 -0
  189. package/dist/actions/github/search-issues.cjs +200 -0
  190. package/dist/actions/github/search-issues.cjs.map +1 -0
  191. package/dist/actions/github/search-issues.d.cts +1 -0
  192. package/dist/actions/github/search-issues.d.ts +1 -0
  193. package/dist/actions/github/search-issues.js +198 -0
  194. package/dist/actions/github/search-issues.js.map +1 -0
  195. package/dist/actions/github/update-issue.cjs +243 -0
  196. package/dist/actions/github/update-issue.cjs.map +1 -0
  197. package/dist/actions/github/update-issue.d.cts +1 -0
  198. package/dist/actions/github/update-issue.d.ts +1 -0
  199. package/dist/actions/github/update-issue.js +241 -0
  200. package/dist/actions/github/update-issue.js.map +1 -0
  201. package/dist/actions/gmail/create-draft.cjs +228 -0
  202. package/dist/actions/gmail/create-draft.cjs.map +1 -0
  203. package/dist/actions/gmail/create-draft.d.cts +1 -0
  204. package/dist/actions/gmail/create-draft.d.ts +1 -0
  205. package/dist/actions/gmail/create-draft.js +226 -0
  206. package/dist/actions/gmail/create-draft.js.map +1 -0
  207. package/dist/actions/gmail/get-message.cjs +205 -0
  208. package/dist/actions/gmail/get-message.cjs.map +1 -0
  209. package/dist/actions/gmail/get-message.d.cts +1 -0
  210. package/dist/actions/gmail/get-message.d.ts +1 -0
  211. package/dist/actions/gmail/get-message.js +203 -0
  212. package/dist/actions/gmail/get-message.js.map +1 -0
  213. package/dist/actions/gmail/index.cjs +18 -0
  214. package/dist/actions/gmail/index.cjs.map +1 -0
  215. package/dist/actions/gmail/index.d.cts +7 -0
  216. package/dist/actions/gmail/index.d.cts.map +1 -0
  217. package/dist/actions/gmail/index.d.ts +7 -0
  218. package/dist/actions/gmail/index.d.ts.map +1 -0
  219. package/dist/actions/gmail/index.js +18 -0
  220. package/dist/actions/gmail/index.js.map +1 -0
  221. package/dist/actions/gmail/list-messages.cjs +195 -0
  222. package/dist/actions/gmail/list-messages.cjs.map +1 -0
  223. package/dist/actions/gmail/list-messages.d.cts +1 -0
  224. package/dist/actions/gmail/list-messages.d.ts +1 -0
  225. package/dist/actions/gmail/list-messages.js +193 -0
  226. package/dist/actions/gmail/list-messages.js.map +1 -0
  227. package/dist/actions/gmail/modify-labels.cjs +163 -0
  228. package/dist/actions/gmail/modify-labels.cjs.map +1 -0
  229. package/dist/actions/gmail/modify-labels.d.cts +1 -0
  230. package/dist/actions/gmail/modify-labels.d.ts +1 -0
  231. package/dist/actions/gmail/modify-labels.js +161 -0
  232. package/dist/actions/gmail/modify-labels.js.map +1 -0
  233. package/dist/actions/gmail/send-message.cjs +233 -0
  234. package/dist/actions/gmail/send-message.cjs.map +1 -0
  235. package/dist/actions/gmail/send-message.d.cts +1 -0
  236. package/dist/actions/gmail/send-message.d.ts +1 -0
  237. package/dist/actions/gmail/send-message.js +231 -0
  238. package/dist/actions/gmail/send-message.js.map +1 -0
  239. package/dist/actions/google-calendar/create-event.cjs +274 -0
  240. package/dist/actions/google-calendar/create-event.cjs.map +1 -0
  241. package/dist/actions/google-calendar/create-event.d.cts +1 -0
  242. package/dist/actions/google-calendar/create-event.d.ts +1 -0
  243. package/dist/actions/google-calendar/create-event.js +272 -0
  244. package/dist/actions/google-calendar/create-event.js.map +1 -0
  245. package/dist/actions/google-calendar/delete-event.cjs +145 -0
  246. package/dist/actions/google-calendar/delete-event.cjs.map +1 -0
  247. package/dist/actions/google-calendar/delete-event.d.cts +1 -0
  248. package/dist/actions/google-calendar/delete-event.d.ts +1 -0
  249. package/dist/actions/google-calendar/delete-event.js +143 -0
  250. package/dist/actions/google-calendar/delete-event.js.map +1 -0
  251. package/dist/actions/google-calendar/get-event.cjs +128 -0
  252. package/dist/actions/google-calendar/get-event.cjs.map +1 -0
  253. package/dist/actions/google-calendar/get-event.d.cts +1 -0
  254. package/dist/actions/google-calendar/get-event.d.ts +1 -0
  255. package/dist/actions/google-calendar/get-event.js +126 -0
  256. package/dist/actions/google-calendar/get-event.js.map +1 -0
  257. package/dist/actions/google-calendar/index.cjs +20 -0
  258. package/dist/actions/google-calendar/index.cjs.map +1 -0
  259. package/dist/actions/google-calendar/index.d.cts +7 -0
  260. package/dist/actions/google-calendar/index.d.cts.map +1 -0
  261. package/dist/actions/google-calendar/index.d.ts +7 -0
  262. package/dist/actions/google-calendar/index.d.ts.map +1 -0
  263. package/dist/actions/google-calendar/index.js +20 -0
  264. package/dist/actions/google-calendar/index.js.map +1 -0
  265. package/dist/actions/google-calendar/list-events.cjs +193 -0
  266. package/dist/actions/google-calendar/list-events.cjs.map +1 -0
  267. package/dist/actions/google-calendar/list-events.d.cts +1 -0
  268. package/dist/actions/google-calendar/list-events.d.ts +1 -0
  269. package/dist/actions/google-calendar/list-events.js +191 -0
  270. package/dist/actions/google-calendar/list-events.js.map +1 -0
  271. package/dist/actions/google-calendar/query-freebusy.cjs +160 -0
  272. package/dist/actions/google-calendar/query-freebusy.cjs.map +1 -0
  273. package/dist/actions/google-calendar/query-freebusy.d.cts +1 -0
  274. package/dist/actions/google-calendar/query-freebusy.d.ts +1 -0
  275. package/dist/actions/google-calendar/query-freebusy.js +158 -0
  276. package/dist/actions/google-calendar/query-freebusy.js.map +1 -0
  277. package/dist/actions/google-calendar/update-event.cjs +221 -0
  278. package/dist/actions/google-calendar/update-event.cjs.map +1 -0
  279. package/dist/actions/google-calendar/update-event.d.cts +1 -0
  280. package/dist/actions/google-calendar/update-event.d.ts +1 -0
  281. package/dist/actions/google-calendar/update-event.js +219 -0
  282. package/dist/actions/google-calendar/update-event.js.map +1 -0
  283. package/dist/actions/google-docs/append-text.cjs +138 -0
  284. package/dist/actions/google-docs/append-text.cjs.map +1 -0
  285. package/dist/actions/google-docs/append-text.d.cts +1 -0
  286. package/dist/actions/google-docs/append-text.d.ts +1 -0
  287. package/dist/actions/google-docs/append-text.js +136 -0
  288. package/dist/actions/google-docs/append-text.js.map +1 -0
  289. package/dist/actions/google-docs/create-document.cjs +138 -0
  290. package/dist/actions/google-docs/create-document.cjs.map +1 -0
  291. package/dist/actions/google-docs/create-document.d.cts +1 -0
  292. package/dist/actions/google-docs/create-document.d.ts +1 -0
  293. package/dist/actions/google-docs/create-document.js +136 -0
  294. package/dist/actions/google-docs/create-document.js.map +1 -0
  295. package/dist/actions/google-docs/get-document.cjs +118 -0
  296. package/dist/actions/google-docs/get-document.cjs.map +1 -0
  297. package/dist/actions/google-docs/get-document.d.cts +1 -0
  298. package/dist/actions/google-docs/get-document.d.ts +1 -0
  299. package/dist/actions/google-docs/get-document.js +116 -0
  300. package/dist/actions/google-docs/get-document.js.map +1 -0
  301. package/dist/actions/google-docs/index.cjs +18 -0
  302. package/dist/actions/google-docs/index.cjs.map +1 -0
  303. package/dist/actions/google-docs/index.d.cts +7 -0
  304. package/dist/actions/google-docs/index.d.cts.map +1 -0
  305. package/dist/actions/google-docs/index.d.ts +7 -0
  306. package/dist/actions/google-docs/index.d.ts.map +1 -0
  307. package/dist/actions/google-docs/index.js +18 -0
  308. package/dist/actions/google-docs/index.js.map +1 -0
  309. package/dist/actions/google-docs/insert-text.cjs +136 -0
  310. package/dist/actions/google-docs/insert-text.cjs.map +1 -0
  311. package/dist/actions/google-docs/insert-text.d.cts +1 -0
  312. package/dist/actions/google-docs/insert-text.d.ts +1 -0
  313. package/dist/actions/google-docs/insert-text.js +134 -0
  314. package/dist/actions/google-docs/insert-text.js.map +1 -0
  315. package/dist/actions/google-docs/replace-text.cjs +152 -0
  316. package/dist/actions/google-docs/replace-text.cjs.map +1 -0
  317. package/dist/actions/google-docs/replace-text.d.cts +1 -0
  318. package/dist/actions/google-docs/replace-text.d.ts +1 -0
  319. package/dist/actions/google-docs/replace-text.js +150 -0
  320. package/dist/actions/google-docs/replace-text.js.map +1 -0
  321. package/dist/actions/google-drive/create-file.cjs +155 -0
  322. package/dist/actions/google-drive/create-file.cjs.map +1 -0
  323. package/dist/actions/google-drive/create-file.d.cts +1 -0
  324. package/dist/actions/google-drive/create-file.d.ts +1 -0
  325. package/dist/actions/google-drive/create-file.js +153 -0
  326. package/dist/actions/google-drive/create-file.js.map +1 -0
  327. package/dist/actions/google-drive/create-folder.cjs +130 -0
  328. package/dist/actions/google-drive/create-folder.cjs.map +1 -0
  329. package/dist/actions/google-drive/create-folder.d.cts +1 -0
  330. package/dist/actions/google-drive/create-folder.d.ts +1 -0
  331. package/dist/actions/google-drive/create-folder.js +128 -0
  332. package/dist/actions/google-drive/create-folder.js.map +1 -0
  333. package/dist/actions/google-drive/delete-file.cjs +98 -0
  334. package/dist/actions/google-drive/delete-file.cjs.map +1 -0
  335. package/dist/actions/google-drive/delete-file.d.cts +1 -0
  336. package/dist/actions/google-drive/delete-file.d.ts +1 -0
  337. package/dist/actions/google-drive/delete-file.js +96 -0
  338. package/dist/actions/google-drive/delete-file.js.map +1 -0
  339. package/dist/actions/google-drive/get-file.cjs +103 -0
  340. package/dist/actions/google-drive/get-file.cjs.map +1 -0
  341. package/dist/actions/google-drive/get-file.d.cts +1 -0
  342. package/dist/actions/google-drive/get-file.d.ts +1 -0
  343. package/dist/actions/google-drive/get-file.js +101 -0
  344. package/dist/actions/google-drive/get-file.js.map +1 -0
  345. package/dist/actions/google-drive/index.cjs +22 -0
  346. package/dist/actions/google-drive/index.cjs.map +1 -0
  347. package/dist/actions/google-drive/index.d.cts +7 -0
  348. package/dist/actions/google-drive/index.d.cts.map +1 -0
  349. package/dist/actions/google-drive/index.d.ts +7 -0
  350. package/dist/actions/google-drive/index.d.ts.map +1 -0
  351. package/dist/actions/google-drive/index.js +22 -0
  352. package/dist/actions/google-drive/index.js.map +1 -0
  353. package/dist/actions/google-drive/list-files.cjs +156 -0
  354. package/dist/actions/google-drive/list-files.cjs.map +1 -0
  355. package/dist/actions/google-drive/list-files.d.cts +1 -0
  356. package/dist/actions/google-drive/list-files.d.ts +1 -0
  357. package/dist/actions/google-drive/list-files.js +154 -0
  358. package/dist/actions/google-drive/list-files.js.map +1 -0
  359. package/dist/actions/google-drive/search-files.cjs +138 -0
  360. package/dist/actions/google-drive/search-files.cjs.map +1 -0
  361. package/dist/actions/google-drive/search-files.d.cts +1 -0
  362. package/dist/actions/google-drive/search-files.d.ts +1 -0
  363. package/dist/actions/google-drive/search-files.js +136 -0
  364. package/dist/actions/google-drive/search-files.js.map +1 -0
  365. package/dist/actions/google-drive/share-file.cjs +226 -0
  366. package/dist/actions/google-drive/share-file.cjs.map +1 -0
  367. package/dist/actions/google-drive/share-file.d.cts +1 -0
  368. package/dist/actions/google-drive/share-file.d.ts +1 -0
  369. package/dist/actions/google-drive/share-file.js +224 -0
  370. package/dist/actions/google-drive/share-file.js.map +1 -0
  371. package/dist/actions/google-sheets/append-values.cjs +175 -0
  372. package/dist/actions/google-sheets/append-values.cjs.map +1 -0
  373. package/dist/actions/google-sheets/append-values.d.cts +1 -0
  374. package/dist/actions/google-sheets/append-values.d.ts +1 -0
  375. package/dist/actions/google-sheets/append-values.js +173 -0
  376. package/dist/actions/google-sheets/append-values.js.map +1 -0
  377. package/dist/actions/google-sheets/clear-values.cjs +118 -0
  378. package/dist/actions/google-sheets/clear-values.cjs.map +1 -0
  379. package/dist/actions/google-sheets/clear-values.d.cts +1 -0
  380. package/dist/actions/google-sheets/clear-values.d.ts +1 -0
  381. package/dist/actions/google-sheets/clear-values.js +116 -0
  382. package/dist/actions/google-sheets/clear-values.js.map +1 -0
  383. package/dist/actions/google-sheets/create-spreadsheet.cjs +128 -0
  384. package/dist/actions/google-sheets/create-spreadsheet.cjs.map +1 -0
  385. package/dist/actions/google-sheets/create-spreadsheet.d.cts +1 -0
  386. package/dist/actions/google-sheets/create-spreadsheet.d.ts +1 -0
  387. package/dist/actions/google-sheets/create-spreadsheet.js +126 -0
  388. package/dist/actions/google-sheets/create-spreadsheet.js.map +1 -0
  389. package/dist/actions/google-sheets/get-values.cjs +168 -0
  390. package/dist/actions/google-sheets/get-values.cjs.map +1 -0
  391. package/dist/actions/google-sheets/get-values.d.cts +1 -0
  392. package/dist/actions/google-sheets/get-values.d.ts +1 -0
  393. package/dist/actions/google-sheets/get-values.js +166 -0
  394. package/dist/actions/google-sheets/get-values.js.map +1 -0
  395. package/dist/actions/google-sheets/index.cjs +18 -0
  396. package/dist/actions/google-sheets/index.cjs.map +1 -0
  397. package/dist/actions/google-sheets/index.d.cts +7 -0
  398. package/dist/actions/google-sheets/index.d.cts.map +1 -0
  399. package/dist/actions/google-sheets/index.d.ts +7 -0
  400. package/dist/actions/google-sheets/index.d.ts.map +1 -0
  401. package/dist/actions/google-sheets/index.js +18 -0
  402. package/dist/actions/google-sheets/index.js.map +1 -0
  403. package/dist/actions/google-sheets/update-values.cjs +158 -0
  404. package/dist/actions/google-sheets/update-values.cjs.map +1 -0
  405. package/dist/actions/google-sheets/update-values.d.cts +1 -0
  406. package/dist/actions/google-sheets/update-values.d.ts +1 -0
  407. package/dist/actions/google-sheets/update-values.js +156 -0
  408. package/dist/actions/google-sheets/update-values.js.map +1 -0
  409. package/dist/actions/http/index.cjs +7 -0
  410. package/dist/actions/http/index.cjs.map +1 -0
  411. package/dist/actions/http/index.d.cts +7 -0
  412. package/dist/actions/http/index.d.cts.map +1 -0
  413. package/dist/actions/http/index.d.ts +7 -0
  414. package/dist/actions/http/index.d.ts.map +1 -0
  415. package/dist/actions/http/index.js +8 -0
  416. package/dist/actions/http/index.js.map +1 -0
  417. package/dist/actions/http/request.cjs +223 -0
  418. package/dist/actions/http/request.cjs.map +1 -0
  419. package/dist/actions/http/request.d.cts +1 -0
  420. package/dist/actions/http/request.d.ts +1 -0
  421. package/dist/actions/http/request.js +222 -0
  422. package/dist/actions/http/request.js.map +1 -0
  423. package/dist/actions/index.cjs +46 -0
  424. package/dist/actions/index.cjs.map +1 -0
  425. package/dist/actions/index.d.cts +27 -0
  426. package/dist/actions/index.d.cts.map +1 -0
  427. package/dist/actions/index.d.ts +27 -0
  428. package/dist/actions/index.d.ts.map +1 -0
  429. package/dist/actions/index.js +45 -0
  430. package/dist/actions/index.js.map +1 -0
  431. package/dist/actions/linear/create-issue.cjs +296 -0
  432. package/dist/actions/linear/create-issue.cjs.map +1 -0
  433. package/dist/actions/linear/create-issue.d.cts +1 -0
  434. package/dist/actions/linear/create-issue.d.ts +1 -0
  435. package/dist/actions/linear/create-issue.js +294 -0
  436. package/dist/actions/linear/create-issue.js.map +1 -0
  437. package/dist/actions/linear/index.cjs +16 -0
  438. package/dist/actions/linear/index.cjs.map +1 -0
  439. package/dist/actions/linear/index.d.cts +7 -0
  440. package/dist/actions/linear/index.d.cts.map +1 -0
  441. package/dist/actions/linear/index.d.ts +7 -0
  442. package/dist/actions/linear/index.d.ts.map +1 -0
  443. package/dist/actions/linear/index.js +16 -0
  444. package/dist/actions/linear/index.js.map +1 -0
  445. package/dist/actions/linear/list-issues.cjs +239 -0
  446. package/dist/actions/linear/list-issues.cjs.map +1 -0
  447. package/dist/actions/linear/list-issues.d.cts +1 -0
  448. package/dist/actions/linear/list-issues.d.ts +1 -0
  449. package/dist/actions/linear/list-issues.js +237 -0
  450. package/dist/actions/linear/list-issues.js.map +1 -0
  451. package/dist/actions/linear/list-teams.cjs +183 -0
  452. package/dist/actions/linear/list-teams.cjs.map +1 -0
  453. package/dist/actions/linear/list-teams.d.cts +1 -0
  454. package/dist/actions/linear/list-teams.d.ts +1 -0
  455. package/dist/actions/linear/list-teams.js +181 -0
  456. package/dist/actions/linear/list-teams.js.map +1 -0
  457. package/dist/actions/linear/update-issue.cjs +282 -0
  458. package/dist/actions/linear/update-issue.cjs.map +1 -0
  459. package/dist/actions/linear/update-issue.d.cts +1 -0
  460. package/dist/actions/linear/update-issue.d.ts +1 -0
  461. package/dist/actions/linear/update-issue.js +280 -0
  462. package/dist/actions/linear/update-issue.js.map +1 -0
  463. package/dist/actions/microsoft/get-calendar-event.cjs +139 -0
  464. package/dist/actions/microsoft/get-calendar-event.cjs.map +1 -0
  465. package/dist/actions/microsoft/get-calendar-event.d.cts +1 -0
  466. package/dist/actions/microsoft/get-calendar-event.d.ts +1 -0
  467. package/dist/actions/microsoft/get-calendar-event.js +137 -0
  468. package/dist/actions/microsoft/get-calendar-event.js.map +1 -0
  469. package/dist/actions/microsoft/get-meeting-transcript.cjs +221 -0
  470. package/dist/actions/microsoft/get-meeting-transcript.cjs.map +1 -0
  471. package/dist/actions/microsoft/get-meeting-transcript.d.cts +1 -0
  472. package/dist/actions/microsoft/get-meeting-transcript.d.ts +1 -0
  473. package/dist/actions/microsoft/get-meeting-transcript.js +219 -0
  474. package/dist/actions/microsoft/get-meeting-transcript.js.map +1 -0
  475. package/dist/actions/microsoft/get-message.cjs +173 -0
  476. package/dist/actions/microsoft/get-message.cjs.map +1 -0
  477. package/dist/actions/microsoft/get-message.d.cts +1 -0
  478. package/dist/actions/microsoft/get-message.d.ts +1 -0
  479. package/dist/actions/microsoft/get-message.js +171 -0
  480. package/dist/actions/microsoft/get-message.js.map +1 -0
  481. package/dist/actions/microsoft/index.cjs +22 -0
  482. package/dist/actions/microsoft/index.cjs.map +1 -0
  483. package/dist/actions/microsoft/index.d.cts +1 -0
  484. package/dist/actions/microsoft/index.d.ts +1 -0
  485. package/dist/actions/microsoft/index.js +22 -0
  486. package/dist/actions/microsoft/index.js.map +1 -0
  487. package/dist/actions/microsoft/list-calendar-events.cjs +202 -0
  488. package/dist/actions/microsoft/list-calendar-events.cjs.map +1 -0
  489. package/dist/actions/microsoft/list-calendar-events.d.cts +1 -0
  490. package/dist/actions/microsoft/list-calendar-events.d.ts +1 -0
  491. package/dist/actions/microsoft/list-calendar-events.js +200 -0
  492. package/dist/actions/microsoft/list-calendar-events.js.map +1 -0
  493. package/dist/actions/microsoft/list-calendars.cjs +99 -0
  494. package/dist/actions/microsoft/list-calendars.cjs.map +1 -0
  495. package/dist/actions/microsoft/list-calendars.d.cts +1 -0
  496. package/dist/actions/microsoft/list-calendars.d.ts +1 -0
  497. package/dist/actions/microsoft/list-calendars.js +97 -0
  498. package/dist/actions/microsoft/list-calendars.js.map +1 -0
  499. package/dist/actions/microsoft/list-messages.cjs +223 -0
  500. package/dist/actions/microsoft/list-messages.cjs.map +1 -0
  501. package/dist/actions/microsoft/list-messages.d.cts +1 -0
  502. package/dist/actions/microsoft/list-messages.d.ts +1 -0
  503. package/dist/actions/microsoft/list-messages.js +221 -0
  504. package/dist/actions/microsoft/list-messages.js.map +1 -0
  505. package/dist/actions/microsoft/list-online-meetings.cjs +132 -0
  506. package/dist/actions/microsoft/list-online-meetings.cjs.map +1 -0
  507. package/dist/actions/microsoft/list-online-meetings.d.cts +1 -0
  508. package/dist/actions/microsoft/list-online-meetings.d.ts +1 -0
  509. package/dist/actions/microsoft/list-online-meetings.js +130 -0
  510. package/dist/actions/microsoft/list-online-meetings.js.map +1 -0
  511. package/dist/actions/postgres/describe-table.cjs +175 -0
  512. package/dist/actions/postgres/describe-table.cjs.map +1 -0
  513. package/dist/actions/postgres/describe-table.d.cts +1 -0
  514. package/dist/actions/postgres/describe-table.d.ts +1 -0
  515. package/dist/actions/postgres/describe-table.js +165 -0
  516. package/dist/actions/postgres/describe-table.js.map +1 -0
  517. package/dist/actions/postgres/execute-query.cjs +120 -0
  518. package/dist/actions/postgres/execute-query.cjs.map +1 -0
  519. package/dist/actions/postgres/execute-query.d.cts +1 -0
  520. package/dist/actions/postgres/execute-query.d.ts +1 -0
  521. package/dist/actions/postgres/execute-query.js +110 -0
  522. package/dist/actions/postgres/execute-query.js.map +1 -0
  523. package/dist/actions/postgres/index.cjs +16 -0
  524. package/dist/actions/postgres/index.cjs.map +1 -0
  525. package/dist/actions/postgres/index.d.cts +7 -0
  526. package/dist/actions/postgres/index.d.cts.map +1 -0
  527. package/dist/actions/postgres/index.d.ts +7 -0
  528. package/dist/actions/postgres/index.d.ts.map +1 -0
  529. package/dist/actions/postgres/index.js +16 -0
  530. package/dist/actions/postgres/index.js.map +1 -0
  531. package/dist/actions/postgres/insert-rows.cjs +168 -0
  532. package/dist/actions/postgres/insert-rows.cjs.map +1 -0
  533. package/dist/actions/postgres/insert-rows.d.cts +1 -0
  534. package/dist/actions/postgres/insert-rows.d.ts +1 -0
  535. package/dist/actions/postgres/insert-rows.js +158 -0
  536. package/dist/actions/postgres/insert-rows.js.map +1 -0
  537. package/dist/actions/postgres/list-tables.cjs +133 -0
  538. package/dist/actions/postgres/list-tables.cjs.map +1 -0
  539. package/dist/actions/postgres/list-tables.d.cts +1 -0
  540. package/dist/actions/postgres/list-tables.d.ts +1 -0
  541. package/dist/actions/postgres/list-tables.js +123 -0
  542. package/dist/actions/postgres/list-tables.js.map +1 -0
  543. package/dist/actions/providers.cjs +128 -0
  544. package/dist/actions/providers.cjs.map +1 -0
  545. package/dist/actions/providers.d.cts +22 -0
  546. package/dist/actions/providers.d.cts.map +1 -0
  547. package/dist/actions/providers.d.ts +22 -0
  548. package/dist/actions/providers.d.ts.map +1 -0
  549. package/dist/actions/providers.js +116 -0
  550. package/dist/actions/providers.js.map +1 -0
  551. package/dist/actions/slack/index.cjs +9 -0
  552. package/dist/actions/slack/index.cjs.map +1 -0
  553. package/dist/actions/slack/index.d.cts +7 -0
  554. package/dist/actions/slack/index.d.cts.map +1 -0
  555. package/dist/actions/slack/index.d.ts +7 -0
  556. package/dist/actions/slack/index.d.ts.map +1 -0
  557. package/dist/actions/slack/index.js +9 -0
  558. package/dist/actions/slack/index.js.map +1 -0
  559. package/dist/actions/slack/list-channels.cjs +157 -0
  560. package/dist/actions/slack/list-channels.cjs.map +1 -0
  561. package/dist/actions/slack/list-channels.d.cts +1 -0
  562. package/dist/actions/slack/list-channels.d.ts +1 -0
  563. package/dist/actions/slack/list-channels.js +155 -0
  564. package/dist/actions/slack/list-channels.js.map +1 -0
  565. package/dist/actions/slack/send-message.cjs +157 -0
  566. package/dist/actions/slack/send-message.cjs.map +1 -0
  567. package/dist/actions/slack/send-message.d.cts +1 -0
  568. package/dist/actions/slack/send-message.d.ts +1 -0
  569. package/dist/actions/slack/send-message.js +155 -0
  570. package/dist/actions/slack/send-message.js.map +1 -0
  571. package/dist/actions/triggers/cron.cjs +95 -0
  572. package/dist/actions/triggers/cron.cjs.map +1 -0
  573. package/dist/actions/triggers/cron.d.cts +1 -0
  574. package/dist/actions/triggers/cron.d.ts +1 -0
  575. package/dist/actions/triggers/cron.js +83 -0
  576. package/dist/actions/triggers/cron.js.map +1 -0
  577. package/dist/actions/triggers/index.cjs +9 -0
  578. package/dist/actions/triggers/index.cjs.map +1 -0
  579. package/dist/actions/triggers/index.d.cts +1 -0
  580. package/dist/actions/triggers/index.d.ts +1 -0
  581. package/dist/actions/triggers/index.js +9 -0
  582. package/dist/actions/triggers/index.js.map +1 -0
  583. package/dist/actions/triggers/manual.cjs +105 -0
  584. package/dist/actions/triggers/manual.cjs.map +1 -0
  585. package/dist/actions/triggers/manual.d.cts +1 -0
  586. package/dist/actions/triggers/manual.d.ts +1 -0
  587. package/dist/actions/triggers/manual.js +103 -0
  588. package/dist/actions/triggers/manual.js.map +1 -0
  589. package/dist/actions/types.d.cts +373 -0
  590. package/dist/actions/types.d.cts.map +1 -0
  591. package/dist/actions/types.d.ts +373 -0
  592. package/dist/actions/types.d.ts.map +1 -0
  593. package/dist/database/adapter-factory.cjs +188 -0
  594. package/dist/database/adapter-factory.cjs.map +1 -0
  595. package/dist/database/adapter-factory.js +187 -0
  596. package/dist/database/adapter-factory.js.map +1 -0
  597. package/dist/database/adapter.cjs +33 -0
  598. package/dist/database/adapter.cjs.map +1 -0
  599. package/dist/database/adapter.d.cts +76 -0
  600. package/dist/database/adapter.d.cts.map +1 -0
  601. package/dist/database/adapter.d.ts +76 -0
  602. package/dist/database/adapter.d.ts.map +1 -0
  603. package/dist/database/adapter.js +33 -0
  604. package/dist/database/adapter.js.map +1 -0
  605. package/dist/database/adapters/connection-bridge.cjs +119 -0
  606. package/dist/database/adapters/connection-bridge.cjs.map +1 -0
  607. package/dist/database/adapters/connection-bridge.js +118 -0
  608. package/dist/database/adapters/connection-bridge.js.map +1 -0
  609. package/dist/database/adapters/kysely-adapter.cjs +138 -0
  610. package/dist/database/adapters/kysely-adapter.cjs.map +1 -0
  611. package/dist/database/adapters/kysely-adapter.js +137 -0
  612. package/dist/database/adapters/kysely-adapter.js.map +1 -0
  613. package/dist/database/connection.cjs +277 -0
  614. package/dist/database/connection.cjs.map +1 -0
  615. package/dist/database/connection.d.cts +115 -0
  616. package/dist/database/connection.d.cts.map +1 -0
  617. package/dist/database/connection.d.ts +115 -0
  618. package/dist/database/connection.d.ts.map +1 -0
  619. package/dist/database/connection.js +271 -0
  620. package/dist/database/connection.js.map +1 -0
  621. package/dist/database/core-schema.cjs +644 -0
  622. package/dist/database/core-schema.cjs.map +1 -0
  623. package/dist/database/core-schema.d.cts +22 -0
  624. package/dist/database/core-schema.d.cts.map +1 -0
  625. package/dist/database/core-schema.d.ts +22 -0
  626. package/dist/database/core-schema.d.ts.map +1 -0
  627. package/dist/database/core-schema.js +642 -0
  628. package/dist/database/core-schema.js.map +1 -0
  629. package/dist/database/index.cjs +4 -0
  630. package/dist/database/index.d.cts +10 -0
  631. package/dist/database/index.d.cts.map +1 -0
  632. package/dist/database/index.d.ts +10 -0
  633. package/dist/database/index.d.ts.map +1 -0
  634. package/dist/database/index.js +5 -0
  635. package/dist/database/prisma-schema-generator.cjs +219 -0
  636. package/dist/database/prisma-schema-generator.cjs.map +1 -0
  637. package/dist/database/prisma-schema-generator.d.cts +19 -0
  638. package/dist/database/prisma-schema-generator.d.cts.map +1 -0
  639. package/dist/database/prisma-schema-generator.d.ts +19 -0
  640. package/dist/database/prisma-schema-generator.d.ts.map +1 -0
  641. package/dist/database/prisma-schema-generator.js +218 -0
  642. package/dist/database/prisma-schema-generator.js.map +1 -0
  643. package/dist/database/schema-generator.cjs +576 -0
  644. package/dist/database/schema-generator.cjs.map +1 -0
  645. package/dist/database/schema-generator.d.cts +18 -0
  646. package/dist/database/schema-generator.d.cts.map +1 -0
  647. package/dist/database/schema-generator.d.ts +18 -0
  648. package/dist/database/schema-generator.d.ts.map +1 -0
  649. package/dist/database/schema-generator.js +571 -0
  650. package/dist/database/schema-generator.js.map +1 -0
  651. package/dist/database/schema-merger.cjs +153 -0
  652. package/dist/database/schema-merger.cjs.map +1 -0
  653. package/dist/database/schema-merger.d.cts +53 -0
  654. package/dist/database/schema-merger.d.cts.map +1 -0
  655. package/dist/database/schema-merger.d.ts +53 -0
  656. package/dist/database/schema-merger.d.ts.map +1 -0
  657. package/dist/database/schema-merger.js +152 -0
  658. package/dist/database/schema-merger.js.map +1 -0
  659. package/dist/database/schema-metadata.cjs +98 -0
  660. package/dist/database/schema-metadata.cjs.map +1 -0
  661. package/dist/database/schema-metadata.js +98 -0
  662. package/dist/database/schema-metadata.js.map +1 -0
  663. package/dist/database/schema-mysql.cjs +288 -0
  664. package/dist/database/schema-mysql.cjs.map +1 -0
  665. package/dist/database/schema-mysql.d.cts +2117 -0
  666. package/dist/database/schema-mysql.d.cts.map +1 -0
  667. package/dist/database/schema-mysql.d.ts +2117 -0
  668. package/dist/database/schema-mysql.d.ts.map +1 -0
  669. package/dist/database/schema-mysql.js +263 -0
  670. package/dist/database/schema-mysql.js.map +1 -0
  671. package/dist/database/schema-postgres.cjs +312 -0
  672. package/dist/database/schema-postgres.cjs.map +1 -0
  673. package/dist/database/schema-postgres.d.cts +2127 -0
  674. package/dist/database/schema-postgres.d.cts.map +1 -0
  675. package/dist/database/schema-postgres.d.ts +2127 -0
  676. package/dist/database/schema-postgres.d.ts.map +1 -0
  677. package/dist/database/schema-postgres.js +280 -0
  678. package/dist/database/schema-postgres.js.map +1 -0
  679. package/dist/database/schema-sqlite.cjs +247 -0
  680. package/dist/database/schema-sqlite.cjs.map +1 -0
  681. package/dist/database/schema-sqlite.d.cts +2294 -0
  682. package/dist/database/schema-sqlite.d.cts.map +1 -0
  683. package/dist/database/schema-sqlite.d.ts +2294 -0
  684. package/dist/database/schema-sqlite.d.ts.map +1 -0
  685. package/dist/database/schema-sqlite.js +222 -0
  686. package/dist/database/schema-sqlite.js.map +1 -0
  687. package/dist/database/schema-verification.cjs +123 -0
  688. package/dist/database/schema-verification.cjs.map +1 -0
  689. package/dist/database/schema-verification.d.cts +40 -0
  690. package/dist/database/schema-verification.d.cts.map +1 -0
  691. package/dist/database/schema-verification.d.ts +40 -0
  692. package/dist/database/schema-verification.d.ts.map +1 -0
  693. package/dist/database/schema-verification.js +123 -0
  694. package/dist/database/schema-verification.js.map +1 -0
  695. package/dist/database/schema.cjs +3 -0
  696. package/dist/database/schema.d.cts +3 -0
  697. package/dist/database/schema.d.ts +3 -0
  698. package/dist/database/schema.js +4 -0
  699. package/dist/index.cjs +199 -0
  700. package/dist/index.d.cts +70 -0
  701. package/dist/index.d.ts +70 -0
  702. package/dist/index.js +56 -0
  703. package/dist/invect-core.cjs +1688 -0
  704. package/dist/invect-core.cjs.map +1 -0
  705. package/dist/invect-core.d.cts +846 -0
  706. package/dist/invect-core.d.cts.map +1 -0
  707. package/dist/invect-core.d.ts +846 -0
  708. package/dist/invect-core.d.ts.map +1 -0
  709. package/dist/invect-core.js +1688 -0
  710. package/dist/invect-core.js.map +1 -0
  711. package/dist/nodes/agent-executor.cjs +881 -0
  712. package/dist/nodes/agent-executor.cjs.map +1 -0
  713. package/dist/nodes/agent-executor.d.cts +243 -0
  714. package/dist/nodes/agent-executor.d.cts.map +1 -0
  715. package/dist/nodes/agent-executor.d.ts +243 -0
  716. package/dist/nodes/agent-executor.d.ts.map +1 -0
  717. package/dist/nodes/agent-executor.js +877 -0
  718. package/dist/nodes/agent-executor.js.map +1 -0
  719. package/dist/nodes/base-node.cjs +174 -0
  720. package/dist/nodes/base-node.cjs.map +1 -0
  721. package/dist/nodes/base-node.d.cts +125 -0
  722. package/dist/nodes/base-node.d.cts.map +1 -0
  723. package/dist/nodes/base-node.d.ts +125 -0
  724. package/dist/nodes/base-node.d.ts.map +1 -0
  725. package/dist/nodes/base-node.js +170 -0
  726. package/dist/nodes/base-node.js.map +1 -0
  727. package/dist/nodes/executor-registry.cjs +46 -0
  728. package/dist/nodes/executor-registry.cjs.map +1 -0
  729. package/dist/nodes/executor-registry.d.cts +18 -0
  730. package/dist/nodes/executor-registry.d.cts.map +1 -0
  731. package/dist/nodes/executor-registry.d.ts +18 -0
  732. package/dist/nodes/executor-registry.d.ts.map +1 -0
  733. package/dist/nodes/executor-registry.js +46 -0
  734. package/dist/nodes/executor-registry.js.map +1 -0
  735. package/dist/nodes/index.cjs +2 -0
  736. package/dist/nodes/index.d.cts +3 -0
  737. package/dist/nodes/index.d.ts +3 -0
  738. package/dist/nodes/index.js +3 -0
  739. package/dist/services/agent-tool-executions/agent-tool-execution.service.cjs +110 -0
  740. package/dist/services/agent-tool-executions/agent-tool-execution.service.cjs.map +1 -0
  741. package/dist/services/agent-tool-executions/agent-tool-execution.service.d.cts +42 -0
  742. package/dist/services/agent-tool-executions/agent-tool-execution.service.d.cts.map +1 -0
  743. package/dist/services/agent-tool-executions/agent-tool-execution.service.d.ts +42 -0
  744. package/dist/services/agent-tool-executions/agent-tool-execution.service.d.ts.map +1 -0
  745. package/dist/services/agent-tool-executions/agent-tool-execution.service.js +110 -0
  746. package/dist/services/agent-tool-executions/agent-tool-execution.service.js.map +1 -0
  747. package/dist/services/agent-tool-executions/agent-tool-executions.model.cjs +152 -0
  748. package/dist/services/agent-tool-executions/agent-tool-executions.model.cjs.map +1 -0
  749. package/dist/services/agent-tool-executions/agent-tool-executions.model.d.cts +71 -0
  750. package/dist/services/agent-tool-executions/agent-tool-executions.model.d.cts.map +1 -0
  751. package/dist/services/agent-tool-executions/agent-tool-executions.model.d.ts +71 -0
  752. package/dist/services/agent-tool-executions/agent-tool-executions.model.d.ts.map +1 -0
  753. package/dist/services/agent-tool-executions/agent-tool-executions.model.js +152 -0
  754. package/dist/services/agent-tool-executions/agent-tool-executions.model.js.map +1 -0
  755. package/dist/services/agent-tools/agent-tool-registry.cjs +101 -0
  756. package/dist/services/agent-tools/agent-tool-registry.cjs.map +1 -0
  757. package/dist/services/agent-tools/agent-tool-registry.d.cts +51 -0
  758. package/dist/services/agent-tools/agent-tool-registry.d.cts.map +1 -0
  759. package/dist/services/agent-tools/agent-tool-registry.d.ts +51 -0
  760. package/dist/services/agent-tools/agent-tool-registry.d.ts.map +1 -0
  761. package/dist/services/agent-tools/agent-tool-registry.js +98 -0
  762. package/dist/services/agent-tools/agent-tool-registry.js.map +1 -0
  763. package/dist/services/agent-tools/builtin/index.cjs +17 -0
  764. package/dist/services/agent-tools/builtin/index.cjs.map +1 -0
  765. package/dist/services/agent-tools/builtin/index.js +17 -0
  766. package/dist/services/agent-tools/builtin/index.js.map +1 -0
  767. package/dist/services/agent-tools/builtin/json-logic-tool.cjs +73 -0
  768. package/dist/services/agent-tools/builtin/json-logic-tool.cjs.map +1 -0
  769. package/dist/services/agent-tools/builtin/json-logic-tool.js +70 -0
  770. package/dist/services/agent-tools/builtin/json-logic-tool.js.map +1 -0
  771. package/dist/services/agent-tools/builtin/math-tool.cjs +117 -0
  772. package/dist/services/agent-tools/builtin/math-tool.cjs.map +1 -0
  773. package/dist/services/agent-tools/builtin/math-tool.js +116 -0
  774. package/dist/services/agent-tools/builtin/math-tool.js.map +1 -0
  775. package/dist/services/agent-tools/index.cjs +2 -0
  776. package/dist/services/agent-tools/index.js +3 -0
  777. package/dist/services/ai/ai-types.cjs +37 -0
  778. package/dist/services/ai/ai-types.cjs.map +1 -0
  779. package/dist/services/ai/ai-types.d.cts +105 -0
  780. package/dist/services/ai/ai-types.d.cts.map +1 -0
  781. package/dist/services/ai/ai-types.d.ts +105 -0
  782. package/dist/services/ai/ai-types.d.ts.map +1 -0
  783. package/dist/services/ai/ai-types.js +35 -0
  784. package/dist/services/ai/ai-types.js.map +1 -0
  785. package/dist/services/ai/anthropic-adapter.cjs +411 -0
  786. package/dist/services/ai/anthropic-adapter.cjs.map +1 -0
  787. package/dist/services/ai/anthropic-adapter.d.cts +1 -0
  788. package/dist/services/ai/anthropic-adapter.d.ts +1 -0
  789. package/dist/services/ai/anthropic-adapter.js +409 -0
  790. package/dist/services/ai/anthropic-adapter.js.map +1 -0
  791. package/dist/services/ai/base-client.cjs +345 -0
  792. package/dist/services/ai/base-client.cjs.map +1 -0
  793. package/dist/services/ai/base-client.d.cts +138 -0
  794. package/dist/services/ai/base-client.d.cts.map +1 -0
  795. package/dist/services/ai/base-client.d.ts +138 -0
  796. package/dist/services/ai/base-client.d.ts.map +1 -0
  797. package/dist/services/ai/base-client.js +345 -0
  798. package/dist/services/ai/base-client.js.map +1 -0
  799. package/dist/services/ai/openai-adapter.cjs +460 -0
  800. package/dist/services/ai/openai-adapter.cjs.map +1 -0
  801. package/dist/services/ai/openai-adapter.d.cts +1 -0
  802. package/dist/services/ai/openai-adapter.d.ts +1 -0
  803. package/dist/services/ai/openai-adapter.js +458 -0
  804. package/dist/services/ai/openai-adapter.js.map +1 -0
  805. package/dist/services/ai/openrouter-adapter.cjs +124 -0
  806. package/dist/services/ai/openrouter-adapter.cjs.map +1 -0
  807. package/dist/services/ai/openrouter-adapter.d.cts +1 -0
  808. package/dist/services/ai/openrouter-adapter.d.ts +1 -0
  809. package/dist/services/ai/openrouter-adapter.js +122 -0
  810. package/dist/services/ai/openrouter-adapter.js.map +1 -0
  811. package/dist/services/ai/provider-adapter.cjs +72 -0
  812. package/dist/services/ai/provider-adapter.cjs.map +1 -0
  813. package/dist/services/ai/provider-adapter.d.cts +81 -0
  814. package/dist/services/ai/provider-adapter.d.cts.map +1 -0
  815. package/dist/services/ai/provider-adapter.d.ts +81 -0
  816. package/dist/services/ai/provider-adapter.d.ts.map +1 -0
  817. package/dist/services/ai/provider-adapter.js +72 -0
  818. package/dist/services/ai/provider-adapter.js.map +1 -0
  819. package/dist/services/auth/authorization.service.cjs +259 -0
  820. package/dist/services/auth/authorization.service.cjs.map +1 -0
  821. package/dist/services/auth/authorization.service.d.cts +102 -0
  822. package/dist/services/auth/authorization.service.d.cts.map +1 -0
  823. package/dist/services/auth/authorization.service.d.ts +102 -0
  824. package/dist/services/auth/authorization.service.d.ts.map +1 -0
  825. package/dist/services/auth/authorization.service.js +257 -0
  826. package/dist/services/auth/authorization.service.js.map +1 -0
  827. package/dist/services/auth/flow-access.service.cjs +259 -0
  828. package/dist/services/auth/flow-access.service.cjs.map +1 -0
  829. package/dist/services/auth/flow-access.service.d.cts +89 -0
  830. package/dist/services/auth/flow-access.service.d.cts.map +1 -0
  831. package/dist/services/auth/flow-access.service.d.ts +89 -0
  832. package/dist/services/auth/flow-access.service.d.ts.map +1 -0
  833. package/dist/services/auth/flow-access.service.js +259 -0
  834. package/dist/services/auth/flow-access.service.js.map +1 -0
  835. package/dist/services/auth/index.d.ts +2 -0
  836. package/dist/services/batch-jobs/batch-jobs.model.cjs +213 -0
  837. package/dist/services/batch-jobs/batch-jobs.model.cjs.map +1 -0
  838. package/dist/services/batch-jobs/batch-jobs.model.d.cts +79 -0
  839. package/dist/services/batch-jobs/batch-jobs.model.d.cts.map +1 -0
  840. package/dist/services/batch-jobs/batch-jobs.model.d.ts +79 -0
  841. package/dist/services/batch-jobs/batch-jobs.model.d.ts.map +1 -0
  842. package/dist/services/batch-jobs/batch-jobs.model.js +213 -0
  843. package/dist/services/batch-jobs/batch-jobs.model.js.map +1 -0
  844. package/dist/services/batch-jobs/batch-jobs.service.cjs +178 -0
  845. package/dist/services/batch-jobs/batch-jobs.service.cjs.map +1 -0
  846. package/dist/services/batch-jobs/batch-jobs.service.d.cts +83 -0
  847. package/dist/services/batch-jobs/batch-jobs.service.d.cts.map +1 -0
  848. package/dist/services/batch-jobs/batch-jobs.service.d.ts +83 -0
  849. package/dist/services/batch-jobs/batch-jobs.service.d.ts.map +1 -0
  850. package/dist/services/batch-jobs/batch-jobs.service.js +178 -0
  851. package/dist/services/batch-jobs/batch-jobs.service.js.map +1 -0
  852. package/dist/services/chat/chat-messages.model.cjs +143 -0
  853. package/dist/services/chat/chat-messages.model.cjs.map +1 -0
  854. package/dist/services/chat/chat-messages.model.d.cts +43 -0
  855. package/dist/services/chat/chat-messages.model.d.cts.map +1 -0
  856. package/dist/services/chat/chat-messages.model.d.ts +43 -0
  857. package/dist/services/chat/chat-messages.model.d.ts.map +1 -0
  858. package/dist/services/chat/chat-messages.model.js +142 -0
  859. package/dist/services/chat/chat-messages.model.js.map +1 -0
  860. package/dist/services/chat/chat-stream-session.cjs +181 -0
  861. package/dist/services/chat/chat-stream-session.cjs.map +1 -0
  862. package/dist/services/chat/chat-stream-session.d.cts +1 -0
  863. package/dist/services/chat/chat-stream-session.d.ts +1 -0
  864. package/dist/services/chat/chat-stream-session.js +181 -0
  865. package/dist/services/chat/chat-stream-session.js.map +1 -0
  866. package/dist/services/chat/chat-stream.service.cjs +205 -0
  867. package/dist/services/chat/chat-stream.service.cjs.map +1 -0
  868. package/dist/services/chat/chat-stream.service.d.cts +84 -0
  869. package/dist/services/chat/chat-stream.service.d.cts.map +1 -0
  870. package/dist/services/chat/chat-stream.service.d.ts +84 -0
  871. package/dist/services/chat/chat-stream.service.d.ts.map +1 -0
  872. package/dist/services/chat/chat-stream.service.js +205 -0
  873. package/dist/services/chat/chat-stream.service.js.map +1 -0
  874. package/dist/services/chat/chat-toolkit.cjs +125 -0
  875. package/dist/services/chat/chat-toolkit.cjs.map +1 -0
  876. package/dist/services/chat/chat-toolkit.d.cts +58 -0
  877. package/dist/services/chat/chat-toolkit.d.cts.map +1 -0
  878. package/dist/services/chat/chat-toolkit.d.ts +58 -0
  879. package/dist/services/chat/chat-toolkit.d.ts.map +1 -0
  880. package/dist/services/chat/chat-toolkit.js +124 -0
  881. package/dist/services/chat/chat-toolkit.js.map +1 -0
  882. package/dist/services/chat/chat-types.cjs +24 -0
  883. package/dist/services/chat/chat-types.cjs.map +1 -0
  884. package/dist/services/chat/chat-types.d.cts +134 -0
  885. package/dist/services/chat/chat-types.d.cts.map +1 -0
  886. package/dist/services/chat/chat-types.d.ts +134 -0
  887. package/dist/services/chat/chat-types.d.ts.map +1 -0
  888. package/dist/services/chat/chat-types.js +23 -0
  889. package/dist/services/chat/chat-types.js.map +1 -0
  890. package/dist/services/chat/index.cjs +5 -0
  891. package/dist/services/chat/index.d.cts +3 -0
  892. package/dist/services/chat/index.d.ts +3 -0
  893. package/dist/services/chat/index.js +6 -0
  894. package/dist/services/chat/system-prompt.cjs +223 -0
  895. package/dist/services/chat/system-prompt.cjs.map +1 -0
  896. package/dist/services/chat/system-prompt.d.cts +1 -0
  897. package/dist/services/chat/system-prompt.d.ts +1 -0
  898. package/dist/services/chat/system-prompt.js +223 -0
  899. package/dist/services/chat/system-prompt.js.map +1 -0
  900. package/dist/services/chat/tools/agent-tools.cjs +472 -0
  901. package/dist/services/chat/tools/agent-tools.cjs.map +1 -0
  902. package/dist/services/chat/tools/agent-tools.js +471 -0
  903. package/dist/services/chat/tools/agent-tools.js.map +1 -0
  904. package/dist/services/chat/tools/context-tools.cjs +252 -0
  905. package/dist/services/chat/tools/context-tools.cjs.map +1 -0
  906. package/dist/services/chat/tools/context-tools.js +251 -0
  907. package/dist/services/chat/tools/context-tools.js.map +1 -0
  908. package/dist/services/chat/tools/flow-tools.cjs +244 -0
  909. package/dist/services/chat/tools/flow-tools.cjs.map +1 -0
  910. package/dist/services/chat/tools/flow-tools.js +243 -0
  911. package/dist/services/chat/tools/flow-tools.js.map +1 -0
  912. package/dist/services/chat/tools/index.cjs +22 -0
  913. package/dist/services/chat/tools/index.cjs.map +1 -0
  914. package/dist/services/chat/tools/index.js +22 -0
  915. package/dist/services/chat/tools/index.js.map +1 -0
  916. package/dist/services/chat/tools/node-tools.cjs +323 -0
  917. package/dist/services/chat/tools/node-tools.cjs.map +1 -0
  918. package/dist/services/chat/tools/node-tools.js +322 -0
  919. package/dist/services/chat/tools/node-tools.js.map +1 -0
  920. package/dist/services/chat/tools/plan-tools.cjs +94 -0
  921. package/dist/services/chat/tools/plan-tools.cjs.map +1 -0
  922. package/dist/services/chat/tools/plan-tools.js +93 -0
  923. package/dist/services/chat/tools/plan-tools.js.map +1 -0
  924. package/dist/services/chat/tools/run-tools.cjs +121 -0
  925. package/dist/services/chat/tools/run-tools.cjs.map +1 -0
  926. package/dist/services/chat/tools/run-tools.js +120 -0
  927. package/dist/services/chat/tools/run-tools.js.map +1 -0
  928. package/dist/services/credentials/credentials.model.cjs +313 -0
  929. package/dist/services/credentials/credentials.model.cjs.map +1 -0
  930. package/dist/services/credentials/credentials.model.d.cts +27 -0
  931. package/dist/services/credentials/credentials.model.d.cts.map +1 -0
  932. package/dist/services/credentials/credentials.model.d.ts +27 -0
  933. package/dist/services/credentials/credentials.model.d.ts.map +1 -0
  934. package/dist/services/credentials/credentials.model.js +312 -0
  935. package/dist/services/credentials/credentials.model.js.map +1 -0
  936. package/dist/services/credentials/credentials.service.cjs +358 -0
  937. package/dist/services/credentials/credentials.service.cjs.map +1 -0
  938. package/dist/services/credentials/credentials.service.d.cts +156 -0
  939. package/dist/services/credentials/credentials.service.d.cts.map +1 -0
  940. package/dist/services/credentials/credentials.service.d.ts +156 -0
  941. package/dist/services/credentials/credentials.service.d.ts.map +1 -0
  942. package/dist/services/credentials/credentials.service.js +357 -0
  943. package/dist/services/credentials/credentials.service.js.map +1 -0
  944. package/dist/services/credentials/encryption.service.cjs +121 -0
  945. package/dist/services/credentials/encryption.service.cjs.map +1 -0
  946. package/dist/services/credentials/encryption.service.d.cts +70 -0
  947. package/dist/services/credentials/encryption.service.d.cts.map +1 -0
  948. package/dist/services/credentials/encryption.service.d.ts +70 -0
  949. package/dist/services/credentials/encryption.service.d.ts.map +1 -0
  950. package/dist/services/credentials/encryption.service.js +119 -0
  951. package/dist/services/credentials/encryption.service.js.map +1 -0
  952. package/dist/services/credentials/index.d.cts +4 -0
  953. package/dist/services/credentials/index.d.ts +4 -0
  954. package/dist/services/credentials/oauth2-providers.cjs +668 -0
  955. package/dist/services/credentials/oauth2-providers.cjs.map +1 -0
  956. package/dist/services/credentials/oauth2-providers.d.cts +39 -0
  957. package/dist/services/credentials/oauth2-providers.d.cts.map +1 -0
  958. package/dist/services/credentials/oauth2-providers.d.ts +39 -0
  959. package/dist/services/credentials/oauth2-providers.d.ts.map +1 -0
  960. package/dist/services/credentials/oauth2-providers.js +667 -0
  961. package/dist/services/credentials/oauth2-providers.js.map +1 -0
  962. package/dist/services/credentials/oauth2.service.cjs +252 -0
  963. package/dist/services/credentials/oauth2.service.cjs.map +1 -0
  964. package/dist/services/credentials/oauth2.service.d.cts +132 -0
  965. package/dist/services/credentials/oauth2.service.d.cts.map +1 -0
  966. package/dist/services/credentials/oauth2.service.d.ts +132 -0
  967. package/dist/services/credentials/oauth2.service.d.ts.map +1 -0
  968. package/dist/services/credentials/oauth2.service.js +251 -0
  969. package/dist/services/credentials/oauth2.service.js.map +1 -0
  970. package/dist/services/database/database.service.cjs +469 -0
  971. package/dist/services/database/database.service.cjs.map +1 -0
  972. package/dist/services/database/database.service.d.cts +162 -0
  973. package/dist/services/database/database.service.d.cts.map +1 -0
  974. package/dist/services/database/database.service.d.ts +162 -0
  975. package/dist/services/database/database.service.d.ts.map +1 -0
  976. package/dist/services/database/database.service.js +469 -0
  977. package/dist/services/database/database.service.js.map +1 -0
  978. package/dist/services/execution-event-bus.cjs +80 -0
  979. package/dist/services/execution-event-bus.cjs.map +1 -0
  980. package/dist/services/execution-event-bus.d.cts +57 -0
  981. package/dist/services/execution-event-bus.d.cts.map +1 -0
  982. package/dist/services/execution-event-bus.d.ts +57 -0
  983. package/dist/services/execution-event-bus.d.ts.map +1 -0
  984. package/dist/services/execution-event-bus.js +77 -0
  985. package/dist/services/execution-event-bus.js.map +1 -0
  986. package/dist/services/flow-orchestration/flow-run-coordinator.cjs +499 -0
  987. package/dist/services/flow-orchestration/flow-run-coordinator.cjs.map +1 -0
  988. package/dist/services/flow-orchestration/flow-run-coordinator.js +499 -0
  989. package/dist/services/flow-orchestration/flow-run-coordinator.js.map +1 -0
  990. package/dist/services/flow-orchestration/node-execution-coordinator.cjs +657 -0
  991. package/dist/services/flow-orchestration/node-execution-coordinator.cjs.map +1 -0
  992. package/dist/services/flow-orchestration/node-execution-coordinator.js +657 -0
  993. package/dist/services/flow-orchestration/node-execution-coordinator.js.map +1 -0
  994. package/dist/services/flow-orchestration.service.cjs +493 -0
  995. package/dist/services/flow-orchestration.service.cjs.map +1 -0
  996. package/dist/services/flow-orchestration.service.d.cts +149 -0
  997. package/dist/services/flow-orchestration.service.d.cts.map +1 -0
  998. package/dist/services/flow-orchestration.service.d.ts +149 -0
  999. package/dist/services/flow-orchestration.service.d.ts.map +1 -0
  1000. package/dist/services/flow-orchestration.service.js +493 -0
  1001. package/dist/services/flow-orchestration.service.js.map +1 -0
  1002. package/dist/services/flow-runs/flow-runs.model.cjs +403 -0
  1003. package/dist/services/flow-runs/flow-runs.model.cjs.map +1 -0
  1004. package/dist/services/flow-runs/flow-runs.model.d.cts +113 -0
  1005. package/dist/services/flow-runs/flow-runs.model.d.cts.map +1 -0
  1006. package/dist/services/flow-runs/flow-runs.model.d.ts +113 -0
  1007. package/dist/services/flow-runs/flow-runs.model.d.ts.map +1 -0
  1008. package/dist/services/flow-runs/flow-runs.model.js +403 -0
  1009. package/dist/services/flow-runs/flow-runs.model.js.map +1 -0
  1010. package/dist/services/flow-runs/flow-runs.service.cjs +273 -0
  1011. package/dist/services/flow-runs/flow-runs.service.cjs.map +1 -0
  1012. package/dist/services/flow-runs/flow-runs.service.d.cts +129 -0
  1013. package/dist/services/flow-runs/flow-runs.service.d.cts.map +1 -0
  1014. package/dist/services/flow-runs/flow-runs.service.d.ts +129 -0
  1015. package/dist/services/flow-runs/flow-runs.service.d.ts.map +1 -0
  1016. package/dist/services/flow-runs/flow-runs.service.js +273 -0
  1017. package/dist/services/flow-runs/flow-runs.service.js.map +1 -0
  1018. package/dist/services/flow-validator.cjs +149 -0
  1019. package/dist/services/flow-validator.cjs.map +1 -0
  1020. package/dist/services/flow-validator.js +149 -0
  1021. package/dist/services/flow-validator.js.map +1 -0
  1022. package/dist/services/flow-versions/flow-versions.model.cjs +231 -0
  1023. package/dist/services/flow-versions/flow-versions.model.cjs.map +1 -0
  1024. package/dist/services/flow-versions/flow-versions.model.d.cts +55 -0
  1025. package/dist/services/flow-versions/flow-versions.model.d.cts.map +1 -0
  1026. package/dist/services/flow-versions/flow-versions.model.d.ts +55 -0
  1027. package/dist/services/flow-versions/flow-versions.model.d.ts.map +1 -0
  1028. package/dist/services/flow-versions/flow-versions.model.js +231 -0
  1029. package/dist/services/flow-versions/flow-versions.model.js.map +1 -0
  1030. package/dist/services/flow-versions/flow-versions.service.cjs +72 -0
  1031. package/dist/services/flow-versions/flow-versions.service.cjs.map +1 -0
  1032. package/dist/services/flow-versions/flow-versions.service.d.cts +63 -0
  1033. package/dist/services/flow-versions/flow-versions.service.d.cts.map +1 -0
  1034. package/dist/services/flow-versions/flow-versions.service.d.ts +63 -0
  1035. package/dist/services/flow-versions/flow-versions.service.d.ts.map +1 -0
  1036. package/dist/services/flow-versions/flow-versions.service.js +72 -0
  1037. package/dist/services/flow-versions/flow-versions.service.js.map +1 -0
  1038. package/dist/services/flow-versions/schemas-fresh.cjs +90 -0
  1039. package/dist/services/flow-versions/schemas-fresh.cjs.map +1 -0
  1040. package/dist/services/flow-versions/schemas-fresh.d.cts +201 -0
  1041. package/dist/services/flow-versions/schemas-fresh.d.cts.map +1 -0
  1042. package/dist/services/flow-versions/schemas-fresh.d.ts +201 -0
  1043. package/dist/services/flow-versions/schemas-fresh.d.ts.map +1 -0
  1044. package/dist/services/flow-versions/schemas-fresh.js +85 -0
  1045. package/dist/services/flow-versions/schemas-fresh.js.map +1 -0
  1046. package/dist/services/flows/flows.model.cjs +273 -0
  1047. package/dist/services/flows/flows.model.cjs.map +1 -0
  1048. package/dist/services/flows/flows.model.d.cts +105 -0
  1049. package/dist/services/flows/flows.model.d.cts.map +1 -0
  1050. package/dist/services/flows/flows.model.d.ts +105 -0
  1051. package/dist/services/flows/flows.model.d.ts.map +1 -0
  1052. package/dist/services/flows/flows.model.js +273 -0
  1053. package/dist/services/flows/flows.model.js.map +1 -0
  1054. package/dist/services/flows/flows.service.cjs +134 -0
  1055. package/dist/services/flows/flows.service.cjs.map +1 -0
  1056. package/dist/services/flows/flows.service.d.cts +105 -0
  1057. package/dist/services/flows/flows.service.d.cts.map +1 -0
  1058. package/dist/services/flows/flows.service.d.ts +105 -0
  1059. package/dist/services/flows/flows.service.d.ts.map +1 -0
  1060. package/dist/services/flows/flows.service.js +134 -0
  1061. package/dist/services/flows/flows.service.js.map +1 -0
  1062. package/dist/services/graph.service.cjs +375 -0
  1063. package/dist/services/graph.service.cjs.map +1 -0
  1064. package/dist/services/graph.service.d.cts +90 -0
  1065. package/dist/services/graph.service.d.cts.map +1 -0
  1066. package/dist/services/graph.service.d.ts +90 -0
  1067. package/dist/services/graph.service.d.ts.map +1 -0
  1068. package/dist/services/graph.service.js +375 -0
  1069. package/dist/services/graph.service.js.map +1 -0
  1070. package/dist/services/node-data.service.cjs +232 -0
  1071. package/dist/services/node-data.service.cjs.map +1 -0
  1072. package/dist/services/node-data.service.d.cts +119 -0
  1073. package/dist/services/node-data.service.d.cts.map +1 -0
  1074. package/dist/services/node-data.service.d.ts +119 -0
  1075. package/dist/services/node-data.service.d.ts.map +1 -0
  1076. package/dist/services/node-data.service.js +230 -0
  1077. package/dist/services/node-data.service.js.map +1 -0
  1078. package/dist/services/node-executions/node-execution.service.cjs +236 -0
  1079. package/dist/services/node-executions/node-execution.service.cjs.map +1 -0
  1080. package/dist/services/node-executions/node-execution.service.d.cts +126 -0
  1081. package/dist/services/node-executions/node-execution.service.d.cts.map +1 -0
  1082. package/dist/services/node-executions/node-execution.service.d.ts +126 -0
  1083. package/dist/services/node-executions/node-execution.service.d.ts.map +1 -0
  1084. package/dist/services/node-executions/node-execution.service.js +236 -0
  1085. package/dist/services/node-executions/node-execution.service.js.map +1 -0
  1086. package/dist/services/node-executions/node-executions.model.cjs +300 -0
  1087. package/dist/services/node-executions/node-executions.model.cjs.map +1 -0
  1088. package/dist/services/node-executions/node-executions.model.d.cts +102 -0
  1089. package/dist/services/node-executions/node-executions.model.d.cts.map +1 -0
  1090. package/dist/services/node-executions/node-executions.model.d.ts +102 -0
  1091. package/dist/services/node-executions/node-executions.model.d.ts.map +1 -0
  1092. package/dist/services/node-executions/node-executions.model.js +300 -0
  1093. package/dist/services/node-executions/node-executions.model.js.map +1 -0
  1094. package/dist/services/plugin-manager.cjs +205 -0
  1095. package/dist/services/plugin-manager.cjs.map +1 -0
  1096. package/dist/services/plugin-manager.js +205 -0
  1097. package/dist/services/plugin-manager.js.map +1 -0
  1098. package/dist/services/react-flow-renderer.service.cjs +236 -0
  1099. package/dist/services/react-flow-renderer.service.cjs.map +1 -0
  1100. package/dist/services/react-flow-renderer.service.d.cts +149 -0
  1101. package/dist/services/react-flow-renderer.service.d.cts.map +1 -0
  1102. package/dist/services/react-flow-renderer.service.d.ts +149 -0
  1103. package/dist/services/react-flow-renderer.service.d.ts.map +1 -0
  1104. package/dist/services/react-flow-renderer.service.js +235 -0
  1105. package/dist/services/react-flow-renderer.service.js.map +1 -0
  1106. package/dist/services/service-factory.cjs +301 -0
  1107. package/dist/services/service-factory.cjs.map +1 -0
  1108. package/dist/services/service-factory.d.cts +172 -0
  1109. package/dist/services/service-factory.d.cts.map +1 -0
  1110. package/dist/services/service-factory.d.ts +172 -0
  1111. package/dist/services/service-factory.d.ts.map +1 -0
  1112. package/dist/services/service-factory.js +301 -0
  1113. package/dist/services/service-factory.js.map +1 -0
  1114. package/dist/services/templating/index.cjs +2 -0
  1115. package/dist/services/templating/index.d.ts +2 -0
  1116. package/dist/services/templating/index.js +3 -0
  1117. package/dist/services/templating/js-expression.service.cjs +148 -0
  1118. package/dist/services/templating/js-expression.service.cjs.map +1 -0
  1119. package/dist/services/templating/js-expression.service.d.cts +61 -0
  1120. package/dist/services/templating/js-expression.service.d.cts.map +1 -0
  1121. package/dist/services/templating/js-expression.service.d.ts +60 -0
  1122. package/dist/services/templating/js-expression.service.d.ts.map +1 -0
  1123. package/dist/services/templating/js-expression.service.js +143 -0
  1124. package/dist/services/templating/js-expression.service.js.map +1 -0
  1125. package/dist/services/templating/template.service.cjs +182 -0
  1126. package/dist/services/templating/template.service.cjs.map +1 -0
  1127. package/dist/services/templating/template.service.d.cts +62 -0
  1128. package/dist/services/templating/template.service.d.cts.map +1 -0
  1129. package/dist/services/templating/template.service.d.ts +62 -0
  1130. package/dist/services/templating/template.service.d.ts.map +1 -0
  1131. package/dist/services/templating/template.service.js +180 -0
  1132. package/dist/services/templating/template.service.js.map +1 -0
  1133. package/dist/services/triggers/cron-scheduler.service.cjs +141 -0
  1134. package/dist/services/triggers/cron-scheduler.service.cjs.map +1 -0
  1135. package/dist/services/triggers/cron-scheduler.service.d.cts +36 -0
  1136. package/dist/services/triggers/cron-scheduler.service.d.cts.map +1 -0
  1137. package/dist/services/triggers/cron-scheduler.service.d.ts +36 -0
  1138. package/dist/services/triggers/cron-scheduler.service.d.ts.map +1 -0
  1139. package/dist/services/triggers/cron-scheduler.service.js +140 -0
  1140. package/dist/services/triggers/cron-scheduler.service.js.map +1 -0
  1141. package/dist/services/triggers/flow-triggers.model.cjs +241 -0
  1142. package/dist/services/triggers/flow-triggers.model.cjs.map +1 -0
  1143. package/dist/services/triggers/flow-triggers.model.d.cts +53 -0
  1144. package/dist/services/triggers/flow-triggers.model.d.cts.map +1 -0
  1145. package/dist/services/triggers/flow-triggers.model.d.ts +53 -0
  1146. package/dist/services/triggers/flow-triggers.model.d.ts.map +1 -0
  1147. package/dist/services/triggers/flow-triggers.model.js +241 -0
  1148. package/dist/services/triggers/flow-triggers.model.js.map +1 -0
  1149. package/dist/services/triggers/flow-triggers.service.cjs +218 -0
  1150. package/dist/services/triggers/flow-triggers.service.cjs.map +1 -0
  1151. package/dist/services/triggers/flow-triggers.service.d.cts +77 -0
  1152. package/dist/services/triggers/flow-triggers.service.d.cts.map +1 -0
  1153. package/dist/services/triggers/flow-triggers.service.d.ts +77 -0
  1154. package/dist/services/triggers/flow-triggers.service.d.ts.map +1 -0
  1155. package/dist/services/triggers/flow-triggers.service.js +217 -0
  1156. package/dist/services/triggers/flow-triggers.service.js.map +1 -0
  1157. package/dist/services/triggers/index.cjs +3 -0
  1158. package/dist/services/triggers/index.d.cts +4 -0
  1159. package/dist/services/triggers/index.d.ts +4 -0
  1160. package/dist/services/triggers/index.js +4 -0
  1161. package/dist/services/triggers/trigger.types.d.cts +63 -0
  1162. package/dist/services/triggers/trigger.types.d.cts.map +1 -0
  1163. package/dist/services/triggers/trigger.types.d.ts +63 -0
  1164. package/dist/services/triggers/trigger.types.d.ts.map +1 -0
  1165. package/dist/types/agent-tool.types.cjs +20 -0
  1166. package/dist/types/agent-tool.types.cjs.map +1 -0
  1167. package/dist/types/agent-tool.types.d.cts +211 -0
  1168. package/dist/types/agent-tool.types.d.cts.map +1 -0
  1169. package/dist/types/agent-tool.types.d.ts +211 -0
  1170. package/dist/types/agent-tool.types.d.ts.map +1 -0
  1171. package/dist/types/agent-tool.types.js +18 -0
  1172. package/dist/types/agent-tool.types.js.map +1 -0
  1173. package/dist/types/auth.types.cjs +76 -0
  1174. package/dist/types/auth.types.cjs.map +1 -0
  1175. package/dist/types/auth.types.d.cts +235 -0
  1176. package/dist/types/auth.types.d.cts.map +1 -0
  1177. package/dist/types/auth.types.d.ts +235 -0
  1178. package/dist/types/auth.types.d.ts.map +1 -0
  1179. package/dist/types/auth.types.js +75 -0
  1180. package/dist/types/auth.types.js.map +1 -0
  1181. package/dist/types/base.cjs +25 -0
  1182. package/dist/types/base.cjs.map +1 -0
  1183. package/dist/types/base.d.cts +21 -0
  1184. package/dist/types/base.d.cts.map +1 -0
  1185. package/dist/types/base.d.ts +21 -0
  1186. package/dist/types/base.d.ts.map +1 -0
  1187. package/dist/types/base.js +24 -0
  1188. package/dist/types/base.js.map +1 -0
  1189. package/dist/types/common/errors.types.cjs +46 -0
  1190. package/dist/types/common/errors.types.cjs.map +1 -0
  1191. package/dist/types/common/errors.types.js +44 -0
  1192. package/dist/types/common/errors.types.js.map +1 -0
  1193. package/dist/types/graph-node-types.cjs +46 -0
  1194. package/dist/types/graph-node-types.cjs.map +1 -0
  1195. package/dist/types/graph-node-types.d.cts +32 -0
  1196. package/dist/types/graph-node-types.d.cts.map +1 -0
  1197. package/dist/types/graph-node-types.d.ts +32 -0
  1198. package/dist/types/graph-node-types.d.ts.map +1 -0
  1199. package/dist/types/graph-node-types.js +45 -0
  1200. package/dist/types/graph-node-types.js.map +1 -0
  1201. package/dist/types/node-config-update.types.d.cts +33 -0
  1202. package/dist/types/node-config-update.types.d.cts.map +1 -0
  1203. package/dist/types/node-config-update.types.d.ts +33 -0
  1204. package/dist/types/node-config-update.types.d.ts.map +1 -0
  1205. package/dist/types/node-definition.types.d.cts +88 -0
  1206. package/dist/types/node-definition.types.d.cts.map +1 -0
  1207. package/dist/types/node-definition.types.d.ts +88 -0
  1208. package/dist/types/node-definition.types.d.ts.map +1 -0
  1209. package/dist/types/node-execution.types.d.cts +39 -0
  1210. package/dist/types/node-execution.types.d.cts.map +1 -0
  1211. package/dist/types/node-execution.types.d.ts +39 -0
  1212. package/dist/types/node-execution.types.d.ts.map +1 -0
  1213. package/dist/types/node-io-types.cjs +19 -0
  1214. package/dist/types/node-io-types.cjs.map +1 -0
  1215. package/dist/types/node-io-types.d.cts +65 -0
  1216. package/dist/types/node-io-types.d.cts.map +1 -0
  1217. package/dist/types/node-io-types.d.ts +65 -0
  1218. package/dist/types/node-io-types.d.ts.map +1 -0
  1219. package/dist/types/node-io-types.js +18 -0
  1220. package/dist/types/node-io-types.js.map +1 -0
  1221. package/dist/types/node-output-schemas.cjs +51 -0
  1222. package/dist/types/node-output-schemas.cjs.map +1 -0
  1223. package/dist/types/node-output-schemas.js +50 -0
  1224. package/dist/types/node-output-schemas.js.map +1 -0
  1225. package/dist/types/plugin.types.d.cts +654 -0
  1226. package/dist/types/plugin.types.d.cts.map +1 -0
  1227. package/dist/types/plugin.types.d.ts +654 -0
  1228. package/dist/types/plugin.types.d.ts.map +1 -0
  1229. package/dist/types/schemas/flow/create-flow-version.schema.cjs +1 -0
  1230. package/dist/types/schemas/flow/create-flow-version.schema.d.ts +1 -0
  1231. package/dist/types/schemas/flow/create-flow-version.schema.js +2 -0
  1232. package/dist/types/schemas/flow/create-flow.schema.cjs +9 -0
  1233. package/dist/types/schemas/flow/create-flow.schema.cjs.map +1 -0
  1234. package/dist/types/schemas/flow/create-flow.schema.d.cts +14 -0
  1235. package/dist/types/schemas/flow/create-flow.schema.d.cts.map +1 -0
  1236. package/dist/types/schemas/flow/create-flow.schema.d.ts +14 -0
  1237. package/dist/types/schemas/flow/create-flow.schema.d.ts.map +1 -0
  1238. package/dist/types/schemas/flow/create-flow.schema.js +10 -0
  1239. package/dist/types/schemas/flow/create-flow.schema.js.map +1 -0
  1240. package/dist/types/schemas/flow/delete-flow.schema.cjs +11 -0
  1241. package/dist/types/schemas/flow/delete-flow.schema.cjs.map +1 -0
  1242. package/dist/types/schemas/flow/delete-flow.schema.d.ts +1 -0
  1243. package/dist/types/schemas/flow/delete-flow.schema.js +11 -0
  1244. package/dist/types/schemas/flow/delete-flow.schema.js.map +1 -0
  1245. package/dist/types/schemas/flow/flow-executions.schema.cjs +36 -0
  1246. package/dist/types/schemas/flow/flow-executions.schema.cjs.map +1 -0
  1247. package/dist/types/schemas/flow/flow-executions.schema.d.ts +1 -0
  1248. package/dist/types/schemas/flow/flow-executions.schema.js +35 -0
  1249. package/dist/types/schemas/flow/flow-executions.schema.js.map +1 -0
  1250. package/dist/types/schemas/flow/get-flow-by-id-response.schema.cjs +7 -0
  1251. package/dist/types/schemas/flow/get-flow-by-id-response.schema.cjs.map +1 -0
  1252. package/dist/types/schemas/flow/get-flow-by-id-response.schema.d.ts +1 -0
  1253. package/dist/types/schemas/flow/get-flow-by-id-response.schema.js +7 -0
  1254. package/dist/types/schemas/flow/get-flow-by-id-response.schema.js.map +1 -0
  1255. package/dist/types/schemas/flow/get-flow-versions-response.schema.cjs +1 -0
  1256. package/dist/types/schemas/flow/get-flow-versions-response.schema.d.ts +1 -0
  1257. package/dist/types/schemas/flow/get-flow-versions-response.schema.js +2 -0
  1258. package/dist/types/schemas/flow/get-flows-response.schema.cjs +6 -0
  1259. package/dist/types/schemas/flow/get-flows-response.schema.cjs.map +1 -0
  1260. package/dist/types/schemas/flow/get-flows-response.schema.d.ts +1 -0
  1261. package/dist/types/schemas/flow/get-flows-response.schema.js +7 -0
  1262. package/dist/types/schemas/flow/get-flows-response.schema.js.map +1 -0
  1263. package/dist/types/schemas/flow/index.cjs +9 -0
  1264. package/dist/types/schemas/flow/index.d.ts +1 -0
  1265. package/dist/types/schemas/flow/index.js +10 -0
  1266. package/dist/types/schemas/flow/update-flow.schema.cjs +1 -0
  1267. package/dist/types/schemas/flow/update-flow.schema.d.ts +1 -0
  1268. package/dist/types/schemas/flow/update-flow.schema.js +2 -0
  1269. package/dist/types/schemas/flow/validate-flow.schema.cjs +19 -0
  1270. package/dist/types/schemas/flow/validate-flow.schema.cjs.map +1 -0
  1271. package/dist/types/schemas/flow/validate-flow.schema.d.ts +1 -0
  1272. package/dist/types/schemas/flow/validate-flow.schema.js +19 -0
  1273. package/dist/types/schemas/flow/validate-flow.schema.js.map +1 -0
  1274. package/dist/types/schemas/index.cjs +3 -0
  1275. package/dist/types/schemas/index.d.ts +2 -0
  1276. package/dist/types/schemas/index.js +4 -0
  1277. package/dist/types/schemas/pagination-sort-filter.cjs +56 -0
  1278. package/dist/types/schemas/pagination-sort-filter.cjs.map +1 -0
  1279. package/dist/types/schemas/pagination-sort-filter.d.cts +38 -0
  1280. package/dist/types/schemas/pagination-sort-filter.d.cts.map +1 -0
  1281. package/dist/types/schemas/pagination-sort-filter.d.ts +38 -0
  1282. package/dist/types/schemas/pagination-sort-filter.d.ts.map +1 -0
  1283. package/dist/types/schemas/pagination-sort-filter.js +50 -0
  1284. package/dist/types/schemas/pagination-sort-filter.js.map +1 -0
  1285. package/dist/types/schemas-fresh/invect-config.cjs +181 -0
  1286. package/dist/types/schemas-fresh/invect-config.cjs.map +1 -0
  1287. package/dist/types/schemas-fresh/invect-config.d.cts +207 -0
  1288. package/dist/types/schemas-fresh/invect-config.d.cts.map +1 -0
  1289. package/dist/types/schemas-fresh/invect-config.d.ts +207 -0
  1290. package/dist/types/schemas-fresh/invect-config.d.ts.map +1 -0
  1291. package/dist/types/schemas-fresh/invect-config.js +174 -0
  1292. package/dist/types/schemas-fresh/invect-config.js.map +1 -0
  1293. package/dist/types/validation/common.schemas.cjs +41 -0
  1294. package/dist/types/validation/common.schemas.cjs.map +1 -0
  1295. package/dist/types/validation/common.schemas.js +39 -0
  1296. package/dist/types/validation/common.schemas.js.map +1 -0
  1297. package/dist/types/validation/flow.schemas.cjs +49 -0
  1298. package/dist/types/validation/flow.schemas.cjs.map +1 -0
  1299. package/dist/types/validation/flow.schemas.js +46 -0
  1300. package/dist/types/validation/flow.schemas.js.map +1 -0
  1301. package/dist/types/validation.cjs +49 -0
  1302. package/dist/types/validation.cjs.map +1 -0
  1303. package/dist/types/validation.d.cts +49 -0
  1304. package/dist/types/validation.d.cts.map +1 -0
  1305. package/dist/types/validation.d.ts +49 -0
  1306. package/dist/types/validation.d.ts.map +1 -0
  1307. package/dist/types/validation.js +48 -0
  1308. package/dist/types/validation.js.map +1 -0
  1309. package/dist/types-export.cjs +11 -0
  1310. package/dist/types-export.d.cts +25 -0
  1311. package/dist/types-export.d.ts +25 -0
  1312. package/dist/types-export.js +5 -0
  1313. package/dist/types-fresh.cjs +9 -0
  1314. package/dist/types-fresh.cjs.map +1 -0
  1315. package/dist/types-fresh.d.cts +129 -0
  1316. package/dist/types-fresh.d.cts.map +1 -0
  1317. package/dist/types-fresh.d.ts +129 -0
  1318. package/dist/types-fresh.d.ts.map +1 -0
  1319. package/dist/types-fresh.js +8 -0
  1320. package/dist/types-fresh.js.map +1 -0
  1321. package/dist/utils/id-generator.cjs +34 -0
  1322. package/dist/utils/id-generator.cjs.map +1 -0
  1323. package/dist/utils/id-generator.js +34 -0
  1324. package/dist/utils/id-generator.js.map +1 -0
  1325. package/dist/utils/logger.cjs +285 -0
  1326. package/dist/utils/logger.cjs.map +1 -0
  1327. package/dist/utils/logger.d.cts +161 -0
  1328. package/dist/utils/logger.d.cts.map +1 -0
  1329. package/dist/utils/logger.d.ts +160 -0
  1330. package/dist/utils/logger.d.ts.map +1 -0
  1331. package/dist/utils/logger.js +282 -0
  1332. package/dist/utils/logger.js.map +1 -0
  1333. package/dist/utils/node-slug.cjs +13 -0
  1334. package/dist/utils/node-slug.cjs.map +1 -0
  1335. package/dist/utils/node-slug.d.cts +8 -0
  1336. package/dist/utils/node-slug.d.cts.map +1 -0
  1337. package/dist/utils/node-slug.d.ts +8 -0
  1338. package/dist/utils/node-slug.d.ts.map +1 -0
  1339. package/dist/utils/node-slug.js +13 -0
  1340. package/dist/utils/node-slug.js.map +1 -0
  1341. package/dist/utils/provider-detection.cjs +72 -0
  1342. package/dist/utils/provider-detection.cjs.map +1 -0
  1343. package/dist/utils/provider-detection.js +72 -0
  1344. package/dist/utils/provider-detection.js.map +1 -0
  1345. package/dist/utils/url-safe-id.cjs +52 -0
  1346. package/dist/utils/url-safe-id.cjs.map +1 -0
  1347. package/dist/utils/url-safe-id.js +52 -0
  1348. package/dist/utils/url-safe-id.js.map +1 -0
  1349. package/package.json +121 -0
@@ -0,0 +1,499 @@
1
+ const require_errors_types = require("../../types/common/errors.types.cjs");
2
+ const require_base = require("../../types/base.cjs");
3
+ const require_ai_types = require("../ai/ai-types.cjs");
4
+ require("../ai/base-client.cjs");
5
+ const require_graph_node_types = require("../../types/graph-node-types.cjs");
6
+ require("../../types-fresh.cjs");
7
+ const require_graph_service = require("../graph.service.cjs");
8
+ //#region src/services/flow-orchestration/flow-run-coordinator.ts
9
+ /**
10
+ * Coordinates full flow run execution including batch pauses and resumption.
11
+ */
12
+ var FlowRunCoordinator = class {
13
+ /** Active heartbeat timers keyed by flowRunId */
14
+ heartbeatTimers = /* @__PURE__ */ new Map();
15
+ constructor(deps) {
16
+ this.deps = deps;
17
+ }
18
+ /**
19
+ * Start a periodic heartbeat for a flow run.
20
+ * The first heartbeat is written immediately.
21
+ */
22
+ startHeartbeat(flowRunId) {
23
+ const { heartbeatIntervalMs, flowRunsService, logger } = this.deps;
24
+ if (!heartbeatIntervalMs || heartbeatIntervalMs <= 0) return;
25
+ flowRunsService.updateHeartbeat(flowRunId).catch((_err) => {});
26
+ const timer = setInterval(() => {
27
+ flowRunsService.updateHeartbeat(flowRunId).catch((err) => {
28
+ logger.debug("Heartbeat write failed (non-fatal)", {
29
+ flowRunId,
30
+ error: String(err)
31
+ });
32
+ });
33
+ }, heartbeatIntervalMs);
34
+ this.heartbeatTimers.set(flowRunId, timer);
35
+ }
36
+ /** Stop the heartbeat timer for a flow run. */
37
+ stopHeartbeat(flowRunId) {
38
+ const timer = this.heartbeatTimers.get(flowRunId);
39
+ if (timer) {
40
+ clearInterval(timer);
41
+ this.heartbeatTimers.delete(flowRunId);
42
+ }
43
+ }
44
+ /** Stop all active heartbeat timers (used during shutdown). */
45
+ stopAllHeartbeats() {
46
+ for (const [_id, timer] of this.heartbeatTimers) clearInterval(timer);
47
+ this.heartbeatTimers.clear();
48
+ }
49
+ async executeFlowDefinition(execution, definition, flowInputs, useBatchProcessing) {
50
+ let mutableFlowInputs = flowInputs;
51
+ const { logger, nodeExecutionCoordinator } = this.deps;
52
+ logger.debug("Executing flow definition", { flowRunId: execution.id });
53
+ await this.markExecutionRunning(execution.id);
54
+ if (this.deps.pluginHookRunner) {
55
+ const hookResult = await this.deps.pluginHookRunner.runBeforeFlowRun({
56
+ flowId: execution.flowId,
57
+ flowRunId: execution.id,
58
+ flowVersion: execution.flowVersion,
59
+ inputs: mutableFlowInputs
60
+ });
61
+ if (hookResult.cancelled) {
62
+ logger.info("Flow run cancelled by plugin hook", {
63
+ flowRunId: execution.id,
64
+ reason: hookResult.reason
65
+ });
66
+ await this.markExecutionFailed(execution.id, hookResult.reason || "Cancelled by plugin");
67
+ const traces = await this.deps.nodeExecutionService.listNodeExecutionsByFlowRunId(execution.id);
68
+ return {
69
+ flowRunId: execution.id,
70
+ status: require_base.FlowRunStatus.FAILED,
71
+ inputs: execution.inputs,
72
+ outputs: {},
73
+ error: hookResult.reason || "Cancelled by plugin",
74
+ startedAt: typeof execution.startedAt === "string" ? new Date(execution.startedAt) : execution.startedAt,
75
+ completedAt: /* @__PURE__ */ new Date(),
76
+ duration: 0,
77
+ traces
78
+ };
79
+ }
80
+ if (hookResult.inputs) mutableFlowInputs = hookResult.inputs;
81
+ }
82
+ const { nodes, edges } = definition;
83
+ const nodeMap = new Map(nodes.map((node) => [node.id, node]));
84
+ const executionOrder = require_graph_service.GraphService.topologicalSort(nodes, edges);
85
+ logger.debug("Flow execution order determined", {
86
+ flowRunId: execution.id,
87
+ nodeCount: nodes.length,
88
+ order: executionOrder
89
+ });
90
+ const nodeExecutions = [];
91
+ const nodeOutputs = /* @__PURE__ */ new Map();
92
+ const skippedNodeIds = /* @__PURE__ */ new Set();
93
+ const batchPendingNodeIds = /* @__PURE__ */ new Set();
94
+ let hasFailure = false;
95
+ let hasBatchSubmission = false;
96
+ for (const nodeId of executionOrder) {
97
+ if (hasFailure || hasBatchSubmission) break;
98
+ const node = nodeMap.get(nodeId);
99
+ if (!node) {
100
+ logger.warn("Node not found in definition", {
101
+ flowRunId: execution.id,
102
+ nodeId
103
+ });
104
+ continue;
105
+ }
106
+ if (skippedNodeIds.has(nodeId)) {
107
+ logger.debug("Skipping node execution due to conditional branching", {
108
+ flowRunId: execution.id,
109
+ nodeId,
110
+ nodeType: node.type
111
+ });
112
+ continue;
113
+ }
114
+ const isTriggerNode = node.type.startsWith("trigger.");
115
+ const activeTriggerNodeId = mutableFlowInputs.__triggerNodeId;
116
+ if (isTriggerNode && activeTriggerNodeId && node.id !== activeTriggerNodeId) {
117
+ skippedNodeIds.add(nodeId);
118
+ this.deps.graphService.markDownstreamNodesAsSkipped(nodeId, edges, skippedNodeIds);
119
+ logger.debug("Skipping inactive trigger node and its branch", {
120
+ flowRunId: execution.id,
121
+ nodeId,
122
+ nodeType: node.type,
123
+ activeTriggerNodeId
124
+ });
125
+ continue;
126
+ }
127
+ const incomingEdges = edges.filter((edge) => edge.target === nodeId);
128
+ if (incomingEdges.some((edge) => batchPendingNodeIds.has(edge.source))) {
129
+ logger.debug("Skipping node execution due to batch-pending dependencies", {
130
+ flowRunId: execution.id,
131
+ nodeId,
132
+ nodeType: node.type,
133
+ batchPendingDependencies: incomingEdges.filter((edge) => batchPendingNodeIds.has(edge.source)).map((e) => e.source)
134
+ });
135
+ continue;
136
+ }
137
+ logger.debug("Node execution check", {
138
+ flowRunId: execution.id,
139
+ nodeId,
140
+ nodeType: node.type,
141
+ isSkipped: skippedNodeIds.has(nodeId),
142
+ skippedNodeIds: Array.from(skippedNodeIds),
143
+ skippedNodeCount: skippedNodeIds.size,
144
+ batchPendingNodeIds: Array.from(batchPendingNodeIds)
145
+ });
146
+ try {
147
+ const nodeInputs = nodeExecutionCoordinator.prepareNodeInputs(node, nodeOutputs, edges, nodeMap);
148
+ const incomingData = nodeExecutionCoordinator.buildIncomingDataObject(node, nodeOutputs, edges, nodeMap);
149
+ const trace = await nodeExecutionCoordinator.executeNode(execution.id, node, nodeInputs, mutableFlowInputs, definition, skippedNodeIds, useBatchProcessing, incomingData);
150
+ nodeExecutions.push(trace);
151
+ if (trace.status === require_base.NodeExecutionStatus.BATCH_SUBMITTED) {
152
+ logger.debug("Batch submission detected - pausing flow", {
153
+ flowRunId: execution.id,
154
+ nodeId: trace.nodeId
155
+ });
156
+ batchPendingNodeIds.add(nodeId);
157
+ hasBatchSubmission = true;
158
+ await this.pauseFlowForBatch(execution.id);
159
+ return this.buildPausedFlowResult(execution.id, nodeExecutions);
160
+ }
161
+ if (trace.status === require_base.NodeExecutionStatus.SUCCESS) {
162
+ if (trace.outputs) nodeOutputs.set(nodeId, trace.outputs);
163
+ } else if (trace.status === require_base.NodeExecutionStatus.FAILED) {
164
+ hasFailure = true;
165
+ logger.warn("Node execution failed, stopping flow", {
166
+ flowRunId: execution.id,
167
+ nodeId,
168
+ error: trace.error
169
+ });
170
+ break;
171
+ }
172
+ } catch (error) {
173
+ logger.error("Unexpected error during node execution", {
174
+ flowRunId: execution.id,
175
+ nodeId,
176
+ error
177
+ });
178
+ hasFailure = true;
179
+ break;
180
+ }
181
+ }
182
+ const success = !hasFailure;
183
+ const finalOutputs = this.collectFlowOutputs(definition, nodeOutputs);
184
+ if (success) await this.markExecutionSuccess(execution.id, finalOutputs);
185
+ else await this.markExecutionFailed(execution.id, "One or more nodes failed");
186
+ const updatedExecution = await this.deps.flowRunsService.getRunById(execution.id);
187
+ if (this.deps.pluginHookRunner) try {
188
+ await this.deps.pluginHookRunner.runAfterFlowRun({
189
+ flowId: execution.flowId,
190
+ flowRunId: execution.id,
191
+ flowVersion: execution.flowVersion,
192
+ inputs: mutableFlowInputs,
193
+ status: success ? "SUCCESS" : "FAILED",
194
+ outputs: finalOutputs,
195
+ error: success ? void 0 : "One or more nodes failed",
196
+ duration: updatedExecution.duration ?? void 0
197
+ });
198
+ } catch (hookError) {
199
+ logger.warn("afterFlowRun plugin hook error (non-fatal)", {
200
+ flowRunId: execution.id,
201
+ error: hookError instanceof Error ? hookError.message : String(hookError)
202
+ });
203
+ }
204
+ return {
205
+ flowRunId: execution.id,
206
+ status: success ? require_base.FlowRunStatus.SUCCESS : require_base.FlowRunStatus.FAILED,
207
+ inputs: execution.inputs,
208
+ outputs: finalOutputs,
209
+ startedAt: typeof updatedExecution.startedAt === "string" ? new Date(updatedExecution.startedAt) : updatedExecution.startedAt,
210
+ completedAt: updatedExecution.completedAt ? typeof updatedExecution.completedAt === "string" ? new Date(updatedExecution.completedAt) : updatedExecution.completedAt : void 0,
211
+ duration: updatedExecution.duration,
212
+ traces: nodeExecutions
213
+ };
214
+ }
215
+ async resumeFromBatchCompletion(flowRunId, completedBatchNodeId, batchResult, batchError) {
216
+ const { logger, nodeExecutionService, flowRunsService, flowsService } = this.deps;
217
+ logger.debug("Resuming flow from batch completion", {
218
+ flowRunId,
219
+ completedBatchNodeId,
220
+ hasError: !!batchError
221
+ });
222
+ if (batchError) {
223
+ await this.markExecutionFailed(flowRunId, `Batch processing failed: ${batchError}`);
224
+ const traces = await nodeExecutionService.listNodeExecutionsByFlowRunId(flowRunId);
225
+ return {
226
+ flowRunId,
227
+ status: require_base.FlowRunStatus.FAILED,
228
+ inputs: {},
229
+ outputs: {},
230
+ error: `Batch processing failed: ${batchError}`,
231
+ startedAt: /* @__PURE__ */ new Date(),
232
+ traces
233
+ };
234
+ }
235
+ const flowRun = await flowRunsService.getRunById(flowRunId);
236
+ const flow = await flowsService.getFlowById(flowRun.flowId);
237
+ if (!flow?.flowVersion?.invectDefinition) throw new require_errors_types.ValidationError("Flow definition not found for batch resume");
238
+ const definition = flow.flowVersion.invectDefinition;
239
+ await flowRunsService.updateRunStatus(flowRunId, require_base.FlowRunStatus.RUNNING);
240
+ return this.continueFlowRunFromBatch(flowRunId, definition, flowRun.inputs || {});
241
+ }
242
+ async continueFlowRunFromBatch(flowRunId, definition, flowInputs) {
243
+ const { logger, nodeExecutionCoordinator, nodeExecutionService, batchJobsService, flowRunsService } = this.deps;
244
+ const { nodes, edges } = definition;
245
+ const nodeMap = new Map(nodes.map((node) => [node.id, node]));
246
+ const executionOrder = require_graph_service.GraphService.topologicalSort(nodes, edges);
247
+ const existingNodeExecutions = await nodeExecutionService.listNodeExecutionsByFlowRunId(flowRunId);
248
+ const processedNodeIds = new Set(existingNodeExecutions.map((trace) => trace.nodeId));
249
+ const nodeOutputs = /* @__PURE__ */ new Map();
250
+ const skippedNodeIds = /* @__PURE__ */ new Set();
251
+ let hasFailure = false;
252
+ for (const nodeExecution of existingNodeExecutions) if (nodeExecution.status === require_base.NodeExecutionStatus.SUCCESS && nodeExecution.outputs) nodeOutputs.set(nodeExecution.nodeId, nodeExecution.outputs);
253
+ else if (nodeExecution.status === require_base.NodeExecutionStatus.SKIPPED) skippedNodeIds.add(nodeExecution.nodeId);
254
+ else if (nodeExecution.status === require_base.NodeExecutionStatus.BATCH_SUBMITTED) {
255
+ const batchJobs = await batchJobsService.getBatchJobsByExecutionAndNode(flowRunId, nodeExecution.nodeId);
256
+ for (const batchJob of batchJobs) if (batchJob.status === require_ai_types.BatchStatus.COMPLETED && batchJob.responseData) {
257
+ const batchResult = batchJob.responseData[0];
258
+ if (batchResult.status === require_ai_types.BatchStatus.COMPLETED) {
259
+ const updatedTrace = await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, require_base.NodeExecutionStatus.SUCCESS, { outputs: {
260
+ data: { variables: { output: batchResult.content } },
261
+ nodeType: require_graph_node_types.GraphNodeType.MODEL
262
+ } });
263
+ if (updatedTrace.outputs) nodeOutputs.set(nodeExecution.nodeId, updatedTrace.outputs);
264
+ } else if (batchResult.status === require_ai_types.BatchStatus.FAILED) {
265
+ await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, require_base.NodeExecutionStatus.FAILED, { error: batchResult.error || "Batch processing failed" });
266
+ hasFailure = true;
267
+ break;
268
+ } else if (batchResult.status === require_ai_types.BatchStatus.CANCELLED) {
269
+ await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, require_base.NodeExecutionStatus.FAILED, { error: batchResult.error || "Batch processing was cancelled" });
270
+ hasFailure = true;
271
+ break;
272
+ } else if (batchResult.status === require_ai_types.BatchStatus.SUBMITTED || batchResult.status === require_ai_types.BatchStatus.PROCESSING) continue;
273
+ else {
274
+ await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, require_base.NodeExecutionStatus.FAILED, { error: `Unknown batch status: ${batchResult.status}` });
275
+ hasFailure = true;
276
+ break;
277
+ }
278
+ }
279
+ }
280
+ const remainingNodes = executionOrder.filter((nodeId) => !processedNodeIds.has(nodeId) && !skippedNodeIds.has(nodeId));
281
+ logger.debug("Continuing execution after batch", {
282
+ flowRunId,
283
+ totalNodes: nodes.length,
284
+ processedNodes: processedNodeIds.size,
285
+ remainingNodes: remainingNodes.length
286
+ });
287
+ const newTraces = [];
288
+ for (const nodeId of remainingNodes) {
289
+ if (hasFailure) break;
290
+ const node = nodeMap.get(nodeId);
291
+ if (!node) continue;
292
+ const nodeInputs = nodeExecutionCoordinator.prepareNodeInputs(node, nodeOutputs, edges, nodeMap);
293
+ const incomingData = nodeExecutionCoordinator.buildIncomingDataObject(node, nodeOutputs, edges, nodeMap);
294
+ try {
295
+ const trace = await nodeExecutionCoordinator.executeNode(flowRunId, node, nodeInputs, flowInputs, definition, skippedNodeIds, true, incomingData);
296
+ newTraces.push(trace);
297
+ if (trace.status === require_base.NodeExecutionStatus.SUCCESS && trace.outputs) nodeOutputs.set(nodeId, trace.outputs);
298
+ else if (trace.status === require_base.NodeExecutionStatus.FAILED) hasFailure = true;
299
+ if (trace.status === require_base.NodeExecutionStatus.BATCH_SUBMITTED) {
300
+ await this.pauseFlowForBatch(flowRunId);
301
+ return this.buildPausedFlowResult(flowRunId, [...existingNodeExecutions, ...newTraces]);
302
+ }
303
+ } catch (error) {
304
+ hasFailure = true;
305
+ logger.error("Node execution failed during batch resume", {
306
+ flowRunId,
307
+ nodeId,
308
+ error: error instanceof Error ? error.message : String(error)
309
+ });
310
+ }
311
+ }
312
+ const finalOutputs = this.collectFlowOutputs(definition, nodeOutputs);
313
+ if (hasFailure) await this.markExecutionFailed(flowRunId, "One or more nodes failed during batch resume");
314
+ else await this.markExecutionSuccess(flowRunId, finalOutputs);
315
+ const updatedExecution = await flowRunsService.getRunById(flowRunId);
316
+ const allTraces = await nodeExecutionService.listNodeExecutionsByFlowRunId(flowRunId);
317
+ return {
318
+ flowRunId,
319
+ status: hasFailure ? require_base.FlowRunStatus.FAILED : require_base.FlowRunStatus.SUCCESS,
320
+ inputs: updatedExecution.inputs,
321
+ outputs: finalOutputs,
322
+ startedAt: typeof updatedExecution.startedAt === "string" ? new Date(updatedExecution.startedAt) : updatedExecution.startedAt,
323
+ completedAt: updatedExecution.completedAt ? typeof updatedExecution.completedAt === "string" ? new Date(updatedExecution.completedAt) : updatedExecution.completedAt : void 0,
324
+ duration: updatedExecution.duration,
325
+ traces: allTraces
326
+ };
327
+ }
328
+ collectFlowOutputs(_definition, nodeOutputs) {
329
+ const outputs = {};
330
+ for (const [nodeId, nodeOutput] of nodeOutputs) outputs[nodeId] = nodeOutput;
331
+ return outputs;
332
+ }
333
+ async pauseFlowForBatch(flowRunId) {
334
+ const { logger, flowRunsService } = this.deps;
335
+ this.stopHeartbeat(flowRunId);
336
+ logger.debug("Pausing flow for batch processing", { flowRunId });
337
+ await flowRunsService.updateRunStatus(flowRunId, require_base.FlowRunStatus.PAUSED_FOR_BATCH);
338
+ logger.debug("Flow paused for batch processing", { flowRunId });
339
+ }
340
+ async buildPausedFlowResult(flowRunId, traces) {
341
+ const execution = await this.deps.flowRunsService.getRunById(flowRunId);
342
+ return {
343
+ flowRunId: execution.id,
344
+ status: require_base.FlowRunStatus.PAUSED_FOR_BATCH,
345
+ inputs: execution.inputs,
346
+ outputs: {},
347
+ startedAt: typeof execution.startedAt === "string" ? new Date(execution.startedAt) : execution.startedAt,
348
+ traces
349
+ };
350
+ }
351
+ async markExecutionRunning(flowRunId) {
352
+ const { logger, flowRunsService } = this.deps;
353
+ logger.debug("Marking execution as running", { flowRunId });
354
+ await flowRunsService.updateRunStatus(flowRunId, require_base.FlowRunStatus.RUNNING);
355
+ this.startHeartbeat(flowRunId);
356
+ }
357
+ async markExecutionSuccess(flowRunId, outputs) {
358
+ const { logger, flowRunsService } = this.deps;
359
+ this.stopHeartbeat(flowRunId);
360
+ logger.debug("Marking execution as successful", { flowRunId });
361
+ await flowRunsService.updateRunStatus(flowRunId, require_base.FlowRunStatus.SUCCESS, { outputs });
362
+ }
363
+ async markExecutionFailed(flowRunId, error) {
364
+ const { logger, flowRunsService } = this.deps;
365
+ this.stopHeartbeat(flowRunId);
366
+ logger.debug("Marking execution as failed", {
367
+ flowRunId,
368
+ error
369
+ });
370
+ await flowRunsService.updateRunStatus(flowRunId, require_base.FlowRunStatus.FAILED, { error });
371
+ }
372
+ /**
373
+ * Execute a flow up to and including a specific target node.
374
+ * Only executes the upstream nodes required to produce output for the target node.
375
+ *
376
+ * @param execution - The flow run record
377
+ * @param definition - The flow definition
378
+ * @param targetNodeId - The node to execute up to (this node will also be executed)
379
+ * @param flowInputs - Flow-level inputs
380
+ * @param useBatchProcessing - Whether to use batch processing for AI nodes
381
+ */
382
+ async executeFlowToNode(execution, definition, targetNodeId, flowInputs, useBatchProcessing) {
383
+ const { logger, nodeExecutionCoordinator, graphService } = this.deps;
384
+ logger.debug("Executing flow to specific node", {
385
+ flowRunId: execution.id,
386
+ targetNodeId
387
+ });
388
+ await this.markExecutionRunning(execution.id);
389
+ const { nodes, edges } = definition;
390
+ const nodeMap = new Map(nodes.map((node) => [node.id, node]));
391
+ if (!nodeMap.get(targetNodeId)) throw new require_errors_types.ValidationError(`Target node not found: ${targetNodeId}`);
392
+ const executionPath = graphService.getExecutionPathToNode(targetNodeId, nodes, edges);
393
+ logger.debug("Flow execution path to target node", {
394
+ flowRunId: execution.id,
395
+ targetNodeId,
396
+ executionPath,
397
+ totalNodes: nodes.length,
398
+ nodesToExecute: executionPath.length
399
+ });
400
+ const nodeExecutions = [];
401
+ const nodeOutputs = /* @__PURE__ */ new Map();
402
+ const nodeErrors = {};
403
+ const skippedNodeIds = /* @__PURE__ */ new Set();
404
+ const batchPendingNodeIds = /* @__PURE__ */ new Set();
405
+ let hasFailure = false;
406
+ let hasBatchSubmission = false;
407
+ for (const nodeId of executionPath) {
408
+ if (hasFailure || hasBatchSubmission) break;
409
+ const node = nodeMap.get(nodeId);
410
+ if (!node) {
411
+ logger.warn("Node not found in definition", {
412
+ flowRunId: execution.id,
413
+ nodeId
414
+ });
415
+ continue;
416
+ }
417
+ if (skippedNodeIds.has(nodeId)) {
418
+ logger.debug("Skipping node execution due to conditional branching", {
419
+ flowRunId: execution.id,
420
+ nodeId,
421
+ nodeType: node.type
422
+ });
423
+ continue;
424
+ }
425
+ logger.debug("Processing node in partial execution", {
426
+ flowRunId: execution.id,
427
+ nodeId,
428
+ nodeType: node.type,
429
+ isTargetNode: nodeId === targetNodeId
430
+ });
431
+ try {
432
+ const nodeInputs = nodeExecutionCoordinator.prepareNodeInputs(node, nodeOutputs, edges, nodeMap);
433
+ const incomingData = nodeExecutionCoordinator.buildIncomingDataObject(node, nodeOutputs, edges, nodeMap);
434
+ const trace = await nodeExecutionCoordinator.executeNode(execution.id, node, nodeInputs, flowInputs, definition, skippedNodeIds, useBatchProcessing, incomingData);
435
+ nodeExecutions.push(trace);
436
+ if (trace.status === require_base.NodeExecutionStatus.BATCH_SUBMITTED) {
437
+ logger.debug("Batch submission detected - pausing partial flow", {
438
+ flowRunId: execution.id,
439
+ nodeId: trace.nodeId
440
+ });
441
+ batchPendingNodeIds.add(nodeId);
442
+ hasBatchSubmission = true;
443
+ await this.pauseFlowForBatch(execution.id);
444
+ return this.buildPausedFlowResult(execution.id, nodeExecutions);
445
+ }
446
+ if (trace.status === require_base.NodeExecutionStatus.SUCCESS) {
447
+ if (trace.outputs) nodeOutputs.set(nodeId, trace.outputs);
448
+ } else if (trace.status === require_base.NodeExecutionStatus.FAILED) {
449
+ hasFailure = true;
450
+ nodeErrors[nodeId] = trace.error || "Node execution failed";
451
+ logger.error("Node execution failed in partial execution", {
452
+ flowRunId: execution.id,
453
+ nodeId,
454
+ nodeType: node.type
455
+ });
456
+ }
457
+ if (node.type === require_graph_node_types.GraphNodeType.IF_ELSE && trace.status === require_base.NodeExecutionStatus.SUCCESS) {
458
+ const executedBranch = (trace.outputs?.data?.variables)?.executedBranch?.value;
459
+ if (executedBranch && typeof executedBranch === "string") {
460
+ const nonExecutedBranches = ["true_branch", "false_branch"].filter((b) => b !== executedBranch);
461
+ for (const branch of nonExecutedBranches) {
462
+ const branchEdges = edges.filter((e) => e.source === nodeId && e.sourceHandle === branch);
463
+ for (const edge of branchEdges) graphService.markDownstreamNodesAsSkipped(edge.target, edges, skippedNodeIds, true);
464
+ }
465
+ }
466
+ }
467
+ } catch (error) {
468
+ hasFailure = true;
469
+ nodeErrors[nodeId] = error instanceof Error ? error.message : String(error);
470
+ logger.error("Node execution threw an exception in partial execution", {
471
+ flowRunId: execution.id,
472
+ nodeId,
473
+ error: error instanceof Error ? error.message : String(error)
474
+ });
475
+ }
476
+ }
477
+ const success = !hasFailure;
478
+ const finalOutputs = {};
479
+ for (const [executedNodeId, output] of nodeOutputs.entries()) finalOutputs[executedNodeId] = output;
480
+ if (success) await this.markExecutionSuccess(execution.id, finalOutputs);
481
+ else await this.markExecutionFailed(execution.id, "One or more nodes failed");
482
+ const updatedExecution = await this.deps.flowRunsService.getRunById(execution.id);
483
+ return {
484
+ flowRunId: execution.id,
485
+ status: success ? require_base.FlowRunStatus.SUCCESS : require_base.FlowRunStatus.FAILED,
486
+ inputs: execution.inputs,
487
+ outputs: finalOutputs,
488
+ nodeErrors: Object.keys(nodeErrors).length > 0 ? nodeErrors : void 0,
489
+ startedAt: typeof updatedExecution.startedAt === "string" ? new Date(updatedExecution.startedAt) : updatedExecution.startedAt,
490
+ completedAt: updatedExecution.completedAt ? typeof updatedExecution.completedAt === "string" ? new Date(updatedExecution.completedAt) : updatedExecution.completedAt : void 0,
491
+ duration: updatedExecution.duration,
492
+ traces: nodeExecutions
493
+ };
494
+ }
495
+ };
496
+ //#endregion
497
+ exports.FlowRunCoordinator = FlowRunCoordinator;
498
+
499
+ //# sourceMappingURL=flow-run-coordinator.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flow-run-coordinator.cjs","names":["FlowRunStatus","GraphService","NodeExecutionStatus","ValidationError","BatchStatus","GraphNodeType"],"sources":["../../../src/services/flow-orchestration/flow-run-coordinator.ts"],"sourcesContent":["import { FlowRunStatus, NodeExecutionStatus } from 'src/types/base';\nimport { GraphNodeType } from 'src/types-fresh';\nimport { InvectDefinition, FlowNodeDefinitions } from '../flow-versions/schemas-fresh';\nimport type { FlowRun } from '../flow-runs/flow-runs.model';\nimport type { FlowRunResult } from '../flow-runs/flow-runs.service';\nimport type { FlowRunsService } from '../flow-runs/flow-runs.service';\nimport type { NodeExecution } from '../node-executions/node-executions.model';\nimport type { NodeExecutionService } from '../node-executions/node-execution.service';\nimport type { NodeOutput } from 'src/types/node-io-types';\nimport type { BatchJobsService } from '../batch-jobs/batch-jobs.service';\nimport type { FlowsService } from '../flows/flows.service';\nimport type { Logger } from 'src/types/schemas';\nimport type { PluginHookRunner } from 'src/types/plugin.types';\nimport { ValidationError } from 'src/types/common/errors.types';\nimport { GraphService } from '../graph.service';\nimport { BatchStatus } from '../ai/base-client';\nimport { NodeExecutionCoordinator } from './node-execution-coordinator';\n\nexport type FlowRunCoordinatorDeps = {\n logger: Logger;\n flowRunsService: FlowRunsService;\n nodeExecutionCoordinator: NodeExecutionCoordinator;\n graphService: GraphService;\n nodeExecutionService: NodeExecutionService;\n batchJobsService: BatchJobsService;\n flowsService: FlowsService;\n /** Interval in ms between heartbeat writes. 0 = disabled. */\n heartbeatIntervalMs: number;\n /** Plugin hook runner for lifecycle hooks (optional for backward compat). */\n pluginHookRunner?: PluginHookRunner;\n};\n\n/**\n * Coordinates full flow run execution including batch pauses and resumption.\n */\nexport class FlowRunCoordinator {\n /** Active heartbeat timers keyed by flowRunId */\n private heartbeatTimers = new Map<string, NodeJS.Timeout>();\n\n constructor(private readonly deps: FlowRunCoordinatorDeps) {}\n\n /**\n * Start a periodic heartbeat for a flow run.\n * The first heartbeat is written immediately.\n */\n private startHeartbeat(flowRunId: string): void {\n const { heartbeatIntervalMs, flowRunsService, logger } = this.deps;\n if (!heartbeatIntervalMs || heartbeatIntervalMs <= 0) {\n return;\n }\n\n // Write initial heartbeat\n flowRunsService.updateHeartbeat(flowRunId).catch((_err) => {\n // Intentionally swallowed — initial heartbeat failure is non-fatal\n });\n\n const timer = setInterval(() => {\n flowRunsService.updateHeartbeat(flowRunId).catch((err) => {\n logger.debug('Heartbeat write failed (non-fatal)', { flowRunId, error: String(err) });\n });\n }, heartbeatIntervalMs);\n\n this.heartbeatTimers.set(flowRunId, timer);\n }\n\n /** Stop the heartbeat timer for a flow run. */\n private stopHeartbeat(flowRunId: string): void {\n const timer = this.heartbeatTimers.get(flowRunId);\n if (timer) {\n clearInterval(timer);\n this.heartbeatTimers.delete(flowRunId);\n }\n }\n\n /** Stop all active heartbeat timers (used during shutdown). */\n stopAllHeartbeats(): void {\n for (const [_id, timer] of this.heartbeatTimers) {\n clearInterval(timer);\n }\n this.heartbeatTimers.clear();\n }\n\n async executeFlowDefinition(\n execution: FlowRun,\n definition: InvectDefinition,\n flowInputs: Record<string, unknown>,\n useBatchProcessing?: boolean,\n ): Promise<FlowRunResult> {\n // Allow plugins to mutate inputs via hooks\n let mutableFlowInputs = flowInputs;\n const { logger, nodeExecutionCoordinator } = this.deps;\n\n logger.debug('Executing flow definition', { flowRunId: execution.id });\n\n await this.markExecutionRunning(execution.id);\n\n // ── Plugin hook: beforeFlowRun ─────────────────────────────────────\n if (this.deps.pluginHookRunner) {\n const hookResult = await this.deps.pluginHookRunner.runBeforeFlowRun({\n flowId: execution.flowId,\n flowRunId: execution.id,\n flowVersion: execution.flowVersion,\n inputs: mutableFlowInputs,\n });\n\n if (hookResult.cancelled) {\n logger.info('Flow run cancelled by plugin hook', {\n flowRunId: execution.id,\n reason: hookResult.reason,\n });\n await this.markExecutionFailed(execution.id, hookResult.reason || 'Cancelled by plugin');\n const traces = await this.deps.nodeExecutionService.listNodeExecutionsByFlowRunId(\n execution.id,\n );\n return {\n flowRunId: execution.id,\n status: FlowRunStatus.FAILED,\n inputs: execution.inputs,\n outputs: {},\n error: hookResult.reason || 'Cancelled by plugin',\n startedAt:\n typeof execution.startedAt === 'string'\n ? new Date(execution.startedAt)\n : execution.startedAt,\n completedAt: new Date(),\n duration: 0,\n traces,\n };\n }\n\n // Allow plugins to modify inputs\n if (hookResult.inputs) {\n mutableFlowInputs = hookResult.inputs as Record<string, unknown>;\n }\n }\n\n const { nodes, edges } = definition;\n const nodeMap = new Map(nodes.map((node) => [node.id, node]));\n const executionOrder = GraphService.topologicalSort(nodes, edges);\n\n logger.debug('Flow execution order determined', {\n flowRunId: execution.id,\n nodeCount: nodes.length,\n order: executionOrder,\n });\n\n const nodeExecutions: NodeExecution[] = [];\n const nodeOutputs = new Map<FlowNodeDefinitions['id'], NodeOutput>();\n const skippedNodeIds = new Set<string>();\n const batchPendingNodeIds = new Set<string>();\n let hasFailure = false;\n let hasBatchSubmission = false;\n\n for (const nodeId of executionOrder) {\n if (hasFailure || hasBatchSubmission) {\n break;\n }\n\n const node = nodeMap.get(nodeId);\n if (!node) {\n logger.warn('Node not found in definition', { flowRunId: execution.id, nodeId });\n continue;\n }\n\n if (skippedNodeIds.has(nodeId)) {\n logger.debug('Skipping node execution due to conditional branching', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n });\n continue;\n }\n\n // D2: Skip inactive trigger nodes — when a flow is triggered by a specific\n // trigger node (webhook/cron), skip all other trigger nodes and their branches.\n // When activeTriggerNodeId is absent (manual run), all trigger nodes execute.\n const isTriggerNode = node.type.startsWith('trigger.');\n const activeTriggerNodeId = (mutableFlowInputs as Record<string, unknown>).__triggerNodeId as\n | string\n | undefined;\n\n if (isTriggerNode && activeTriggerNodeId && node.id !== activeTriggerNodeId) {\n skippedNodeIds.add(nodeId);\n this.deps.graphService.markDownstreamNodesAsSkipped(nodeId, edges, skippedNodeIds);\n logger.debug('Skipping inactive trigger node and its branch', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n activeTriggerNodeId,\n });\n continue;\n }\n\n const incomingEdges = edges.filter((edge) => edge.target === nodeId);\n const hasBatchPendingDependencies = incomingEdges.some((edge) =>\n batchPendingNodeIds.has(edge.source),\n );\n\n if (hasBatchPendingDependencies) {\n logger.debug('Skipping node execution due to batch-pending dependencies', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n batchPendingDependencies: incomingEdges\n .filter((edge) => batchPendingNodeIds.has(edge.source))\n .map((e) => e.source),\n });\n continue;\n }\n\n logger.debug('Node execution check', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n isSkipped: skippedNodeIds.has(nodeId),\n skippedNodeIds: Array.from(skippedNodeIds),\n skippedNodeCount: skippedNodeIds.size,\n batchPendingNodeIds: Array.from(batchPendingNodeIds),\n });\n\n try {\n const nodeInputs = nodeExecutionCoordinator.prepareNodeInputs(\n node,\n nodeOutputs,\n edges,\n nodeMap,\n );\n\n // Build incoming data object for template resolution\n const incomingData = nodeExecutionCoordinator.buildIncomingDataObject(\n node,\n nodeOutputs,\n edges,\n nodeMap,\n );\n\n const trace = await nodeExecutionCoordinator.executeNode(\n execution.id,\n node,\n nodeInputs,\n mutableFlowInputs,\n definition,\n skippedNodeIds,\n useBatchProcessing,\n incomingData,\n );\n nodeExecutions.push(trace);\n\n if (trace.status === NodeExecutionStatus.BATCH_SUBMITTED) {\n logger.debug('Batch submission detected - pausing flow', {\n flowRunId: execution.id,\n nodeId: trace.nodeId,\n });\n\n batchPendingNodeIds.add(nodeId);\n hasBatchSubmission = true;\n\n await this.pauseFlowForBatch(execution.id);\n return this.buildPausedFlowResult(execution.id, nodeExecutions);\n }\n\n if (trace.status === NodeExecutionStatus.SUCCESS) {\n if (trace.outputs) {\n nodeOutputs.set(nodeId, trace.outputs);\n }\n } else if (trace.status === NodeExecutionStatus.FAILED) {\n hasFailure = true;\n logger.warn('Node execution failed, stopping flow', {\n flowRunId: execution.id,\n nodeId,\n error: trace.error,\n });\n break;\n }\n } catch (error) {\n logger.error('Unexpected error during node execution', {\n flowRunId: execution.id,\n nodeId,\n error,\n });\n hasFailure = true;\n break;\n }\n }\n\n const success = !hasFailure;\n const finalOutputs = this.collectFlowOutputs(definition, nodeOutputs);\n\n if (success) {\n await this.markExecutionSuccess(execution.id, finalOutputs);\n } else {\n await this.markExecutionFailed(execution.id, 'One or more nodes failed');\n }\n\n const updatedExecution = await this.deps.flowRunsService.getRunById(execution.id);\n\n // ── Plugin hook: afterFlowRun ──────────────────────────────────────\n if (this.deps.pluginHookRunner) {\n try {\n await this.deps.pluginHookRunner.runAfterFlowRun({\n flowId: execution.flowId,\n flowRunId: execution.id,\n flowVersion: execution.flowVersion,\n inputs: mutableFlowInputs,\n status: success ? 'SUCCESS' : 'FAILED',\n outputs: finalOutputs as Record<string, unknown>,\n error: success ? undefined : 'One or more nodes failed',\n duration: updatedExecution.duration ?? undefined,\n });\n } catch (hookError) {\n // afterFlowRun hooks must not crash the flow result\n logger.warn('afterFlowRun plugin hook error (non-fatal)', {\n flowRunId: execution.id,\n error: hookError instanceof Error ? hookError.message : String(hookError),\n });\n }\n }\n\n return {\n flowRunId: execution.id,\n status: success ? FlowRunStatus.SUCCESS : FlowRunStatus.FAILED,\n inputs: execution.inputs,\n outputs: finalOutputs,\n startedAt:\n typeof updatedExecution.startedAt === 'string'\n ? new Date(updatedExecution.startedAt)\n : updatedExecution.startedAt,\n completedAt: updatedExecution.completedAt\n ? typeof updatedExecution.completedAt === 'string'\n ? new Date(updatedExecution.completedAt)\n : updatedExecution.completedAt\n : undefined,\n duration: updatedExecution.duration,\n traces: nodeExecutions,\n };\n }\n\n async resumeFromBatchCompletion(\n flowRunId: string,\n completedBatchNodeId: string,\n batchResult?: unknown,\n batchError?: string,\n ): Promise<FlowRunResult> {\n const { logger, nodeExecutionService, flowRunsService, flowsService } = this.deps;\n\n logger.debug('Resuming flow from batch completion', {\n flowRunId,\n completedBatchNodeId,\n hasError: !!batchError,\n });\n\n if (batchError) {\n await this.markExecutionFailed(flowRunId, `Batch processing failed: ${batchError}`);\n\n const traces = await nodeExecutionService.listNodeExecutionsByFlowRunId(flowRunId);\n return {\n flowRunId,\n status: FlowRunStatus.FAILED,\n inputs: {},\n outputs: {},\n error: `Batch processing failed: ${batchError}`,\n startedAt: new Date(),\n traces,\n };\n }\n\n const flowRun = await flowRunsService.getRunById(flowRunId);\n const flow = await flowsService.getFlowById(flowRun.flowId);\n\n if (!flow?.flowVersion?.invectDefinition) {\n throw new ValidationError('Flow definition not found for batch resume');\n }\n\n const definition = flow.flowVersion.invectDefinition as InvectDefinition;\n\n await flowRunsService.updateRunStatus(flowRunId, FlowRunStatus.RUNNING);\n\n return this.continueFlowRunFromBatch(flowRunId, definition, flowRun.inputs || {});\n }\n\n async continueFlowRunFromBatch(\n flowRunId: string,\n definition: InvectDefinition,\n flowInputs: Record<string, unknown>,\n ): Promise<FlowRunResult> {\n const {\n logger,\n nodeExecutionCoordinator,\n nodeExecutionService,\n batchJobsService,\n flowRunsService,\n } = this.deps;\n\n const { nodes, edges } = definition;\n const nodeMap = new Map(nodes.map((node) => [node.id, node]));\n const executionOrder = GraphService.topologicalSort(nodes, edges);\n\n const existingNodeExecutions =\n await nodeExecutionService.listNodeExecutionsByFlowRunId(flowRunId);\n const processedNodeIds = new Set(existingNodeExecutions.map((trace) => trace.nodeId));\n\n const nodeOutputs = new Map<FlowNodeDefinitions['id'], NodeOutput>();\n const skippedNodeIds = new Set<string>();\n let hasFailure = false;\n\n for (const nodeExecution of existingNodeExecutions) {\n if (nodeExecution.status === NodeExecutionStatus.SUCCESS && nodeExecution.outputs) {\n nodeOutputs.set(nodeExecution.nodeId, nodeExecution.outputs);\n } else if (nodeExecution.status === NodeExecutionStatus.SKIPPED) {\n skippedNodeIds.add(nodeExecution.nodeId);\n } else if (nodeExecution.status === NodeExecutionStatus.BATCH_SUBMITTED) {\n const batchJobs = await batchJobsService.getBatchJobsByExecutionAndNode(\n flowRunId,\n nodeExecution.nodeId,\n );\n\n for (const batchJob of batchJobs) {\n if (batchJob.status === BatchStatus.COMPLETED && batchJob.responseData) {\n const batchResult = batchJob.responseData[0];\n\n if (batchResult.status === BatchStatus.COMPLETED) {\n const updatedTrace = await nodeExecutionService.updateNodeExecutionStatus(\n nodeExecution.id,\n NodeExecutionStatus.SUCCESS,\n {\n outputs: {\n data: {\n variables: {\n // batchResult.content is already a PromptResult (discriminated union)\n output: batchResult.content,\n },\n },\n nodeType: GraphNodeType.MODEL,\n },\n },\n );\n\n if (updatedTrace.outputs) {\n nodeOutputs.set(nodeExecution.nodeId, updatedTrace.outputs);\n }\n } else if (batchResult.status === BatchStatus.FAILED) {\n await nodeExecutionService.updateNodeExecutionStatus(\n nodeExecution.id,\n NodeExecutionStatus.FAILED,\n {\n error: batchResult.error || 'Batch processing failed',\n },\n );\n\n hasFailure = true;\n break;\n } else if (batchResult.status === BatchStatus.CANCELLED) {\n await nodeExecutionService.updateNodeExecutionStatus(\n nodeExecution.id,\n NodeExecutionStatus.FAILED,\n {\n error: batchResult.error || 'Batch processing was cancelled',\n },\n );\n\n hasFailure = true;\n break;\n } else if (\n batchResult.status === BatchStatus.SUBMITTED ||\n batchResult.status === BatchStatus.PROCESSING\n ) {\n continue;\n } else {\n await nodeExecutionService.updateNodeExecutionStatus(\n nodeExecution.id,\n NodeExecutionStatus.FAILED,\n {\n error: `Unknown batch status: ${batchResult.status}`,\n },\n );\n\n hasFailure = true;\n break;\n }\n }\n }\n }\n }\n\n const remainingNodes = executionOrder.filter(\n (nodeId) => !processedNodeIds.has(nodeId) && !skippedNodeIds.has(nodeId),\n );\n\n logger.debug('Continuing execution after batch', {\n flowRunId,\n totalNodes: nodes.length,\n processedNodes: processedNodeIds.size,\n remainingNodes: remainingNodes.length,\n });\n\n const newTraces: NodeExecution[] = [];\n\n for (const nodeId of remainingNodes) {\n if (hasFailure) {\n break;\n }\n\n const node = nodeMap.get(nodeId);\n if (!node) {\n continue;\n }\n\n const nodeInputs = nodeExecutionCoordinator.prepareNodeInputs(\n node,\n nodeOutputs,\n edges,\n nodeMap,\n );\n\n // Build incoming data object for template resolution\n const incomingData = nodeExecutionCoordinator.buildIncomingDataObject(\n node,\n nodeOutputs,\n edges,\n nodeMap,\n );\n\n try {\n const trace = await nodeExecutionCoordinator.executeNode(\n flowRunId,\n node,\n nodeInputs,\n flowInputs,\n definition,\n skippedNodeIds,\n true,\n incomingData,\n );\n\n newTraces.push(trace);\n\n if (trace.status === NodeExecutionStatus.SUCCESS && trace.outputs) {\n nodeOutputs.set(nodeId, trace.outputs);\n } else if (trace.status === NodeExecutionStatus.FAILED) {\n hasFailure = true;\n }\n\n if (trace.status === NodeExecutionStatus.BATCH_SUBMITTED) {\n await this.pauseFlowForBatch(flowRunId);\n return this.buildPausedFlowResult(flowRunId, [...existingNodeExecutions, ...newTraces]);\n }\n } catch (error) {\n hasFailure = true;\n logger.error('Node execution failed during batch resume', {\n flowRunId,\n nodeId,\n error: error instanceof Error ? error.message : String(error),\n });\n }\n }\n\n const finalOutputs = this.collectFlowOutputs(definition, nodeOutputs);\n\n if (hasFailure) {\n await this.markExecutionFailed(flowRunId, 'One or more nodes failed during batch resume');\n } else {\n await this.markExecutionSuccess(flowRunId, finalOutputs);\n }\n\n const updatedExecution = await flowRunsService.getRunById(flowRunId);\n const allTraces = await nodeExecutionService.listNodeExecutionsByFlowRunId(flowRunId);\n\n return {\n flowRunId,\n status: hasFailure ? FlowRunStatus.FAILED : FlowRunStatus.SUCCESS,\n inputs: updatedExecution.inputs,\n outputs: finalOutputs,\n startedAt:\n typeof updatedExecution.startedAt === 'string'\n ? new Date(updatedExecution.startedAt)\n : updatedExecution.startedAt,\n completedAt: updatedExecution.completedAt\n ? typeof updatedExecution.completedAt === 'string'\n ? new Date(updatedExecution.completedAt)\n : updatedExecution.completedAt\n : undefined,\n duration: updatedExecution.duration,\n traces: allTraces,\n };\n }\n\n private collectFlowOutputs(\n _definition: InvectDefinition,\n nodeOutputs: Map<string, NodeOutput | undefined>,\n ): Record<string, unknown> {\n const outputs: Record<string, unknown> = {};\n for (const [nodeId, nodeOutput] of nodeOutputs) {\n outputs[nodeId] = nodeOutput;\n }\n return outputs;\n }\n\n private async pauseFlowForBatch(flowRunId: string): Promise<void> {\n const { logger, flowRunsService } = this.deps;\n this.stopHeartbeat(flowRunId);\n logger.debug('Pausing flow for batch processing', { flowRunId });\n await flowRunsService.updateRunStatus(flowRunId, FlowRunStatus.PAUSED_FOR_BATCH);\n logger.debug('Flow paused for batch processing', { flowRunId });\n }\n\n private async buildPausedFlowResult(\n flowRunId: string,\n traces: NodeExecution[],\n ): Promise<FlowRunResult> {\n const execution = await this.deps.flowRunsService.getRunById(flowRunId);\n\n return {\n flowRunId: execution.id,\n status: FlowRunStatus.PAUSED_FOR_BATCH,\n inputs: execution.inputs,\n outputs: {},\n startedAt:\n typeof execution.startedAt === 'string'\n ? new Date(execution.startedAt)\n : execution.startedAt,\n traces,\n };\n }\n\n private async markExecutionRunning(flowRunId: string): Promise<void> {\n const { logger, flowRunsService } = this.deps;\n logger.debug('Marking execution as running', { flowRunId });\n await flowRunsService.updateRunStatus(flowRunId, FlowRunStatus.RUNNING);\n this.startHeartbeat(flowRunId);\n }\n\n private async markExecutionSuccess(\n flowRunId: string,\n outputs: Record<string, unknown>,\n ): Promise<void> {\n const { logger, flowRunsService } = this.deps;\n this.stopHeartbeat(flowRunId);\n logger.debug('Marking execution as successful', { flowRunId });\n await flowRunsService.updateRunStatus(flowRunId, FlowRunStatus.SUCCESS, { outputs });\n }\n\n private async markExecutionFailed(flowRunId: string, error: string): Promise<void> {\n const { logger, flowRunsService } = this.deps;\n this.stopHeartbeat(flowRunId);\n logger.debug('Marking execution as failed', { flowRunId, error });\n await flowRunsService.updateRunStatus(flowRunId, FlowRunStatus.FAILED, { error });\n }\n\n /**\n * Execute a flow up to and including a specific target node.\n * Only executes the upstream nodes required to produce output for the target node.\n *\n * @param execution - The flow run record\n * @param definition - The flow definition\n * @param targetNodeId - The node to execute up to (this node will also be executed)\n * @param flowInputs - Flow-level inputs\n * @param useBatchProcessing - Whether to use batch processing for AI nodes\n */\n async executeFlowToNode(\n execution: FlowRun,\n definition: InvectDefinition,\n targetNodeId: string,\n flowInputs: Record<string, unknown>,\n useBatchProcessing?: boolean,\n ): Promise<FlowRunResult> {\n const { logger, nodeExecutionCoordinator, graphService } = this.deps;\n\n logger.debug('Executing flow to specific node', {\n flowRunId: execution.id,\n targetNodeId,\n });\n\n await this.markExecutionRunning(execution.id);\n\n const { nodes, edges } = definition;\n const nodeMap = new Map(nodes.map((node) => [node.id, node]));\n\n // Verify target node exists\n const targetNode = nodeMap.get(targetNodeId);\n if (!targetNode) {\n throw new ValidationError(`Target node not found: ${targetNodeId}`);\n }\n\n // Get only the nodes needed to execute to the target\n const executionPath = graphService.getExecutionPathToNode(targetNodeId, nodes, edges);\n\n logger.debug('Flow execution path to target node', {\n flowRunId: execution.id,\n targetNodeId,\n executionPath,\n totalNodes: nodes.length,\n nodesToExecute: executionPath.length,\n });\n\n const nodeExecutions: NodeExecution[] = [];\n const nodeOutputs = new Map<FlowNodeDefinitions['id'], NodeOutput>();\n const nodeErrors: Record<string, string> = {};\n const skippedNodeIds = new Set<string>();\n const batchPendingNodeIds = new Set<string>();\n let hasFailure = false;\n let hasBatchSubmission = false;\n\n for (const nodeId of executionPath) {\n if (hasFailure || hasBatchSubmission) {\n break;\n }\n\n const node = nodeMap.get(nodeId);\n if (!node) {\n logger.warn('Node not found in definition', { flowRunId: execution.id, nodeId });\n continue;\n }\n\n if (skippedNodeIds.has(nodeId)) {\n logger.debug('Skipping node execution due to conditional branching', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n });\n continue;\n }\n\n logger.debug('Processing node in partial execution', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n isTargetNode: nodeId === targetNodeId,\n });\n\n try {\n const nodeInputs = nodeExecutionCoordinator.prepareNodeInputs(\n node,\n nodeOutputs,\n edges,\n nodeMap,\n );\n\n // Build incoming data object for template resolution\n const incomingData = nodeExecutionCoordinator.buildIncomingDataObject(\n node,\n nodeOutputs,\n edges,\n nodeMap,\n );\n\n const trace = await nodeExecutionCoordinator.executeNode(\n execution.id,\n node,\n nodeInputs,\n flowInputs,\n definition,\n skippedNodeIds,\n useBatchProcessing,\n incomingData,\n );\n nodeExecutions.push(trace);\n\n if (trace.status === NodeExecutionStatus.BATCH_SUBMITTED) {\n logger.debug('Batch submission detected - pausing partial flow', {\n flowRunId: execution.id,\n nodeId: trace.nodeId,\n });\n\n batchPendingNodeIds.add(nodeId);\n hasBatchSubmission = true;\n\n await this.pauseFlowForBatch(execution.id);\n return this.buildPausedFlowResult(execution.id, nodeExecutions);\n }\n\n if (trace.status === NodeExecutionStatus.SUCCESS) {\n if (trace.outputs) {\n nodeOutputs.set(nodeId, trace.outputs);\n }\n } else if (trace.status === NodeExecutionStatus.FAILED) {\n hasFailure = true;\n nodeErrors[nodeId] = trace.error || 'Node execution failed';\n logger.error('Node execution failed in partial execution', {\n flowRunId: execution.id,\n nodeId,\n nodeType: node.type,\n });\n }\n\n // Handle if-else node conditional branching\n if (node.type === GraphNodeType.IF_ELSE && trace.status === NodeExecutionStatus.SUCCESS) {\n const outputs = trace.outputs?.data?.variables;\n const executedBranch = (outputs as Record<string, { value: unknown }>)?.executedBranch\n ?.value;\n\n if (executedBranch && typeof executedBranch === 'string') {\n const allBranches = ['true_branch', 'false_branch'];\n const nonExecutedBranches = allBranches.filter((b) => b !== executedBranch);\n\n for (const branch of nonExecutedBranches) {\n const branchEdges = edges.filter(\n (e) => e.source === nodeId && e.sourceHandle === branch,\n );\n\n for (const edge of branchEdges) {\n graphService.markDownstreamNodesAsSkipped(edge.target, edges, skippedNodeIds, true);\n }\n }\n }\n }\n } catch (error) {\n hasFailure = true;\n nodeErrors[nodeId] = error instanceof Error ? error.message : String(error);\n logger.error('Node execution threw an exception in partial execution', {\n flowRunId: execution.id,\n nodeId,\n error: error instanceof Error ? error.message : String(error),\n });\n }\n }\n\n const success = !hasFailure;\n\n // For partial execution, include outputs for all executed nodes\n const finalOutputs: Record<string, unknown> = {};\n for (const [executedNodeId, output] of nodeOutputs.entries()) {\n finalOutputs[executedNodeId] = output;\n }\n\n if (success) {\n await this.markExecutionSuccess(execution.id, finalOutputs);\n } else {\n await this.markExecutionFailed(execution.id, 'One or more nodes failed');\n }\n\n const updatedExecution = await this.deps.flowRunsService.getRunById(execution.id);\n\n return {\n flowRunId: execution.id,\n status: success ? FlowRunStatus.SUCCESS : FlowRunStatus.FAILED,\n inputs: execution.inputs,\n outputs: finalOutputs,\n nodeErrors: Object.keys(nodeErrors).length > 0 ? nodeErrors : undefined,\n startedAt:\n typeof updatedExecution.startedAt === 'string'\n ? new Date(updatedExecution.startedAt)\n : updatedExecution.startedAt,\n completedAt: updatedExecution.completedAt\n ? typeof updatedExecution.completedAt === 'string'\n ? new Date(updatedExecution.completedAt)\n : updatedExecution.completedAt\n : undefined,\n duration: updatedExecution.duration,\n traces: nodeExecutions,\n };\n }\n}\n"],"mappings":"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"}