@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.
- package/LICENSE +21 -0
- package/README.md +103 -0
- package/dist/_virtual/_rolldown/runtime.cjs +33 -0
- package/dist/_virtual/_rolldown/runtime.js +13 -0
- package/dist/actions/action-executor.cjs +166 -0
- package/dist/actions/action-executor.cjs.map +1 -0
- package/dist/actions/action-executor.d.cts +33 -0
- package/dist/actions/action-executor.d.cts.map +1 -0
- package/dist/actions/action-executor.d.ts +33 -0
- package/dist/actions/action-executor.d.ts.map +1 -0
- package/dist/actions/action-executor.js +164 -0
- package/dist/actions/action-executor.js.map +1 -0
- package/dist/actions/action-registry.cjs +236 -0
- package/dist/actions/action-registry.cjs.map +1 -0
- package/dist/actions/action-registry.d.cts +58 -0
- package/dist/actions/action-registry.d.cts.map +1 -0
- package/dist/actions/action-registry.d.ts +58 -0
- package/dist/actions/action-registry.d.ts.map +1 -0
- package/dist/actions/action-registry.js +233 -0
- package/dist/actions/action-registry.js.map +1 -0
- package/dist/actions/core/if-else.cjs +111 -0
- package/dist/actions/core/if-else.cjs.map +1 -0
- package/dist/actions/core/if-else.d.cts +1 -0
- package/dist/actions/core/if-else.d.ts +1 -0
- package/dist/actions/core/if-else.js +98 -0
- package/dist/actions/core/if-else.js.map +1 -0
- package/dist/actions/core/index.cjs +20 -0
- package/dist/actions/core/index.cjs.map +1 -0
- package/dist/actions/core/index.d.cts +7 -0
- package/dist/actions/core/index.d.cts.map +1 -0
- package/dist/actions/core/index.d.ts +7 -0
- package/dist/actions/core/index.d.ts.map +1 -0
- package/dist/actions/core/index.js +20 -0
- package/dist/actions/core/index.js.map +1 -0
- package/dist/actions/core/input.cjs +73 -0
- package/dist/actions/core/input.cjs.map +1 -0
- package/dist/actions/core/input.d.cts +1 -0
- package/dist/actions/core/input.d.ts +1 -0
- package/dist/actions/core/input.js +72 -0
- package/dist/actions/core/input.js.map +1 -0
- package/dist/actions/core/javascript.cjs +77 -0
- package/dist/actions/core/javascript.cjs.map +1 -0
- package/dist/actions/core/javascript.d.cts +1 -0
- package/dist/actions/core/javascript.d.ts +1 -0
- package/dist/actions/core/javascript.js +62 -0
- package/dist/actions/core/javascript.js.map +1 -0
- package/dist/actions/core/model.cjs +285 -0
- package/dist/actions/core/model.cjs.map +1 -0
- package/dist/actions/core/model.d.cts +1 -0
- package/dist/actions/core/model.d.ts +1 -0
- package/dist/actions/core/model.js +276 -0
- package/dist/actions/core/model.js.map +1 -0
- package/dist/actions/core/output.cjs +66 -0
- package/dist/actions/core/output.cjs.map +1 -0
- package/dist/actions/core/output.d.cts +1 -0
- package/dist/actions/core/output.d.ts +1 -0
- package/dist/actions/core/output.js +57 -0
- package/dist/actions/core/output.js.map +1 -0
- package/dist/actions/core/template-string.cjs +85 -0
- package/dist/actions/core/template-string.cjs.map +1 -0
- package/dist/actions/core/template-string.d.cts +1 -0
- package/dist/actions/core/template-string.d.ts +1 -0
- package/dist/actions/core/template-string.js +76 -0
- package/dist/actions/core/template-string.js.map +1 -0
- package/dist/actions/define-action.cjs +14 -0
- package/dist/actions/define-action.cjs.map +1 -0
- package/dist/actions/define-action.d.cts +13 -0
- package/dist/actions/define-action.d.cts.map +1 -0
- package/dist/actions/define-action.d.ts +13 -0
- package/dist/actions/define-action.d.ts.map +1 -0
- package/dist/actions/define-action.js +14 -0
- package/dist/actions/define-action.js.map +1 -0
- package/dist/actions/github/add-issue-comment.cjs +152 -0
- package/dist/actions/github/add-issue-comment.cjs.map +1 -0
- package/dist/actions/github/add-issue-comment.d.cts +1 -0
- package/dist/actions/github/add-issue-comment.d.ts +1 -0
- package/dist/actions/github/add-issue-comment.js +150 -0
- package/dist/actions/github/add-issue-comment.js.map +1 -0
- package/dist/actions/github/create-branch.cjs +201 -0
- package/dist/actions/github/create-branch.cjs.map +1 -0
- package/dist/actions/github/create-branch.d.cts +1 -0
- package/dist/actions/github/create-branch.d.ts +1 -0
- package/dist/actions/github/create-branch.js +199 -0
- package/dist/actions/github/create-branch.js.map +1 -0
- package/dist/actions/github/create-issue.cjs +190 -0
- package/dist/actions/github/create-issue.cjs.map +1 -0
- package/dist/actions/github/create-issue.d.cts +1 -0
- package/dist/actions/github/create-issue.d.ts +1 -0
- package/dist/actions/github/create-issue.js +188 -0
- package/dist/actions/github/create-issue.js.map +1 -0
- package/dist/actions/github/create-or-update-file.cjs +216 -0
- package/dist/actions/github/create-or-update-file.cjs.map +1 -0
- package/dist/actions/github/create-or-update-file.d.cts +1 -0
- package/dist/actions/github/create-or-update-file.d.ts +1 -0
- package/dist/actions/github/create-or-update-file.js +214 -0
- package/dist/actions/github/create-or-update-file.js.map +1 -0
- package/dist/actions/github/create-pull-request.cjs +206 -0
- package/dist/actions/github/create-pull-request.cjs.map +1 -0
- package/dist/actions/github/create-pull-request.d.cts +1 -0
- package/dist/actions/github/create-pull-request.d.ts +1 -0
- package/dist/actions/github/create-pull-request.js +204 -0
- package/dist/actions/github/create-pull-request.js.map +1 -0
- package/dist/actions/github/create-release.cjs +218 -0
- package/dist/actions/github/create-release.cjs.map +1 -0
- package/dist/actions/github/create-release.d.cts +1 -0
- package/dist/actions/github/create-release.d.ts +1 -0
- package/dist/actions/github/create-release.js +216 -0
- package/dist/actions/github/create-release.js.map +1 -0
- package/dist/actions/github/get-file-content.cjs +164 -0
- package/dist/actions/github/get-file-content.cjs.map +1 -0
- package/dist/actions/github/get-file-content.d.cts +1 -0
- package/dist/actions/github/get-file-content.d.ts +1 -0
- package/dist/actions/github/get-file-content.js +162 -0
- package/dist/actions/github/get-file-content.js.map +1 -0
- package/dist/actions/github/get-issue.cjs +149 -0
- package/dist/actions/github/get-issue.cjs.map +1 -0
- package/dist/actions/github/get-issue.d.cts +1 -0
- package/dist/actions/github/get-issue.d.ts +1 -0
- package/dist/actions/github/get-issue.js +147 -0
- package/dist/actions/github/get-issue.js.map +1 -0
- package/dist/actions/github/get-pull-request.cjs +160 -0
- package/dist/actions/github/get-pull-request.cjs.map +1 -0
- package/dist/actions/github/get-pull-request.d.cts +1 -0
- package/dist/actions/github/get-pull-request.d.ts +1 -0
- package/dist/actions/github/get-pull-request.js +158 -0
- package/dist/actions/github/get-pull-request.js.map +1 -0
- package/dist/actions/github/get-repo.cjs +144 -0
- package/dist/actions/github/get-repo.cjs.map +1 -0
- package/dist/actions/github/get-repo.d.cts +1 -0
- package/dist/actions/github/get-repo.d.ts +1 -0
- package/dist/actions/github/get-repo.js +142 -0
- package/dist/actions/github/get-repo.js.map +1 -0
- package/dist/actions/github/index.cjs +48 -0
- package/dist/actions/github/index.cjs.map +1 -0
- package/dist/actions/github/index.d.cts +7 -0
- package/dist/actions/github/index.d.cts.map +1 -0
- package/dist/actions/github/index.d.ts +7 -0
- package/dist/actions/github/index.d.ts.map +1 -0
- package/dist/actions/github/index.js +48 -0
- package/dist/actions/github/index.js.map +1 -0
- package/dist/actions/github/list-branches.cjs +149 -0
- package/dist/actions/github/list-branches.cjs.map +1 -0
- package/dist/actions/github/list-branches.d.cts +1 -0
- package/dist/actions/github/list-branches.d.ts +1 -0
- package/dist/actions/github/list-branches.js +147 -0
- package/dist/actions/github/list-branches.js.map +1 -0
- package/dist/actions/github/list-commits.cjs +200 -0
- package/dist/actions/github/list-commits.cjs.map +1 -0
- package/dist/actions/github/list-commits.d.cts +1 -0
- package/dist/actions/github/list-commits.d.ts +1 -0
- package/dist/actions/github/list-commits.js +198 -0
- package/dist/actions/github/list-commits.js.map +1 -0
- package/dist/actions/github/list-issue-comments.cjs +153 -0
- package/dist/actions/github/list-issue-comments.cjs.map +1 -0
- package/dist/actions/github/list-issue-comments.d.cts +1 -0
- package/dist/actions/github/list-issue-comments.d.ts +1 -0
- package/dist/actions/github/list-issue-comments.js +151 -0
- package/dist/actions/github/list-issue-comments.js.map +1 -0
- package/dist/actions/github/list-issues.cjs +244 -0
- package/dist/actions/github/list-issues.cjs.map +1 -0
- package/dist/actions/github/list-issues.d.cts +1 -0
- package/dist/actions/github/list-issues.d.ts +1 -0
- package/dist/actions/github/list-issues.js +242 -0
- package/dist/actions/github/list-issues.js.map +1 -0
- package/dist/actions/github/list-pull-requests.cjs +252 -0
- package/dist/actions/github/list-pull-requests.cjs.map +1 -0
- package/dist/actions/github/list-pull-requests.d.cts +1 -0
- package/dist/actions/github/list-pull-requests.d.ts +1 -0
- package/dist/actions/github/list-pull-requests.js +250 -0
- package/dist/actions/github/list-pull-requests.js.map +1 -0
- package/dist/actions/github/list-releases.cjs +152 -0
- package/dist/actions/github/list-releases.cjs.map +1 -0
- package/dist/actions/github/list-releases.d.cts +1 -0
- package/dist/actions/github/list-releases.d.ts +1 -0
- package/dist/actions/github/list-releases.js +150 -0
- package/dist/actions/github/list-releases.js.map +1 -0
- package/dist/actions/github/list-repos.cjs +227 -0
- package/dist/actions/github/list-repos.cjs.map +1 -0
- package/dist/actions/github/list-repos.d.cts +1 -0
- package/dist/actions/github/list-repos.d.ts +1 -0
- package/dist/actions/github/list-repos.js +225 -0
- package/dist/actions/github/list-repos.js.map +1 -0
- package/dist/actions/github/merge-pull-request.cjs +204 -0
- package/dist/actions/github/merge-pull-request.cjs.map +1 -0
- package/dist/actions/github/merge-pull-request.d.cts +1 -0
- package/dist/actions/github/merge-pull-request.d.ts +1 -0
- package/dist/actions/github/merge-pull-request.js +202 -0
- package/dist/actions/github/merge-pull-request.js.map +1 -0
- package/dist/actions/github/search-issues.cjs +200 -0
- package/dist/actions/github/search-issues.cjs.map +1 -0
- package/dist/actions/github/search-issues.d.cts +1 -0
- package/dist/actions/github/search-issues.d.ts +1 -0
- package/dist/actions/github/search-issues.js +198 -0
- package/dist/actions/github/search-issues.js.map +1 -0
- package/dist/actions/github/update-issue.cjs +243 -0
- package/dist/actions/github/update-issue.cjs.map +1 -0
- package/dist/actions/github/update-issue.d.cts +1 -0
- package/dist/actions/github/update-issue.d.ts +1 -0
- package/dist/actions/github/update-issue.js +241 -0
- package/dist/actions/github/update-issue.js.map +1 -0
- package/dist/actions/gmail/create-draft.cjs +228 -0
- package/dist/actions/gmail/create-draft.cjs.map +1 -0
- package/dist/actions/gmail/create-draft.d.cts +1 -0
- package/dist/actions/gmail/create-draft.d.ts +1 -0
- package/dist/actions/gmail/create-draft.js +226 -0
- package/dist/actions/gmail/create-draft.js.map +1 -0
- package/dist/actions/gmail/get-message.cjs +205 -0
- package/dist/actions/gmail/get-message.cjs.map +1 -0
- package/dist/actions/gmail/get-message.d.cts +1 -0
- package/dist/actions/gmail/get-message.d.ts +1 -0
- package/dist/actions/gmail/get-message.js +203 -0
- package/dist/actions/gmail/get-message.js.map +1 -0
- package/dist/actions/gmail/index.cjs +18 -0
- package/dist/actions/gmail/index.cjs.map +1 -0
- package/dist/actions/gmail/index.d.cts +7 -0
- package/dist/actions/gmail/index.d.cts.map +1 -0
- package/dist/actions/gmail/index.d.ts +7 -0
- package/dist/actions/gmail/index.d.ts.map +1 -0
- package/dist/actions/gmail/index.js +18 -0
- package/dist/actions/gmail/index.js.map +1 -0
- package/dist/actions/gmail/list-messages.cjs +195 -0
- package/dist/actions/gmail/list-messages.cjs.map +1 -0
- package/dist/actions/gmail/list-messages.d.cts +1 -0
- package/dist/actions/gmail/list-messages.d.ts +1 -0
- package/dist/actions/gmail/list-messages.js +193 -0
- package/dist/actions/gmail/list-messages.js.map +1 -0
- package/dist/actions/gmail/modify-labels.cjs +163 -0
- package/dist/actions/gmail/modify-labels.cjs.map +1 -0
- package/dist/actions/gmail/modify-labels.d.cts +1 -0
- package/dist/actions/gmail/modify-labels.d.ts +1 -0
- package/dist/actions/gmail/modify-labels.js +161 -0
- package/dist/actions/gmail/modify-labels.js.map +1 -0
- package/dist/actions/gmail/send-message.cjs +233 -0
- package/dist/actions/gmail/send-message.cjs.map +1 -0
- package/dist/actions/gmail/send-message.d.cts +1 -0
- package/dist/actions/gmail/send-message.d.ts +1 -0
- package/dist/actions/gmail/send-message.js +231 -0
- package/dist/actions/gmail/send-message.js.map +1 -0
- package/dist/actions/google-calendar/create-event.cjs +274 -0
- package/dist/actions/google-calendar/create-event.cjs.map +1 -0
- package/dist/actions/google-calendar/create-event.d.cts +1 -0
- package/dist/actions/google-calendar/create-event.d.ts +1 -0
- package/dist/actions/google-calendar/create-event.js +272 -0
- package/dist/actions/google-calendar/create-event.js.map +1 -0
- package/dist/actions/google-calendar/delete-event.cjs +145 -0
- package/dist/actions/google-calendar/delete-event.cjs.map +1 -0
- package/dist/actions/google-calendar/delete-event.d.cts +1 -0
- package/dist/actions/google-calendar/delete-event.d.ts +1 -0
- package/dist/actions/google-calendar/delete-event.js +143 -0
- package/dist/actions/google-calendar/delete-event.js.map +1 -0
- package/dist/actions/google-calendar/get-event.cjs +128 -0
- package/dist/actions/google-calendar/get-event.cjs.map +1 -0
- package/dist/actions/google-calendar/get-event.d.cts +1 -0
- package/dist/actions/google-calendar/get-event.d.ts +1 -0
- package/dist/actions/google-calendar/get-event.js +126 -0
- package/dist/actions/google-calendar/get-event.js.map +1 -0
- package/dist/actions/google-calendar/index.cjs +20 -0
- package/dist/actions/google-calendar/index.cjs.map +1 -0
- package/dist/actions/google-calendar/index.d.cts +7 -0
- package/dist/actions/google-calendar/index.d.cts.map +1 -0
- package/dist/actions/google-calendar/index.d.ts +7 -0
- package/dist/actions/google-calendar/index.d.ts.map +1 -0
- package/dist/actions/google-calendar/index.js +20 -0
- package/dist/actions/google-calendar/index.js.map +1 -0
- package/dist/actions/google-calendar/list-events.cjs +193 -0
- package/dist/actions/google-calendar/list-events.cjs.map +1 -0
- package/dist/actions/google-calendar/list-events.d.cts +1 -0
- package/dist/actions/google-calendar/list-events.d.ts +1 -0
- package/dist/actions/google-calendar/list-events.js +191 -0
- package/dist/actions/google-calendar/list-events.js.map +1 -0
- package/dist/actions/google-calendar/query-freebusy.cjs +160 -0
- package/dist/actions/google-calendar/query-freebusy.cjs.map +1 -0
- package/dist/actions/google-calendar/query-freebusy.d.cts +1 -0
- package/dist/actions/google-calendar/query-freebusy.d.ts +1 -0
- package/dist/actions/google-calendar/query-freebusy.js +158 -0
- package/dist/actions/google-calendar/query-freebusy.js.map +1 -0
- package/dist/actions/google-calendar/update-event.cjs +221 -0
- package/dist/actions/google-calendar/update-event.cjs.map +1 -0
- package/dist/actions/google-calendar/update-event.d.cts +1 -0
- package/dist/actions/google-calendar/update-event.d.ts +1 -0
- package/dist/actions/google-calendar/update-event.js +219 -0
- package/dist/actions/google-calendar/update-event.js.map +1 -0
- package/dist/actions/google-docs/append-text.cjs +138 -0
- package/dist/actions/google-docs/append-text.cjs.map +1 -0
- package/dist/actions/google-docs/append-text.d.cts +1 -0
- package/dist/actions/google-docs/append-text.d.ts +1 -0
- package/dist/actions/google-docs/append-text.js +136 -0
- package/dist/actions/google-docs/append-text.js.map +1 -0
- package/dist/actions/google-docs/create-document.cjs +138 -0
- package/dist/actions/google-docs/create-document.cjs.map +1 -0
- package/dist/actions/google-docs/create-document.d.cts +1 -0
- package/dist/actions/google-docs/create-document.d.ts +1 -0
- package/dist/actions/google-docs/create-document.js +136 -0
- package/dist/actions/google-docs/create-document.js.map +1 -0
- package/dist/actions/google-docs/get-document.cjs +118 -0
- package/dist/actions/google-docs/get-document.cjs.map +1 -0
- package/dist/actions/google-docs/get-document.d.cts +1 -0
- package/dist/actions/google-docs/get-document.d.ts +1 -0
- package/dist/actions/google-docs/get-document.js +116 -0
- package/dist/actions/google-docs/get-document.js.map +1 -0
- package/dist/actions/google-docs/index.cjs +18 -0
- package/dist/actions/google-docs/index.cjs.map +1 -0
- package/dist/actions/google-docs/index.d.cts +7 -0
- package/dist/actions/google-docs/index.d.cts.map +1 -0
- package/dist/actions/google-docs/index.d.ts +7 -0
- package/dist/actions/google-docs/index.d.ts.map +1 -0
- package/dist/actions/google-docs/index.js +18 -0
- package/dist/actions/google-docs/index.js.map +1 -0
- package/dist/actions/google-docs/insert-text.cjs +136 -0
- package/dist/actions/google-docs/insert-text.cjs.map +1 -0
- package/dist/actions/google-docs/insert-text.d.cts +1 -0
- package/dist/actions/google-docs/insert-text.d.ts +1 -0
- package/dist/actions/google-docs/insert-text.js +134 -0
- package/dist/actions/google-docs/insert-text.js.map +1 -0
- package/dist/actions/google-docs/replace-text.cjs +152 -0
- package/dist/actions/google-docs/replace-text.cjs.map +1 -0
- package/dist/actions/google-docs/replace-text.d.cts +1 -0
- package/dist/actions/google-docs/replace-text.d.ts +1 -0
- package/dist/actions/google-docs/replace-text.js +150 -0
- package/dist/actions/google-docs/replace-text.js.map +1 -0
- package/dist/actions/google-drive/create-file.cjs +155 -0
- package/dist/actions/google-drive/create-file.cjs.map +1 -0
- package/dist/actions/google-drive/create-file.d.cts +1 -0
- package/dist/actions/google-drive/create-file.d.ts +1 -0
- package/dist/actions/google-drive/create-file.js +153 -0
- package/dist/actions/google-drive/create-file.js.map +1 -0
- package/dist/actions/google-drive/create-folder.cjs +130 -0
- package/dist/actions/google-drive/create-folder.cjs.map +1 -0
- package/dist/actions/google-drive/create-folder.d.cts +1 -0
- package/dist/actions/google-drive/create-folder.d.ts +1 -0
- package/dist/actions/google-drive/create-folder.js +128 -0
- package/dist/actions/google-drive/create-folder.js.map +1 -0
- package/dist/actions/google-drive/delete-file.cjs +98 -0
- package/dist/actions/google-drive/delete-file.cjs.map +1 -0
- package/dist/actions/google-drive/delete-file.d.cts +1 -0
- package/dist/actions/google-drive/delete-file.d.ts +1 -0
- package/dist/actions/google-drive/delete-file.js +96 -0
- package/dist/actions/google-drive/delete-file.js.map +1 -0
- package/dist/actions/google-drive/get-file.cjs +103 -0
- package/dist/actions/google-drive/get-file.cjs.map +1 -0
- package/dist/actions/google-drive/get-file.d.cts +1 -0
- package/dist/actions/google-drive/get-file.d.ts +1 -0
- package/dist/actions/google-drive/get-file.js +101 -0
- package/dist/actions/google-drive/get-file.js.map +1 -0
- package/dist/actions/google-drive/index.cjs +22 -0
- package/dist/actions/google-drive/index.cjs.map +1 -0
- package/dist/actions/google-drive/index.d.cts +7 -0
- package/dist/actions/google-drive/index.d.cts.map +1 -0
- package/dist/actions/google-drive/index.d.ts +7 -0
- package/dist/actions/google-drive/index.d.ts.map +1 -0
- package/dist/actions/google-drive/index.js +22 -0
- package/dist/actions/google-drive/index.js.map +1 -0
- package/dist/actions/google-drive/list-files.cjs +156 -0
- package/dist/actions/google-drive/list-files.cjs.map +1 -0
- package/dist/actions/google-drive/list-files.d.cts +1 -0
- package/dist/actions/google-drive/list-files.d.ts +1 -0
- package/dist/actions/google-drive/list-files.js +154 -0
- package/dist/actions/google-drive/list-files.js.map +1 -0
- package/dist/actions/google-drive/search-files.cjs +138 -0
- package/dist/actions/google-drive/search-files.cjs.map +1 -0
- package/dist/actions/google-drive/search-files.d.cts +1 -0
- package/dist/actions/google-drive/search-files.d.ts +1 -0
- package/dist/actions/google-drive/search-files.js +136 -0
- package/dist/actions/google-drive/search-files.js.map +1 -0
- package/dist/actions/google-drive/share-file.cjs +226 -0
- package/dist/actions/google-drive/share-file.cjs.map +1 -0
- package/dist/actions/google-drive/share-file.d.cts +1 -0
- package/dist/actions/google-drive/share-file.d.ts +1 -0
- package/dist/actions/google-drive/share-file.js +224 -0
- package/dist/actions/google-drive/share-file.js.map +1 -0
- package/dist/actions/google-sheets/append-values.cjs +175 -0
- package/dist/actions/google-sheets/append-values.cjs.map +1 -0
- package/dist/actions/google-sheets/append-values.d.cts +1 -0
- package/dist/actions/google-sheets/append-values.d.ts +1 -0
- package/dist/actions/google-sheets/append-values.js +173 -0
- package/dist/actions/google-sheets/append-values.js.map +1 -0
- package/dist/actions/google-sheets/clear-values.cjs +118 -0
- package/dist/actions/google-sheets/clear-values.cjs.map +1 -0
- package/dist/actions/google-sheets/clear-values.d.cts +1 -0
- package/dist/actions/google-sheets/clear-values.d.ts +1 -0
- package/dist/actions/google-sheets/clear-values.js +116 -0
- package/dist/actions/google-sheets/clear-values.js.map +1 -0
- package/dist/actions/google-sheets/create-spreadsheet.cjs +128 -0
- package/dist/actions/google-sheets/create-spreadsheet.cjs.map +1 -0
- package/dist/actions/google-sheets/create-spreadsheet.d.cts +1 -0
- package/dist/actions/google-sheets/create-spreadsheet.d.ts +1 -0
- package/dist/actions/google-sheets/create-spreadsheet.js +126 -0
- package/dist/actions/google-sheets/create-spreadsheet.js.map +1 -0
- package/dist/actions/google-sheets/get-values.cjs +168 -0
- package/dist/actions/google-sheets/get-values.cjs.map +1 -0
- package/dist/actions/google-sheets/get-values.d.cts +1 -0
- package/dist/actions/google-sheets/get-values.d.ts +1 -0
- package/dist/actions/google-sheets/get-values.js +166 -0
- package/dist/actions/google-sheets/get-values.js.map +1 -0
- package/dist/actions/google-sheets/index.cjs +18 -0
- package/dist/actions/google-sheets/index.cjs.map +1 -0
- package/dist/actions/google-sheets/index.d.cts +7 -0
- package/dist/actions/google-sheets/index.d.cts.map +1 -0
- package/dist/actions/google-sheets/index.d.ts +7 -0
- package/dist/actions/google-sheets/index.d.ts.map +1 -0
- package/dist/actions/google-sheets/index.js +18 -0
- package/dist/actions/google-sheets/index.js.map +1 -0
- package/dist/actions/google-sheets/update-values.cjs +158 -0
- package/dist/actions/google-sheets/update-values.cjs.map +1 -0
- package/dist/actions/google-sheets/update-values.d.cts +1 -0
- package/dist/actions/google-sheets/update-values.d.ts +1 -0
- package/dist/actions/google-sheets/update-values.js +156 -0
- package/dist/actions/google-sheets/update-values.js.map +1 -0
- package/dist/actions/http/index.cjs +7 -0
- package/dist/actions/http/index.cjs.map +1 -0
- package/dist/actions/http/index.d.cts +7 -0
- package/dist/actions/http/index.d.cts.map +1 -0
- package/dist/actions/http/index.d.ts +7 -0
- package/dist/actions/http/index.d.ts.map +1 -0
- package/dist/actions/http/index.js +8 -0
- package/dist/actions/http/index.js.map +1 -0
- package/dist/actions/http/request.cjs +223 -0
- package/dist/actions/http/request.cjs.map +1 -0
- package/dist/actions/http/request.d.cts +1 -0
- package/dist/actions/http/request.d.ts +1 -0
- package/dist/actions/http/request.js +222 -0
- package/dist/actions/http/request.js.map +1 -0
- package/dist/actions/index.cjs +46 -0
- package/dist/actions/index.cjs.map +1 -0
- package/dist/actions/index.d.cts +27 -0
- package/dist/actions/index.d.cts.map +1 -0
- package/dist/actions/index.d.ts +27 -0
- package/dist/actions/index.d.ts.map +1 -0
- package/dist/actions/index.js +45 -0
- package/dist/actions/index.js.map +1 -0
- package/dist/actions/linear/create-issue.cjs +296 -0
- package/dist/actions/linear/create-issue.cjs.map +1 -0
- package/dist/actions/linear/create-issue.d.cts +1 -0
- package/dist/actions/linear/create-issue.d.ts +1 -0
- package/dist/actions/linear/create-issue.js +294 -0
- package/dist/actions/linear/create-issue.js.map +1 -0
- package/dist/actions/linear/index.cjs +16 -0
- package/dist/actions/linear/index.cjs.map +1 -0
- package/dist/actions/linear/index.d.cts +7 -0
- package/dist/actions/linear/index.d.cts.map +1 -0
- package/dist/actions/linear/index.d.ts +7 -0
- package/dist/actions/linear/index.d.ts.map +1 -0
- package/dist/actions/linear/index.js +16 -0
- package/dist/actions/linear/index.js.map +1 -0
- package/dist/actions/linear/list-issues.cjs +239 -0
- package/dist/actions/linear/list-issues.cjs.map +1 -0
- package/dist/actions/linear/list-issues.d.cts +1 -0
- package/dist/actions/linear/list-issues.d.ts +1 -0
- package/dist/actions/linear/list-issues.js +237 -0
- package/dist/actions/linear/list-issues.js.map +1 -0
- package/dist/actions/linear/list-teams.cjs +183 -0
- package/dist/actions/linear/list-teams.cjs.map +1 -0
- package/dist/actions/linear/list-teams.d.cts +1 -0
- package/dist/actions/linear/list-teams.d.ts +1 -0
- package/dist/actions/linear/list-teams.js +181 -0
- package/dist/actions/linear/list-teams.js.map +1 -0
- package/dist/actions/linear/update-issue.cjs +282 -0
- package/dist/actions/linear/update-issue.cjs.map +1 -0
- package/dist/actions/linear/update-issue.d.cts +1 -0
- package/dist/actions/linear/update-issue.d.ts +1 -0
- package/dist/actions/linear/update-issue.js +280 -0
- package/dist/actions/linear/update-issue.js.map +1 -0
- package/dist/actions/microsoft/get-calendar-event.cjs +139 -0
- package/dist/actions/microsoft/get-calendar-event.cjs.map +1 -0
- package/dist/actions/microsoft/get-calendar-event.d.cts +1 -0
- package/dist/actions/microsoft/get-calendar-event.d.ts +1 -0
- package/dist/actions/microsoft/get-calendar-event.js +137 -0
- package/dist/actions/microsoft/get-calendar-event.js.map +1 -0
- package/dist/actions/microsoft/get-meeting-transcript.cjs +221 -0
- package/dist/actions/microsoft/get-meeting-transcript.cjs.map +1 -0
- package/dist/actions/microsoft/get-meeting-transcript.d.cts +1 -0
- package/dist/actions/microsoft/get-meeting-transcript.d.ts +1 -0
- package/dist/actions/microsoft/get-meeting-transcript.js +219 -0
- package/dist/actions/microsoft/get-meeting-transcript.js.map +1 -0
- package/dist/actions/microsoft/get-message.cjs +173 -0
- package/dist/actions/microsoft/get-message.cjs.map +1 -0
- package/dist/actions/microsoft/get-message.d.cts +1 -0
- package/dist/actions/microsoft/get-message.d.ts +1 -0
- package/dist/actions/microsoft/get-message.js +171 -0
- package/dist/actions/microsoft/get-message.js.map +1 -0
- package/dist/actions/microsoft/index.cjs +22 -0
- package/dist/actions/microsoft/index.cjs.map +1 -0
- package/dist/actions/microsoft/index.d.cts +1 -0
- package/dist/actions/microsoft/index.d.ts +1 -0
- package/dist/actions/microsoft/index.js +22 -0
- package/dist/actions/microsoft/index.js.map +1 -0
- package/dist/actions/microsoft/list-calendar-events.cjs +202 -0
- package/dist/actions/microsoft/list-calendar-events.cjs.map +1 -0
- package/dist/actions/microsoft/list-calendar-events.d.cts +1 -0
- package/dist/actions/microsoft/list-calendar-events.d.ts +1 -0
- package/dist/actions/microsoft/list-calendar-events.js +200 -0
- package/dist/actions/microsoft/list-calendar-events.js.map +1 -0
- package/dist/actions/microsoft/list-calendars.cjs +99 -0
- package/dist/actions/microsoft/list-calendars.cjs.map +1 -0
- package/dist/actions/microsoft/list-calendars.d.cts +1 -0
- package/dist/actions/microsoft/list-calendars.d.ts +1 -0
- package/dist/actions/microsoft/list-calendars.js +97 -0
- package/dist/actions/microsoft/list-calendars.js.map +1 -0
- package/dist/actions/microsoft/list-messages.cjs +223 -0
- package/dist/actions/microsoft/list-messages.cjs.map +1 -0
- package/dist/actions/microsoft/list-messages.d.cts +1 -0
- package/dist/actions/microsoft/list-messages.d.ts +1 -0
- package/dist/actions/microsoft/list-messages.js +221 -0
- package/dist/actions/microsoft/list-messages.js.map +1 -0
- package/dist/actions/microsoft/list-online-meetings.cjs +132 -0
- package/dist/actions/microsoft/list-online-meetings.cjs.map +1 -0
- package/dist/actions/microsoft/list-online-meetings.d.cts +1 -0
- package/dist/actions/microsoft/list-online-meetings.d.ts +1 -0
- package/dist/actions/microsoft/list-online-meetings.js +130 -0
- package/dist/actions/microsoft/list-online-meetings.js.map +1 -0
- package/dist/actions/postgres/describe-table.cjs +175 -0
- package/dist/actions/postgres/describe-table.cjs.map +1 -0
- package/dist/actions/postgres/describe-table.d.cts +1 -0
- package/dist/actions/postgres/describe-table.d.ts +1 -0
- package/dist/actions/postgres/describe-table.js +165 -0
- package/dist/actions/postgres/describe-table.js.map +1 -0
- package/dist/actions/postgres/execute-query.cjs +120 -0
- package/dist/actions/postgres/execute-query.cjs.map +1 -0
- package/dist/actions/postgres/execute-query.d.cts +1 -0
- package/dist/actions/postgres/execute-query.d.ts +1 -0
- package/dist/actions/postgres/execute-query.js +110 -0
- package/dist/actions/postgres/execute-query.js.map +1 -0
- package/dist/actions/postgres/index.cjs +16 -0
- package/dist/actions/postgres/index.cjs.map +1 -0
- package/dist/actions/postgres/index.d.cts +7 -0
- package/dist/actions/postgres/index.d.cts.map +1 -0
- package/dist/actions/postgres/index.d.ts +7 -0
- package/dist/actions/postgres/index.d.ts.map +1 -0
- package/dist/actions/postgres/index.js +16 -0
- package/dist/actions/postgres/index.js.map +1 -0
- package/dist/actions/postgres/insert-rows.cjs +168 -0
- package/dist/actions/postgres/insert-rows.cjs.map +1 -0
- package/dist/actions/postgres/insert-rows.d.cts +1 -0
- package/dist/actions/postgres/insert-rows.d.ts +1 -0
- package/dist/actions/postgres/insert-rows.js +158 -0
- package/dist/actions/postgres/insert-rows.js.map +1 -0
- package/dist/actions/postgres/list-tables.cjs +133 -0
- package/dist/actions/postgres/list-tables.cjs.map +1 -0
- package/dist/actions/postgres/list-tables.d.cts +1 -0
- package/dist/actions/postgres/list-tables.d.ts +1 -0
- package/dist/actions/postgres/list-tables.js +123 -0
- package/dist/actions/postgres/list-tables.js.map +1 -0
- package/dist/actions/providers.cjs +128 -0
- package/dist/actions/providers.cjs.map +1 -0
- package/dist/actions/providers.d.cts +22 -0
- package/dist/actions/providers.d.cts.map +1 -0
- package/dist/actions/providers.d.ts +22 -0
- package/dist/actions/providers.d.ts.map +1 -0
- package/dist/actions/providers.js +116 -0
- package/dist/actions/providers.js.map +1 -0
- package/dist/actions/slack/index.cjs +9 -0
- package/dist/actions/slack/index.cjs.map +1 -0
- package/dist/actions/slack/index.d.cts +7 -0
- package/dist/actions/slack/index.d.cts.map +1 -0
- package/dist/actions/slack/index.d.ts +7 -0
- package/dist/actions/slack/index.d.ts.map +1 -0
- package/dist/actions/slack/index.js +9 -0
- package/dist/actions/slack/index.js.map +1 -0
- package/dist/actions/slack/list-channels.cjs +157 -0
- package/dist/actions/slack/list-channels.cjs.map +1 -0
- package/dist/actions/slack/list-channels.d.cts +1 -0
- package/dist/actions/slack/list-channels.d.ts +1 -0
- package/dist/actions/slack/list-channels.js +155 -0
- package/dist/actions/slack/list-channels.js.map +1 -0
- package/dist/actions/slack/send-message.cjs +157 -0
- package/dist/actions/slack/send-message.cjs.map +1 -0
- package/dist/actions/slack/send-message.d.cts +1 -0
- package/dist/actions/slack/send-message.d.ts +1 -0
- package/dist/actions/slack/send-message.js +155 -0
- package/dist/actions/slack/send-message.js.map +1 -0
- package/dist/actions/triggers/cron.cjs +95 -0
- package/dist/actions/triggers/cron.cjs.map +1 -0
- package/dist/actions/triggers/cron.d.cts +1 -0
- package/dist/actions/triggers/cron.d.ts +1 -0
- package/dist/actions/triggers/cron.js +83 -0
- package/dist/actions/triggers/cron.js.map +1 -0
- package/dist/actions/triggers/index.cjs +9 -0
- package/dist/actions/triggers/index.cjs.map +1 -0
- package/dist/actions/triggers/index.d.cts +1 -0
- package/dist/actions/triggers/index.d.ts +1 -0
- package/dist/actions/triggers/index.js +9 -0
- package/dist/actions/triggers/index.js.map +1 -0
- package/dist/actions/triggers/manual.cjs +105 -0
- package/dist/actions/triggers/manual.cjs.map +1 -0
- package/dist/actions/triggers/manual.d.cts +1 -0
- package/dist/actions/triggers/manual.d.ts +1 -0
- package/dist/actions/triggers/manual.js +103 -0
- package/dist/actions/triggers/manual.js.map +1 -0
- package/dist/actions/types.d.cts +373 -0
- package/dist/actions/types.d.cts.map +1 -0
- package/dist/actions/types.d.ts +373 -0
- package/dist/actions/types.d.ts.map +1 -0
- package/dist/database/adapter-factory.cjs +188 -0
- package/dist/database/adapter-factory.cjs.map +1 -0
- package/dist/database/adapter-factory.js +187 -0
- package/dist/database/adapter-factory.js.map +1 -0
- package/dist/database/adapter.cjs +33 -0
- package/dist/database/adapter.cjs.map +1 -0
- package/dist/database/adapter.d.cts +76 -0
- package/dist/database/adapter.d.cts.map +1 -0
- package/dist/database/adapter.d.ts +76 -0
- package/dist/database/adapter.d.ts.map +1 -0
- package/dist/database/adapter.js +33 -0
- package/dist/database/adapter.js.map +1 -0
- package/dist/database/adapters/connection-bridge.cjs +119 -0
- package/dist/database/adapters/connection-bridge.cjs.map +1 -0
- package/dist/database/adapters/connection-bridge.js +118 -0
- package/dist/database/adapters/connection-bridge.js.map +1 -0
- package/dist/database/adapters/kysely-adapter.cjs +138 -0
- package/dist/database/adapters/kysely-adapter.cjs.map +1 -0
- package/dist/database/adapters/kysely-adapter.js +137 -0
- package/dist/database/adapters/kysely-adapter.js.map +1 -0
- package/dist/database/connection.cjs +277 -0
- package/dist/database/connection.cjs.map +1 -0
- package/dist/database/connection.d.cts +115 -0
- package/dist/database/connection.d.cts.map +1 -0
- package/dist/database/connection.d.ts +115 -0
- package/dist/database/connection.d.ts.map +1 -0
- package/dist/database/connection.js +271 -0
- package/dist/database/connection.js.map +1 -0
- package/dist/database/core-schema.cjs +644 -0
- package/dist/database/core-schema.cjs.map +1 -0
- package/dist/database/core-schema.d.cts +22 -0
- package/dist/database/core-schema.d.cts.map +1 -0
- package/dist/database/core-schema.d.ts +22 -0
- package/dist/database/core-schema.d.ts.map +1 -0
- package/dist/database/core-schema.js +642 -0
- package/dist/database/core-schema.js.map +1 -0
- package/dist/database/index.cjs +4 -0
- package/dist/database/index.d.cts +10 -0
- package/dist/database/index.d.cts.map +1 -0
- package/dist/database/index.d.ts +10 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +5 -0
- package/dist/database/prisma-schema-generator.cjs +219 -0
- package/dist/database/prisma-schema-generator.cjs.map +1 -0
- package/dist/database/prisma-schema-generator.d.cts +19 -0
- package/dist/database/prisma-schema-generator.d.cts.map +1 -0
- package/dist/database/prisma-schema-generator.d.ts +19 -0
- package/dist/database/prisma-schema-generator.d.ts.map +1 -0
- package/dist/database/prisma-schema-generator.js +218 -0
- package/dist/database/prisma-schema-generator.js.map +1 -0
- package/dist/database/schema-generator.cjs +576 -0
- package/dist/database/schema-generator.cjs.map +1 -0
- package/dist/database/schema-generator.d.cts +18 -0
- package/dist/database/schema-generator.d.cts.map +1 -0
- package/dist/database/schema-generator.d.ts +18 -0
- package/dist/database/schema-generator.d.ts.map +1 -0
- package/dist/database/schema-generator.js +571 -0
- package/dist/database/schema-generator.js.map +1 -0
- package/dist/database/schema-merger.cjs +153 -0
- package/dist/database/schema-merger.cjs.map +1 -0
- package/dist/database/schema-merger.d.cts +53 -0
- package/dist/database/schema-merger.d.cts.map +1 -0
- package/dist/database/schema-merger.d.ts +53 -0
- package/dist/database/schema-merger.d.ts.map +1 -0
- package/dist/database/schema-merger.js +152 -0
- package/dist/database/schema-merger.js.map +1 -0
- package/dist/database/schema-metadata.cjs +98 -0
- package/dist/database/schema-metadata.cjs.map +1 -0
- package/dist/database/schema-metadata.js +98 -0
- package/dist/database/schema-metadata.js.map +1 -0
- package/dist/database/schema-mysql.cjs +288 -0
- package/dist/database/schema-mysql.cjs.map +1 -0
- package/dist/database/schema-mysql.d.cts +2117 -0
- package/dist/database/schema-mysql.d.cts.map +1 -0
- package/dist/database/schema-mysql.d.ts +2117 -0
- package/dist/database/schema-mysql.d.ts.map +1 -0
- package/dist/database/schema-mysql.js +263 -0
- package/dist/database/schema-mysql.js.map +1 -0
- package/dist/database/schema-postgres.cjs +312 -0
- package/dist/database/schema-postgres.cjs.map +1 -0
- package/dist/database/schema-postgres.d.cts +2127 -0
- package/dist/database/schema-postgres.d.cts.map +1 -0
- package/dist/database/schema-postgres.d.ts +2127 -0
- package/dist/database/schema-postgres.d.ts.map +1 -0
- package/dist/database/schema-postgres.js +280 -0
- package/dist/database/schema-postgres.js.map +1 -0
- package/dist/database/schema-sqlite.cjs +247 -0
- package/dist/database/schema-sqlite.cjs.map +1 -0
- package/dist/database/schema-sqlite.d.cts +2294 -0
- package/dist/database/schema-sqlite.d.cts.map +1 -0
- package/dist/database/schema-sqlite.d.ts +2294 -0
- package/dist/database/schema-sqlite.d.ts.map +1 -0
- package/dist/database/schema-sqlite.js +222 -0
- package/dist/database/schema-sqlite.js.map +1 -0
- package/dist/database/schema-verification.cjs +123 -0
- package/dist/database/schema-verification.cjs.map +1 -0
- package/dist/database/schema-verification.d.cts +40 -0
- package/dist/database/schema-verification.d.cts.map +1 -0
- package/dist/database/schema-verification.d.ts +40 -0
- package/dist/database/schema-verification.d.ts.map +1 -0
- package/dist/database/schema-verification.js +123 -0
- package/dist/database/schema-verification.js.map +1 -0
- package/dist/database/schema.cjs +3 -0
- package/dist/database/schema.d.cts +3 -0
- package/dist/database/schema.d.ts +3 -0
- package/dist/database/schema.js +4 -0
- package/dist/index.cjs +199 -0
- package/dist/index.d.cts +70 -0
- package/dist/index.d.ts +70 -0
- package/dist/index.js +56 -0
- package/dist/invect-core.cjs +1688 -0
- package/dist/invect-core.cjs.map +1 -0
- package/dist/invect-core.d.cts +846 -0
- package/dist/invect-core.d.cts.map +1 -0
- package/dist/invect-core.d.ts +846 -0
- package/dist/invect-core.d.ts.map +1 -0
- package/dist/invect-core.js +1688 -0
- package/dist/invect-core.js.map +1 -0
- package/dist/nodes/agent-executor.cjs +881 -0
- package/dist/nodes/agent-executor.cjs.map +1 -0
- package/dist/nodes/agent-executor.d.cts +243 -0
- package/dist/nodes/agent-executor.d.cts.map +1 -0
- package/dist/nodes/agent-executor.d.ts +243 -0
- package/dist/nodes/agent-executor.d.ts.map +1 -0
- package/dist/nodes/agent-executor.js +877 -0
- package/dist/nodes/agent-executor.js.map +1 -0
- package/dist/nodes/base-node.cjs +174 -0
- package/dist/nodes/base-node.cjs.map +1 -0
- package/dist/nodes/base-node.d.cts +125 -0
- package/dist/nodes/base-node.d.cts.map +1 -0
- package/dist/nodes/base-node.d.ts +125 -0
- package/dist/nodes/base-node.d.ts.map +1 -0
- package/dist/nodes/base-node.js +170 -0
- package/dist/nodes/base-node.js.map +1 -0
- package/dist/nodes/executor-registry.cjs +46 -0
- package/dist/nodes/executor-registry.cjs.map +1 -0
- package/dist/nodes/executor-registry.d.cts +18 -0
- package/dist/nodes/executor-registry.d.cts.map +1 -0
- package/dist/nodes/executor-registry.d.ts +18 -0
- package/dist/nodes/executor-registry.d.ts.map +1 -0
- package/dist/nodes/executor-registry.js +46 -0
- package/dist/nodes/executor-registry.js.map +1 -0
- package/dist/nodes/index.cjs +2 -0
- package/dist/nodes/index.d.cts +3 -0
- package/dist/nodes/index.d.ts +3 -0
- package/dist/nodes/index.js +3 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.cjs +110 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.cjs.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.d.cts +42 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.d.cts.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.d.ts +42 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.d.ts.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.js +110 -0
- package/dist/services/agent-tool-executions/agent-tool-execution.service.js.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.cjs +152 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.cjs.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.d.cts +71 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.d.cts.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.d.ts +71 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.d.ts.map +1 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.js +152 -0
- package/dist/services/agent-tool-executions/agent-tool-executions.model.js.map +1 -0
- package/dist/services/agent-tools/agent-tool-registry.cjs +101 -0
- package/dist/services/agent-tools/agent-tool-registry.cjs.map +1 -0
- package/dist/services/agent-tools/agent-tool-registry.d.cts +51 -0
- package/dist/services/agent-tools/agent-tool-registry.d.cts.map +1 -0
- package/dist/services/agent-tools/agent-tool-registry.d.ts +51 -0
- package/dist/services/agent-tools/agent-tool-registry.d.ts.map +1 -0
- package/dist/services/agent-tools/agent-tool-registry.js +98 -0
- package/dist/services/agent-tools/agent-tool-registry.js.map +1 -0
- package/dist/services/agent-tools/builtin/index.cjs +17 -0
- package/dist/services/agent-tools/builtin/index.cjs.map +1 -0
- package/dist/services/agent-tools/builtin/index.js +17 -0
- package/dist/services/agent-tools/builtin/index.js.map +1 -0
- package/dist/services/agent-tools/builtin/json-logic-tool.cjs +73 -0
- package/dist/services/agent-tools/builtin/json-logic-tool.cjs.map +1 -0
- package/dist/services/agent-tools/builtin/json-logic-tool.js +70 -0
- package/dist/services/agent-tools/builtin/json-logic-tool.js.map +1 -0
- package/dist/services/agent-tools/builtin/math-tool.cjs +117 -0
- package/dist/services/agent-tools/builtin/math-tool.cjs.map +1 -0
- package/dist/services/agent-tools/builtin/math-tool.js +116 -0
- package/dist/services/agent-tools/builtin/math-tool.js.map +1 -0
- package/dist/services/agent-tools/index.cjs +2 -0
- package/dist/services/agent-tools/index.js +3 -0
- package/dist/services/ai/ai-types.cjs +37 -0
- package/dist/services/ai/ai-types.cjs.map +1 -0
- package/dist/services/ai/ai-types.d.cts +105 -0
- package/dist/services/ai/ai-types.d.cts.map +1 -0
- package/dist/services/ai/ai-types.d.ts +105 -0
- package/dist/services/ai/ai-types.d.ts.map +1 -0
- package/dist/services/ai/ai-types.js +35 -0
- package/dist/services/ai/ai-types.js.map +1 -0
- package/dist/services/ai/anthropic-adapter.cjs +411 -0
- package/dist/services/ai/anthropic-adapter.cjs.map +1 -0
- package/dist/services/ai/anthropic-adapter.d.cts +1 -0
- package/dist/services/ai/anthropic-adapter.d.ts +1 -0
- package/dist/services/ai/anthropic-adapter.js +409 -0
- package/dist/services/ai/anthropic-adapter.js.map +1 -0
- package/dist/services/ai/base-client.cjs +345 -0
- package/dist/services/ai/base-client.cjs.map +1 -0
- package/dist/services/ai/base-client.d.cts +138 -0
- package/dist/services/ai/base-client.d.cts.map +1 -0
- package/dist/services/ai/base-client.d.ts +138 -0
- package/dist/services/ai/base-client.d.ts.map +1 -0
- package/dist/services/ai/base-client.js +345 -0
- package/dist/services/ai/base-client.js.map +1 -0
- package/dist/services/ai/openai-adapter.cjs +460 -0
- package/dist/services/ai/openai-adapter.cjs.map +1 -0
- package/dist/services/ai/openai-adapter.d.cts +1 -0
- package/dist/services/ai/openai-adapter.d.ts +1 -0
- package/dist/services/ai/openai-adapter.js +458 -0
- package/dist/services/ai/openai-adapter.js.map +1 -0
- package/dist/services/ai/openrouter-adapter.cjs +124 -0
- package/dist/services/ai/openrouter-adapter.cjs.map +1 -0
- package/dist/services/ai/openrouter-adapter.d.cts +1 -0
- package/dist/services/ai/openrouter-adapter.d.ts +1 -0
- package/dist/services/ai/openrouter-adapter.js +122 -0
- package/dist/services/ai/openrouter-adapter.js.map +1 -0
- package/dist/services/ai/provider-adapter.cjs +72 -0
- package/dist/services/ai/provider-adapter.cjs.map +1 -0
- package/dist/services/ai/provider-adapter.d.cts +81 -0
- package/dist/services/ai/provider-adapter.d.cts.map +1 -0
- package/dist/services/ai/provider-adapter.d.ts +81 -0
- package/dist/services/ai/provider-adapter.d.ts.map +1 -0
- package/dist/services/ai/provider-adapter.js +72 -0
- package/dist/services/ai/provider-adapter.js.map +1 -0
- package/dist/services/auth/authorization.service.cjs +259 -0
- package/dist/services/auth/authorization.service.cjs.map +1 -0
- package/dist/services/auth/authorization.service.d.cts +102 -0
- package/dist/services/auth/authorization.service.d.cts.map +1 -0
- package/dist/services/auth/authorization.service.d.ts +102 -0
- package/dist/services/auth/authorization.service.d.ts.map +1 -0
- package/dist/services/auth/authorization.service.js +257 -0
- package/dist/services/auth/authorization.service.js.map +1 -0
- package/dist/services/auth/flow-access.service.cjs +259 -0
- package/dist/services/auth/flow-access.service.cjs.map +1 -0
- package/dist/services/auth/flow-access.service.d.cts +89 -0
- package/dist/services/auth/flow-access.service.d.cts.map +1 -0
- package/dist/services/auth/flow-access.service.d.ts +89 -0
- package/dist/services/auth/flow-access.service.d.ts.map +1 -0
- package/dist/services/auth/flow-access.service.js +259 -0
- package/dist/services/auth/flow-access.service.js.map +1 -0
- package/dist/services/auth/index.d.ts +2 -0
- package/dist/services/batch-jobs/batch-jobs.model.cjs +213 -0
- package/dist/services/batch-jobs/batch-jobs.model.cjs.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.model.d.cts +79 -0
- package/dist/services/batch-jobs/batch-jobs.model.d.cts.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.model.d.ts +79 -0
- package/dist/services/batch-jobs/batch-jobs.model.d.ts.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.model.js +213 -0
- package/dist/services/batch-jobs/batch-jobs.model.js.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.service.cjs +178 -0
- package/dist/services/batch-jobs/batch-jobs.service.cjs.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.service.d.cts +83 -0
- package/dist/services/batch-jobs/batch-jobs.service.d.cts.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.service.d.ts +83 -0
- package/dist/services/batch-jobs/batch-jobs.service.d.ts.map +1 -0
- package/dist/services/batch-jobs/batch-jobs.service.js +178 -0
- package/dist/services/batch-jobs/batch-jobs.service.js.map +1 -0
- package/dist/services/chat/chat-messages.model.cjs +143 -0
- package/dist/services/chat/chat-messages.model.cjs.map +1 -0
- package/dist/services/chat/chat-messages.model.d.cts +43 -0
- package/dist/services/chat/chat-messages.model.d.cts.map +1 -0
- package/dist/services/chat/chat-messages.model.d.ts +43 -0
- package/dist/services/chat/chat-messages.model.d.ts.map +1 -0
- package/dist/services/chat/chat-messages.model.js +142 -0
- package/dist/services/chat/chat-messages.model.js.map +1 -0
- package/dist/services/chat/chat-stream-session.cjs +181 -0
- package/dist/services/chat/chat-stream-session.cjs.map +1 -0
- package/dist/services/chat/chat-stream-session.d.cts +1 -0
- package/dist/services/chat/chat-stream-session.d.ts +1 -0
- package/dist/services/chat/chat-stream-session.js +181 -0
- package/dist/services/chat/chat-stream-session.js.map +1 -0
- package/dist/services/chat/chat-stream.service.cjs +205 -0
- package/dist/services/chat/chat-stream.service.cjs.map +1 -0
- package/dist/services/chat/chat-stream.service.d.cts +84 -0
- package/dist/services/chat/chat-stream.service.d.cts.map +1 -0
- package/dist/services/chat/chat-stream.service.d.ts +84 -0
- package/dist/services/chat/chat-stream.service.d.ts.map +1 -0
- package/dist/services/chat/chat-stream.service.js +205 -0
- package/dist/services/chat/chat-stream.service.js.map +1 -0
- package/dist/services/chat/chat-toolkit.cjs +125 -0
- package/dist/services/chat/chat-toolkit.cjs.map +1 -0
- package/dist/services/chat/chat-toolkit.d.cts +58 -0
- package/dist/services/chat/chat-toolkit.d.cts.map +1 -0
- package/dist/services/chat/chat-toolkit.d.ts +58 -0
- package/dist/services/chat/chat-toolkit.d.ts.map +1 -0
- package/dist/services/chat/chat-toolkit.js +124 -0
- package/dist/services/chat/chat-toolkit.js.map +1 -0
- package/dist/services/chat/chat-types.cjs +24 -0
- package/dist/services/chat/chat-types.cjs.map +1 -0
- package/dist/services/chat/chat-types.d.cts +134 -0
- package/dist/services/chat/chat-types.d.cts.map +1 -0
- package/dist/services/chat/chat-types.d.ts +134 -0
- package/dist/services/chat/chat-types.d.ts.map +1 -0
- package/dist/services/chat/chat-types.js +23 -0
- package/dist/services/chat/chat-types.js.map +1 -0
- package/dist/services/chat/index.cjs +5 -0
- package/dist/services/chat/index.d.cts +3 -0
- package/dist/services/chat/index.d.ts +3 -0
- package/dist/services/chat/index.js +6 -0
- package/dist/services/chat/system-prompt.cjs +223 -0
- package/dist/services/chat/system-prompt.cjs.map +1 -0
- package/dist/services/chat/system-prompt.d.cts +1 -0
- package/dist/services/chat/system-prompt.d.ts +1 -0
- package/dist/services/chat/system-prompt.js +223 -0
- package/dist/services/chat/system-prompt.js.map +1 -0
- package/dist/services/chat/tools/agent-tools.cjs +472 -0
- package/dist/services/chat/tools/agent-tools.cjs.map +1 -0
- package/dist/services/chat/tools/agent-tools.js +471 -0
- package/dist/services/chat/tools/agent-tools.js.map +1 -0
- package/dist/services/chat/tools/context-tools.cjs +252 -0
- package/dist/services/chat/tools/context-tools.cjs.map +1 -0
- package/dist/services/chat/tools/context-tools.js +251 -0
- package/dist/services/chat/tools/context-tools.js.map +1 -0
- package/dist/services/chat/tools/flow-tools.cjs +244 -0
- package/dist/services/chat/tools/flow-tools.cjs.map +1 -0
- package/dist/services/chat/tools/flow-tools.js +243 -0
- package/dist/services/chat/tools/flow-tools.js.map +1 -0
- package/dist/services/chat/tools/index.cjs +22 -0
- package/dist/services/chat/tools/index.cjs.map +1 -0
- package/dist/services/chat/tools/index.js +22 -0
- package/dist/services/chat/tools/index.js.map +1 -0
- package/dist/services/chat/tools/node-tools.cjs +323 -0
- package/dist/services/chat/tools/node-tools.cjs.map +1 -0
- package/dist/services/chat/tools/node-tools.js +322 -0
- package/dist/services/chat/tools/node-tools.js.map +1 -0
- package/dist/services/chat/tools/plan-tools.cjs +94 -0
- package/dist/services/chat/tools/plan-tools.cjs.map +1 -0
- package/dist/services/chat/tools/plan-tools.js +93 -0
- package/dist/services/chat/tools/plan-tools.js.map +1 -0
- package/dist/services/chat/tools/run-tools.cjs +121 -0
- package/dist/services/chat/tools/run-tools.cjs.map +1 -0
- package/dist/services/chat/tools/run-tools.js +120 -0
- package/dist/services/chat/tools/run-tools.js.map +1 -0
- package/dist/services/credentials/credentials.model.cjs +313 -0
- package/dist/services/credentials/credentials.model.cjs.map +1 -0
- package/dist/services/credentials/credentials.model.d.cts +27 -0
- package/dist/services/credentials/credentials.model.d.cts.map +1 -0
- package/dist/services/credentials/credentials.model.d.ts +27 -0
- package/dist/services/credentials/credentials.model.d.ts.map +1 -0
- package/dist/services/credentials/credentials.model.js +312 -0
- package/dist/services/credentials/credentials.model.js.map +1 -0
- package/dist/services/credentials/credentials.service.cjs +358 -0
- package/dist/services/credentials/credentials.service.cjs.map +1 -0
- package/dist/services/credentials/credentials.service.d.cts +156 -0
- package/dist/services/credentials/credentials.service.d.cts.map +1 -0
- package/dist/services/credentials/credentials.service.d.ts +156 -0
- package/dist/services/credentials/credentials.service.d.ts.map +1 -0
- package/dist/services/credentials/credentials.service.js +357 -0
- package/dist/services/credentials/credentials.service.js.map +1 -0
- package/dist/services/credentials/encryption.service.cjs +121 -0
- package/dist/services/credentials/encryption.service.cjs.map +1 -0
- package/dist/services/credentials/encryption.service.d.cts +70 -0
- package/dist/services/credentials/encryption.service.d.cts.map +1 -0
- package/dist/services/credentials/encryption.service.d.ts +70 -0
- package/dist/services/credentials/encryption.service.d.ts.map +1 -0
- package/dist/services/credentials/encryption.service.js +119 -0
- package/dist/services/credentials/encryption.service.js.map +1 -0
- package/dist/services/credentials/index.d.cts +4 -0
- package/dist/services/credentials/index.d.ts +4 -0
- package/dist/services/credentials/oauth2-providers.cjs +668 -0
- package/dist/services/credentials/oauth2-providers.cjs.map +1 -0
- package/dist/services/credentials/oauth2-providers.d.cts +39 -0
- package/dist/services/credentials/oauth2-providers.d.cts.map +1 -0
- package/dist/services/credentials/oauth2-providers.d.ts +39 -0
- package/dist/services/credentials/oauth2-providers.d.ts.map +1 -0
- package/dist/services/credentials/oauth2-providers.js +667 -0
- package/dist/services/credentials/oauth2-providers.js.map +1 -0
- package/dist/services/credentials/oauth2.service.cjs +252 -0
- package/dist/services/credentials/oauth2.service.cjs.map +1 -0
- package/dist/services/credentials/oauth2.service.d.cts +132 -0
- package/dist/services/credentials/oauth2.service.d.cts.map +1 -0
- package/dist/services/credentials/oauth2.service.d.ts +132 -0
- package/dist/services/credentials/oauth2.service.d.ts.map +1 -0
- package/dist/services/credentials/oauth2.service.js +251 -0
- package/dist/services/credentials/oauth2.service.js.map +1 -0
- package/dist/services/database/database.service.cjs +469 -0
- package/dist/services/database/database.service.cjs.map +1 -0
- package/dist/services/database/database.service.d.cts +162 -0
- package/dist/services/database/database.service.d.cts.map +1 -0
- package/dist/services/database/database.service.d.ts +162 -0
- package/dist/services/database/database.service.d.ts.map +1 -0
- package/dist/services/database/database.service.js +469 -0
- package/dist/services/database/database.service.js.map +1 -0
- package/dist/services/execution-event-bus.cjs +80 -0
- package/dist/services/execution-event-bus.cjs.map +1 -0
- package/dist/services/execution-event-bus.d.cts +57 -0
- package/dist/services/execution-event-bus.d.cts.map +1 -0
- package/dist/services/execution-event-bus.d.ts +57 -0
- package/dist/services/execution-event-bus.d.ts.map +1 -0
- package/dist/services/execution-event-bus.js +77 -0
- package/dist/services/execution-event-bus.js.map +1 -0
- package/dist/services/flow-orchestration/flow-run-coordinator.cjs +499 -0
- package/dist/services/flow-orchestration/flow-run-coordinator.cjs.map +1 -0
- package/dist/services/flow-orchestration/flow-run-coordinator.js +499 -0
- package/dist/services/flow-orchestration/flow-run-coordinator.js.map +1 -0
- package/dist/services/flow-orchestration/node-execution-coordinator.cjs +657 -0
- package/dist/services/flow-orchestration/node-execution-coordinator.cjs.map +1 -0
- package/dist/services/flow-orchestration/node-execution-coordinator.js +657 -0
- package/dist/services/flow-orchestration/node-execution-coordinator.js.map +1 -0
- package/dist/services/flow-orchestration.service.cjs +493 -0
- package/dist/services/flow-orchestration.service.cjs.map +1 -0
- package/dist/services/flow-orchestration.service.d.cts +149 -0
- package/dist/services/flow-orchestration.service.d.cts.map +1 -0
- package/dist/services/flow-orchestration.service.d.ts +149 -0
- package/dist/services/flow-orchestration.service.d.ts.map +1 -0
- package/dist/services/flow-orchestration.service.js +493 -0
- package/dist/services/flow-orchestration.service.js.map +1 -0
- package/dist/services/flow-runs/flow-runs.model.cjs +403 -0
- package/dist/services/flow-runs/flow-runs.model.cjs.map +1 -0
- package/dist/services/flow-runs/flow-runs.model.d.cts +113 -0
- package/dist/services/flow-runs/flow-runs.model.d.cts.map +1 -0
- package/dist/services/flow-runs/flow-runs.model.d.ts +113 -0
- package/dist/services/flow-runs/flow-runs.model.d.ts.map +1 -0
- package/dist/services/flow-runs/flow-runs.model.js +403 -0
- package/dist/services/flow-runs/flow-runs.model.js.map +1 -0
- package/dist/services/flow-runs/flow-runs.service.cjs +273 -0
- package/dist/services/flow-runs/flow-runs.service.cjs.map +1 -0
- package/dist/services/flow-runs/flow-runs.service.d.cts +129 -0
- package/dist/services/flow-runs/flow-runs.service.d.cts.map +1 -0
- package/dist/services/flow-runs/flow-runs.service.d.ts +129 -0
- package/dist/services/flow-runs/flow-runs.service.d.ts.map +1 -0
- package/dist/services/flow-runs/flow-runs.service.js +273 -0
- package/dist/services/flow-runs/flow-runs.service.js.map +1 -0
- package/dist/services/flow-validator.cjs +149 -0
- package/dist/services/flow-validator.cjs.map +1 -0
- package/dist/services/flow-validator.js +149 -0
- package/dist/services/flow-validator.js.map +1 -0
- package/dist/services/flow-versions/flow-versions.model.cjs +231 -0
- package/dist/services/flow-versions/flow-versions.model.cjs.map +1 -0
- package/dist/services/flow-versions/flow-versions.model.d.cts +55 -0
- package/dist/services/flow-versions/flow-versions.model.d.cts.map +1 -0
- package/dist/services/flow-versions/flow-versions.model.d.ts +55 -0
- package/dist/services/flow-versions/flow-versions.model.d.ts.map +1 -0
- package/dist/services/flow-versions/flow-versions.model.js +231 -0
- package/dist/services/flow-versions/flow-versions.model.js.map +1 -0
- package/dist/services/flow-versions/flow-versions.service.cjs +72 -0
- package/dist/services/flow-versions/flow-versions.service.cjs.map +1 -0
- package/dist/services/flow-versions/flow-versions.service.d.cts +63 -0
- package/dist/services/flow-versions/flow-versions.service.d.cts.map +1 -0
- package/dist/services/flow-versions/flow-versions.service.d.ts +63 -0
- package/dist/services/flow-versions/flow-versions.service.d.ts.map +1 -0
- package/dist/services/flow-versions/flow-versions.service.js +72 -0
- package/dist/services/flow-versions/flow-versions.service.js.map +1 -0
- package/dist/services/flow-versions/schemas-fresh.cjs +90 -0
- package/dist/services/flow-versions/schemas-fresh.cjs.map +1 -0
- package/dist/services/flow-versions/schemas-fresh.d.cts +201 -0
- package/dist/services/flow-versions/schemas-fresh.d.cts.map +1 -0
- package/dist/services/flow-versions/schemas-fresh.d.ts +201 -0
- package/dist/services/flow-versions/schemas-fresh.d.ts.map +1 -0
- package/dist/services/flow-versions/schemas-fresh.js +85 -0
- package/dist/services/flow-versions/schemas-fresh.js.map +1 -0
- package/dist/services/flows/flows.model.cjs +273 -0
- package/dist/services/flows/flows.model.cjs.map +1 -0
- package/dist/services/flows/flows.model.d.cts +105 -0
- package/dist/services/flows/flows.model.d.cts.map +1 -0
- package/dist/services/flows/flows.model.d.ts +105 -0
- package/dist/services/flows/flows.model.d.ts.map +1 -0
- package/dist/services/flows/flows.model.js +273 -0
- package/dist/services/flows/flows.model.js.map +1 -0
- package/dist/services/flows/flows.service.cjs +134 -0
- package/dist/services/flows/flows.service.cjs.map +1 -0
- package/dist/services/flows/flows.service.d.cts +105 -0
- package/dist/services/flows/flows.service.d.cts.map +1 -0
- package/dist/services/flows/flows.service.d.ts +105 -0
- package/dist/services/flows/flows.service.d.ts.map +1 -0
- package/dist/services/flows/flows.service.js +134 -0
- package/dist/services/flows/flows.service.js.map +1 -0
- package/dist/services/graph.service.cjs +375 -0
- package/dist/services/graph.service.cjs.map +1 -0
- package/dist/services/graph.service.d.cts +90 -0
- package/dist/services/graph.service.d.cts.map +1 -0
- package/dist/services/graph.service.d.ts +90 -0
- package/dist/services/graph.service.d.ts.map +1 -0
- package/dist/services/graph.service.js +375 -0
- package/dist/services/graph.service.js.map +1 -0
- package/dist/services/node-data.service.cjs +232 -0
- package/dist/services/node-data.service.cjs.map +1 -0
- package/dist/services/node-data.service.d.cts +119 -0
- package/dist/services/node-data.service.d.cts.map +1 -0
- package/dist/services/node-data.service.d.ts +119 -0
- package/dist/services/node-data.service.d.ts.map +1 -0
- package/dist/services/node-data.service.js +230 -0
- package/dist/services/node-data.service.js.map +1 -0
- package/dist/services/node-executions/node-execution.service.cjs +236 -0
- package/dist/services/node-executions/node-execution.service.cjs.map +1 -0
- package/dist/services/node-executions/node-execution.service.d.cts +126 -0
- package/dist/services/node-executions/node-execution.service.d.cts.map +1 -0
- package/dist/services/node-executions/node-execution.service.d.ts +126 -0
- package/dist/services/node-executions/node-execution.service.d.ts.map +1 -0
- package/dist/services/node-executions/node-execution.service.js +236 -0
- package/dist/services/node-executions/node-execution.service.js.map +1 -0
- package/dist/services/node-executions/node-executions.model.cjs +300 -0
- package/dist/services/node-executions/node-executions.model.cjs.map +1 -0
- package/dist/services/node-executions/node-executions.model.d.cts +102 -0
- package/dist/services/node-executions/node-executions.model.d.cts.map +1 -0
- package/dist/services/node-executions/node-executions.model.d.ts +102 -0
- package/dist/services/node-executions/node-executions.model.d.ts.map +1 -0
- package/dist/services/node-executions/node-executions.model.js +300 -0
- package/dist/services/node-executions/node-executions.model.js.map +1 -0
- package/dist/services/plugin-manager.cjs +205 -0
- package/dist/services/plugin-manager.cjs.map +1 -0
- package/dist/services/plugin-manager.js +205 -0
- package/dist/services/plugin-manager.js.map +1 -0
- package/dist/services/react-flow-renderer.service.cjs +236 -0
- package/dist/services/react-flow-renderer.service.cjs.map +1 -0
- package/dist/services/react-flow-renderer.service.d.cts +149 -0
- package/dist/services/react-flow-renderer.service.d.cts.map +1 -0
- package/dist/services/react-flow-renderer.service.d.ts +149 -0
- package/dist/services/react-flow-renderer.service.d.ts.map +1 -0
- package/dist/services/react-flow-renderer.service.js +235 -0
- package/dist/services/react-flow-renderer.service.js.map +1 -0
- package/dist/services/service-factory.cjs +301 -0
- package/dist/services/service-factory.cjs.map +1 -0
- package/dist/services/service-factory.d.cts +172 -0
- package/dist/services/service-factory.d.cts.map +1 -0
- package/dist/services/service-factory.d.ts +172 -0
- package/dist/services/service-factory.d.ts.map +1 -0
- package/dist/services/service-factory.js +301 -0
- package/dist/services/service-factory.js.map +1 -0
- package/dist/services/templating/index.cjs +2 -0
- package/dist/services/templating/index.d.ts +2 -0
- package/dist/services/templating/index.js +3 -0
- package/dist/services/templating/js-expression.service.cjs +148 -0
- package/dist/services/templating/js-expression.service.cjs.map +1 -0
- package/dist/services/templating/js-expression.service.d.cts +61 -0
- package/dist/services/templating/js-expression.service.d.cts.map +1 -0
- package/dist/services/templating/js-expression.service.d.ts +60 -0
- package/dist/services/templating/js-expression.service.d.ts.map +1 -0
- package/dist/services/templating/js-expression.service.js +143 -0
- package/dist/services/templating/js-expression.service.js.map +1 -0
- package/dist/services/templating/template.service.cjs +182 -0
- package/dist/services/templating/template.service.cjs.map +1 -0
- package/dist/services/templating/template.service.d.cts +62 -0
- package/dist/services/templating/template.service.d.cts.map +1 -0
- package/dist/services/templating/template.service.d.ts +62 -0
- package/dist/services/templating/template.service.d.ts.map +1 -0
- package/dist/services/templating/template.service.js +180 -0
- package/dist/services/templating/template.service.js.map +1 -0
- package/dist/services/triggers/cron-scheduler.service.cjs +141 -0
- package/dist/services/triggers/cron-scheduler.service.cjs.map +1 -0
- package/dist/services/triggers/cron-scheduler.service.d.cts +36 -0
- package/dist/services/triggers/cron-scheduler.service.d.cts.map +1 -0
- package/dist/services/triggers/cron-scheduler.service.d.ts +36 -0
- package/dist/services/triggers/cron-scheduler.service.d.ts.map +1 -0
- package/dist/services/triggers/cron-scheduler.service.js +140 -0
- package/dist/services/triggers/cron-scheduler.service.js.map +1 -0
- package/dist/services/triggers/flow-triggers.model.cjs +241 -0
- package/dist/services/triggers/flow-triggers.model.cjs.map +1 -0
- package/dist/services/triggers/flow-triggers.model.d.cts +53 -0
- package/dist/services/triggers/flow-triggers.model.d.cts.map +1 -0
- package/dist/services/triggers/flow-triggers.model.d.ts +53 -0
- package/dist/services/triggers/flow-triggers.model.d.ts.map +1 -0
- package/dist/services/triggers/flow-triggers.model.js +241 -0
- package/dist/services/triggers/flow-triggers.model.js.map +1 -0
- package/dist/services/triggers/flow-triggers.service.cjs +218 -0
- package/dist/services/triggers/flow-triggers.service.cjs.map +1 -0
- package/dist/services/triggers/flow-triggers.service.d.cts +77 -0
- package/dist/services/triggers/flow-triggers.service.d.cts.map +1 -0
- package/dist/services/triggers/flow-triggers.service.d.ts +77 -0
- package/dist/services/triggers/flow-triggers.service.d.ts.map +1 -0
- package/dist/services/triggers/flow-triggers.service.js +217 -0
- package/dist/services/triggers/flow-triggers.service.js.map +1 -0
- package/dist/services/triggers/index.cjs +3 -0
- package/dist/services/triggers/index.d.cts +4 -0
- package/dist/services/triggers/index.d.ts +4 -0
- package/dist/services/triggers/index.js +4 -0
- package/dist/services/triggers/trigger.types.d.cts +63 -0
- package/dist/services/triggers/trigger.types.d.cts.map +1 -0
- package/dist/services/triggers/trigger.types.d.ts +63 -0
- package/dist/services/triggers/trigger.types.d.ts.map +1 -0
- package/dist/types/agent-tool.types.cjs +20 -0
- package/dist/types/agent-tool.types.cjs.map +1 -0
- package/dist/types/agent-tool.types.d.cts +211 -0
- package/dist/types/agent-tool.types.d.cts.map +1 -0
- package/dist/types/agent-tool.types.d.ts +211 -0
- package/dist/types/agent-tool.types.d.ts.map +1 -0
- package/dist/types/agent-tool.types.js +18 -0
- package/dist/types/agent-tool.types.js.map +1 -0
- package/dist/types/auth.types.cjs +76 -0
- package/dist/types/auth.types.cjs.map +1 -0
- package/dist/types/auth.types.d.cts +235 -0
- package/dist/types/auth.types.d.cts.map +1 -0
- package/dist/types/auth.types.d.ts +235 -0
- package/dist/types/auth.types.d.ts.map +1 -0
- package/dist/types/auth.types.js +75 -0
- package/dist/types/auth.types.js.map +1 -0
- package/dist/types/base.cjs +25 -0
- package/dist/types/base.cjs.map +1 -0
- package/dist/types/base.d.cts +21 -0
- package/dist/types/base.d.cts.map +1 -0
- package/dist/types/base.d.ts +21 -0
- package/dist/types/base.d.ts.map +1 -0
- package/dist/types/base.js +24 -0
- package/dist/types/base.js.map +1 -0
- package/dist/types/common/errors.types.cjs +46 -0
- package/dist/types/common/errors.types.cjs.map +1 -0
- package/dist/types/common/errors.types.js +44 -0
- package/dist/types/common/errors.types.js.map +1 -0
- package/dist/types/graph-node-types.cjs +46 -0
- package/dist/types/graph-node-types.cjs.map +1 -0
- package/dist/types/graph-node-types.d.cts +32 -0
- package/dist/types/graph-node-types.d.cts.map +1 -0
- package/dist/types/graph-node-types.d.ts +32 -0
- package/dist/types/graph-node-types.d.ts.map +1 -0
- package/dist/types/graph-node-types.js +45 -0
- package/dist/types/graph-node-types.js.map +1 -0
- package/dist/types/node-config-update.types.d.cts +33 -0
- package/dist/types/node-config-update.types.d.cts.map +1 -0
- package/dist/types/node-config-update.types.d.ts +33 -0
- package/dist/types/node-config-update.types.d.ts.map +1 -0
- package/dist/types/node-definition.types.d.cts +88 -0
- package/dist/types/node-definition.types.d.cts.map +1 -0
- package/dist/types/node-definition.types.d.ts +88 -0
- package/dist/types/node-definition.types.d.ts.map +1 -0
- package/dist/types/node-execution.types.d.cts +39 -0
- package/dist/types/node-execution.types.d.cts.map +1 -0
- package/dist/types/node-execution.types.d.ts +39 -0
- package/dist/types/node-execution.types.d.ts.map +1 -0
- package/dist/types/node-io-types.cjs +19 -0
- package/dist/types/node-io-types.cjs.map +1 -0
- package/dist/types/node-io-types.d.cts +65 -0
- package/dist/types/node-io-types.d.cts.map +1 -0
- package/dist/types/node-io-types.d.ts +65 -0
- package/dist/types/node-io-types.d.ts.map +1 -0
- package/dist/types/node-io-types.js +18 -0
- package/dist/types/node-io-types.js.map +1 -0
- package/dist/types/node-output-schemas.cjs +51 -0
- package/dist/types/node-output-schemas.cjs.map +1 -0
- package/dist/types/node-output-schemas.js +50 -0
- package/dist/types/node-output-schemas.js.map +1 -0
- package/dist/types/plugin.types.d.cts +654 -0
- package/dist/types/plugin.types.d.cts.map +1 -0
- package/dist/types/plugin.types.d.ts +654 -0
- package/dist/types/plugin.types.d.ts.map +1 -0
- package/dist/types/schemas/flow/create-flow-version.schema.cjs +1 -0
- package/dist/types/schemas/flow/create-flow-version.schema.d.ts +1 -0
- package/dist/types/schemas/flow/create-flow-version.schema.js +2 -0
- package/dist/types/schemas/flow/create-flow.schema.cjs +9 -0
- package/dist/types/schemas/flow/create-flow.schema.cjs.map +1 -0
- package/dist/types/schemas/flow/create-flow.schema.d.cts +14 -0
- package/dist/types/schemas/flow/create-flow.schema.d.cts.map +1 -0
- package/dist/types/schemas/flow/create-flow.schema.d.ts +14 -0
- package/dist/types/schemas/flow/create-flow.schema.d.ts.map +1 -0
- package/dist/types/schemas/flow/create-flow.schema.js +10 -0
- package/dist/types/schemas/flow/create-flow.schema.js.map +1 -0
- package/dist/types/schemas/flow/delete-flow.schema.cjs +11 -0
- package/dist/types/schemas/flow/delete-flow.schema.cjs.map +1 -0
- package/dist/types/schemas/flow/delete-flow.schema.d.ts +1 -0
- package/dist/types/schemas/flow/delete-flow.schema.js +11 -0
- package/dist/types/schemas/flow/delete-flow.schema.js.map +1 -0
- package/dist/types/schemas/flow/flow-executions.schema.cjs +36 -0
- package/dist/types/schemas/flow/flow-executions.schema.cjs.map +1 -0
- package/dist/types/schemas/flow/flow-executions.schema.d.ts +1 -0
- package/dist/types/schemas/flow/flow-executions.schema.js +35 -0
- package/dist/types/schemas/flow/flow-executions.schema.js.map +1 -0
- package/dist/types/schemas/flow/get-flow-by-id-response.schema.cjs +7 -0
- package/dist/types/schemas/flow/get-flow-by-id-response.schema.cjs.map +1 -0
- package/dist/types/schemas/flow/get-flow-by-id-response.schema.d.ts +1 -0
- package/dist/types/schemas/flow/get-flow-by-id-response.schema.js +7 -0
- package/dist/types/schemas/flow/get-flow-by-id-response.schema.js.map +1 -0
- package/dist/types/schemas/flow/get-flow-versions-response.schema.cjs +1 -0
- package/dist/types/schemas/flow/get-flow-versions-response.schema.d.ts +1 -0
- package/dist/types/schemas/flow/get-flow-versions-response.schema.js +2 -0
- package/dist/types/schemas/flow/get-flows-response.schema.cjs +6 -0
- package/dist/types/schemas/flow/get-flows-response.schema.cjs.map +1 -0
- package/dist/types/schemas/flow/get-flows-response.schema.d.ts +1 -0
- package/dist/types/schemas/flow/get-flows-response.schema.js +7 -0
- package/dist/types/schemas/flow/get-flows-response.schema.js.map +1 -0
- package/dist/types/schemas/flow/index.cjs +9 -0
- package/dist/types/schemas/flow/index.d.ts +1 -0
- package/dist/types/schemas/flow/index.js +10 -0
- package/dist/types/schemas/flow/update-flow.schema.cjs +1 -0
- package/dist/types/schemas/flow/update-flow.schema.d.ts +1 -0
- package/dist/types/schemas/flow/update-flow.schema.js +2 -0
- package/dist/types/schemas/flow/validate-flow.schema.cjs +19 -0
- package/dist/types/schemas/flow/validate-flow.schema.cjs.map +1 -0
- package/dist/types/schemas/flow/validate-flow.schema.d.ts +1 -0
- package/dist/types/schemas/flow/validate-flow.schema.js +19 -0
- package/dist/types/schemas/flow/validate-flow.schema.js.map +1 -0
- package/dist/types/schemas/index.cjs +3 -0
- package/dist/types/schemas/index.d.ts +2 -0
- package/dist/types/schemas/index.js +4 -0
- package/dist/types/schemas/pagination-sort-filter.cjs +56 -0
- package/dist/types/schemas/pagination-sort-filter.cjs.map +1 -0
- package/dist/types/schemas/pagination-sort-filter.d.cts +38 -0
- package/dist/types/schemas/pagination-sort-filter.d.cts.map +1 -0
- package/dist/types/schemas/pagination-sort-filter.d.ts +38 -0
- package/dist/types/schemas/pagination-sort-filter.d.ts.map +1 -0
- package/dist/types/schemas/pagination-sort-filter.js +50 -0
- package/dist/types/schemas/pagination-sort-filter.js.map +1 -0
- package/dist/types/schemas-fresh/invect-config.cjs +181 -0
- package/dist/types/schemas-fresh/invect-config.cjs.map +1 -0
- package/dist/types/schemas-fresh/invect-config.d.cts +207 -0
- package/dist/types/schemas-fresh/invect-config.d.cts.map +1 -0
- package/dist/types/schemas-fresh/invect-config.d.ts +207 -0
- package/dist/types/schemas-fresh/invect-config.d.ts.map +1 -0
- package/dist/types/schemas-fresh/invect-config.js +174 -0
- package/dist/types/schemas-fresh/invect-config.js.map +1 -0
- package/dist/types/validation/common.schemas.cjs +41 -0
- package/dist/types/validation/common.schemas.cjs.map +1 -0
- package/dist/types/validation/common.schemas.js +39 -0
- package/dist/types/validation/common.schemas.js.map +1 -0
- package/dist/types/validation/flow.schemas.cjs +49 -0
- package/dist/types/validation/flow.schemas.cjs.map +1 -0
- package/dist/types/validation/flow.schemas.js +46 -0
- package/dist/types/validation/flow.schemas.js.map +1 -0
- package/dist/types/validation.cjs +49 -0
- package/dist/types/validation.cjs.map +1 -0
- package/dist/types/validation.d.cts +49 -0
- package/dist/types/validation.d.cts.map +1 -0
- package/dist/types/validation.d.ts +49 -0
- package/dist/types/validation.d.ts.map +1 -0
- package/dist/types/validation.js +48 -0
- package/dist/types/validation.js.map +1 -0
- package/dist/types-export.cjs +11 -0
- package/dist/types-export.d.cts +25 -0
- package/dist/types-export.d.ts +25 -0
- package/dist/types-export.js +5 -0
- package/dist/types-fresh.cjs +9 -0
- package/dist/types-fresh.cjs.map +1 -0
- package/dist/types-fresh.d.cts +129 -0
- package/dist/types-fresh.d.cts.map +1 -0
- package/dist/types-fresh.d.ts +129 -0
- package/dist/types-fresh.d.ts.map +1 -0
- package/dist/types-fresh.js +8 -0
- package/dist/types-fresh.js.map +1 -0
- package/dist/utils/id-generator.cjs +34 -0
- package/dist/utils/id-generator.cjs.map +1 -0
- package/dist/utils/id-generator.js +34 -0
- package/dist/utils/id-generator.js.map +1 -0
- package/dist/utils/logger.cjs +285 -0
- package/dist/utils/logger.cjs.map +1 -0
- package/dist/utils/logger.d.cts +161 -0
- package/dist/utils/logger.d.cts.map +1 -0
- package/dist/utils/logger.d.ts +160 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +282 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/node-slug.cjs +13 -0
- package/dist/utils/node-slug.cjs.map +1 -0
- package/dist/utils/node-slug.d.cts +8 -0
- package/dist/utils/node-slug.d.cts.map +1 -0
- package/dist/utils/node-slug.d.ts +8 -0
- package/dist/utils/node-slug.d.ts.map +1 -0
- package/dist/utils/node-slug.js +13 -0
- package/dist/utils/node-slug.js.map +1 -0
- package/dist/utils/provider-detection.cjs +72 -0
- package/dist/utils/provider-detection.cjs.map +1 -0
- package/dist/utils/provider-detection.js +72 -0
- package/dist/utils/provider-detection.js.map +1 -0
- package/dist/utils/url-safe-id.cjs +52 -0
- package/dist/utils/url-safe-id.cjs.map +1 -0
- package/dist/utils/url-safe-id.js +52 -0
- package/dist/utils/url-safe-id.js.map +1 -0
- package/package.json +121 -0
|
@@ -0,0 +1,499 @@
|
|
|
1
|
+
import { ValidationError } from "../../types/common/errors.types.js";
|
|
2
|
+
import { FlowRunStatus, NodeExecutionStatus } from "../../types/base.js";
|
|
3
|
+
import { BatchStatus } from "../ai/ai-types.js";
|
|
4
|
+
import "../ai/base-client.js";
|
|
5
|
+
import { GraphNodeType } from "../../types/graph-node-types.js";
|
|
6
|
+
import "../../types-fresh.js";
|
|
7
|
+
import { GraphService } from "../graph.service.js";
|
|
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: 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 = 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 === 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 === NodeExecutionStatus.SUCCESS) {
|
|
162
|
+
if (trace.outputs) nodeOutputs.set(nodeId, trace.outputs);
|
|
163
|
+
} else if (trace.status === 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 ? FlowRunStatus.SUCCESS : 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: 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 ValidationError("Flow definition not found for batch resume");
|
|
238
|
+
const definition = flow.flowVersion.invectDefinition;
|
|
239
|
+
await flowRunsService.updateRunStatus(flowRunId, 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 = 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 === NodeExecutionStatus.SUCCESS && nodeExecution.outputs) nodeOutputs.set(nodeExecution.nodeId, nodeExecution.outputs);
|
|
253
|
+
else if (nodeExecution.status === NodeExecutionStatus.SKIPPED) skippedNodeIds.add(nodeExecution.nodeId);
|
|
254
|
+
else if (nodeExecution.status === NodeExecutionStatus.BATCH_SUBMITTED) {
|
|
255
|
+
const batchJobs = await batchJobsService.getBatchJobsByExecutionAndNode(flowRunId, nodeExecution.nodeId);
|
|
256
|
+
for (const batchJob of batchJobs) if (batchJob.status === BatchStatus.COMPLETED && batchJob.responseData) {
|
|
257
|
+
const batchResult = batchJob.responseData[0];
|
|
258
|
+
if (batchResult.status === BatchStatus.COMPLETED) {
|
|
259
|
+
const updatedTrace = await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, NodeExecutionStatus.SUCCESS, { outputs: {
|
|
260
|
+
data: { variables: { output: batchResult.content } },
|
|
261
|
+
nodeType: GraphNodeType.MODEL
|
|
262
|
+
} });
|
|
263
|
+
if (updatedTrace.outputs) nodeOutputs.set(nodeExecution.nodeId, updatedTrace.outputs);
|
|
264
|
+
} else if (batchResult.status === BatchStatus.FAILED) {
|
|
265
|
+
await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, NodeExecutionStatus.FAILED, { error: batchResult.error || "Batch processing failed" });
|
|
266
|
+
hasFailure = true;
|
|
267
|
+
break;
|
|
268
|
+
} else if (batchResult.status === BatchStatus.CANCELLED) {
|
|
269
|
+
await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, NodeExecutionStatus.FAILED, { error: batchResult.error || "Batch processing was cancelled" });
|
|
270
|
+
hasFailure = true;
|
|
271
|
+
break;
|
|
272
|
+
} else if (batchResult.status === BatchStatus.SUBMITTED || batchResult.status === BatchStatus.PROCESSING) continue;
|
|
273
|
+
else {
|
|
274
|
+
await nodeExecutionService.updateNodeExecutionStatus(nodeExecution.id, 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 === NodeExecutionStatus.SUCCESS && trace.outputs) nodeOutputs.set(nodeId, trace.outputs);
|
|
298
|
+
else if (trace.status === NodeExecutionStatus.FAILED) hasFailure = true;
|
|
299
|
+
if (trace.status === 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 ? FlowRunStatus.FAILED : 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, 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: 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, 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, 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, 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 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 === 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 === NodeExecutionStatus.SUCCESS) {
|
|
447
|
+
if (trace.outputs) nodeOutputs.set(nodeId, trace.outputs);
|
|
448
|
+
} else if (trace.status === 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 === GraphNodeType.IF_ELSE && trace.status === 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 ? FlowRunStatus.SUCCESS : 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
|
+
export { FlowRunCoordinator };
|
|
498
|
+
|
|
499
|
+
//# sourceMappingURL=flow-run-coordinator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flow-run-coordinator.js","names":[],"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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"}
|