@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 @@
|
|
|
1
|
+
{"version":3,"file":"schema-generator.js","names":[],"sources":["../../src/database/schema-generator.ts"],"sourcesContent":["/**\n * Drizzle Schema Generators\n *\n * Converts the merged abstract schema (core + plugins) into three\n * dialect-specific Drizzle ORM schema files as TypeScript source code.\n *\n * Each generator produces a complete, self-contained .ts file that can\n * be used by Drizzle Kit for migration generation.\n */\n\nimport type { PluginFieldAttribute, PluginFieldType } from 'src/types/plugin.types';\nimport type { MergedSchema, MergedTable } from './schema-merger';\n\n// =============================================================================\n// Common Utilities\n// =============================================================================\n\n/**\n * Convert camelCase to snake_case for DB column names.\n */\nfunction toSnakeCase(str: string): string {\n return str.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n}\n\n/**\n * Check if a field type is an enum (string array).\n */\nfunction isEnumType(type: PluginFieldType): type is string[] {\n return Array.isArray(type);\n}\n\n/**\n * Generate a variable name for an enum from a table + field.\n * e.g., flowRuns + status → flowRunStatusEnum\n */\nfunction enumVarName(tableName: string, fieldName: string): string {\n return `${tableName}${fieldName.charAt(0).toUpperCase() + fieldName.slice(1)}Enum`;\n}\n\nconst SQLITE_RUNTIME_DEFAULT_IMPORTS: Record<string, string> = {\n FlowRunStatus: '@invect/core',\n NodeExecutionStatus: '@invect/core',\n};\n\nfunction collectSqliteRuntimeDefaultImports(schema: MergedSchema): Map<string, Set<string>> {\n const importsByModule = new Map<string, Set<string>>();\n\n for (const table of schema.tables) {\n for (const field of Object.values(table.definition.fields)) {\n if (typeof field.defaultValue !== 'string' || !field.typeAnnotation) {\n continue;\n }\n\n const importPath = SQLITE_RUNTIME_DEFAULT_IMPORTS[field.typeAnnotation];\n if (!importPath) {\n continue;\n }\n\n const existing = importsByModule.get(importPath) ?? new Set<string>();\n existing.add(field.typeAnnotation);\n importsByModule.set(importPath, existing);\n }\n }\n\n return importsByModule;\n}\n\n// =============================================================================\n// SQLite Generator\n// =============================================================================\n\nexport function generateSqliteSchema(schema: MergedSchema): string {\n const lines: string[] = [];\n const runtimeImports = collectSqliteRuntimeDefaultImports(schema);\n\n // Header\n lines.push(`// SQLite schema for Invect — AUTO-GENERATED by @invect/cli`);\n lines.push(`// Do not edit manually. Run \\`npx invect generate\\` to regenerate.`);\n lines.push(``);\n lines.push(\n `import { sqliteTable, text, integer, primaryKey, type AnySQLiteColumn } from 'drizzle-orm/sqlite-core';`,\n );\n lines.push(`import { relations, sql } from 'drizzle-orm';`);\n for (const [importPath, identifiers] of runtimeImports.entries()) {\n lines.push(`import { ${Array.from(identifiers).sort().join(', ')} } from '${importPath}';`);\n }\n lines.push(`import { randomUUID } from 'crypto';`);\n lines.push(``);\n lines.push(`// Type imports — these are used for $type<>() annotations`);\n lines.push(`import type { JSONValue } from '.';`);\n lines.push(``);\n\n // Collect all typeAnnotations to generate type imports\n const typeAnnotations = collectTypeAnnotations(schema);\n if (typeAnnotations.size > 0) {\n lines.push(`// Plugin & core type annotations`);\n lines.push(`// You may need to adjust these imports based on your project structure`);\n lines.push(``);\n }\n\n // Tables\n lines.push(`// =============================================================================`);\n lines.push(`// Tables`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n\n for (const table of schema.tables) {\n lines.push(generateSqliteTable(table, schema));\n lines.push(``);\n }\n\n // Relations\n lines.push(`// =============================================================================`);\n lines.push(`// Relations`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n lines.push(generateRelations(schema));\n\n // Type exports\n lines.push(``);\n lines.push(`// =============================================================================`);\n lines.push(`// Type exports`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n for (const table of schema.tables) {\n const varName = table.name;\n const typeName = capitalize(table.name);\n lines.push(`export type ${typeName} = typeof ${varName}.$inferSelect;`);\n lines.push(`export type New${typeName} = typeof ${varName}.$inferInsert;`);\n }\n\n return lines.join('\\n');\n}\n\nfunction generateSqliteTable(table: MergedTable, schema: MergedSchema): string {\n const lines: string[] = [];\n const { name, definition } = table;\n const dbTableName = definition.tableName || toSnakeCase(name);\n const hasCompositePK = !!definition.compositePrimaryKey?.length;\n\n lines.push(`export const ${name} = sqliteTable('${dbTableName}', {`);\n\n for (const [fieldName, field] of Object.entries(definition.fields)) {\n const colName = toSnakeCase(fieldName);\n lines.push(` ${fieldName}: ${sqliteColumn(fieldName, colName, field, name, schema)},`);\n }\n\n if (hasCompositePK) {\n const pkCols = (definition.compositePrimaryKey ?? []).map((f) => `table.${f}`).join(', ');\n lines.push(`}, (table) => [primaryKey({ columns: [${pkCols}] })]);`);\n } else {\n lines.push(`});`);\n }\n\n return lines.join('\\n');\n}\n\nfunction sqliteColumn(\n fieldName: string,\n colName: string,\n field: PluginFieldAttribute,\n tableName: string,\n schema?: MergedSchema,\n): string {\n let col: string;\n\n if (isEnumType(field.type)) {\n // SQLite: enums are just text columns\n col = `text('${colName}')`;\n } else {\n switch (field.type) {\n case 'string':\n case 'text':\n col = `text('${colName}')`;\n break;\n case 'uuid':\n col = `text('${colName}')`;\n break;\n case 'number':\n case 'bigint':\n col = `integer('${colName}')`;\n break;\n case 'boolean':\n col = `integer('${colName}', { mode: 'boolean' })`;\n break;\n case 'date':\n col = `text('${colName}')`;\n break;\n case 'json':\n col = `text('${colName}', { mode: 'json' })`;\n break;\n default:\n col = `text('${colName}')`;\n }\n }\n\n // Type annotation\n if (field.typeAnnotation) {\n col += `.$type<${field.typeAnnotation}>()`;\n }\n\n // Primary key\n if (field.primaryKey) {\n col += `.primaryKey()`;\n }\n\n // Not null\n if (field.required !== false) {\n col += `.notNull()`;\n }\n\n // Unique\n if (field.unique) {\n col += `.unique()`;\n }\n\n // Default value\n if (field.defaultValue !== undefined) {\n col += sqliteDefault(field.defaultValue, field.type, field.typeAnnotation);\n }\n\n // Foreign key\n if (field.references) {\n const refTable = findTableVarForDbName(field.references.table, schema);\n const refField = field.references.field;\n const onDelete = field.references.onDelete || 'no action';\n if (refTable === tableName) {\n col += `.references((): AnySQLiteColumn => ${refTable}.${refField}, { onDelete: '${onDelete}' })`;\n } else {\n col += `.references(() => ${refTable}.${refField}, { onDelete: '${onDelete}' })`;\n }\n }\n\n return col;\n}\n\nfunction sqliteDefault(\n value: string | number | boolean | 'uuid()' | 'now()',\n _type: PluginFieldType,\n typeAnnotation?: string,\n): string {\n if (value === 'uuid()') {\n return `.$defaultFn(() => randomUUID())`;\n }\n if (value === 'now()') {\n return `.default(sql\\`CURRENT_TIMESTAMP\\`)`;\n }\n if (typeof value === 'boolean') {\n return `.default(${value})`;\n }\n if (typeof value === 'number') {\n return `.default(${value})`;\n }\n if (typeof value === 'string') {\n if (typeAnnotation && SQLITE_RUNTIME_DEFAULT_IMPORTS[typeAnnotation]) {\n return `.default(${typeAnnotation}.${value})`;\n }\n return `.default('${value}')`;\n }\n return '';\n}\n\n// =============================================================================\n// PostgreSQL Generator\n// =============================================================================\n\nexport function generatePostgresSchema(schema: MergedSchema): string {\n const lines: string[] = [];\n\n // Header\n lines.push(`// PostgreSQL schema for Invect — AUTO-GENERATED by @invect/cli`);\n lines.push(`// Do not edit manually. Run \\`npx invect generate\\` to regenerate.`);\n lines.push(``);\n lines.push(`import {`);\n lines.push(` pgTable,`);\n lines.push(` text,`);\n lines.push(` integer,`);\n lines.push(` boolean,`);\n lines.push(` timestamp,`);\n lines.push(` json,`);\n lines.push(` pgEnum,`);\n lines.push(` uuid,`);\n lines.push(` bigint,`);\n lines.push(` type AnyPgColumn,`);\n lines.push(` primaryKey,`);\n lines.push(`} from 'drizzle-orm/pg-core';`);\n lines.push(`import { relations } from 'drizzle-orm';`);\n lines.push(`import { randomUUID } from 'crypto';`);\n lines.push(``);\n lines.push(`import type { JSONValue } from '.';`);\n lines.push(``);\n\n // Enums\n const enums = collectEnums(schema);\n if (enums.length > 0) {\n lines.push(`// =============================================================================`);\n lines.push(`// Enums`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n for (const e of enums) {\n lines.push(\n `export const ${e.varName} = pgEnum('${e.dbName}', [${e.values.map((v) => `'${v}'`).join(', ')}]);`,\n );\n }\n lines.push(``);\n }\n\n // Tables\n lines.push(`// =============================================================================`);\n lines.push(`// Tables`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n\n for (const table of schema.tables) {\n lines.push(generatePostgresTable(table, schema, enums));\n lines.push(``);\n }\n\n // Relations\n lines.push(`// =============================================================================`);\n lines.push(`// Relations`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n lines.push(generateRelations(schema));\n\n // Type exports\n lines.push(``);\n lines.push(`// =============================================================================`);\n lines.push(`// Type exports`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n for (const table of schema.tables) {\n const typeName = capitalize(table.name);\n lines.push(`export type ${typeName} = typeof ${table.name}.$inferSelect;`);\n lines.push(`export type New${typeName} = typeof ${table.name}.$inferInsert;`);\n }\n\n return lines.join('\\n');\n}\n\nfunction generatePostgresTable(table: MergedTable, schema: MergedSchema, enums: EnumDef[]): string {\n const lines: string[] = [];\n const { name, definition } = table;\n const dbTableName = definition.tableName || toSnakeCase(name);\n const hasCompositePK = !!definition.compositePrimaryKey?.length;\n\n lines.push(`export const ${name} = pgTable('${dbTableName}', {`);\n\n for (const [fieldName, field] of Object.entries(definition.fields)) {\n const colName = toSnakeCase(fieldName);\n lines.push(\n ` ${fieldName}: ${postgresColumn(fieldName, colName, field, name, enums, schema)},`,\n );\n }\n\n if (hasCompositePK) {\n const pkCols = (definition.compositePrimaryKey ?? []).map((f) => `table.${f}`).join(', ');\n lines.push(`}, (table) => [primaryKey({ columns: [${pkCols}] })]);`);\n } else {\n lines.push(`});`);\n }\n\n return lines.join('\\n');\n}\n\nfunction postgresColumn(\n fieldName: string,\n colName: string,\n field: PluginFieldAttribute,\n tableName: string,\n enums: EnumDef[],\n schema?: MergedSchema,\n): string {\n let col: string;\n\n if (isEnumType(field.type)) {\n const eVar = enums.find((e) => e.tableName === tableName && e.fieldName === fieldName)?.varName;\n col = eVar ? `${eVar}('${colName}')` : `text('${colName}')`;\n } else {\n switch (field.type) {\n case 'string':\n case 'text':\n col = `text('${colName}')`;\n break;\n case 'uuid':\n col = `uuid('${colName}')`;\n break;\n case 'number':\n col = `integer('${colName}')`;\n break;\n case 'bigint':\n col = `bigint('${colName}', { mode: 'bigint' })`;\n break;\n case 'boolean':\n col = `boolean('${colName}')`;\n break;\n case 'date':\n col = `timestamp('${colName}')`;\n break;\n case 'json':\n col = `json('${colName}')`;\n break;\n default:\n col = `text('${colName}')`;\n }\n }\n\n // Type annotation\n if (field.typeAnnotation) {\n col += `.$type<${field.typeAnnotation}>()`;\n }\n\n // Primary key\n if (field.primaryKey) {\n col += `.primaryKey()`;\n }\n\n // Not null\n if (field.required !== false) {\n col += `.notNull()`;\n }\n\n // Unique\n if (field.unique) {\n col += `.unique()`;\n }\n\n // Default value\n if (field.defaultValue !== undefined) {\n col += postgresDefault(field.defaultValue, field.type);\n }\n\n // Foreign key\n if (field.references) {\n const refTable = findTableVarForDbName(field.references.table, schema);\n const refField = field.references.field;\n const onDelete = field.references.onDelete || 'no action';\n if (refTable === tableName) {\n col += `.references((): AnyPgColumn => ${refTable}.${refField}, { onDelete: '${onDelete}' })`;\n } else {\n col += `.references(() => ${refTable}.${refField}, { onDelete: '${onDelete}' })`;\n }\n }\n\n return col;\n}\n\nfunction postgresDefault(\n value: string | number | boolean | 'uuid()' | 'now()',\n _type: PluginFieldType,\n): string {\n if (value === 'uuid()') {\n return `.$default(() => randomUUID())`;\n }\n if (value === 'now()') {\n return `.defaultNow()`;\n }\n if (typeof value === 'boolean') {\n return `.default(${value})`;\n }\n if (typeof value === 'number') {\n return `.default(${value})`;\n }\n if (typeof value === 'string') {\n return `.default('${value}')`;\n }\n return '';\n}\n\n// =============================================================================\n// MySQL Generator\n// =============================================================================\n\nexport function generateMysqlSchema(schema: MergedSchema): string {\n const lines: string[] = [];\n\n // Header\n lines.push(`// MySQL schema for Invect — AUTO-GENERATED by @invect/cli`);\n lines.push(`// Do not edit manually. Run \\`npx invect generate\\` to regenerate.`);\n lines.push(``);\n lines.push(`import {`);\n lines.push(` mysqlTable,`);\n lines.push(` varchar,`);\n lines.push(` text,`);\n lines.push(` int,`);\n lines.push(` bigint,`);\n lines.push(` boolean,`);\n lines.push(` timestamp,`);\n lines.push(` json,`);\n lines.push(` mysqlEnum,`);\n lines.push(` type AnyMySqlColumn,`);\n lines.push(` primaryKey,`);\n lines.push(`} from 'drizzle-orm/mysql-core';`);\n lines.push(`import { relations, sql } from 'drizzle-orm';`);\n lines.push(`import { randomUUID } from 'crypto';`);\n lines.push(``);\n lines.push(`import type { JSONValue } from '.';`);\n lines.push(``);\n\n // Tables\n lines.push(`// =============================================================================`);\n lines.push(`// Tables`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n\n for (const table of schema.tables) {\n lines.push(generateMysqlTable(table, schema));\n lines.push(``);\n }\n\n // Relations\n lines.push(`// =============================================================================`);\n lines.push(`// Relations`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n lines.push(generateRelations(schema));\n\n // Type exports\n lines.push(``);\n lines.push(`// =============================================================================`);\n lines.push(`// Type exports`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n for (const table of schema.tables) {\n const typeName = capitalize(table.name);\n lines.push(`export type ${typeName} = typeof ${table.name}.$inferSelect;`);\n lines.push(`export type New${typeName} = typeof ${table.name}.$inferInsert;`);\n }\n\n return lines.join('\\n');\n}\n\nfunction generateMysqlTable(table: MergedTable, schema: MergedSchema): string {\n // schema is used by mysqlColumn for FK reference resolution\n const lines: string[] = [];\n const { name, definition } = table;\n const dbTableName = definition.tableName || toSnakeCase(name);\n const hasCompositePK = !!definition.compositePrimaryKey?.length;\n\n lines.push(`export const ${name} = mysqlTable('${dbTableName}', {`);\n\n for (const [fieldName, field] of Object.entries(definition.fields)) {\n const colName = toSnakeCase(fieldName);\n lines.push(` ${fieldName}: ${mysqlColumn(fieldName, colName, field, name, schema)},`);\n }\n\n if (hasCompositePK) {\n const pkCols = (definition.compositePrimaryKey ?? []).map((f) => `table.${f}`).join(', ');\n lines.push(`}, (table) => [primaryKey({ columns: [${pkCols}] })]);`);\n } else {\n lines.push(`});`);\n }\n\n return lines.join('\\n');\n}\n\nfunction mysqlColumn(\n fieldName: string,\n colName: string,\n field: PluginFieldAttribute,\n tableName: string,\n schema?: MergedSchema,\n): string {\n const maxLen = field.maxLength ?? 255;\n let col: string;\n\n if (isEnumType(field.type)) {\n const enumValues = field.type.map((v) => `'${v}'`).join(', ');\n col = `mysqlEnum('${colName}', [${enumValues}])`;\n } else {\n switch (field.type) {\n case 'string':\n col = `varchar('${colName}', { length: ${maxLen} })`;\n break;\n case 'text':\n col = `text('${colName}')`;\n break;\n case 'uuid':\n col = `varchar('${colName}', { length: 36 })`;\n break;\n case 'number':\n col = `int('${colName}')`;\n break;\n case 'bigint':\n col = `bigint('${colName}', { mode: 'bigint' })`;\n break;\n case 'boolean':\n col = `boolean('${colName}')`;\n break;\n case 'date':\n col = `timestamp('${colName}')`;\n break;\n case 'json':\n col = `json('${colName}')`;\n break;\n default:\n col = `varchar('${colName}', { length: ${maxLen} })`;\n }\n }\n\n // Type annotation\n if (field.typeAnnotation) {\n col += `.$type<${field.typeAnnotation}>()`;\n }\n\n // Primary key\n if (field.primaryKey) {\n col += `.primaryKey()`;\n }\n\n // Not null\n if (field.required !== false) {\n col += `.notNull()`;\n }\n\n // Unique\n if (field.unique) {\n col += `.unique()`;\n }\n\n // Default value\n if (field.defaultValue !== undefined) {\n col += mysqlDefault(field.defaultValue, field.type);\n }\n\n // Foreign key\n if (field.references) {\n const refTable = findTableVarForDbName(field.references.table, schema);\n const refField = field.references.field;\n const onDelete = field.references.onDelete || 'no action';\n if (refTable === tableName) {\n col += `.references((): AnyMySqlColumn => ${refTable}.${refField}, { onDelete: '${onDelete}' })`;\n } else {\n col += `.references(() => ${refTable}.${refField}, { onDelete: '${onDelete}' })`;\n }\n }\n\n return col;\n}\n\nfunction mysqlDefault(\n value: string | number | boolean | 'uuid()' | 'now()',\n _type: PluginFieldType,\n): string {\n if (value === 'uuid()') {\n return `.$defaultFn(() => randomUUID())`;\n }\n if (value === 'now()') {\n return `.default(sql\\`CURRENT_TIMESTAMP\\`)`;\n }\n if (typeof value === 'boolean') {\n return `.default(${value})`;\n }\n if (typeof value === 'number') {\n return `.default(${value})`;\n }\n if (typeof value === 'string') {\n return `.default('${value}')`;\n }\n return '';\n}\n\n// =============================================================================\n// Append-mode Generators\n// =============================================================================\n//\n// These produce only the table definitions, relations, and type exports\n// for appending to an existing Drizzle schema file. They include:\n// - A commented section marker\n// - Additional imports needed (inserted at top when used by CLI)\n// - Table definitions\n// - Relations\n// - Type exports\n//\n// The CLI handles merging the import lines into the existing file.\n// This approach mirrors how better-auth generates schema code that can\n// be appended to the user's existing schema file.\n\nexport interface AppendSchemaResult {\n /** Import statements that need to be added (CLI merges these) */\n imports: string[];\n /** Table + relation + type code to append */\n code: string;\n}\n\nexport function generateSqliteSchemaAppend(schema: MergedSchema): AppendSchemaResult {\n const runtimeImports = collectSqliteRuntimeDefaultImports(schema);\n const imports = [\n `import { sqliteTable, text, integer, primaryKey, type AnySQLiteColumn } from 'drizzle-orm/sqlite-core';`,\n `import { relations, sql } from 'drizzle-orm';`,\n `import { randomUUID } from 'crypto';`,\n ];\n\n for (const [importPath, identifiers] of runtimeImports.entries()) {\n imports.push(`import { ${Array.from(identifiers).sort().join(', ')} } from '${importPath}';`);\n }\n\n const lines: string[] = [];\n lines.push(``);\n lines.push(`// =============================================================================`);\n lines.push(`// Invect tables — AUTO-GENERATED by @invect/cli`);\n lines.push(`// Do not edit below this line. Run \\`npx invect generate\\` to regenerate.`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n\n for (const table of schema.tables) {\n lines.push(generateSqliteTable(table, schema));\n lines.push(``);\n }\n\n lines.push(generateRelations(schema));\n lines.push(``);\n\n for (const table of schema.tables) {\n const typeName = capitalize(table.name);\n lines.push(`export type ${typeName} = typeof ${table.name}.$inferSelect;`);\n lines.push(`export type New${typeName} = typeof ${table.name}.$inferInsert;`);\n }\n\n return { imports, code: lines.join('\\n') };\n}\n\nexport function generatePostgresSchemaAppend(schema: MergedSchema): AppendSchemaResult {\n const imports = [\n `import { pgTable, text, integer, boolean, timestamp, json, pgEnum, uuid, bigint, primaryKey, type AnyPgColumn } from 'drizzle-orm/pg-core';`,\n `import { relations } from 'drizzle-orm';`,\n `import { randomUUID } from 'crypto';`,\n ];\n\n const lines: string[] = [];\n lines.push(``);\n lines.push(`// =============================================================================`);\n lines.push(`// Invect tables — AUTO-GENERATED by @invect/cli`);\n lines.push(`// Do not edit below this line. Run \\`npx invect generate\\` to regenerate.`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n\n const enums = collectEnums(schema);\n if (enums.length > 0) {\n for (const e of enums) {\n lines.push(\n `export const ${e.varName} = pgEnum('${e.dbName}', [${e.values.map((v) => `'${v}'`).join(', ')}]);`,\n );\n }\n lines.push(``);\n }\n\n for (const table of schema.tables) {\n lines.push(generatePostgresTable(table, schema, enums));\n lines.push(``);\n }\n\n lines.push(generateRelations(schema));\n lines.push(``);\n\n for (const table of schema.tables) {\n const typeName = capitalize(table.name);\n lines.push(`export type ${typeName} = typeof ${table.name}.$inferSelect;`);\n lines.push(`export type New${typeName} = typeof ${table.name}.$inferInsert;`);\n }\n\n return { imports, code: lines.join('\\n') };\n}\n\nexport function generateMysqlSchemaAppend(schema: MergedSchema): AppendSchemaResult {\n const imports = [\n `import { mysqlTable, varchar, text, int, bigint, boolean, timestamp, json, mysqlEnum, primaryKey, type AnyMySqlColumn } from 'drizzle-orm/mysql-core';`,\n `import { relations, sql } from 'drizzle-orm';`,\n `import { randomUUID } from 'crypto';`,\n ];\n\n const lines: string[] = [];\n lines.push(``);\n lines.push(`// =============================================================================`);\n lines.push(`// Invect tables — AUTO-GENERATED by @invect/cli`);\n lines.push(`// Do not edit below this line. Run \\`npx invect generate\\` to regenerate.`);\n lines.push(`// =============================================================================`);\n lines.push(``);\n\n for (const table of schema.tables) {\n lines.push(generateMysqlTable(table, schema));\n lines.push(``);\n }\n\n lines.push(generateRelations(schema));\n lines.push(``);\n\n for (const table of schema.tables) {\n const typeName = capitalize(table.name);\n lines.push(`export type ${typeName} = typeof ${table.name}.$inferSelect;`);\n lines.push(`export type New${typeName} = typeof ${table.name}.$inferInsert;`);\n }\n\n return { imports, code: lines.join('\\n') };\n}\n\n// =============================================================================\n// Relation Generator (shared across dialects)\n// =============================================================================\n\nfunction generateRelations(schema: MergedSchema): string {\n const lines: string[] = [];\n\n // Build a map of FK references: which tables reference which\n const refs: { from: string; fromField: string; to: string; toField: string }[] = [];\n\n for (const table of schema.tables) {\n for (const [fieldName, field] of Object.entries(table.definition.fields)) {\n if (field.references) {\n const toTableVar = findTableVarForDbName(field.references.table, schema);\n refs.push({\n from: table.name,\n fromField: fieldName,\n to: toTableVar,\n toField: field.references.field,\n });\n }\n }\n }\n\n for (const table of schema.tables) {\n // Find \"one\" relations (this table has FK → other table)\n const oneRels = refs.filter((r) => r.from === table.name);\n // Find \"many\" relations (other tables have FK → this table)\n const manyRels = refs.filter((r) => r.to === table.name);\n\n if (oneRels.length === 0 && manyRels.length === 0) {\n continue;\n }\n\n const relParts: string[] = [];\n const destructure: string[] = [];\n\n if (oneRels.length > 0) {\n destructure.push('one');\n }\n if (manyRels.length > 0) {\n destructure.push('many');\n }\n\n for (const rel of oneRels) {\n // Derive a relation name from the FK field: \"flowId\" → \"flow\"\n const relName = rel.fromField.replace(/Id$/, '').replace(/(_id)$/, '');\n relParts.push(\n ` ${relName}: one(${rel.to}, { fields: [${table.name}.${rel.fromField}], references: [${rel.to}.${rel.toField}] }),`,\n );\n }\n\n for (const rel of manyRels) {\n // Derive a relation name from the source table\n const relName = rel.from;\n // Avoid duplicates (e.g., multiple FKs from same table)\n relParts.push(` ${relName}: many(${rel.from}),`);\n }\n\n lines.push(\n `export const ${table.name}Relations = relations(${table.name}, ({ ${destructure.join(', ')} }) => ({`,\n );\n lines.push(relParts.join('\\n'));\n lines.push(`}));`);\n lines.push(``);\n }\n\n return lines.join('\\n');\n}\n\n// =============================================================================\n// Enum Collection\n// =============================================================================\n\ninterface EnumDef {\n varName: string;\n dbName: string;\n values: string[];\n tableName: string;\n fieldName: string;\n}\n\nfunction collectEnums(schema: MergedSchema): EnumDef[] {\n const enums: EnumDef[] = [];\n\n for (const table of schema.tables) {\n for (const [fieldName, field] of Object.entries(table.definition.fields)) {\n if (isEnumType(field.type)) {\n const varName = enumVarName(table.name, fieldName);\n const dbName = `${toSnakeCase(table.name)}_${toSnakeCase(fieldName)}`;\n enums.push({\n varName,\n dbName,\n values: field.type,\n tableName: table.name,\n fieldName,\n });\n }\n }\n }\n\n return enums;\n}\n\n// =============================================================================\n// Type Annotation Collection\n// =============================================================================\n\nfunction collectTypeAnnotations(schema: MergedSchema): Set<string> {\n const annotations = new Set<string>();\n for (const table of schema.tables) {\n for (const field of Object.values(table.definition.fields)) {\n if (field.typeAnnotation) {\n annotations.add(field.typeAnnotation);\n }\n }\n }\n return annotations;\n}\n\n// =============================================================================\n// Shared Helpers\n// =============================================================================\n\n/**\n * Build a map from DB table name → JS variable name from the schema.\n */\nfunction buildTableMap(schema: MergedSchema): Map<string, string> {\n const map = new Map<string, string>();\n for (const table of schema.tables) {\n const dbName = table.definition.tableName || toSnakeCase(table.name);\n map.set(dbName, table.name);\n // Also map by logical name for convenience\n map.set(table.name, table.name);\n }\n return map;\n}\n\n/**\n * Find the JS variable name for a given DB table name.\n * Uses the schema to do a proper lookup (e.g., 'execution_traces' → 'nodeExecutions').\n * Falls back to camelCase heuristic if no schema provided.\n */\nfunction findTableVarForDbName(dbName: string, schema?: MergedSchema): string {\n if (schema) {\n const tableMap = buildTableMap(schema);\n const found = tableMap.get(dbName);\n if (found) {\n return found;\n }\n }\n // Fallback: convert snake_case to camelCase\n if (dbName.includes('_')) {\n return dbName.replace(/_([a-z])/g, (_, c) => c.toUpperCase());\n }\n return dbName;\n}\n\nfunction capitalize(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
const require_core_schema = require("./core-schema.cjs");
|
|
2
|
+
//#region src/database/schema-merger.ts
|
|
3
|
+
/**
|
|
4
|
+
* Merge core schema with all plugin schemas.
|
|
5
|
+
*
|
|
6
|
+
* @param plugins - Array of plugins (only those with `schema` are processed)
|
|
7
|
+
* @returns Merged schema with tables in dependency order
|
|
8
|
+
* @throws Error if there are conflicting field definitions
|
|
9
|
+
*/
|
|
10
|
+
function mergeSchemas(plugins) {
|
|
11
|
+
const errors = [];
|
|
12
|
+
const provenance = [];
|
|
13
|
+
const merged = {};
|
|
14
|
+
const tableSources = {};
|
|
15
|
+
for (const [name, def] of Object.entries(require_core_schema.CORE_SCHEMA)) {
|
|
16
|
+
merged[name] = deepCopyTableDef(def);
|
|
17
|
+
tableSources[name] = "core";
|
|
18
|
+
provenance.push({
|
|
19
|
+
table: name,
|
|
20
|
+
field: null,
|
|
21
|
+
source: "core"
|
|
22
|
+
});
|
|
23
|
+
for (const fieldName of Object.keys(def.fields)) provenance.push({
|
|
24
|
+
table: name,
|
|
25
|
+
field: fieldName,
|
|
26
|
+
source: "core"
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
for (const plugin of plugins) {
|
|
30
|
+
if (!plugin.schema) continue;
|
|
31
|
+
for (const [tableName, tableDef] of Object.entries(plugin.schema)) {
|
|
32
|
+
if (tableDef.disableMigration) continue;
|
|
33
|
+
require_core_schema.CORE_TABLE_NAMES.includes(tableName);
|
|
34
|
+
if (tableName in merged) {
|
|
35
|
+
const existing = merged[tableName];
|
|
36
|
+
if (!existing) continue;
|
|
37
|
+
for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) {
|
|
38
|
+
if (fieldName in existing.fields) {
|
|
39
|
+
const existingSource = provenance.find((p) => p.table === tableName && p.field === fieldName)?.source;
|
|
40
|
+
if (existingSource && existingSource !== plugin.id) errors.push({
|
|
41
|
+
type: "duplicate_field",
|
|
42
|
+
message: `Field "${fieldName}" on table "${tableName}" already defined by "${existingSource}". Plugin "${plugin.id}" cannot override it.`,
|
|
43
|
+
table: tableName,
|
|
44
|
+
field: fieldName,
|
|
45
|
+
plugin: plugin.id
|
|
46
|
+
});
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
existing.fields[fieldName] = { ...fieldDef };
|
|
50
|
+
provenance.push({
|
|
51
|
+
table: tableName,
|
|
52
|
+
field: fieldName,
|
|
53
|
+
source: plugin.id
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
} else {
|
|
57
|
+
merged[tableName] = deepCopyTableDef(tableDef);
|
|
58
|
+
tableSources[tableName] = plugin.id;
|
|
59
|
+
provenance.push({
|
|
60
|
+
table: tableName,
|
|
61
|
+
field: null,
|
|
62
|
+
source: plugin.id
|
|
63
|
+
});
|
|
64
|
+
for (const fieldName of Object.keys(tableDef.fields)) provenance.push({
|
|
65
|
+
table: tableName,
|
|
66
|
+
field: fieldName,
|
|
67
|
+
source: plugin.id
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
for (const [tableName, tableDef] of Object.entries(merged)) for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) if (fieldDef.references) {
|
|
73
|
+
const refTableName = fieldDef.references.table;
|
|
74
|
+
if (!Object.values(merged).some((t) => t.tableName === refTableName || Object.keys(merged).includes(refTableName))) errors.push({
|
|
75
|
+
type: "invalid_reference",
|
|
76
|
+
message: `Field "${fieldName}" on table "${tableName}" references table "${refTableName}" which does not exist.`,
|
|
77
|
+
table: tableName,
|
|
78
|
+
field: fieldName,
|
|
79
|
+
plugin: tableSources[tableName] || "unknown"
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
if (errors.length > 0) {
|
|
83
|
+
const messages = errors.map((e) => ` - [${e.plugin}] ${e.message}`).join("\n");
|
|
84
|
+
throw new Error(`Schema merge errors:\n${messages}`);
|
|
85
|
+
}
|
|
86
|
+
return {
|
|
87
|
+
tables: Object.entries(merged).map(([name, definition]) => ({
|
|
88
|
+
name,
|
|
89
|
+
definition,
|
|
90
|
+
source: tableSources[name] || "core"
|
|
91
|
+
})).sort((a, b) => {
|
|
92
|
+
const orderA = a.definition.order ?? 100;
|
|
93
|
+
const orderB = b.definition.order ?? 100;
|
|
94
|
+
if (orderA !== orderB) return orderA - orderB;
|
|
95
|
+
return a.name.localeCompare(b.name);
|
|
96
|
+
}),
|
|
97
|
+
provenance
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Compare a merged schema against a "previous" schema (e.g., from last generation).
|
|
102
|
+
* Used for preview/diff output in the CLI.
|
|
103
|
+
*/
|
|
104
|
+
function diffSchemas(current, previous) {
|
|
105
|
+
const diff = {
|
|
106
|
+
newTables: [],
|
|
107
|
+
newFields: [],
|
|
108
|
+
unchangedTables: []
|
|
109
|
+
};
|
|
110
|
+
if (!previous) {
|
|
111
|
+
diff.newTables = current.tables.map((t) => ({
|
|
112
|
+
name: t.name,
|
|
113
|
+
source: t.source
|
|
114
|
+
}));
|
|
115
|
+
return diff;
|
|
116
|
+
}
|
|
117
|
+
const previousTableNames = new Set(previous.tables.map((t) => t.name));
|
|
118
|
+
const previousFieldsByTable = /* @__PURE__ */ new Map();
|
|
119
|
+
for (const table of previous.tables) previousFieldsByTable.set(table.name, new Set(Object.keys(table.definition.fields)));
|
|
120
|
+
for (const table of current.tables) {
|
|
121
|
+
if (!previousTableNames.has(table.name)) {
|
|
122
|
+
diff.newTables.push({
|
|
123
|
+
name: table.name,
|
|
124
|
+
source: table.source
|
|
125
|
+
});
|
|
126
|
+
continue;
|
|
127
|
+
}
|
|
128
|
+
const prevFields = previousFieldsByTable.get(table.name) || /* @__PURE__ */ new Set();
|
|
129
|
+
let hasNewFields = false;
|
|
130
|
+
for (const fieldName of Object.keys(table.definition.fields)) if (!prevFields.has(fieldName)) {
|
|
131
|
+
diff.newFields.push({
|
|
132
|
+
table: table.name,
|
|
133
|
+
field: fieldName,
|
|
134
|
+
source: table.source
|
|
135
|
+
});
|
|
136
|
+
hasNewFields = true;
|
|
137
|
+
}
|
|
138
|
+
if (!hasNewFields) diff.unchangedTables.push(table.name);
|
|
139
|
+
}
|
|
140
|
+
return diff;
|
|
141
|
+
}
|
|
142
|
+
function deepCopyTableDef(def) {
|
|
143
|
+
return {
|
|
144
|
+
...def,
|
|
145
|
+
fields: Object.fromEntries(Object.entries(def.fields).map(([k, v]) => [k, { ...v }])),
|
|
146
|
+
compositePrimaryKey: def.compositePrimaryKey ? [...def.compositePrimaryKey] : void 0
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
//#endregion
|
|
150
|
+
exports.diffSchemas = diffSchemas;
|
|
151
|
+
exports.mergeSchemas = mergeSchemas;
|
|
152
|
+
|
|
153
|
+
//# sourceMappingURL=schema-merger.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-merger.cjs","names":["CORE_SCHEMA"],"sources":["../../src/database/schema-merger.ts"],"sourcesContent":["/**\n * Schema Merger\n *\n * Merges the core abstract schema with plugin schemas to produce a\n * unified abstract schema. The CLI schema generator then converts\n * this merged schema into dialect-specific Drizzle files.\n *\n * Handles:\n * - New plugin tables\n * - Plugin fields added to existing core tables (additive only)\n * - Duplicate field detection (throws error)\n * - Ordering by foreign key dependencies\n */\n\nimport type { InvectPlugin, PluginTableDefinition } from 'src/types/plugin.types';\nimport { CORE_SCHEMA, CORE_TABLE_NAMES } from './core-schema';\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport interface MergedSchema {\n /** All tables (core + plugin) in dependency-resolved order */\n tables: MergedTable[];\n /** Which plugin contributed each table/field (for diagnostics) */\n provenance: SchemaProvenance[];\n}\n\nexport interface MergedTable {\n /** Logical table name (camelCase) */\n name: string;\n /** The merged table definition */\n definition: PluginTableDefinition;\n /** Which source this table came from */\n source: 'core' | string; // 'core' or plugin ID\n}\n\nexport interface SchemaProvenance {\n /** Table name */\n table: string;\n /** Field name (null for table-level provenance) */\n field: string | null;\n /** Source: 'core' or plugin ID */\n source: string;\n}\n\nexport interface SchemaMergeError {\n type: 'duplicate_field' | 'duplicate_table' | 'invalid_reference';\n message: string;\n table: string;\n field?: string;\n plugin: string;\n}\n\n// =============================================================================\n// Merge Function\n// =============================================================================\n\n/**\n * Merge core schema with all plugin schemas.\n *\n * @param plugins - Array of plugins (only those with `schema` are processed)\n * @returns Merged schema with tables in dependency order\n * @throws Error if there are conflicting field definitions\n */\nexport function mergeSchemas(plugins: InvectPlugin[]): MergedSchema {\n const errors: SchemaMergeError[] = [];\n const provenance: SchemaProvenance[] = [];\n\n // Start with a deep copy of the core schema\n const merged: Record<string, PluginTableDefinition> = {};\n const tableSources: Record<string, string> = {}; // table → source\n\n // Add core tables\n for (const [name, def] of Object.entries(CORE_SCHEMA)) {\n merged[name] = deepCopyTableDef(def);\n tableSources[name] = 'core';\n provenance.push({ table: name, field: null, source: 'core' });\n for (const fieldName of Object.keys(def.fields)) {\n provenance.push({ table: name, field: fieldName, source: 'core' });\n }\n }\n\n // Merge each plugin's schema\n for (const plugin of plugins) {\n if (!plugin.schema) {\n continue;\n }\n\n for (const [tableName, tableDef] of Object.entries(plugin.schema)) {\n if (tableDef.disableMigration) {\n continue;\n }\n\n const _isCoreTable = CORE_TABLE_NAMES.includes(tableName);\n const existsAlready = tableName in merged;\n\n if (existsAlready) {\n // Extending an existing table — merge fields additively\n const existing = merged[tableName];\n if (!existing) {\n continue;\n }\n\n for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) {\n if (fieldName in existing.fields) {\n // Field already exists — error unless it's from the same source\n const existingSource = provenance.find(\n (p) => p.table === tableName && p.field === fieldName,\n )?.source;\n\n if (existingSource && existingSource !== plugin.id) {\n errors.push({\n type: 'duplicate_field',\n message: `Field \"${fieldName}\" on table \"${tableName}\" already defined by \"${existingSource}\". Plugin \"${plugin.id}\" cannot override it.`,\n table: tableName,\n field: fieldName,\n plugin: plugin.id,\n });\n }\n continue; // Skip duplicate\n }\n\n // Add new field to existing table\n existing.fields[fieldName] = { ...fieldDef };\n provenance.push({ table: tableName, field: fieldName, source: plugin.id });\n }\n } else {\n // New table from plugin\n merged[tableName] = deepCopyTableDef(tableDef);\n tableSources[tableName] = plugin.id;\n provenance.push({ table: tableName, field: null, source: plugin.id });\n\n for (const fieldName of Object.keys(tableDef.fields)) {\n provenance.push({ table: tableName, field: fieldName, source: plugin.id });\n }\n }\n }\n }\n\n // Validate foreign key references\n for (const [tableName, tableDef] of Object.entries(merged)) {\n for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) {\n if (fieldDef.references) {\n // Check if the referenced table exists (by tableName property, not logical name)\n const refTableName = fieldDef.references.table;\n const refExists = Object.values(merged).some(\n (t) => t.tableName === refTableName || Object.keys(merged).includes(refTableName),\n );\n\n if (!refExists) {\n errors.push({\n type: 'invalid_reference',\n message: `Field \"${fieldName}\" on table \"${tableName}\" references table \"${refTableName}\" which does not exist.`,\n table: tableName,\n field: fieldName,\n plugin: tableSources[tableName] || 'unknown',\n });\n }\n }\n }\n }\n\n if (errors.length > 0) {\n const messages = errors.map((e) => ` - [${e.plugin}] ${e.message}`).join('\\n');\n throw new Error(`Schema merge errors:\\n${messages}`);\n }\n\n // Sort tables by order, then by name for stability\n const tables: MergedTable[] = Object.entries(merged)\n .map(([name, definition]) => ({\n name,\n definition,\n source: (tableSources[name] || 'core') as 'core' | string,\n }))\n .sort((a, b) => {\n const orderA = a.definition.order ?? 100;\n const orderB = b.definition.order ?? 100;\n if (orderA !== orderB) {\n return orderA - orderB;\n }\n return a.name.localeCompare(b.name);\n });\n\n return { tables, provenance };\n}\n\n// =============================================================================\n// Diff Utilities (for `npx invect generate --diff` preview)\n// =============================================================================\n\nexport interface SchemaDiff {\n newTables: { name: string; source: string }[];\n newFields: { table: string; field: string; source: string }[];\n unchangedTables: string[];\n}\n\n/**\n * Compare a merged schema against a \"previous\" schema (e.g., from last generation).\n * Used for preview/diff output in the CLI.\n */\nexport function diffSchemas(current: MergedSchema, previous: MergedSchema | null): SchemaDiff {\n const diff: SchemaDiff = {\n newTables: [],\n newFields: [],\n unchangedTables: [],\n };\n\n if (!previous) {\n // Everything is new\n diff.newTables = current.tables.map((t) => ({ name: t.name, source: t.source }));\n return diff;\n }\n\n const previousTableNames = new Set(previous.tables.map((t) => t.name));\n const previousFieldsByTable = new Map<string, Set<string>>();\n\n for (const table of previous.tables) {\n previousFieldsByTable.set(table.name, new Set(Object.keys(table.definition.fields)));\n }\n\n for (const table of current.tables) {\n if (!previousTableNames.has(table.name)) {\n diff.newTables.push({ name: table.name, source: table.source });\n continue;\n }\n\n const prevFields = previousFieldsByTable.get(table.name) || new Set();\n let hasNewFields = false;\n\n for (const fieldName of Object.keys(table.definition.fields)) {\n if (!prevFields.has(fieldName)) {\n diff.newFields.push({\n table: table.name,\n field: fieldName,\n source: table.source,\n });\n hasNewFields = true;\n }\n }\n\n if (!hasNewFields) {\n diff.unchangedTables.push(table.name);\n }\n }\n\n return diff;\n}\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\nfunction deepCopyTableDef(def: PluginTableDefinition): PluginTableDefinition {\n return {\n ...def,\n fields: Object.fromEntries(Object.entries(def.fields).map(([k, v]) => [k, { ...v }])),\n compositePrimaryKey: def.compositePrimaryKey ? [...def.compositePrimaryKey] : undefined,\n };\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { InvectPlugin, PluginTableDefinition } from "../types/plugin.types.cjs";
|
|
2
|
+
|
|
3
|
+
//#region src/database/schema-merger.d.ts
|
|
4
|
+
interface MergedSchema {
|
|
5
|
+
/** All tables (core + plugin) in dependency-resolved order */
|
|
6
|
+
tables: MergedTable[];
|
|
7
|
+
/** Which plugin contributed each table/field (for diagnostics) */
|
|
8
|
+
provenance: SchemaProvenance[];
|
|
9
|
+
}
|
|
10
|
+
interface MergedTable {
|
|
11
|
+
/** Logical table name (camelCase) */
|
|
12
|
+
name: string;
|
|
13
|
+
/** The merged table definition */
|
|
14
|
+
definition: PluginTableDefinition;
|
|
15
|
+
/** Which source this table came from */
|
|
16
|
+
source: 'core' | string;
|
|
17
|
+
}
|
|
18
|
+
interface SchemaProvenance {
|
|
19
|
+
/** Table name */
|
|
20
|
+
table: string;
|
|
21
|
+
/** Field name (null for table-level provenance) */
|
|
22
|
+
field: string | null;
|
|
23
|
+
/** Source: 'core' or plugin ID */
|
|
24
|
+
source: string;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Merge core schema with all plugin schemas.
|
|
28
|
+
*
|
|
29
|
+
* @param plugins - Array of plugins (only those with `schema` are processed)
|
|
30
|
+
* @returns Merged schema with tables in dependency order
|
|
31
|
+
* @throws Error if there are conflicting field definitions
|
|
32
|
+
*/
|
|
33
|
+
declare function mergeSchemas(plugins: InvectPlugin[]): MergedSchema;
|
|
34
|
+
interface SchemaDiff {
|
|
35
|
+
newTables: {
|
|
36
|
+
name: string;
|
|
37
|
+
source: string;
|
|
38
|
+
}[];
|
|
39
|
+
newFields: {
|
|
40
|
+
table: string;
|
|
41
|
+
field: string;
|
|
42
|
+
source: string;
|
|
43
|
+
}[];
|
|
44
|
+
unchangedTables: string[];
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Compare a merged schema against a "previous" schema (e.g., from last generation).
|
|
48
|
+
* Used for preview/diff output in the CLI.
|
|
49
|
+
*/
|
|
50
|
+
declare function diffSchemas(current: MergedSchema, previous: MergedSchema | null): SchemaDiff;
|
|
51
|
+
//#endregion
|
|
52
|
+
export { MergedSchema, MergedTable, SchemaDiff, SchemaProvenance, diffSchemas, mergeSchemas };
|
|
53
|
+
//# sourceMappingURL=schema-merger.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-merger.d.cts","names":[],"sources":["../../src/database/schema-merger.ts"],"mappings":";;;UAqBiB,YAAA;;EAEf,MAAA,EAAQ,WAAA;EAOR;EALA,UAAA,EAAY,gBAAA;AAAA;AAAA,UAGG,WAAA;EAMT;EAJN,IAAA;EAOe;EALf,UAAA,EAAY,qBAAA;;EAEZ,MAAA;AAAA;AAAA,UAGe,gBAAA;EAMf;EAJA,KAAA;EAIM;EAFN,KAAA;EAwB0B;EAtB1B,MAAA;AAAA;;;;;;;;iBAsBc,YAAA,CAAa,OAAA,EAAS,YAAA,KAAiB,YAAA;AAAA,UA8HtC,UAAA;EACf,SAAA;IAAa,IAAA;IAAc,MAAA;EAAA;EAC3B,SAAA;IAAa,KAAA;IAAe,KAAA;IAAe,MAAA;EAAA;EAC3C,eAAA;AAAA;;;;;iBAOc,WAAA,CAAY,OAAA,EAAS,YAAA,EAAc,QAAA,EAAU,YAAA,UAAsB,UAAA"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { InvectPlugin, PluginTableDefinition } from "../types/plugin.types.js";
|
|
2
|
+
|
|
3
|
+
//#region src/database/schema-merger.d.ts
|
|
4
|
+
interface MergedSchema {
|
|
5
|
+
/** All tables (core + plugin) in dependency-resolved order */
|
|
6
|
+
tables: MergedTable[];
|
|
7
|
+
/** Which plugin contributed each table/field (for diagnostics) */
|
|
8
|
+
provenance: SchemaProvenance[];
|
|
9
|
+
}
|
|
10
|
+
interface MergedTable {
|
|
11
|
+
/** Logical table name (camelCase) */
|
|
12
|
+
name: string;
|
|
13
|
+
/** The merged table definition */
|
|
14
|
+
definition: PluginTableDefinition;
|
|
15
|
+
/** Which source this table came from */
|
|
16
|
+
source: 'core' | string;
|
|
17
|
+
}
|
|
18
|
+
interface SchemaProvenance {
|
|
19
|
+
/** Table name */
|
|
20
|
+
table: string;
|
|
21
|
+
/** Field name (null for table-level provenance) */
|
|
22
|
+
field: string | null;
|
|
23
|
+
/** Source: 'core' or plugin ID */
|
|
24
|
+
source: string;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Merge core schema with all plugin schemas.
|
|
28
|
+
*
|
|
29
|
+
* @param plugins - Array of plugins (only those with `schema` are processed)
|
|
30
|
+
* @returns Merged schema with tables in dependency order
|
|
31
|
+
* @throws Error if there are conflicting field definitions
|
|
32
|
+
*/
|
|
33
|
+
declare function mergeSchemas(plugins: InvectPlugin[]): MergedSchema;
|
|
34
|
+
interface SchemaDiff {
|
|
35
|
+
newTables: {
|
|
36
|
+
name: string;
|
|
37
|
+
source: string;
|
|
38
|
+
}[];
|
|
39
|
+
newFields: {
|
|
40
|
+
table: string;
|
|
41
|
+
field: string;
|
|
42
|
+
source: string;
|
|
43
|
+
}[];
|
|
44
|
+
unchangedTables: string[];
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Compare a merged schema against a "previous" schema (e.g., from last generation).
|
|
48
|
+
* Used for preview/diff output in the CLI.
|
|
49
|
+
*/
|
|
50
|
+
declare function diffSchemas(current: MergedSchema, previous: MergedSchema | null): SchemaDiff;
|
|
51
|
+
//#endregion
|
|
52
|
+
export { MergedSchema, MergedTable, SchemaDiff, SchemaProvenance, diffSchemas, mergeSchemas };
|
|
53
|
+
//# sourceMappingURL=schema-merger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-merger.d.ts","names":[],"sources":["../../src/database/schema-merger.ts"],"mappings":";;;UAqBiB,YAAA;;EAEf,MAAA,EAAQ,WAAA;EAOR;EALA,UAAA,EAAY,gBAAA;AAAA;AAAA,UAGG,WAAA;EAMT;EAJN,IAAA;EAOe;EALf,UAAA,EAAY,qBAAA;;EAEZ,MAAA;AAAA;AAAA,UAGe,gBAAA;EAMf;EAJA,KAAA;EAIM;EAFN,KAAA;EAwB0B;EAtB1B,MAAA;AAAA;;;;;;;;iBAsBc,YAAA,CAAa,OAAA,EAAS,YAAA,KAAiB,YAAA;AAAA,UA8HtC,UAAA;EACf,SAAA;IAAa,IAAA;IAAc,MAAA;EAAA;EAC3B,SAAA;IAAa,KAAA;IAAe,KAAA;IAAe,MAAA;EAAA;EAC3C,eAAA;AAAA;;;;;iBAOc,WAAA,CAAY,OAAA,EAAS,YAAA,EAAc,QAAA,EAAU,YAAA,UAAsB,UAAA"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { CORE_SCHEMA, CORE_TABLE_NAMES } from "./core-schema.js";
|
|
2
|
+
//#region src/database/schema-merger.ts
|
|
3
|
+
/**
|
|
4
|
+
* Merge core schema with all plugin schemas.
|
|
5
|
+
*
|
|
6
|
+
* @param plugins - Array of plugins (only those with `schema` are processed)
|
|
7
|
+
* @returns Merged schema with tables in dependency order
|
|
8
|
+
* @throws Error if there are conflicting field definitions
|
|
9
|
+
*/
|
|
10
|
+
function mergeSchemas(plugins) {
|
|
11
|
+
const errors = [];
|
|
12
|
+
const provenance = [];
|
|
13
|
+
const merged = {};
|
|
14
|
+
const tableSources = {};
|
|
15
|
+
for (const [name, def] of Object.entries(CORE_SCHEMA)) {
|
|
16
|
+
merged[name] = deepCopyTableDef(def);
|
|
17
|
+
tableSources[name] = "core";
|
|
18
|
+
provenance.push({
|
|
19
|
+
table: name,
|
|
20
|
+
field: null,
|
|
21
|
+
source: "core"
|
|
22
|
+
});
|
|
23
|
+
for (const fieldName of Object.keys(def.fields)) provenance.push({
|
|
24
|
+
table: name,
|
|
25
|
+
field: fieldName,
|
|
26
|
+
source: "core"
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
for (const plugin of plugins) {
|
|
30
|
+
if (!plugin.schema) continue;
|
|
31
|
+
for (const [tableName, tableDef] of Object.entries(plugin.schema)) {
|
|
32
|
+
if (tableDef.disableMigration) continue;
|
|
33
|
+
CORE_TABLE_NAMES.includes(tableName);
|
|
34
|
+
if (tableName in merged) {
|
|
35
|
+
const existing = merged[tableName];
|
|
36
|
+
if (!existing) continue;
|
|
37
|
+
for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) {
|
|
38
|
+
if (fieldName in existing.fields) {
|
|
39
|
+
const existingSource = provenance.find((p) => p.table === tableName && p.field === fieldName)?.source;
|
|
40
|
+
if (existingSource && existingSource !== plugin.id) errors.push({
|
|
41
|
+
type: "duplicate_field",
|
|
42
|
+
message: `Field "${fieldName}" on table "${tableName}" already defined by "${existingSource}". Plugin "${plugin.id}" cannot override it.`,
|
|
43
|
+
table: tableName,
|
|
44
|
+
field: fieldName,
|
|
45
|
+
plugin: plugin.id
|
|
46
|
+
});
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
existing.fields[fieldName] = { ...fieldDef };
|
|
50
|
+
provenance.push({
|
|
51
|
+
table: tableName,
|
|
52
|
+
field: fieldName,
|
|
53
|
+
source: plugin.id
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
} else {
|
|
57
|
+
merged[tableName] = deepCopyTableDef(tableDef);
|
|
58
|
+
tableSources[tableName] = plugin.id;
|
|
59
|
+
provenance.push({
|
|
60
|
+
table: tableName,
|
|
61
|
+
field: null,
|
|
62
|
+
source: plugin.id
|
|
63
|
+
});
|
|
64
|
+
for (const fieldName of Object.keys(tableDef.fields)) provenance.push({
|
|
65
|
+
table: tableName,
|
|
66
|
+
field: fieldName,
|
|
67
|
+
source: plugin.id
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
for (const [tableName, tableDef] of Object.entries(merged)) for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) if (fieldDef.references) {
|
|
73
|
+
const refTableName = fieldDef.references.table;
|
|
74
|
+
if (!Object.values(merged).some((t) => t.tableName === refTableName || Object.keys(merged).includes(refTableName))) errors.push({
|
|
75
|
+
type: "invalid_reference",
|
|
76
|
+
message: `Field "${fieldName}" on table "${tableName}" references table "${refTableName}" which does not exist.`,
|
|
77
|
+
table: tableName,
|
|
78
|
+
field: fieldName,
|
|
79
|
+
plugin: tableSources[tableName] || "unknown"
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
if (errors.length > 0) {
|
|
83
|
+
const messages = errors.map((e) => ` - [${e.plugin}] ${e.message}`).join("\n");
|
|
84
|
+
throw new Error(`Schema merge errors:\n${messages}`);
|
|
85
|
+
}
|
|
86
|
+
return {
|
|
87
|
+
tables: Object.entries(merged).map(([name, definition]) => ({
|
|
88
|
+
name,
|
|
89
|
+
definition,
|
|
90
|
+
source: tableSources[name] || "core"
|
|
91
|
+
})).sort((a, b) => {
|
|
92
|
+
const orderA = a.definition.order ?? 100;
|
|
93
|
+
const orderB = b.definition.order ?? 100;
|
|
94
|
+
if (orderA !== orderB) return orderA - orderB;
|
|
95
|
+
return a.name.localeCompare(b.name);
|
|
96
|
+
}),
|
|
97
|
+
provenance
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Compare a merged schema against a "previous" schema (e.g., from last generation).
|
|
102
|
+
* Used for preview/diff output in the CLI.
|
|
103
|
+
*/
|
|
104
|
+
function diffSchemas(current, previous) {
|
|
105
|
+
const diff = {
|
|
106
|
+
newTables: [],
|
|
107
|
+
newFields: [],
|
|
108
|
+
unchangedTables: []
|
|
109
|
+
};
|
|
110
|
+
if (!previous) {
|
|
111
|
+
diff.newTables = current.tables.map((t) => ({
|
|
112
|
+
name: t.name,
|
|
113
|
+
source: t.source
|
|
114
|
+
}));
|
|
115
|
+
return diff;
|
|
116
|
+
}
|
|
117
|
+
const previousTableNames = new Set(previous.tables.map((t) => t.name));
|
|
118
|
+
const previousFieldsByTable = /* @__PURE__ */ new Map();
|
|
119
|
+
for (const table of previous.tables) previousFieldsByTable.set(table.name, new Set(Object.keys(table.definition.fields)));
|
|
120
|
+
for (const table of current.tables) {
|
|
121
|
+
if (!previousTableNames.has(table.name)) {
|
|
122
|
+
diff.newTables.push({
|
|
123
|
+
name: table.name,
|
|
124
|
+
source: table.source
|
|
125
|
+
});
|
|
126
|
+
continue;
|
|
127
|
+
}
|
|
128
|
+
const prevFields = previousFieldsByTable.get(table.name) || /* @__PURE__ */ new Set();
|
|
129
|
+
let hasNewFields = false;
|
|
130
|
+
for (const fieldName of Object.keys(table.definition.fields)) if (!prevFields.has(fieldName)) {
|
|
131
|
+
diff.newFields.push({
|
|
132
|
+
table: table.name,
|
|
133
|
+
field: fieldName,
|
|
134
|
+
source: table.source
|
|
135
|
+
});
|
|
136
|
+
hasNewFields = true;
|
|
137
|
+
}
|
|
138
|
+
if (!hasNewFields) diff.unchangedTables.push(table.name);
|
|
139
|
+
}
|
|
140
|
+
return diff;
|
|
141
|
+
}
|
|
142
|
+
function deepCopyTableDef(def) {
|
|
143
|
+
return {
|
|
144
|
+
...def,
|
|
145
|
+
fields: Object.fromEntries(Object.entries(def.fields).map(([k, v]) => [k, { ...v }])),
|
|
146
|
+
compositePrimaryKey: def.compositePrimaryKey ? [...def.compositePrimaryKey] : void 0
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
//#endregion
|
|
150
|
+
export { diffSchemas, mergeSchemas };
|
|
151
|
+
|
|
152
|
+
//# sourceMappingURL=schema-merger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-merger.js","names":[],"sources":["../../src/database/schema-merger.ts"],"sourcesContent":["/**\n * Schema Merger\n *\n * Merges the core abstract schema with plugin schemas to produce a\n * unified abstract schema. The CLI schema generator then converts\n * this merged schema into dialect-specific Drizzle files.\n *\n * Handles:\n * - New plugin tables\n * - Plugin fields added to existing core tables (additive only)\n * - Duplicate field detection (throws error)\n * - Ordering by foreign key dependencies\n */\n\nimport type { InvectPlugin, PluginTableDefinition } from 'src/types/plugin.types';\nimport { CORE_SCHEMA, CORE_TABLE_NAMES } from './core-schema';\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport interface MergedSchema {\n /** All tables (core + plugin) in dependency-resolved order */\n tables: MergedTable[];\n /** Which plugin contributed each table/field (for diagnostics) */\n provenance: SchemaProvenance[];\n}\n\nexport interface MergedTable {\n /** Logical table name (camelCase) */\n name: string;\n /** The merged table definition */\n definition: PluginTableDefinition;\n /** Which source this table came from */\n source: 'core' | string; // 'core' or plugin ID\n}\n\nexport interface SchemaProvenance {\n /** Table name */\n table: string;\n /** Field name (null for table-level provenance) */\n field: string | null;\n /** Source: 'core' or plugin ID */\n source: string;\n}\n\nexport interface SchemaMergeError {\n type: 'duplicate_field' | 'duplicate_table' | 'invalid_reference';\n message: string;\n table: string;\n field?: string;\n plugin: string;\n}\n\n// =============================================================================\n// Merge Function\n// =============================================================================\n\n/**\n * Merge core schema with all plugin schemas.\n *\n * @param plugins - Array of plugins (only those with `schema` are processed)\n * @returns Merged schema with tables in dependency order\n * @throws Error if there are conflicting field definitions\n */\nexport function mergeSchemas(plugins: InvectPlugin[]): MergedSchema {\n const errors: SchemaMergeError[] = [];\n const provenance: SchemaProvenance[] = [];\n\n // Start with a deep copy of the core schema\n const merged: Record<string, PluginTableDefinition> = {};\n const tableSources: Record<string, string> = {}; // table → source\n\n // Add core tables\n for (const [name, def] of Object.entries(CORE_SCHEMA)) {\n merged[name] = deepCopyTableDef(def);\n tableSources[name] = 'core';\n provenance.push({ table: name, field: null, source: 'core' });\n for (const fieldName of Object.keys(def.fields)) {\n provenance.push({ table: name, field: fieldName, source: 'core' });\n }\n }\n\n // Merge each plugin's schema\n for (const plugin of plugins) {\n if (!plugin.schema) {\n continue;\n }\n\n for (const [tableName, tableDef] of Object.entries(plugin.schema)) {\n if (tableDef.disableMigration) {\n continue;\n }\n\n const _isCoreTable = CORE_TABLE_NAMES.includes(tableName);\n const existsAlready = tableName in merged;\n\n if (existsAlready) {\n // Extending an existing table — merge fields additively\n const existing = merged[tableName];\n if (!existing) {\n continue;\n }\n\n for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) {\n if (fieldName in existing.fields) {\n // Field already exists — error unless it's from the same source\n const existingSource = provenance.find(\n (p) => p.table === tableName && p.field === fieldName,\n )?.source;\n\n if (existingSource && existingSource !== plugin.id) {\n errors.push({\n type: 'duplicate_field',\n message: `Field \"${fieldName}\" on table \"${tableName}\" already defined by \"${existingSource}\". Plugin \"${plugin.id}\" cannot override it.`,\n table: tableName,\n field: fieldName,\n plugin: plugin.id,\n });\n }\n continue; // Skip duplicate\n }\n\n // Add new field to existing table\n existing.fields[fieldName] = { ...fieldDef };\n provenance.push({ table: tableName, field: fieldName, source: plugin.id });\n }\n } else {\n // New table from plugin\n merged[tableName] = deepCopyTableDef(tableDef);\n tableSources[tableName] = plugin.id;\n provenance.push({ table: tableName, field: null, source: plugin.id });\n\n for (const fieldName of Object.keys(tableDef.fields)) {\n provenance.push({ table: tableName, field: fieldName, source: plugin.id });\n }\n }\n }\n }\n\n // Validate foreign key references\n for (const [tableName, tableDef] of Object.entries(merged)) {\n for (const [fieldName, fieldDef] of Object.entries(tableDef.fields)) {\n if (fieldDef.references) {\n // Check if the referenced table exists (by tableName property, not logical name)\n const refTableName = fieldDef.references.table;\n const refExists = Object.values(merged).some(\n (t) => t.tableName === refTableName || Object.keys(merged).includes(refTableName),\n );\n\n if (!refExists) {\n errors.push({\n type: 'invalid_reference',\n message: `Field \"${fieldName}\" on table \"${tableName}\" references table \"${refTableName}\" which does not exist.`,\n table: tableName,\n field: fieldName,\n plugin: tableSources[tableName] || 'unknown',\n });\n }\n }\n }\n }\n\n if (errors.length > 0) {\n const messages = errors.map((e) => ` - [${e.plugin}] ${e.message}`).join('\\n');\n throw new Error(`Schema merge errors:\\n${messages}`);\n }\n\n // Sort tables by order, then by name for stability\n const tables: MergedTable[] = Object.entries(merged)\n .map(([name, definition]) => ({\n name,\n definition,\n source: (tableSources[name] || 'core') as 'core' | string,\n }))\n .sort((a, b) => {\n const orderA = a.definition.order ?? 100;\n const orderB = b.definition.order ?? 100;\n if (orderA !== orderB) {\n return orderA - orderB;\n }\n return a.name.localeCompare(b.name);\n });\n\n return { tables, provenance };\n}\n\n// =============================================================================\n// Diff Utilities (for `npx invect generate --diff` preview)\n// =============================================================================\n\nexport interface SchemaDiff {\n newTables: { name: string; source: string }[];\n newFields: { table: string; field: string; source: string }[];\n unchangedTables: string[];\n}\n\n/**\n * Compare a merged schema against a \"previous\" schema (e.g., from last generation).\n * Used for preview/diff output in the CLI.\n */\nexport function diffSchemas(current: MergedSchema, previous: MergedSchema | null): SchemaDiff {\n const diff: SchemaDiff = {\n newTables: [],\n newFields: [],\n unchangedTables: [],\n };\n\n if (!previous) {\n // Everything is new\n diff.newTables = current.tables.map((t) => ({ name: t.name, source: t.source }));\n return diff;\n }\n\n const previousTableNames = new Set(previous.tables.map((t) => t.name));\n const previousFieldsByTable = new Map<string, Set<string>>();\n\n for (const table of previous.tables) {\n previousFieldsByTable.set(table.name, new Set(Object.keys(table.definition.fields)));\n }\n\n for (const table of current.tables) {\n if (!previousTableNames.has(table.name)) {\n diff.newTables.push({ name: table.name, source: table.source });\n continue;\n }\n\n const prevFields = previousFieldsByTable.get(table.name) || new Set();\n let hasNewFields = false;\n\n for (const fieldName of Object.keys(table.definition.fields)) {\n if (!prevFields.has(fieldName)) {\n diff.newFields.push({\n table: table.name,\n field: fieldName,\n source: table.source,\n });\n hasNewFields = true;\n }\n }\n\n if (!hasNewFields) {\n diff.unchangedTables.push(table.name);\n }\n }\n\n return diff;\n}\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\nfunction deepCopyTableDef(def: PluginTableDefinition): PluginTableDefinition {\n return {\n ...def,\n fields: Object.fromEntries(Object.entries(def.fields).map(([k, v]) => [k, { ...v }])),\n compositePrimaryKey: def.compositePrimaryKey ? [...def.compositePrimaryKey] : undefined,\n };\n}\n"],"mappings":"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"}
|