@powerhousedao/connect 6.0.0-dev.52 → 6.0.0-dev.54
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/dist/assets/AddDriveModal-CUlc2LVq.js +2 -0
- package/dist/assets/AddDriveModal-CUlc2LVq.js.map +1 -0
- package/dist/assets/AnalyticsSubscriptionManager-B5G_L5RP.js +3 -0
- package/dist/assets/AnalyticsSubscriptionManager-B5G_L5RP.js.map +1 -0
- package/dist/assets/ClearStorageModal-xiZInXK_.js +2 -0
- package/dist/assets/ClearStorageModal-xiZInXK_.js.map +1 -0
- package/dist/assets/CookiesPolicyModal-DVXJp787.js +2 -0
- package/dist/assets/CookiesPolicyModal-DVXJp787.js.map +1 -0
- package/dist/assets/CreateDocumentModal-Cjpq1PBD.js +2 -0
- package/dist/assets/CreateDocumentModal-Cjpq1PBD.js.map +1 -0
- package/dist/assets/DebugSettingsModal-BvEPWw2E.js +7 -0
- package/dist/assets/DebugSettingsModal-BvEPWw2E.js.map +1 -0
- package/dist/assets/DeleteDriveModal-BEq8v3-E.js +2 -0
- package/dist/assets/DeleteDriveModal-BEq8v3-E.js.map +1 -0
- package/dist/assets/DeleteItemModal-B3ziER8J.js +2 -0
- package/dist/assets/DeleteItemModal-B3ziER8J.js.map +1 -0
- package/dist/assets/DisclaimerModal-CFnBcICu.js +2 -0
- package/dist/assets/DisclaimerModal-CFnBcICu.js.map +1 -0
- package/dist/assets/DriveSettingsModal-BOdnkWJn.js +2 -0
- package/dist/assets/DriveSettingsModal-BOdnkWJn.js.map +1 -0
- package/dist/assets/ExportDocumentWithErrorsModal--uHwELhU.js +2 -0
- package/dist/assets/ExportDocumentWithErrorsModal--uHwELhU.js.map +1 -0
- package/dist/assets/SettingsModal-BntFjuQb.js +2 -0
- package/dist/assets/SettingsModal-BntFjuQb.js.map +1 -0
- package/dist/assets/UpgradeDriveModal-DmbwNsbG.js +2 -0
- package/dist/assets/UpgradeDriveModal-DmbwNsbG.js.map +1 -0
- package/dist/assets/__vite-browser-external-D7Ct-6yo.js +2 -0
- package/dist/assets/__vite-browser-external-D7Ct-6yo.js.map +1 -0
- package/dist/assets/_virtual_ph_external-packages-CM1tCR4L.js +1 -0
- package/dist/assets/_virtual_ph_external-packages-CM1tCR4L.js.map +1 -0
- package/dist/assets/analytics-2CJbiDed.js +3 -0
- package/dist/assets/analytics-2CJbiDed.js.map +1 -0
- package/dist/assets/ccip-BEAjQRKG.js +2 -0
- package/dist/assets/ccip-BEAjQRKG.js.map +1 -0
- package/dist/assets/confirmation-modal-BOwR5ZQq.js +2 -0
- package/dist/assets/confirmation-modal-BOwR5ZQq.js.map +1 -0
- package/dist/assets/core-BmuZEe8D.js +2 -0
- package/dist/assets/core-BmuZEe8D.js.map +1 -0
- package/dist/assets/disclosure-BhnV_XS1.js +2 -0
- package/dist/assets/disclosure-BhnV_XS1.js.map +1 -0
- package/dist/assets/drive-by-id-DvdlB_kB.js +2 -0
- package/dist/assets/drive-by-id-DvdlB_kB.js.map +1 -0
- package/dist/assets/drives-DjHuIXXn.js +2 -0
- package/dist/assets/drives-DjHuIXXn.js.map +1 -0
- package/dist/assets/dropdown-menu-BzZBDp_E.js +2 -0
- package/dist/assets/dropdown-menu-BzZBDp_E.js.map +1 -0
- package/dist/assets/editor-DBekHIfI.js +2 -0
- package/dist/assets/editor-DBekHIfI.js.map +1 -0
- package/dist/assets/editor-DV2TvDV5.js +46 -0
- package/dist/assets/editor-DV2TvDV5.js.map +1 -0
- package/dist/assets/exports-CQVZRuji.js +3 -0
- package/dist/assets/exports-CQVZRuji.js.map +1 -0
- package/dist/assets/form-input-CPs_z-6y.js +2 -0
- package/dist/assets/form-input-CPs_z-6y.js.map +1 -0
- package/dist/assets/graphql-editor-CcDLLpoK.js +74 -0
- package/dist/assets/graphql-editor-CcDLLpoK.js.map +1 -0
- package/dist/assets/hmr-BfH10IPs.js +2 -0
- package/dist/assets/hmr-BfH10IPs.js.map +1 -0
- package/dist/assets/hmr-LMNkvzP7.js +1 -0
- package/dist/assets/hmr-LMNkvzP7.js.map +1 -0
- package/dist/assets/{hooks-DfJBOC53.js → hooks--iZen3H-.js} +13 -12
- package/dist/assets/hooks--iZen3H-.js.map +1 -0
- package/dist/assets/index-BDI8rK1R.js +2 -0
- package/dist/assets/index-BDI8rK1R.js.map +1 -0
- package/dist/assets/index-BWgPOeS2.js +500 -0
- package/dist/assets/index-BWgPOeS2.js.map +1 -0
- package/dist/assets/index-BeyYTlkr.js +2 -0
- package/dist/assets/index-BeyYTlkr.js.map +1 -0
- package/dist/assets/index-CUlo2oTb.js +199 -0
- package/dist/assets/index-CUlo2oTb.js.map +1 -0
- package/dist/assets/index-DN20Z-2K.js +222 -0
- package/dist/assets/index-DN20Z-2K.js.map +1 -0
- package/dist/assets/index-DPCEN2cB.js +2 -0
- package/dist/assets/index-DPCEN2cB.js.map +1 -0
- package/dist/assets/index-DcvFnjR9.css +1 -0
- package/dist/assets/index-RTtoSfzq.js +2 -0
- package/dist/assets/index-RTtoSfzq.js.map +1 -0
- package/dist/assets/index-WdPlK4TH.js +32 -0
- package/dist/assets/index-WdPlK4TH.js.map +1 -0
- package/dist/assets/index.esm-BeYGM8vk.js +2 -0
- package/dist/assets/index.esm-BeYGM8vk.js.map +1 -0
- package/dist/assets/index.modern-BKQ3hpRq.js +2 -0
- package/dist/assets/index.modern-BKQ3hpRq.js.map +1 -0
- package/dist/assets/json-editor-CfHUc1UK.js +2 -0
- package/dist/assets/json-editor-CfHUc1UK.js.map +1 -0
- package/dist/assets/load-D23NmM_n.js +4 -0
- package/dist/assets/load-D23NmM_n.js.map +1 -0
- package/dist/assets/location-info-N8RPWokW.js +2 -0
- package/dist/assets/location-info-N8RPWokW.js.map +1 -0
- package/dist/assets/message-list-0i5gk_8j.js +2 -0
- package/dist/assets/message-list-0i5gk_8j.js.map +1 -0
- package/dist/assets/migrator-CmQyl4ZK.js +78 -0
- package/dist/assets/migrator-CmQyl4ZK.js.map +1 -0
- package/dist/assets/node-input-DnUl9CxT.js +2 -0
- package/dist/assets/node-input-DnUl9CxT.js.map +1 -0
- package/dist/assets/nodefs-BP-sxN1O.js +2 -0
- package/dist/assets/nodefs-BP-sxN1O.js.map +1 -0
- package/dist/assets/nodefs-_NvywCGz.js +1 -0
- package/dist/assets/nodefs-_NvywCGz.js.map +1 -0
- package/dist/assets/opfs-ahp-DN9nZuJs.js +1 -0
- package/dist/assets/opfs-ahp-DN9nZuJs.js.map +1 -0
- package/dist/assets/opfs-ahp-DtmzPaVs.js +4 -0
- package/dist/assets/opfs-ahp-DtmzPaVs.js.map +1 -0
- package/dist/assets/options-CBc6-sTL.js +2 -0
- package/dist/assets/options-CBc6-sTL.js.map +1 -0
- package/dist/assets/pglite.db-B2bT8QML.js +133 -0
- package/dist/assets/pglite.db-B2bT8QML.js.map +1 -0
- package/dist/assets/pglite.worker-Ca6pWokV.js +1 -0
- package/dist/assets/pglite.worker-Ca6pWokV.js.map +1 -0
- package/dist/assets/processor-host-module-B89Dt9nZ.js +3 -0
- package/dist/assets/processor-host-module-B89Dt9nZ.js.map +1 -0
- package/dist/assets/queue-CxFgA-r3.js +2 -0
- package/dist/assets/queue-CxFgA-r3.js.map +1 -0
- package/dist/assets/reactor-7tK-WVaY.js +16 -0
- package/dist/assets/reactor-7tK-WVaY.js.map +1 -0
- package/dist/assets/reactor-Bsjwm88i.js +193 -0
- package/dist/assets/reactor-Bsjwm88i.js.map +1 -0
- package/dist/assets/reactor-CRqBKYEo.css +1 -0
- package/dist/assets/read-required-modal-BKEkfucI.js +2 -0
- package/dist/assets/read-required-modal-BKEkfucI.js.map +1 -0
- package/dist/assets/renown-CgfQ6oBU.js +2 -0
- package/dist/assets/renown-CgfQ6oBU.js.map +1 -0
- package/dist/assets/state-schemas-DK8TnzfC.js +3 -0
- package/dist/assets/state-schemas-DK8TnzfC.js.map +1 -0
- package/dist/assets/tabs-DY_DEdtI.js +2 -0
- package/dist/assets/tabs-DY_DEdtI.js.map +1 -0
- package/dist/assets/use-get-switchboard-link-B47eB8lt.js +12 -0
- package/dist/assets/use-get-switchboard-link-B47eB8lt.js.map +1 -0
- package/dist/assets/user-permissions-BJ8c2UOP.js +2 -0
- package/dist/assets/user-permissions-BJ8c2UOP.js.map +1 -0
- package/dist/assets/vetra-Bu3fuZWc.js +221 -0
- package/dist/assets/vetra-Bu3fuZWc.js.map +1 -0
- package/dist/index.html +2 -20
- package/lib/package.copy.json +3 -4
- package/lib/src/components/app-loader.d.ts.map +1 -1
- package/lib/src/components/app-loader.js +5 -16
- package/lib/src/components/app-loader.js.map +1 -1
- package/lib/src/components/index.d.ts +0 -1
- package/lib/src/components/index.d.ts.map +1 -1
- package/lib/src/components/index.js +0 -1
- package/lib/src/components/index.js.map +1 -1
- package/lib/src/components/load.d.ts +8 -0
- package/lib/src/components/load.d.ts.map +1 -0
- package/lib/src/components/load.js +17 -0
- package/lib/src/components/load.js.map +1 -0
- package/lib/src/components/modal/modals/InspectorModal/InspectorModal.d.ts.map +1 -1
- package/lib/src/components/modal/modals/InspectorModal/InspectorModal.js +2 -1
- package/lib/src/components/modal/modals/InspectorModal/InspectorModal.js.map +1 -1
- package/lib/src/components/modal/modals/InspectorModal/useRemotesInspector.d.ts +1 -0
- package/lib/src/components/modal/modals/InspectorModal/useRemotesInspector.d.ts.map +1 -1
- package/lib/src/components/modal/modals/InspectorModal/useRemotesInspector.js +2 -0
- package/lib/src/components/modal/modals/InspectorModal/useRemotesInspector.js.map +1 -1
- package/lib/src/components/modal/modals/SettingsModal.d.ts.map +1 -1
- package/lib/src/components/modal/modals/SettingsModal.js +4 -1
- package/lib/src/components/modal/modals/SettingsModal.js.map +1 -1
- package/lib/src/components/modal/modals-container.d.ts +1 -1
- package/lib/src/components/modal/modals-container.d.ts.map +1 -1
- package/lib/src/components/modal/modals-container.js +12 -8
- package/lib/src/components/modal/modals-container.js.map +1 -1
- package/lib/src/main.js +3 -0
- package/lib/src/main.js.map +1 -1
- package/lib/src/services/storage/base-storage.d.ts.map +1 -1
- package/lib/src/services/storage/base-storage.js.map +1 -1
- package/lib/src/store/processor-host-module.d.ts.map +1 -1
- package/lib/src/store/processor-host-module.js +2 -2
- package/lib/src/store/processor-host-module.js.map +1 -1
- package/lib/src/store/reactor.d.ts.map +1 -1
- package/lib/src/store/reactor.js +1 -1
- package/lib/src/store/reactor.js.map +1 -1
- package/lib/style.css +15 -0
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/vite.config.d.ts.map +1 -1
- package/lib/vite.config.js +1 -29
- package/lib/vite.config.js.map +1 -1
- package/package.copy.json +3 -4
- package/package.json +12 -13
- package/dist/assets/AddDriveModal-CJtOv39H.js +0 -1
- package/dist/assets/ClearStorageModal-y5IKZ5QW.js +0 -1
- package/dist/assets/CookiesPolicyModal-CRQMjvin.js +0 -1
- package/dist/assets/CreateDocumentModal-wq9SMWoi.js +0 -1
- package/dist/assets/DebugSettingsModal-DRXZ3l1V.js +0 -1
- package/dist/assets/DeleteDriveModal-Cr5Usb_L.js +0 -1
- package/dist/assets/DeleteItemModal-8enl6kcm.js +0 -1
- package/dist/assets/DisclaimerModal-XxPC9Ejt.js +0 -1
- package/dist/assets/DriveSettingsModal-6h8SadLE.js +0 -1
- package/dist/assets/ExportDocumentWithErrorsModal-DXqXD8JC.js +0 -1
- package/dist/assets/SettingsModal-hbCXOBTZ.js +0 -1
- package/dist/assets/UpgradeDriveModal-iM7KnmAQ.js +0 -1
- package/dist/assets/config-0mYxXHFp.js +0 -1
- package/dist/assets/design_system-DuOTmGnv.js +0 -45
- package/dist/assets/design_system_connect-oOPqJKY4.js +0 -47
- package/dist/assets/design_system_ui-BpFBMLtp.js +0 -1
- package/dist/assets/document_drive-DiwReQ7A.js +0 -154
- package/dist/assets/document_engineering-p8dj-Cba.js +0 -1
- package/dist/assets/document_model-ly1Z8uco.js +0 -241
- package/dist/assets/document_model_editor-Da4AAuKL.js +0 -25
- package/dist/assets/drive_explorer-DgTtoOmx.js +0 -2
- package/dist/assets/editor-D3CEoO4i.js +0 -1
- package/dist/assets/graphql-BXSeDpaV.js +0 -75
- package/dist/assets/graphql-editor-CduYMSwz.js +0 -73
- package/dist/assets/graphql_request-BHyPFzlZ.js +0 -3
- package/dist/assets/index-B6A7sjLB.css +0 -1
- package/dist/assets/index-DO1hMFtq.js +0 -149
- package/dist/assets/index-DaxIv9p8.js +0 -29
- package/dist/assets/index-nPVGMhnl.js +0 -208
- package/dist/assets/json-editor-ge2w_43Q.js +0 -1
- package/dist/assets/nodefs-BDOJRpNU.js +0 -1
- package/dist/assets/nodefs-CVTQ2TCv.js +0 -1
- package/dist/assets/opfs-ahp--n7Av8I7.js +0 -3
- package/dist/assets/opfs-ahp-gToYnU-E.js +0 -3
- package/dist/assets/postgres-CkP7QCDB.data +0 -0
- package/dist/assets/postgres-CyuUVpXN.wasm +0 -0
- package/dist/assets/react/jsx-runtime-DldvXD6N.js +0 -1
- package/dist/assets/react-D_vzfE_e.js +0 -1
- package/dist/assets/react-dom/client-SoBEzBdt.js +0 -9
- package/dist/assets/react-dom-Cz_KAjfm.js +0 -1
- package/dist/assets/reactor_browser-D9uAHhHf.js +0 -136
- package/dist/assets/sentry_browser-TIBDlywD.js +0 -498
- package/dist/assets/sentry_react-CVx4Qq7f.js +0 -3
- package/dist/assets/state-schemas-CNNgCMhK.js +0 -2
- package/dist/assets/tailwind_merge-CXl88Wxt.js +0 -1
- package/dist/assets/zod-Cc38s6JG.js +0 -39
- package/lib/src/components/modal/index.d.ts +0 -18
- package/lib/src/components/modal/index.d.ts.map +0 -1
- package/lib/src/components/modal/index.js +0 -18
- package/lib/src/components/modal/index.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrator-CmQyl4ZK.js","sources":["../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/util/object-utils.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/identifier-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/schemable-identifier-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/alias-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/table-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/operation-node-source.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/expression/expression.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/select-modifier-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/and-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/or-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/on-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/join-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/binary-operation-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/operator-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/column-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/select-all-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/reference-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/dynamic/dynamic-reference-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/order-by-item-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/raw-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/collate-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/order-by-item-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/util/log-once.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/order-by-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/json-reference-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/json-operator-chain-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/json-path-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/reference-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/primitive-value-list-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/value-list-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/value-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/value-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/parens-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/binary-operation-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/order-by-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/partition-by-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/over-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/from-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/group-by-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/having-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/insert-query-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/list-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/update-query-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/using-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/delete-query-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/where-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/returning-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/explain-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/when-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/merge-query-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/output-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/query-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/select-query-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/join-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/partition-by-item-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/partition-by-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/over-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/selection-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/select-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/values-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/default-insert-value-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/insert-values-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/column-update-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/update-set-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/on-duplicate-key-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/insert-result.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/no-result-error.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/on-conflict-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/on-conflict-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/top-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/top-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/or-action-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/insert-query-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/delete-result.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/limit-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/delete-query-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/update-result.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/update-query-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/common-table-expression-name-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/common-table-expression-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/cte-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/with-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/with-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/util/random-string.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/util/query-id.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/operation-node-transformer.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/plugin/with-schema/with-schema-transformer.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/plugin/with-schema/with-schema-plugin.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/matched-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/merge-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/util/deferred.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/util/provide-controlled-connection.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-executor/query-executor-base.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-executor/noop-query-executor.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/merge-result.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/merge-query-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-creator.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/parse-utils.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/join-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/offset-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/group-by-item-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/group-by-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/set-operation-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/set-operation-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/expression/expression-wrapper.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/fetch-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/fetch-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/select-query-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/aggregate-function-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/function-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/aggregate-function-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/function-module.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/unary-operation-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/unary-operation-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/case-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/case-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/json-path-leg-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/query-builder/json-path-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/tuple-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/data-type-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/data-type-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/operation-node/cast-node.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/expression/expression-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/expression-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/dynamic/dynamic-table-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/parser/table-parser.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/raw-builder/raw-builder.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/raw-builder/sql.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/plugin/noop-plugin.js","../../../../node_modules/.pnpm/kysely@0.28.11/node_modules/kysely/dist/esm/migration/migrator.js","../../../../packages/reactor/dist/src/sync/types.js","../../../../packages/reactor/dist/src/sync/mailbox.js","../../../../packages/reactor/dist/src/sync/buffered-mailbox.js","../../../../packages/reactor/dist/src/sync/errors.js","../../../../packages/reactor/dist/src/sync/sync-operation.js","../../../../packages/reactor/dist/src/sync/utils.js","../../../../packages/reactor/dist/src/sync/channels/interval-poll-timer.js","../../../../packages/reactor/dist/src/sync/channels/utils.js","../../../../packages/reactor/dist/src/sync/channels/gql-req-channel.js","../../../../packages/reactor/dist/src/storage/migrations/001_create_operation_table.js","../../../../packages/reactor/dist/src/storage/migrations/002_create_keyframe_table.js","../../../../packages/reactor/dist/src/storage/migrations/003_create_document_table.js","../../../../packages/reactor/dist/src/storage/migrations/004_create_document_relationship_table.js","../../../../packages/reactor/dist/src/storage/migrations/005_create_indexer_state_table.js","../../../../packages/reactor/dist/src/storage/migrations/006_create_document_snapshot_table.js","../../../../packages/reactor/dist/src/storage/migrations/007_create_slug_mapping_table.js","../../../../packages/reactor/dist/src/storage/migrations/008_create_view_state_table.js","../../../../packages/reactor/dist/src/storage/migrations/009_create_operation_index_tables.js","../../../../packages/reactor/dist/src/storage/migrations/010_create_sync_tables.js","../../../../packages/reactor/dist/src/storage/migrations/011_add_cursor_type_column.js","../../../../packages/reactor/dist/src/storage/migrations/012_add_source_remote_column.js","../../../../packages/reactor/dist/src/storage/migrations/migrator.js"],"sourcesContent":["/// <reference types=\"./object-utils.d.ts\" />\nexport function isEmpty(obj) {\n if (Array.isArray(obj) || isString(obj) || isBuffer(obj)) {\n return obj.length === 0;\n }\n else if (obj) {\n return Object.keys(obj).length === 0;\n }\n return false;\n}\nexport function isUndefined(obj) {\n return typeof obj === 'undefined' || obj === undefined;\n}\nexport function isString(obj) {\n return typeof obj === 'string';\n}\nexport function isNumber(obj) {\n return typeof obj === 'number';\n}\nexport function isBoolean(obj) {\n return typeof obj === 'boolean';\n}\nexport function isNull(obj) {\n return obj === null;\n}\nexport function isDate(obj) {\n return obj instanceof Date;\n}\nexport function isBigInt(obj) {\n return typeof obj === 'bigint';\n}\n// Don't change the returnd type to `obj is Buffer` to not create a\n// hard dependency to node.\nexport function isBuffer(obj) {\n return typeof Buffer !== 'undefined' && Buffer.isBuffer(obj);\n}\nexport function isFunction(obj) {\n return typeof obj === 'function';\n}\nexport function isObject(obj) {\n return typeof obj === 'object' && obj !== null;\n}\nexport function isArrayBufferOrView(obj) {\n return obj instanceof ArrayBuffer || ArrayBuffer.isView(obj);\n}\nexport function isPlainObject(obj) {\n if (!isObject(obj) || getTag(obj) !== '[object Object]') {\n return false;\n }\n if (Object.getPrototypeOf(obj) === null) {\n return true;\n }\n let proto = obj;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(obj) === proto;\n}\nexport function getLast(arr) {\n return arr[arr.length - 1];\n}\nexport function freeze(obj) {\n return Object.freeze(obj);\n}\nexport function asArray(arg) {\n if (isReadonlyArray(arg)) {\n return arg;\n }\n else {\n return [arg];\n }\n}\nexport function asReadonlyArray(arg) {\n if (isReadonlyArray(arg)) {\n return arg;\n }\n else {\n return freeze([arg]);\n }\n}\nexport function isReadonlyArray(arg) {\n return Array.isArray(arg);\n}\nexport function noop(obj) {\n return obj;\n}\nexport function compare(obj1, obj2) {\n if (isReadonlyArray(obj1) && isReadonlyArray(obj2)) {\n return compareArrays(obj1, obj2);\n }\n else if (isObject(obj1) && isObject(obj2)) {\n return compareObjects(obj1, obj2);\n }\n return obj1 === obj2;\n}\nfunction compareArrays(arr1, arr2) {\n if (arr1.length !== arr2.length) {\n return false;\n }\n for (let i = 0; i < arr1.length; ++i) {\n if (!compare(arr1[i], arr2[i])) {\n return false;\n }\n }\n return true;\n}\nfunction compareObjects(obj1, obj2) {\n if (isBuffer(obj1) && isBuffer(obj2)) {\n return compareBuffers(obj1, obj2);\n }\n else if (isDate(obj1) && isDate(obj2)) {\n return compareDates(obj1, obj2);\n }\n return compareGenericObjects(obj1, obj2);\n}\nfunction compareBuffers(buf1, buf2) {\n return Buffer.compare(buf1, buf2) === 0;\n}\nfunction compareDates(date1, date2) {\n return date1.getTime() === date2.getTime();\n}\nfunction compareGenericObjects(obj1, obj2) {\n const keys1 = Object.keys(obj1);\n const keys2 = Object.keys(obj2);\n if (keys1.length !== keys2.length) {\n return false;\n }\n for (const key of keys1) {\n if (!compare(obj1[key], obj2[key])) {\n return false;\n }\n }\n return true;\n}\nconst toString = Object.prototype.toString;\nfunction getTag(value) {\n if (value == null) {\n return value === undefined ? '[object Undefined]' : '[object Null]';\n }\n return toString.call(value);\n}\n","/// <reference types=\"./identifier-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const IdentifierNode = freeze({\n is(node) {\n return node.kind === 'IdentifierNode';\n },\n create(name) {\n return freeze({\n kind: 'IdentifierNode',\n name,\n });\n },\n});\n","/// <reference types=\"./schemable-identifier-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const SchemableIdentifierNode = freeze({\n is(node) {\n return node.kind === 'SchemableIdentifierNode';\n },\n create(identifier) {\n return freeze({\n kind: 'SchemableIdentifierNode',\n identifier: IdentifierNode.create(identifier),\n });\n },\n createWithSchema(schema, identifier) {\n return freeze({\n kind: 'SchemableIdentifierNode',\n schema: IdentifierNode.create(schema),\n identifier: IdentifierNode.create(identifier),\n });\n },\n});\n","/// <reference types=\"./alias-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AliasNode = freeze({\n is(node) {\n return node.kind === 'AliasNode';\n },\n create(node, alias) {\n return freeze({\n kind: 'AliasNode',\n node,\n alias,\n });\n },\n});\n","/// <reference types=\"./table-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { SchemableIdentifierNode } from './schemable-identifier-node.js';\n/**\n * @internal\n */\nexport const TableNode = freeze({\n is(node) {\n return node.kind === 'TableNode';\n },\n create(table) {\n return freeze({\n kind: 'TableNode',\n table: SchemableIdentifierNode.create(table),\n });\n },\n createWithSchema(schema, table) {\n return freeze({\n kind: 'TableNode',\n table: SchemableIdentifierNode.createWithSchema(schema, table),\n });\n },\n});\n","/// <reference types=\"./operation-node-source.d.ts\" />\nimport { isFunction, isObject } from '../util/object-utils.js';\nexport function isOperationNodeSource(obj) {\n return isObject(obj) && isFunction(obj.toOperationNode);\n}\n","/// <reference types=\"./expression.d.ts\" />\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { isObject, isString } from '../util/object-utils.js';\nexport function isExpression(obj) {\n return isObject(obj) && 'expressionType' in obj && isOperationNodeSource(obj);\n}\nexport function isAliasedExpression(obj) {\n return (isObject(obj) &&\n 'expression' in obj &&\n isString(obj.alias) &&\n isOperationNodeSource(obj));\n}\n","/// <reference types=\"./select-modifier-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const SelectModifierNode = freeze({\n is(node) {\n return node.kind === 'SelectModifierNode';\n },\n create(modifier, of) {\n return freeze({\n kind: 'SelectModifierNode',\n modifier,\n of,\n });\n },\n createWithExpression(modifier) {\n return freeze({\n kind: 'SelectModifierNode',\n rawModifier: modifier,\n });\n },\n});\n","/// <reference types=\"./and-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const AndNode = freeze({\n is(node) {\n return node.kind === 'AndNode';\n },\n create(left, right) {\n return freeze({\n kind: 'AndNode',\n left,\n right,\n });\n },\n});\n","/// <reference types=\"./or-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrNode = freeze({\n is(node) {\n return node.kind === 'OrNode';\n },\n create(left, right) {\n return freeze({\n kind: 'OrNode',\n left,\n right,\n });\n },\n});\n","/// <reference types=\"./on-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AndNode } from './and-node.js';\nimport { OrNode } from './or-node.js';\n/**\n * @internal\n */\nexport const OnNode = freeze({\n is(node) {\n return node.kind === 'OnNode';\n },\n create(filter) {\n return freeze({\n kind: 'OnNode',\n on: filter,\n });\n },\n cloneWithOperation(onNode, operator, operation) {\n return freeze({\n ...onNode,\n on: operator === 'And'\n ? AndNode.create(onNode.on, operation)\n : OrNode.create(onNode.on, operation),\n });\n },\n});\n","/// <reference types=\"./join-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { OnNode } from './on-node.js';\n/**\n * @internal\n */\nexport const JoinNode = freeze({\n is(node) {\n return node.kind === 'JoinNode';\n },\n create(joinType, table) {\n return freeze({\n kind: 'JoinNode',\n joinType,\n table,\n on: undefined,\n });\n },\n createWithOn(joinType, table, on) {\n return freeze({\n kind: 'JoinNode',\n joinType,\n table,\n on: OnNode.create(on),\n });\n },\n cloneWithOn(joinNode, operation) {\n return freeze({\n ...joinNode,\n on: joinNode.on\n ? OnNode.cloneWithOperation(joinNode.on, 'And', operation)\n : OnNode.create(operation),\n });\n },\n});\n","/// <reference types=\"./binary-operation-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const BinaryOperationNode = freeze({\n is(node) {\n return node.kind === 'BinaryOperationNode';\n },\n create(leftOperand, operator, rightOperand) {\n return freeze({\n kind: 'BinaryOperationNode',\n leftOperand,\n operator,\n rightOperand,\n });\n },\n});\n","/// <reference types=\"./operator-node.d.ts\" />\nimport { freeze, isString } from '../util/object-utils.js';\nexport const COMPARISON_OPERATORS = [\n '=',\n '==',\n '!=',\n '<>',\n '>',\n '>=',\n '<',\n '<=',\n 'in',\n 'not in',\n 'is',\n 'is not',\n 'like',\n 'not like',\n 'match',\n 'ilike',\n 'not ilike',\n '@>',\n '<@',\n '^@',\n '&&',\n '?',\n '?&',\n '?|',\n '!<',\n '!>',\n '<=>',\n '!~',\n '~',\n '~*',\n '!~*',\n '@@',\n '@@@',\n '!!',\n '<->',\n 'regexp',\n 'is distinct from',\n 'is not distinct from',\n];\nexport const ARITHMETIC_OPERATORS = [\n '+',\n '-',\n '*',\n '/',\n '%',\n '^',\n '&',\n '|',\n '#',\n '<<',\n '>>',\n];\nexport const JSON_OPERATORS = ['->', '->>'];\nexport const BINARY_OPERATORS = [\n ...COMPARISON_OPERATORS,\n ...ARITHMETIC_OPERATORS,\n '&&',\n '||',\n];\nexport const UNARY_FILTER_OPERATORS = ['exists', 'not exists'];\nexport const UNARY_OPERATORS = ['not', '-', ...UNARY_FILTER_OPERATORS];\nexport const OPERATORS = [\n ...BINARY_OPERATORS,\n ...JSON_OPERATORS,\n ...UNARY_OPERATORS,\n 'between',\n 'between symmetric',\n];\n/**\n * @internal\n */\nexport const OperatorNode = freeze({\n is(node) {\n return node.kind === 'OperatorNode';\n },\n create(operator) {\n return freeze({\n kind: 'OperatorNode',\n operator,\n });\n },\n});\nexport function isOperator(op) {\n return isString(op) && OPERATORS.includes(op);\n}\nexport function isBinaryOperator(op) {\n return isString(op) && BINARY_OPERATORS.includes(op);\n}\nexport function isComparisonOperator(op) {\n return isString(op) && COMPARISON_OPERATORS.includes(op);\n}\nexport function isArithmeticOperator(op) {\n return isString(op) && ARITHMETIC_OPERATORS.includes(op);\n}\nexport function isJSONOperator(op) {\n return isString(op) && JSON_OPERATORS.includes(op);\n}\n","/// <reference types=\"./column-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const ColumnNode = freeze({\n is(node) {\n return node.kind === 'ColumnNode';\n },\n create(column) {\n return freeze({\n kind: 'ColumnNode',\n column: IdentifierNode.create(column),\n });\n },\n});\n","/// <reference types=\"./select-all-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const SelectAllNode = freeze({\n is(node) {\n return node.kind === 'SelectAllNode';\n },\n create() {\n return freeze({\n kind: 'SelectAllNode',\n });\n },\n});\n","/// <reference types=\"./reference-node.d.ts\" />\nimport { SelectAllNode } from './select-all-node.js';\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ReferenceNode = freeze({\n is(node) {\n return node.kind === 'ReferenceNode';\n },\n create(column, table) {\n return freeze({\n kind: 'ReferenceNode',\n table,\n column,\n });\n },\n createSelectAll(table) {\n return freeze({\n kind: 'ReferenceNode',\n table,\n column: SelectAllNode.create(),\n });\n },\n});\n","/// <reference types=\"./dynamic-reference-builder.d.ts\" />\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { parseSimpleReferenceExpression } from '../parser/reference-parser.js';\nimport { isObject, isString } from '../util/object-utils.js';\nexport class DynamicReferenceBuilder {\n #dynamicReference;\n get dynamicReference() {\n return this.#dynamicReference;\n }\n /**\n * @private\n *\n * This needs to be here just so that the typings work. Without this\n * the generated .d.ts file contains no reference to the type param R\n * which causes this type to be equal to DynamicReferenceBuilder with\n * any R.\n */\n get refType() {\n return undefined;\n }\n constructor(reference) {\n this.#dynamicReference = reference;\n }\n toOperationNode() {\n return parseSimpleReferenceExpression(this.#dynamicReference);\n }\n}\nexport function isDynamicReferenceBuilder(obj) {\n return (isObject(obj) &&\n isOperationNodeSource(obj) &&\n isString(obj.dynamicReference));\n}\n","/// <reference types=\"./order-by-item-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrderByItemNode = freeze({\n is(node) {\n return node.kind === 'OrderByItemNode';\n },\n create(orderBy, direction) {\n return freeze({\n kind: 'OrderByItemNode',\n orderBy,\n direction,\n });\n },\n cloneWith(node, props) {\n return freeze({\n ...node,\n ...props,\n });\n },\n});\n","/// <reference types=\"./raw-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const RawNode = freeze({\n is(node) {\n return node.kind === 'RawNode';\n },\n create(sqlFragments, parameters) {\n return freeze({\n kind: 'RawNode',\n sqlFragments: freeze(sqlFragments),\n parameters: freeze(parameters),\n });\n },\n createWithSql(sql) {\n return RawNode.create([sql], []);\n },\n createWithChild(child) {\n return RawNode.create(['', ''], [child]);\n },\n createWithChildren(children) {\n return RawNode.create(new Array(children.length + 1).fill(''), children);\n },\n});\n","/// <reference types=\"./collate-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { IdentifierNode } from './identifier-node.js';\n/**\n * @internal\n */\nexport const CollateNode = freeze({\n is(node) {\n return node.kind === 'CollateNode';\n },\n create(collation) {\n return freeze({\n kind: 'CollateNode',\n collation: IdentifierNode.create(collation),\n });\n },\n});\n","/// <reference types=\"./order-by-item-builder.d.ts\" />\nimport { CollateNode } from '../operation-node/collate-node.js';\nimport { OrderByItemNode } from '../operation-node/order-by-item-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class OrderByItemBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Adds `desc` to the `order by` item.\n *\n * See {@link asc} for the opposite.\n */\n desc() {\n return new OrderByItemBuilder({\n node: OrderByItemNode.cloneWith(this.#props.node, {\n direction: RawNode.createWithSql('desc'),\n }),\n });\n }\n /**\n * Adds `asc` to the `order by` item.\n *\n * See {@link desc} for the opposite.\n */\n asc() {\n return new OrderByItemBuilder({\n node: OrderByItemNode.cloneWith(this.#props.node, {\n direction: RawNode.createWithSql('asc'),\n }),\n });\n }\n /**\n * Adds `nulls last` to the `order by` item.\n *\n * This is only supported by some dialects like PostgreSQL and SQLite.\n *\n * See {@link nullsFirst} for the opposite.\n */\n nullsLast() {\n return new OrderByItemBuilder({\n node: OrderByItemNode.cloneWith(this.#props.node, { nulls: 'last' }),\n });\n }\n /**\n * Adds `nulls first` to the `order by` item.\n *\n * This is only supported by some dialects like PostgreSQL and SQLite.\n *\n * See {@link nullsLast} for the opposite.\n */\n nullsFirst() {\n return new OrderByItemBuilder({\n node: OrderByItemNode.cloneWith(this.#props.node, { nulls: 'first' }),\n });\n }\n /**\n * Adds `collate <collationName>` to the `order by` item.\n */\n collate(collation) {\n return new OrderByItemBuilder({\n node: OrderByItemNode.cloneWith(this.#props.node, {\n collation: CollateNode.create(collation),\n }),\n });\n }\n toOperationNode() {\n return this.#props.node;\n }\n}\n","/// <reference types=\"./log-once.d.ts\" />\nconst LOGGED_MESSAGES = new Set();\n/**\n * Use for system-level logging, such as deprecation messages.\n * Logs a message and ensures it won't be logged again.\n */\nexport function logOnce(message) {\n if (LOGGED_MESSAGES.has(message)) {\n return;\n }\n LOGGED_MESSAGES.add(message);\n console.log(message);\n}\n","/// <reference types=\"./order-by-parser.d.ts\" />\nimport { isDynamicReferenceBuilder, } from '../dynamic/dynamic-reference-builder.js';\nimport { isExpression } from '../expression/expression.js';\nimport { OrderByItemNode } from '../operation-node/order-by-item-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { OrderByItemBuilder } from '../query-builder/order-by-item-builder.js';\nimport { logOnce } from '../util/log-once.js';\nimport { isExpressionOrFactory, parseExpression, } from './expression-parser.js';\nimport { parseStringReference, } from './reference-parser.js';\nexport function isOrderByDirection(thing) {\n return thing === 'asc' || thing === 'desc';\n}\nexport function parseOrderBy(args) {\n if (args.length === 2) {\n return [parseOrderByItem(args[0], args[1])];\n }\n if (args.length === 1) {\n const [orderBy] = args;\n if (Array.isArray(orderBy)) {\n logOnce('orderBy(array) is deprecated, use multiple orderBy calls instead.');\n return orderBy.map((item) => parseOrderByItem(item));\n }\n return [parseOrderByItem(orderBy)];\n }\n throw new Error(`Invalid number of arguments at order by! expected 1-2, received ${args.length}`);\n}\nexport function parseOrderByItem(expr, modifiers) {\n const parsedRef = parseOrderByExpression(expr);\n if (OrderByItemNode.is(parsedRef)) {\n if (modifiers) {\n throw new Error('Cannot specify direction twice!');\n }\n return parsedRef;\n }\n return parseOrderByWithModifiers(parsedRef, modifiers);\n}\nfunction parseOrderByExpression(expr) {\n if (isExpressionOrFactory(expr)) {\n return parseExpression(expr);\n }\n if (isDynamicReferenceBuilder(expr)) {\n return expr.toOperationNode();\n }\n const [ref, direction] = expr.split(' ');\n if (direction) {\n logOnce(\"`orderBy('column asc')` is deprecated. Use `orderBy('column', 'asc')` instead.\");\n return parseOrderByWithModifiers(parseStringReference(ref), direction);\n }\n return parseStringReference(expr);\n}\nfunction parseOrderByWithModifiers(expr, modifiers) {\n if (typeof modifiers === 'string') {\n if (!isOrderByDirection(modifiers)) {\n throw new Error(`Invalid order by direction: ${modifiers}`);\n }\n return OrderByItemNode.create(expr, RawNode.createWithSql(modifiers));\n }\n if (isExpression(modifiers)) {\n logOnce(\"`orderBy(..., expr)` is deprecated. Use `orderBy(..., 'asc')` or `orderBy(..., (ob) => ...)` instead.\");\n return OrderByItemNode.create(expr, modifiers.toOperationNode());\n }\n const node = OrderByItemNode.create(expr);\n if (!modifiers) {\n return node;\n }\n return modifiers(new OrderByItemBuilder({ node })).toOperationNode();\n}\n","/// <reference types=\"./json-reference-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONReferenceNode = freeze({\n is(node) {\n return node.kind === 'JSONReferenceNode';\n },\n create(reference, traversal) {\n return freeze({\n kind: 'JSONReferenceNode',\n reference,\n traversal,\n });\n },\n cloneWithTraversal(node, traversal) {\n return freeze({\n ...node,\n traversal,\n });\n },\n});\n","/// <reference types=\"./json-operator-chain-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONOperatorChainNode = freeze({\n is(node) {\n return node.kind === 'JSONOperatorChainNode';\n },\n create(operator) {\n return freeze({\n kind: 'JSONOperatorChainNode',\n operator,\n values: freeze([]),\n });\n },\n cloneWithValue(node, value) {\n return freeze({\n ...node,\n values: freeze([...node.values, value]),\n });\n },\n});\n","/// <reference types=\"./json-path-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONPathNode = freeze({\n is(node) {\n return node.kind === 'JSONPathNode';\n },\n create(inOperator) {\n return freeze({\n kind: 'JSONPathNode',\n inOperator,\n pathLegs: freeze([]),\n });\n },\n cloneWithLeg(jsonPathNode, pathLeg) {\n return freeze({\n ...jsonPathNode,\n pathLegs: freeze([...jsonPathNode.pathLegs, pathLeg]),\n });\n },\n});\n","/// <reference types=\"./reference-parser.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { ReferenceNode } from '../operation-node/reference-node.js';\nimport { TableNode } from '../operation-node/table-node.js';\nimport { isReadonlyArray, isString } from '../util/object-utils.js';\nimport { parseExpression, isExpressionOrFactory, } from './expression-parser.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOrderByDirection, parseOrderBy, } from './order-by-parser.js';\nimport { OperatorNode, isJSONOperator, } from '../operation-node/operator-node.js';\nimport { JSONReferenceNode } from '../operation-node/json-reference-node.js';\nimport { JSONOperatorChainNode } from '../operation-node/json-operator-chain-node.js';\nimport { JSONPathNode } from '../operation-node/json-path-node.js';\nexport function parseSimpleReferenceExpression(exp) {\n if (isString(exp)) {\n return parseStringReference(exp);\n }\n return exp.toOperationNode();\n}\nexport function parseReferenceExpressionOrList(arg) {\n if (isReadonlyArray(arg)) {\n return arg.map((it) => parseReferenceExpression(it));\n }\n else {\n return [parseReferenceExpression(arg)];\n }\n}\nexport function parseReferenceExpression(exp) {\n if (isExpressionOrFactory(exp)) {\n return parseExpression(exp);\n }\n return parseSimpleReferenceExpression(exp);\n}\nexport function parseJSONReference(ref, op) {\n const referenceNode = parseStringReference(ref);\n if (isJSONOperator(op)) {\n return JSONReferenceNode.create(referenceNode, JSONOperatorChainNode.create(OperatorNode.create(op)));\n }\n const opWithoutLastChar = op.slice(0, -1);\n if (isJSONOperator(opWithoutLastChar)) {\n return JSONReferenceNode.create(referenceNode, JSONPathNode.create(OperatorNode.create(opWithoutLastChar)));\n }\n throw new Error(`Invalid JSON operator: ${op}`);\n}\nexport function parseStringReference(ref) {\n const COLUMN_SEPARATOR = '.';\n if (!ref.includes(COLUMN_SEPARATOR)) {\n return ReferenceNode.create(ColumnNode.create(ref));\n }\n const parts = ref.split(COLUMN_SEPARATOR).map(trim);\n if (parts.length === 3) {\n return parseStringReferenceWithTableAndSchema(parts);\n }\n if (parts.length === 2) {\n return parseStringReferenceWithTable(parts);\n }\n throw new Error(`invalid column reference ${ref}`);\n}\nexport function parseAliasedStringReference(ref) {\n const ALIAS_SEPARATOR = ' as ';\n if (ref.includes(ALIAS_SEPARATOR)) {\n const [columnRef, alias] = ref.split(ALIAS_SEPARATOR).map(trim);\n return AliasNode.create(parseStringReference(columnRef), IdentifierNode.create(alias));\n }\n else {\n return parseStringReference(ref);\n }\n}\nexport function parseColumnName(column) {\n return ColumnNode.create(column);\n}\nexport function parseOrderedColumnName(column) {\n const ORDER_SEPARATOR = ' ';\n if (column.includes(ORDER_SEPARATOR)) {\n const [columnName, order] = column.split(ORDER_SEPARATOR).map(trim);\n if (!isOrderByDirection(order)) {\n throw new Error(`invalid order direction \"${order}\" next to \"${columnName}\"`);\n }\n return parseOrderBy([columnName, order])[0];\n }\n else {\n return parseColumnName(column);\n }\n}\nfunction parseStringReferenceWithTableAndSchema(parts) {\n const [schema, table, column] = parts;\n return ReferenceNode.create(ColumnNode.create(column), TableNode.createWithSchema(schema, table));\n}\nfunction parseStringReferenceWithTable(parts) {\n const [table, column] = parts;\n return ReferenceNode.create(ColumnNode.create(column), TableNode.create(table));\n}\nfunction trim(str) {\n return str.trim();\n}\n","/// <reference types=\"./primitive-value-list-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const PrimitiveValueListNode = freeze({\n is(node) {\n return node.kind === 'PrimitiveValueListNode';\n },\n create(values) {\n return freeze({\n kind: 'PrimitiveValueListNode',\n values: freeze([...values]),\n });\n },\n});\n","/// <reference types=\"./value-list-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ValueListNode = freeze({\n is(node) {\n return node.kind === 'ValueListNode';\n },\n create(values) {\n return freeze({\n kind: 'ValueListNode',\n values: freeze(values),\n });\n },\n});\n","/// <reference types=\"./value-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ValueNode = freeze({\n is(node) {\n return node.kind === 'ValueNode';\n },\n create(value) {\n return freeze({\n kind: 'ValueNode',\n value,\n });\n },\n createImmediate(value) {\n return freeze({\n kind: 'ValueNode',\n value,\n immediate: true,\n });\n },\n});\n","/// <reference types=\"./value-parser.d.ts\" />\nimport { PrimitiveValueListNode } from '../operation-node/primitive-value-list-node.js';\nimport { ValueListNode } from '../operation-node/value-list-node.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nimport { isBoolean, isNull, isNumber, isReadonlyArray, } from '../util/object-utils.js';\nimport { parseExpression, isExpressionOrFactory, } from './expression-parser.js';\nexport function parseValueExpressionOrList(arg) {\n if (isReadonlyArray(arg)) {\n return parseValueExpressionList(arg);\n }\n return parseValueExpression(arg);\n}\nexport function parseValueExpression(exp) {\n if (isExpressionOrFactory(exp)) {\n return parseExpression(exp);\n }\n return ValueNode.create(exp);\n}\nexport function isSafeImmediateValue(value) {\n return isNumber(value) || isBoolean(value) || isNull(value);\n}\nexport function parseSafeImmediateValue(value) {\n if (!isSafeImmediateValue(value)) {\n throw new Error(`unsafe immediate value ${JSON.stringify(value)}`);\n }\n return ValueNode.createImmediate(value);\n}\nfunction parseValueExpressionList(arg) {\n if (arg.some(isExpressionOrFactory)) {\n return ValueListNode.create(arg.map((it) => parseValueExpression(it)));\n }\n return PrimitiveValueListNode.create(arg);\n}\n","/// <reference types=\"./parens-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ParensNode = freeze({\n is(node) {\n return node.kind === 'ParensNode';\n },\n create(node) {\n return freeze({\n kind: 'ParensNode',\n node,\n });\n },\n});\n","/// <reference types=\"./binary-operation-parser.d.ts\" />\nimport { BinaryOperationNode } from '../operation-node/binary-operation-node.js';\nimport { isBoolean, isNull, isString, isUndefined, } from '../util/object-utils.js';\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { OperatorNode, OPERATORS, } from '../operation-node/operator-node.js';\nimport { parseReferenceExpression, } from './reference-parser.js';\nimport { parseValueExpression, parseValueExpressionOrList, } from './value-parser.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nimport { AndNode } from '../operation-node/and-node.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { OrNode } from '../operation-node/or-node.js';\nexport function parseValueBinaryOperationOrExpression(args) {\n if (args.length === 3) {\n return parseValueBinaryOperation(args[0], args[1], args[2]);\n }\n else if (args.length === 1) {\n return parseValueExpression(args[0]);\n }\n throw new Error(`invalid arguments: ${JSON.stringify(args)}`);\n}\nexport function parseValueBinaryOperation(left, operator, right) {\n if (isIsOperator(operator) && needsIsOperator(right)) {\n return BinaryOperationNode.create(parseReferenceExpression(left), parseOperator(operator), ValueNode.createImmediate(right));\n }\n return BinaryOperationNode.create(parseReferenceExpression(left), parseOperator(operator), parseValueExpressionOrList(right));\n}\nexport function parseReferentialBinaryOperation(left, operator, right) {\n return BinaryOperationNode.create(parseReferenceExpression(left), parseOperator(operator), parseReferenceExpression(right));\n}\nexport function parseFilterObject(obj, combinator) {\n return parseFilterList(Object.entries(obj)\n .filter(([, v]) => !isUndefined(v))\n .map(([k, v]) => parseValueBinaryOperation(k, needsIsOperator(v) ? 'is' : '=', v)), combinator);\n}\nexport function parseFilterList(list, combinator, withParens = true) {\n const combine = combinator === 'and' ? AndNode.create : OrNode.create;\n if (list.length === 0) {\n return BinaryOperationNode.create(ValueNode.createImmediate(1), OperatorNode.create('='), ValueNode.createImmediate(combinator === 'and' ? 1 : 0));\n }\n let node = toOperationNode(list[0]);\n for (let i = 1; i < list.length; ++i) {\n node = combine(node, toOperationNode(list[i]));\n }\n if (list.length > 1 && withParens) {\n return ParensNode.create(node);\n }\n return node;\n}\nfunction isIsOperator(operator) {\n return operator === 'is' || operator === 'is not';\n}\nfunction needsIsOperator(value) {\n return isNull(value) || isBoolean(value);\n}\nfunction parseOperator(operator) {\n if (isString(operator) && OPERATORS.includes(operator)) {\n return OperatorNode.create(operator);\n }\n if (isOperationNodeSource(operator)) {\n return operator.toOperationNode();\n }\n throw new Error(`invalid operator ${JSON.stringify(operator)}`);\n}\nfunction toOperationNode(nodeOrSource) {\n return isOperationNodeSource(nodeOrSource)\n ? nodeOrSource.toOperationNode()\n : nodeOrSource;\n}\n","/// <reference types=\"./order-by-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrderByNode = freeze({\n is(node) {\n return node.kind === 'OrderByNode';\n },\n create(items) {\n return freeze({\n kind: 'OrderByNode',\n items: freeze([...items]),\n });\n },\n cloneWithItems(orderBy, items) {\n return freeze({\n ...orderBy,\n items: freeze([...orderBy.items, ...items]),\n });\n },\n});\n","/// <reference types=\"./partition-by-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const PartitionByNode = freeze({\n is(node) {\n return node.kind === 'PartitionByNode';\n },\n create(items) {\n return freeze({\n kind: 'PartitionByNode',\n items: freeze(items),\n });\n },\n cloneWithItems(partitionBy, items) {\n return freeze({\n ...partitionBy,\n items: freeze([...partitionBy.items, ...items]),\n });\n },\n});\n","/// <reference types=\"./over-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { OrderByNode } from './order-by-node.js';\nimport { PartitionByNode } from './partition-by-node.js';\n/**\n * @internal\n */\nexport const OverNode = freeze({\n is(node) {\n return node.kind === 'OverNode';\n },\n create() {\n return freeze({\n kind: 'OverNode',\n });\n },\n cloneWithOrderByItems(overNode, items) {\n return freeze({\n ...overNode,\n orderBy: overNode.orderBy\n ? OrderByNode.cloneWithItems(overNode.orderBy, items)\n : OrderByNode.create(items),\n });\n },\n cloneWithPartitionByItems(overNode, items) {\n return freeze({\n ...overNode,\n partitionBy: overNode.partitionBy\n ? PartitionByNode.cloneWithItems(overNode.partitionBy, items)\n : PartitionByNode.create(items),\n });\n },\n});\n","/// <reference types=\"./from-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const FromNode = freeze({\n is(node) {\n return node.kind === 'FromNode';\n },\n create(froms) {\n return freeze({\n kind: 'FromNode',\n froms: freeze(froms),\n });\n },\n cloneWithFroms(from, froms) {\n return freeze({\n ...from,\n froms: freeze([...from.froms, ...froms]),\n });\n },\n});\n","/// <reference types=\"./group-by-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const GroupByNode = freeze({\n is(node) {\n return node.kind === 'GroupByNode';\n },\n create(items) {\n return freeze({\n kind: 'GroupByNode',\n items: freeze(items),\n });\n },\n cloneWithItems(groupBy, items) {\n return freeze({\n ...groupBy,\n items: freeze([...groupBy.items, ...items]),\n });\n },\n});\n","/// <reference types=\"./having-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AndNode } from './and-node.js';\nimport { OrNode } from './or-node.js';\n/**\n * @internal\n */\nexport const HavingNode = freeze({\n is(node) {\n return node.kind === 'HavingNode';\n },\n create(filter) {\n return freeze({\n kind: 'HavingNode',\n having: filter,\n });\n },\n cloneWithOperation(havingNode, operator, operation) {\n return freeze({\n ...havingNode,\n having: operator === 'And'\n ? AndNode.create(havingNode.having, operation)\n : OrNode.create(havingNode.having, operation),\n });\n },\n});\n","/// <reference types=\"./insert-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const InsertQueryNode = freeze({\n is(node) {\n return node.kind === 'InsertQueryNode';\n },\n create(into, withNode, replace) {\n return freeze({\n kind: 'InsertQueryNode',\n into,\n ...(withNode && { with: withNode }),\n replace,\n });\n },\n createWithoutInto() {\n return freeze({\n kind: 'InsertQueryNode',\n });\n },\n cloneWith(insertQuery, props) {\n return freeze({\n ...insertQuery,\n ...props,\n });\n },\n});\n","/// <reference types=\"./list-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ListNode = freeze({\n is(node) {\n return node.kind === 'ListNode';\n },\n create(items) {\n return freeze({\n kind: 'ListNode',\n items: freeze(items),\n });\n },\n});\n","/// <reference types=\"./update-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { FromNode } from './from-node.js';\nimport { ListNode } from './list-node.js';\n/**\n * @internal\n */\nexport const UpdateQueryNode = freeze({\n is(node) {\n return node.kind === 'UpdateQueryNode';\n },\n create(tables, withNode) {\n return freeze({\n kind: 'UpdateQueryNode',\n // For backwards compatibility, use the raw table node when there's only one table\n // and don't rename the property to something like `tables`.\n table: tables.length === 1 ? tables[0] : ListNode.create(tables),\n ...(withNode && { with: withNode }),\n });\n },\n createWithoutTable() {\n return freeze({\n kind: 'UpdateQueryNode',\n });\n },\n cloneWithFromItems(updateQuery, fromItems) {\n return freeze({\n ...updateQuery,\n from: updateQuery.from\n ? FromNode.cloneWithFroms(updateQuery.from, fromItems)\n : FromNode.create(fromItems),\n });\n },\n cloneWithUpdates(updateQuery, updates) {\n return freeze({\n ...updateQuery,\n updates: updateQuery.updates\n ? freeze([...updateQuery.updates, ...updates])\n : updates,\n });\n },\n cloneWithLimit(updateQuery, limit) {\n return freeze({\n ...updateQuery,\n limit,\n });\n },\n});\n","/// <reference types=\"./using-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const UsingNode = freeze({\n is(node) {\n return node.kind === 'UsingNode';\n },\n create(tables) {\n return freeze({\n kind: 'UsingNode',\n tables: freeze(tables),\n });\n },\n cloneWithTables(using, tables) {\n return freeze({\n ...using,\n tables: freeze([...using.tables, ...tables]),\n });\n },\n});\n","/// <reference types=\"./delete-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { FromNode } from './from-node.js';\nimport { UsingNode } from './using-node.js';\nimport { QueryNode } from './query-node.js';\n/**\n * @internal\n */\nexport const DeleteQueryNode = freeze({\n is(node) {\n return node.kind === 'DeleteQueryNode';\n },\n create(fromItems, withNode) {\n return freeze({\n kind: 'DeleteQueryNode',\n from: FromNode.create(fromItems),\n ...(withNode && { with: withNode }),\n });\n },\n // TODO: remove in v0.29\n /**\n * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n */\n cloneWithOrderByItems: (node, items) => QueryNode.cloneWithOrderByItems(node, items),\n // TODO: remove in v0.29\n /**\n * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n */\n cloneWithoutOrderBy: (node) => QueryNode.cloneWithoutOrderBy(node),\n cloneWithLimit(deleteNode, limit) {\n return freeze({\n ...deleteNode,\n limit,\n });\n },\n cloneWithoutLimit(deleteNode) {\n return freeze({\n ...deleteNode,\n limit: undefined,\n });\n },\n cloneWithUsing(deleteNode, tables) {\n return freeze({\n ...deleteNode,\n using: deleteNode.using !== undefined\n ? UsingNode.cloneWithTables(deleteNode.using, tables)\n : UsingNode.create(tables),\n });\n },\n});\n","/// <reference types=\"./where-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AndNode } from './and-node.js';\nimport { OrNode } from './or-node.js';\n/**\n * @internal\n */\nexport const WhereNode = freeze({\n is(node) {\n return node.kind === 'WhereNode';\n },\n create(filter) {\n return freeze({\n kind: 'WhereNode',\n where: filter,\n });\n },\n cloneWithOperation(whereNode, operator, operation) {\n return freeze({\n ...whereNode,\n where: operator === 'And'\n ? AndNode.create(whereNode.where, operation)\n : OrNode.create(whereNode.where, operation),\n });\n },\n});\n","/// <reference types=\"./returning-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ReturningNode = freeze({\n is(node) {\n return node.kind === 'ReturningNode';\n },\n create(selections) {\n return freeze({\n kind: 'ReturningNode',\n selections: freeze(selections),\n });\n },\n cloneWithSelections(returning, selections) {\n return freeze({\n ...returning,\n selections: returning.selections\n ? freeze([...returning.selections, ...selections])\n : freeze(selections),\n });\n },\n});\n","/// <reference types=\"./explain-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ExplainNode = freeze({\n is(node) {\n return node.kind === 'ExplainNode';\n },\n create(format, options) {\n return freeze({\n kind: 'ExplainNode',\n format,\n options,\n });\n },\n});\n","/// <reference types=\"./when-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const WhenNode = freeze({\n is(node) {\n return node.kind === 'WhenNode';\n },\n create(condition) {\n return freeze({\n kind: 'WhenNode',\n condition,\n });\n },\n cloneWithResult(whenNode, result) {\n return freeze({\n ...whenNode,\n result,\n });\n },\n});\n","/// <reference types=\"./merge-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhenNode } from './when-node.js';\n/**\n * @internal\n */\nexport const MergeQueryNode = freeze({\n is(node) {\n return node.kind === 'MergeQueryNode';\n },\n create(into, withNode) {\n return freeze({\n kind: 'MergeQueryNode',\n into,\n ...(withNode && { with: withNode }),\n });\n },\n cloneWithUsing(mergeNode, using) {\n return freeze({\n ...mergeNode,\n using,\n });\n },\n cloneWithWhen(mergeNode, when) {\n return freeze({\n ...mergeNode,\n whens: mergeNode.whens\n ? freeze([...mergeNode.whens, when])\n : freeze([when]),\n });\n },\n cloneWithThen(mergeNode, then) {\n return freeze({\n ...mergeNode,\n whens: mergeNode.whens\n ? freeze([\n ...mergeNode.whens.slice(0, -1),\n WhenNode.cloneWithResult(mergeNode.whens[mergeNode.whens.length - 1], then),\n ])\n : undefined,\n });\n },\n});\n","/// <reference types=\"./output-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OutputNode = freeze({\n is(node) {\n return node.kind === 'OutputNode';\n },\n create(selections) {\n return freeze({\n kind: 'OutputNode',\n selections: freeze(selections),\n });\n },\n cloneWithSelections(output, selections) {\n return freeze({\n ...output,\n selections: output.selections\n ? freeze([...output.selections, ...selections])\n : freeze(selections),\n });\n },\n});\n","/// <reference types=\"./query-node.d.ts\" />\nimport { InsertQueryNode } from './insert-query-node.js';\nimport { SelectQueryNode } from './select-query-node.js';\nimport { UpdateQueryNode } from './update-query-node.js';\nimport { DeleteQueryNode } from './delete-query-node.js';\nimport { WhereNode } from './where-node.js';\nimport { freeze } from '../util/object-utils.js';\nimport { ReturningNode } from './returning-node.js';\nimport { ExplainNode } from './explain-node.js';\nimport { MergeQueryNode } from './merge-query-node.js';\nimport { OutputNode } from './output-node.js';\nimport { OrderByNode } from './order-by-node.js';\n/**\n * @internal\n */\nexport const QueryNode = freeze({\n is(node) {\n return (SelectQueryNode.is(node) ||\n InsertQueryNode.is(node) ||\n UpdateQueryNode.is(node) ||\n DeleteQueryNode.is(node) ||\n MergeQueryNode.is(node));\n },\n cloneWithEndModifier(node, modifier) {\n return freeze({\n ...node,\n endModifiers: node.endModifiers\n ? freeze([...node.endModifiers, modifier])\n : freeze([modifier]),\n });\n },\n cloneWithWhere(node, operation) {\n return freeze({\n ...node,\n where: node.where\n ? WhereNode.cloneWithOperation(node.where, 'And', operation)\n : WhereNode.create(operation),\n });\n },\n cloneWithJoin(node, join) {\n return freeze({\n ...node,\n joins: node.joins ? freeze([...node.joins, join]) : freeze([join]),\n });\n },\n cloneWithReturning(node, selections) {\n return freeze({\n ...node,\n returning: node.returning\n ? ReturningNode.cloneWithSelections(node.returning, selections)\n : ReturningNode.create(selections),\n });\n },\n cloneWithoutReturning(node) {\n return freeze({\n ...node,\n returning: undefined,\n });\n },\n cloneWithoutWhere(node) {\n return freeze({\n ...node,\n where: undefined,\n });\n },\n cloneWithExplain(node, format, options) {\n return freeze({\n ...node,\n explain: ExplainNode.create(format, options?.toOperationNode()),\n });\n },\n cloneWithTop(node, top) {\n return freeze({\n ...node,\n top,\n });\n },\n cloneWithOutput(node, selections) {\n return freeze({\n ...node,\n output: node.output\n ? OutputNode.cloneWithSelections(node.output, selections)\n : OutputNode.create(selections),\n });\n },\n cloneWithOrderByItems(node, items) {\n return freeze({\n ...node,\n orderBy: node.orderBy\n ? OrderByNode.cloneWithItems(node.orderBy, items)\n : OrderByNode.create(items),\n });\n },\n cloneWithoutOrderBy(node) {\n return freeze({\n ...node,\n orderBy: undefined,\n });\n },\n});\n","/// <reference types=\"./select-query-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { FromNode } from './from-node.js';\nimport { GroupByNode } from './group-by-node.js';\nimport { HavingNode } from './having-node.js';\nimport { QueryNode } from './query-node.js';\n/**\n * @internal\n */\nexport const SelectQueryNode = freeze({\n is(node) {\n return node.kind === 'SelectQueryNode';\n },\n create(withNode) {\n return freeze({\n kind: 'SelectQueryNode',\n ...(withNode && { with: withNode }),\n });\n },\n createFrom(fromItems, withNode) {\n return freeze({\n kind: 'SelectQueryNode',\n from: FromNode.create(fromItems),\n ...(withNode && { with: withNode }),\n });\n },\n cloneWithSelections(select, selections) {\n return freeze({\n ...select,\n selections: select.selections\n ? freeze([...select.selections, ...selections])\n : freeze(selections),\n });\n },\n cloneWithDistinctOn(select, expressions) {\n return freeze({\n ...select,\n distinctOn: select.distinctOn\n ? freeze([...select.distinctOn, ...expressions])\n : freeze(expressions),\n });\n },\n cloneWithFrontModifier(select, modifier) {\n return freeze({\n ...select,\n frontModifiers: select.frontModifiers\n ? freeze([...select.frontModifiers, modifier])\n : freeze([modifier]),\n });\n },\n // TODO: remove in v0.29\n /**\n * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n */\n cloneWithOrderByItems: (node, items) => QueryNode.cloneWithOrderByItems(node, items),\n cloneWithGroupByItems(selectNode, items) {\n return freeze({\n ...selectNode,\n groupBy: selectNode.groupBy\n ? GroupByNode.cloneWithItems(selectNode.groupBy, items)\n : GroupByNode.create(items),\n });\n },\n cloneWithLimit(selectNode, limit) {\n return freeze({\n ...selectNode,\n limit,\n });\n },\n cloneWithOffset(selectNode, offset) {\n return freeze({\n ...selectNode,\n offset,\n });\n },\n cloneWithFetch(selectNode, fetch) {\n return freeze({\n ...selectNode,\n fetch,\n });\n },\n cloneWithHaving(selectNode, operation) {\n return freeze({\n ...selectNode,\n having: selectNode.having\n ? HavingNode.cloneWithOperation(selectNode.having, 'And', operation)\n : HavingNode.create(operation),\n });\n },\n cloneWithSetOperations(selectNode, setOperations) {\n return freeze({\n ...selectNode,\n setOperations: selectNode.setOperations\n ? freeze([...selectNode.setOperations, ...setOperations])\n : freeze([...setOperations]),\n });\n },\n cloneWithoutSelections(select) {\n return freeze({\n ...select,\n selections: [],\n });\n },\n cloneWithoutLimit(select) {\n return freeze({\n ...select,\n limit: undefined,\n });\n },\n cloneWithoutOffset(select) {\n return freeze({\n ...select,\n offset: undefined,\n });\n },\n // TODO: remove in v0.29\n /**\n * @deprecated Use `QueryNode.cloneWithoutOrderBy` instead.\n */\n cloneWithoutOrderBy: (node) => QueryNode.cloneWithoutOrderBy(node),\n cloneWithoutGroupBy(select) {\n return freeze({\n ...select,\n groupBy: undefined,\n });\n },\n});\n","/// <reference types=\"./join-builder.d.ts\" />\nimport { JoinNode } from '../operation-node/join-node.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class JoinBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n on(...args) {\n return new JoinBuilder({\n ...this.#props,\n joinNode: JoinNode.cloneWithOn(this.#props.joinNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n /**\n * Just like {@link WhereInterface.whereRef} but adds an item to the join's\n * `on` clause instead.\n *\n * See {@link WhereInterface.whereRef} for documentation and examples.\n */\n onRef(lhs, op, rhs) {\n return new JoinBuilder({\n ...this.#props,\n joinNode: JoinNode.cloneWithOn(this.#props.joinNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n /**\n * Adds `on true`.\n */\n onTrue() {\n return new JoinBuilder({\n ...this.#props,\n joinNode: JoinNode.cloneWithOn(this.#props.joinNode, RawNode.createWithSql('true')),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n */\n $call(func) {\n return func(this);\n }\n toOperationNode() {\n return this.#props.joinNode;\n }\n}\n","/// <reference types=\"./partition-by-item-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const PartitionByItemNode = freeze({\n is(node) {\n return node.kind === 'PartitionByItemNode';\n },\n create(partitionBy) {\n return freeze({\n kind: 'PartitionByItemNode',\n partitionBy,\n });\n },\n});\n","/// <reference types=\"./partition-by-parser.d.ts\" />\nimport { PartitionByItemNode } from '../operation-node/partition-by-item-node.js';\nimport { parseReferenceExpressionOrList, } from './reference-parser.js';\nexport function parsePartitionBy(partitionBy) {\n return parseReferenceExpressionOrList(partitionBy).map(PartitionByItemNode.create);\n}\n","/// <reference types=\"./over-builder.d.ts\" />\nimport { OverNode } from '../operation-node/over-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { parsePartitionBy, } from '../parser/partition-by-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class OverBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n orderBy(...args) {\n return new OverBuilder({\n overNode: OverNode.cloneWithOrderByItems(this.#props.overNode, parseOrderBy(args)),\n });\n }\n clearOrderBy() {\n return new OverBuilder({\n overNode: QueryNode.cloneWithoutOrderBy(this.#props.overNode),\n });\n }\n partitionBy(partitionBy) {\n return new OverBuilder({\n overNode: OverNode.cloneWithPartitionByItems(this.#props.overNode, parsePartitionBy(partitionBy)),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n */\n $call(func) {\n return func(this);\n }\n toOperationNode() {\n return this.#props.overNode;\n }\n}\n","/// <reference types=\"./selection-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ReferenceNode } from './reference-node.js';\nimport { SelectAllNode } from './select-all-node.js';\n/**\n * @internal\n */\nexport const SelectionNode = freeze({\n is(node) {\n return node.kind === 'SelectionNode';\n },\n create(selection) {\n return freeze({\n kind: 'SelectionNode',\n selection: selection,\n });\n },\n createSelectAll() {\n return freeze({\n kind: 'SelectionNode',\n selection: SelectAllNode.create(),\n });\n },\n createSelectAllFromTable(table) {\n return freeze({\n kind: 'SelectionNode',\n selection: ReferenceNode.createSelectAll(table),\n });\n },\n});\n","/// <reference types=\"./select-parser.d.ts\" />\nimport { isFunction, isReadonlyArray, isString } from '../util/object-utils.js';\nimport { SelectionNode } from '../operation-node/selection-node.js';\nimport { parseAliasedStringReference } from './reference-parser.js';\nimport { isDynamicReferenceBuilder, } from '../dynamic/dynamic-reference-builder.js';\nimport { parseAliasedExpression, } from './expression-parser.js';\nimport { parseTable } from './table-parser.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nexport function parseSelectArg(selection) {\n if (isFunction(selection)) {\n return parseSelectArg(selection(expressionBuilder()));\n }\n else if (isReadonlyArray(selection)) {\n return selection.map((it) => parseSelectExpression(it));\n }\n else {\n return [parseSelectExpression(selection)];\n }\n}\nfunction parseSelectExpression(selection) {\n if (isString(selection)) {\n return SelectionNode.create(parseAliasedStringReference(selection));\n }\n else if (isDynamicReferenceBuilder(selection)) {\n return SelectionNode.create(selection.toOperationNode());\n }\n else {\n return SelectionNode.create(parseAliasedExpression(selection));\n }\n}\nexport function parseSelectAll(table) {\n if (!table) {\n return [SelectionNode.createSelectAll()];\n }\n else if (Array.isArray(table)) {\n return table.map(parseSelectAllArg);\n }\n else {\n return [parseSelectAllArg(table)];\n }\n}\nfunction parseSelectAllArg(table) {\n if (isString(table)) {\n return SelectionNode.createSelectAllFromTable(parseTable(table));\n }\n throw new Error(`invalid value selectAll expression: ${JSON.stringify(table)}`);\n}\n","/// <reference types=\"./values-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ValuesNode = freeze({\n is(node) {\n return node.kind === 'ValuesNode';\n },\n create(values) {\n return freeze({\n kind: 'ValuesNode',\n values: freeze(values),\n });\n },\n});\n","/// <reference types=\"./default-insert-value-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const DefaultInsertValueNode = freeze({\n is(node) {\n return node.kind === 'DefaultInsertValueNode';\n },\n create() {\n return freeze({\n kind: 'DefaultInsertValueNode',\n });\n },\n});\n","/// <reference types=\"./insert-values-parser.d.ts\" />\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { PrimitiveValueListNode } from '../operation-node/primitive-value-list-node.js';\nimport { ValueListNode } from '../operation-node/value-list-node.js';\nimport { freeze, isFunction, isReadonlyArray, isUndefined, } from '../util/object-utils.js';\nimport { parseValueExpression } from './value-parser.js';\nimport { ValuesNode } from '../operation-node/values-node.js';\nimport { isExpressionOrFactory } from './expression-parser.js';\nimport { DefaultInsertValueNode } from '../operation-node/default-insert-value-node.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nexport function parseInsertExpression(arg) {\n const objectOrList = isFunction(arg) ? arg(expressionBuilder()) : arg;\n const list = isReadonlyArray(objectOrList)\n ? objectOrList\n : freeze([objectOrList]);\n return parseInsertColumnsAndValues(list);\n}\nfunction parseInsertColumnsAndValues(rows) {\n const columns = parseColumnNamesAndIndexes(rows);\n return [\n freeze([...columns.keys()].map(ColumnNode.create)),\n ValuesNode.create(rows.map((row) => parseRowValues(row, columns))),\n ];\n}\nfunction parseColumnNamesAndIndexes(rows) {\n const columns = new Map();\n for (const row of rows) {\n const cols = Object.keys(row);\n for (const col of cols) {\n if (!columns.has(col) && row[col] !== undefined) {\n columns.set(col, columns.size);\n }\n }\n }\n return columns;\n}\nfunction parseRowValues(row, columns) {\n const rowColumns = Object.keys(row);\n const rowValues = Array.from({\n length: columns.size,\n });\n let hasUndefinedOrComplexColumns = false;\n let indexedRowColumns = rowColumns.length;\n for (const col of rowColumns) {\n const columnIdx = columns.get(col);\n if (isUndefined(columnIdx)) {\n indexedRowColumns--;\n continue;\n }\n const value = row[col];\n if (isUndefined(value) || isExpressionOrFactory(value)) {\n hasUndefinedOrComplexColumns = true;\n }\n rowValues[columnIdx] = value;\n }\n const hasMissingColumns = indexedRowColumns < columns.size;\n if (hasMissingColumns || hasUndefinedOrComplexColumns) {\n const defaultValue = DefaultInsertValueNode.create();\n return ValueListNode.create(rowValues.map((it) => isUndefined(it) ? defaultValue : parseValueExpression(it)));\n }\n return PrimitiveValueListNode.create(rowValues);\n}\n","/// <reference types=\"./column-update-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const ColumnUpdateNode = freeze({\n is(node) {\n return node.kind === 'ColumnUpdateNode';\n },\n create(column, value) {\n return freeze({\n kind: 'ColumnUpdateNode',\n column,\n value,\n });\n },\n});\n","/// <reference types=\"./update-set-parser.d.ts\" />\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { ColumnUpdateNode } from '../operation-node/column-update-node.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nimport { isFunction } from '../util/object-utils.js';\nimport { parseValueExpression } from './value-parser.js';\nimport { parseReferenceExpression, } from './reference-parser.js';\nexport function parseUpdate(...args) {\n if (args.length === 2) {\n return [\n ColumnUpdateNode.create(parseReferenceExpression(args[0]), parseValueExpression(args[1])),\n ];\n }\n return parseUpdateObjectExpression(args[0]);\n}\nexport function parseUpdateObjectExpression(update) {\n const updateObj = isFunction(update) ? update(expressionBuilder()) : update;\n return Object.entries(updateObj)\n .filter(([_, value]) => value !== undefined)\n .map(([key, value]) => {\n return ColumnUpdateNode.create(ColumnNode.create(key), parseValueExpression(value));\n });\n}\n","/// <reference types=\"./on-duplicate-key-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OnDuplicateKeyNode = freeze({\n is(node) {\n return node.kind === 'OnDuplicateKeyNode';\n },\n create(updates) {\n return freeze({\n kind: 'OnDuplicateKeyNode',\n updates,\n });\n },\n});\n","/// <reference types=\"./insert-result.d.ts\" />\n/**\n * The result of an insert query.\n *\n * If the table has an auto incrementing primary key {@link insertId} will hold\n * the generated id on dialects that support it. For example PostgreSQL doesn't\n * return the id by default and {@link insertId} is undefined. On PostgreSQL you\n * need to use {@link ReturningInterface.returning} or {@link ReturningInterface.returningAll}\n * to get out the inserted id.\n *\n * {@link numInsertedOrUpdatedRows} holds the number of (actually) inserted rows.\n * On MySQL, updated rows are counted twice when using `on duplicate key update`.\n *\n * ### Examples\n *\n * ```ts\n * import type { NewPerson } from 'type-editor' // imaginary module\n *\n * async function insertPerson(person: NewPerson) {\n * const result = await db\n * .insertInto('person')\n * .values(person)\n * .executeTakeFirstOrThrow()\n *\n * console.log(result.insertId) // relevant on MySQL\n * console.log(result.numInsertedOrUpdatedRows) // always relevant\n * }\n * ```\n */\nexport class InsertResult {\n /**\n * The auto incrementing primary key of the inserted row.\n *\n * This property can be undefined when the query contains an `on conflict`\n * clause that makes the query succeed even when nothing gets inserted.\n *\n * This property is always undefined on dialects like PostgreSQL that\n * don't return the inserted id by default. On those dialects you need\n * to use the {@link ReturningInterface.returning | returning} method.\n */\n insertId;\n /**\n * Affected rows count.\n */\n numInsertedOrUpdatedRows;\n constructor(insertId, numInsertedOrUpdatedRows) {\n this.insertId = insertId;\n this.numInsertedOrUpdatedRows = numInsertedOrUpdatedRows;\n }\n}\n","/// <reference types=\"./no-result-error.d.ts\" />\nexport class NoResultError extends Error {\n /**\n * The operation node tree of the query that was executed.\n */\n node;\n constructor(node) {\n super('no result');\n this.node = node;\n }\n}\nexport function isNoResultErrorConstructor(fn) {\n return Object.prototype.hasOwnProperty.call(fn, 'prototype');\n}\n","/// <reference types=\"./on-conflict-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhereNode } from './where-node.js';\n/**\n * @internal\n */\nexport const OnConflictNode = freeze({\n is(node) {\n return node.kind === 'OnConflictNode';\n },\n create() {\n return freeze({\n kind: 'OnConflictNode',\n });\n },\n cloneWith(node, props) {\n return freeze({\n ...node,\n ...props,\n });\n },\n cloneWithIndexWhere(node, operation) {\n return freeze({\n ...node,\n indexWhere: node.indexWhere\n ? WhereNode.cloneWithOperation(node.indexWhere, 'And', operation)\n : WhereNode.create(operation),\n });\n },\n cloneWithIndexOrWhere(node, operation) {\n return freeze({\n ...node,\n indexWhere: node.indexWhere\n ? WhereNode.cloneWithOperation(node.indexWhere, 'Or', operation)\n : WhereNode.create(operation),\n });\n },\n cloneWithUpdateWhere(node, operation) {\n return freeze({\n ...node,\n updateWhere: node.updateWhere\n ? WhereNode.cloneWithOperation(node.updateWhere, 'And', operation)\n : WhereNode.create(operation),\n });\n },\n cloneWithUpdateOrWhere(node, operation) {\n return freeze({\n ...node,\n updateWhere: node.updateWhere\n ? WhereNode.cloneWithOperation(node.updateWhere, 'Or', operation)\n : WhereNode.create(operation),\n });\n },\n cloneWithoutIndexWhere(node) {\n return freeze({\n ...node,\n indexWhere: undefined,\n });\n },\n cloneWithoutUpdateWhere(node) {\n return freeze({\n ...node,\n updateWhere: undefined,\n });\n },\n});\n","/// <reference types=\"./on-conflict-builder.d.ts\" />\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { OnConflictNode } from '../operation-node/on-conflict-node.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { parseUpdateObjectExpression, } from '../parser/update-set-parser.js';\nimport { freeze } from '../util/object-utils.js';\nexport class OnConflictBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Specify a single column as the conflict target.\n *\n * Also see the {@link columns}, {@link constraint} and {@link expression}\n * methods for alternative ways to specify the conflict target.\n */\n column(column) {\n const columnNode = ColumnNode.create(column);\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n columns: this.#props.onConflictNode.columns\n ? freeze([...this.#props.onConflictNode.columns, columnNode])\n : freeze([columnNode]),\n }),\n });\n }\n /**\n * Specify a list of columns as the conflict target.\n *\n * Also see the {@link column}, {@link constraint} and {@link expression}\n * methods for alternative ways to specify the conflict target.\n */\n columns(columns) {\n const columnNodes = columns.map(ColumnNode.create);\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n columns: this.#props.onConflictNode.columns\n ? freeze([...this.#props.onConflictNode.columns, ...columnNodes])\n : freeze(columnNodes),\n }),\n });\n }\n /**\n * Specify a specific constraint by name as the conflict target.\n *\n * Also see the {@link column}, {@link columns} and {@link expression}\n * methods for alternative ways to specify the conflict target.\n */\n constraint(constraintName) {\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n constraint: IdentifierNode.create(constraintName),\n }),\n });\n }\n /**\n * Specify an expression as the conflict target.\n *\n * This can be used if the unique index is an expression index.\n *\n * Also see the {@link column}, {@link columns} and {@link constraint}\n * methods for alternative ways to specify the conflict target.\n */\n expression(expression) {\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n indexExpression: expression.toOperationNode(),\n }),\n });\n }\n where(...args) {\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWithIndexWhere(this.#props.onConflictNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n whereRef(lhs, op, rhs) {\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWithIndexWhere(this.#props.onConflictNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n clearWhere() {\n return new OnConflictBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWithoutIndexWhere(this.#props.onConflictNode),\n });\n }\n /**\n * Adds the \"do nothing\" conflict action.\n *\n * ### Examples\n *\n * ```ts\n * const id = 1\n * const first_name = 'John'\n *\n * await db\n * .insertInto('person')\n * .values({ first_name, id })\n * .onConflict((oc) => oc\n * .column('id')\n * .doNothing()\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"id\")\n * values ($1, $2)\n * on conflict (\"id\") do nothing\n * ```\n */\n doNothing() {\n return new OnConflictDoNothingBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n doNothing: true,\n }),\n });\n }\n /**\n * Adds the \"do update set\" conflict action.\n *\n * ### Examples\n *\n * ```ts\n * const id = 1\n * const first_name = 'John'\n *\n * await db\n * .insertInto('person')\n * .values({ first_name, id })\n * .onConflict((oc) => oc\n * .column('id')\n * .doUpdateSet({ first_name })\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"id\")\n * values ($1, $2)\n * on conflict (\"id\")\n * do update set \"first_name\" = $3\n * ```\n *\n * In the next example we use the `ref` method to reference\n * columns of the virtual table `excluded` in a type-safe way\n * to create an upsert operation:\n *\n * ```ts\n * import type { NewPerson } from 'type-editor' // imaginary module\n *\n * async function upsertPerson(person: NewPerson): Promise<void> {\n * await db.insertInto('person')\n * .values(person)\n * .onConflict((oc) => oc\n * .column('id')\n * .doUpdateSet((eb) => ({\n * first_name: eb.ref('excluded.first_name'),\n * last_name: eb.ref('excluded.last_name')\n * })\n * )\n * )\n * .execute()\n * }\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"last_name\")\n * values ($1, $2)\n * on conflict (\"id\")\n * do update set\n * \"first_name\" = excluded.\"first_name\",\n * \"last_name\" = excluded.\"last_name\"\n * ```\n */\n doUpdateSet(update) {\n return new OnConflictUpdateBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWith(this.#props.onConflictNode, {\n updates: parseUpdateObjectExpression(update),\n }),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n */\n $call(func) {\n return func(this);\n }\n}\nexport class OnConflictDoNothingBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n toOperationNode() {\n return this.#props.onConflictNode;\n }\n}\nexport class OnConflictUpdateBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n where(...args) {\n return new OnConflictUpdateBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWithUpdateWhere(this.#props.onConflictNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n /**\n * Specify a where condition for the update operation.\n *\n * See {@link WhereInterface.whereRef} for more info.\n */\n whereRef(lhs, op, rhs) {\n return new OnConflictUpdateBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWithUpdateWhere(this.#props.onConflictNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n clearWhere() {\n return new OnConflictUpdateBuilder({\n ...this.#props,\n onConflictNode: OnConflictNode.cloneWithoutUpdateWhere(this.#props.onConflictNode),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n */\n $call(func) {\n return func(this);\n }\n toOperationNode() {\n return this.#props.onConflictNode;\n }\n}\n","/// <reference types=\"./top-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const TopNode = freeze({\n is(node) {\n return node.kind === 'TopNode';\n },\n create(expression, modifiers) {\n return freeze({\n kind: 'TopNode',\n expression,\n modifiers,\n });\n },\n});\n","/// <reference types=\"./top-parser.d.ts\" />\nimport { TopNode } from '../operation-node/top-node.js';\nimport { isBigInt, isNumber, isUndefined } from '../util/object-utils.js';\nexport function parseTop(expression, modifiers) {\n if (!isNumber(expression) && !isBigInt(expression)) {\n throw new Error(`Invalid top expression: ${expression}`);\n }\n if (!isUndefined(modifiers) && !isTopModifiers(modifiers)) {\n throw new Error(`Invalid top modifiers: ${modifiers}`);\n }\n return TopNode.create(expression, modifiers);\n}\nfunction isTopModifiers(modifiers) {\n return (modifiers === 'percent' ||\n modifiers === 'with ties' ||\n modifiers === 'percent with ties');\n}\n","/// <reference types=\"./or-action-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OrActionNode = freeze({\n is(node) {\n return node.kind === 'OrActionNode';\n },\n create(action) {\n return freeze({\n kind: 'OrActionNode',\n action,\n });\n },\n});\n","/// <reference types=\"./insert-query-builder.d.ts\" />\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { parseInsertExpression, } from '../parser/insert-values-parser.js';\nimport { InsertQueryNode } from '../operation-node/insert-query-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { parseUpdateObjectExpression, } from '../parser/update-set-parser.js';\nimport { freeze } from '../util/object-utils.js';\nimport { OnDuplicateKeyNode } from '../operation-node/on-duplicate-key-node.js';\nimport { InsertResult } from './insert-result.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { parseExpression, } from '../parser/expression-parser.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { OnConflictBuilder, } from './on-conflict-builder.js';\nimport { OnConflictNode } from '../operation-node/on-conflict-node.js';\nimport { parseTop } from '../parser/top-parser.js';\nimport { OrActionNode } from '../operation-node/or-action-node.js';\nexport class InsertQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Sets the values to insert for an {@link Kysely.insertInto | insert} query.\n *\n * This method takes an object whose keys are column names and values are\n * values to insert. In addition to the column's type, the values can be\n * raw {@link sql} snippets or select queries.\n *\n * You must provide all fields you haven't explicitly marked as nullable\n * or optional using {@link Generated} or {@link ColumnType}.\n *\n * The return value of an `insert` query is an instance of {@link InsertResult}. The\n * {@link InsertResult.insertId | insertId} field holds the auto incremented primary\n * key if the database returned one.\n *\n * On PostgreSQL and some other dialects, you need to call `returning` to get\n * something out of the query.\n *\n * Also see the {@link expression} method for inserting the result of a select\n * query or any other expression.\n *\n * ### Examples\n *\n * <!-- siteExample(\"insert\", \"Single row\", 10) -->\n *\n * Insert a single row:\n *\n * ```ts\n * const result = await db\n * .insertInto('person')\n * .values({\n * first_name: 'Jennifer',\n * last_name: 'Aniston',\n * age: 40\n * })\n * .executeTakeFirst()\n *\n * // `insertId` is only available on dialects that\n * // automatically return the id of the inserted row\n * // such as MySQL and SQLite. On PostgreSQL, for example,\n * // you need to add a `returning` clause to the query to\n * // get anything out. See the \"returning data\" example.\n * console.log(result.insertId)\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * insert into `person` (`first_name`, `last_name`, `age`) values (?, ?, ?)\n * ```\n *\n * <!-- siteExample(\"insert\", \"Multiple rows\", 20) -->\n *\n * On dialects that support it (for example PostgreSQL) you can insert multiple\n * rows by providing an array. Note that the return value is once again very\n * dialect-specific. Some databases may only return the id of the *last* inserted\n * row and some return nothing at all unless you call `returning`.\n *\n * ```ts\n * await db\n * .insertInto('person')\n * .values([{\n * first_name: 'Jennifer',\n * last_name: 'Aniston',\n * age: 40,\n * }, {\n * first_name: 'Arnold',\n * last_name: 'Schwarzenegger',\n * age: 70,\n * }])\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"last_name\", \"age\") values (($1, $2, $3), ($4, $5, $6))\n * ```\n *\n * <!-- siteExample(\"insert\", \"Returning data\", 30) -->\n *\n * On supported dialects like PostgreSQL you need to chain `returning` to the query to get\n * the inserted row's columns (or any other expression) as the return value. `returning`\n * works just like `select`. Refer to `select` method's examples and documentation for\n * more info.\n *\n * ```ts\n * const result = await db\n * .insertInto('person')\n * .values({\n * first_name: 'Jennifer',\n * last_name: 'Aniston',\n * age: 40,\n * })\n * .returning(['id', 'first_name as name'])\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"last_name\", \"age\") values ($1, $2, $3) returning \"id\", \"first_name\" as \"name\"\n * ```\n *\n * <!-- siteExample(\"insert\", \"Complex values\", 40) -->\n *\n * In addition to primitives, the values can also be arbitrary expressions.\n * You can build the expressions by using a callback and calling the methods\n * on the expression builder passed to it:\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * const ani = \"Ani\"\n * const ston = \"ston\"\n *\n * const result = await db\n * .insertInto('person')\n * .values(({ ref, selectFrom, fn }) => ({\n * first_name: 'Jennifer',\n * last_name: sql<string>`concat(${ani}, ${ston})`,\n * middle_name: ref('first_name'),\n * age: selectFrom('person')\n * .select(fn.avg<number>('age').as('avg_age')),\n * }))\n * .executeTakeFirst()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\n * \"first_name\",\n * \"last_name\",\n * \"middle_name\",\n * \"age\"\n * )\n * values (\n * $1,\n * concat($2, $3),\n * \"first_name\",\n * (select avg(\"age\") as \"avg_age\" from \"person\")\n * )\n * ```\n *\n * You can also use the callback version of subqueries or raw expressions:\n *\n * ```ts\n * await db.with('jennifer', (db) => db\n * .selectFrom('person')\n * .where('first_name', '=', 'Jennifer')\n * .select(['id', 'first_name', 'gender'])\n * .limit(1)\n * ).insertInto('pet').values((eb) => ({\n * owner_id: eb.selectFrom('jennifer').select('id'),\n * name: eb.selectFrom('jennifer').select('first_name'),\n * species: 'cat',\n * }))\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * with \"jennifer\" as (\n * select \"id\", \"first_name\", \"gender\"\n * from \"person\"\n * where \"first_name\" = $1\n * limit $2\n * )\n * insert into \"pet\" (\"owner_id\", \"name\", \"species\")\n * values (\n * (select \"id\" from \"jennifer\"),\n * (select \"first_name\" from \"jennifer\"),\n * $3\n * )\n * ```\n */\n values(insert) {\n const [columns, values] = parseInsertExpression(insert);\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n columns,\n values,\n }),\n });\n }\n /**\n * Sets the columns to insert.\n *\n * The {@link values} method sets both the columns and the values and this method\n * is not needed. But if you are using the {@link expression} method, you can use\n * this method to set the columns to insert.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .columns(['first_name'])\n * .expression((eb) => eb.selectFrom('pet').select('pet.name'))\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\")\n * select \"pet\".\"name\" from \"pet\"\n * ```\n */\n columns(columns) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n columns: freeze(columns.map(ColumnNode.create)),\n }),\n });\n }\n /**\n * Insert an arbitrary expression. For example the result of a select query.\n *\n * ### Examples\n *\n * <!-- siteExample(\"insert\", \"Insert subquery\", 50) -->\n *\n * You can create an `INSERT INTO SELECT FROM` query using the `expression` method.\n * This API doesn't follow our WYSIWYG principles and might be a bit difficult to\n * remember. The reasons for this design stem from implementation difficulties.\n *\n * ```ts\n * const result = await db.insertInto('person')\n * .columns(['first_name', 'last_name', 'age'])\n * .expression((eb) => eb\n * .selectFrom('pet')\n * .select((eb) => [\n * 'pet.name',\n * eb.val('Petson').as('last_name'),\n * eb.lit(7).as('age'),\n * ])\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"last_name\", \"age\")\n * select \"pet\".\"name\", $1 as \"last_name\", 7 as \"age from \"pet\"\n * ```\n */\n expression(expression) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n values: parseExpression(expression),\n }),\n });\n }\n /**\n * Creates an `insert into \"person\" default values` query.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .defaultValues()\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" default values\n * ```\n */\n defaultValues() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n defaultValues: true,\n }),\n });\n }\n /**\n * This can be used to add any additional SQL to the end of the query.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db.insertInto('person')\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'male',\n * })\n * .modifyEnd(sql`-- This is a comment`)\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * insert into `person` (\"first_name\", \"last_name\", \"gender\")\n * values (?, ?, ?) -- This is a comment\n * ```\n */\n modifyEnd(modifier) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n });\n }\n /**\n * Changes an `insert into` query to an `insert ignore into` query.\n *\n * This is only supported by some dialects like MySQL.\n *\n * To avoid a footgun, when invoked with the SQLite dialect, this method will\n * be handled like {@link orIgnore}. See also, {@link orAbort}, {@link orFail},\n * {@link orReplace}, and {@link orRollback}.\n *\n * If you use the ignore modifier, ignorable errors that occur while executing the\n * insert statement are ignored. For example, without ignore, a row that duplicates\n * an existing unique index or primary key value in the table causes a duplicate-key\n * error and the statement is aborted. With ignore, the row is discarded and no error\n * occurs.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .ignore()\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'female',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * insert ignore into `person` (`first_name`, `last_name`, `gender`) values (?, ?, ?)\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * insert or ignore into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n * ```\n */\n ignore() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n orAction: OrActionNode.create('ignore'),\n }),\n });\n }\n /**\n * Changes an `insert into` query to an `insert or ignore into` query.\n *\n * This is only supported by some dialects like SQLite.\n *\n * To avoid a footgun, when invoked with the MySQL dialect, this method will\n * be handled like {@link ignore}.\n *\n * See also, {@link orAbort}, {@link orFail}, {@link orReplace}, and {@link orRollback}.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .orIgnore()\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'female',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * insert or ignore into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * insert ignore into `person` (`first_name`, `last_name`, `gender`) values (?, ?, ?)\n * ```\n */\n orIgnore() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n orAction: OrActionNode.create('ignore'),\n }),\n });\n }\n /**\n * Changes an `insert into` query to an `insert or abort into` query.\n *\n * This is only supported by some dialects like SQLite.\n *\n * See also, {@link orIgnore}, {@link orFail}, {@link orReplace}, and {@link orRollback}.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .orAbort()\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'female',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * insert or abort into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n * ```\n */\n orAbort() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n orAction: OrActionNode.create('abort'),\n }),\n });\n }\n /**\n * Changes an `insert into` query to an `insert or fail into` query.\n *\n * This is only supported by some dialects like SQLite.\n *\n * See also, {@link orIgnore}, {@link orAbort}, {@link orReplace}, and {@link orRollback}.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .orFail()\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'female',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * insert or fail into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n * ```\n */\n orFail() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n orAction: OrActionNode.create('fail'),\n }),\n });\n }\n /**\n * Changes an `insert into` query to an `insert or replace into` query.\n *\n * This is only supported by some dialects like SQLite.\n *\n * You can also use {@link Kysely.replaceInto} to achieve the same result.\n *\n * See also, {@link orIgnore}, {@link orAbort}, {@link orFail}, and {@link orRollback}.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .orReplace()\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'female',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * insert or replace into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n * ```\n */\n orReplace() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n orAction: OrActionNode.create('replace'),\n }),\n });\n }\n /**\n * Changes an `insert into` query to an `insert or rollback into` query.\n *\n * This is only supported by some dialects like SQLite.\n *\n * See also, {@link orIgnore}, {@link orAbort}, {@link orFail}, and {@link orReplace}.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .orRollback()\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'female',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * insert or rollback into \"person\" (\"first_name\", \"last_name\", \"gender\") values (?, ?, ?)\n * ```\n */\n orRollback() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n orAction: OrActionNode.create('rollback'),\n }),\n });\n }\n /**\n * Changes an `insert into` query to an `insert top into` query.\n *\n * `top` clause is only supported by some dialects like MS SQL Server.\n *\n * ### Examples\n *\n * Insert the first 5 rows:\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db.insertInto('person')\n * .top(5)\n * .columns(['first_name', 'gender'])\n * .expression(\n * (eb) => eb.selectFrom('pet').select(['name', sql.lit('other').as('gender')])\n * )\n * .execute()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * insert top(5) into \"person\" (\"first_name\", \"gender\") select \"name\", 'other' as \"gender\" from \"pet\"\n * ```\n *\n * Insert the first 50 percent of rows:\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db.insertInto('person')\n * .top(50, 'percent')\n * .columns(['first_name', 'gender'])\n * .expression(\n * (eb) => eb.selectFrom('pet').select(['name', sql.lit('other').as('gender')])\n * )\n * .execute()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * insert top(50) percent into \"person\" (\"first_name\", \"gender\") select \"name\", 'other' as \"gender\" from \"pet\"\n * ```\n */\n top(expression, modifiers) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n });\n }\n /**\n * Adds an `on conflict` clause to the query.\n *\n * `on conflict` is only supported by some dialects like PostgreSQL and SQLite. On MySQL\n * you can use {@link ignore} and {@link onDuplicateKeyUpdate} to achieve similar results.\n *\n * ### Examples\n *\n * ```ts\n * await db\n * .insertInto('pet')\n * .values({\n * name: 'Catto',\n * species: 'cat',\n * owner_id: 3,\n * })\n * .onConflict((oc) => oc\n * .column('name')\n * .doUpdateSet({ species: 'hamster' })\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n * values ($1, $2, $3)\n * on conflict (\"name\")\n * do update set \"species\" = $4\n * ```\n *\n * You can provide the name of the constraint instead of a column name:\n *\n * ```ts\n * await db\n * .insertInto('pet')\n * .values({\n * name: 'Catto',\n * species: 'cat',\n * owner_id: 3,\n * })\n * .onConflict((oc) => oc\n * .constraint('pet_name_key')\n * .doUpdateSet({ species: 'hamster' })\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n * values ($1, $2, $3)\n * on conflict on constraint \"pet_name_key\"\n * do update set \"species\" = $4\n * ```\n *\n * You can also specify an expression as the conflict target in case\n * the unique index is an expression index:\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db\n * .insertInto('pet')\n * .values({\n * name: 'Catto',\n * species: 'cat',\n * owner_id: 3,\n * })\n * .onConflict((oc) => oc\n * .expression(sql<string>`lower(name)`)\n * .doUpdateSet({ species: 'hamster' })\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n * values ($1, $2, $3)\n * on conflict (lower(name))\n * do update set \"species\" = $4\n * ```\n *\n * You can add a filter for the update statement like this:\n *\n * ```ts\n * await db\n * .insertInto('pet')\n * .values({\n * name: 'Catto',\n * species: 'cat',\n * owner_id: 3,\n * })\n * .onConflict((oc) => oc\n * .column('name')\n * .doUpdateSet({ species: 'hamster' })\n * .where('excluded.name', '!=', 'Catto')\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n * values ($1, $2, $3)\n * on conflict (\"name\")\n * do update set \"species\" = $4\n * where \"excluded\".\"name\" != $5\n * ```\n *\n * You can create an `on conflict do nothing` clauses like this:\n *\n * ```ts\n * await db\n * .insertInto('pet')\n * .values({\n * name: 'Catto',\n * species: 'cat',\n * owner_id: 3,\n * })\n * .onConflict((oc) => oc\n * .column('name')\n * .doNothing()\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"pet\" (\"name\", \"species\", \"owner_id\")\n * values ($1, $2, $3)\n * on conflict (\"name\") do nothing\n * ```\n *\n * You can refer to the columns of the virtual `excluded` table\n * in a type-safe way using a callback and the `ref` method of\n * `ExpressionBuilder`:\n *\n * ```ts\n * await db.insertInto('person')\n * .values({\n * id: 1,\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'male',\n * })\n * .onConflict(oc => oc\n * .column('id')\n * .doUpdateSet({\n * first_name: (eb) => eb.ref('excluded.first_name'),\n * last_name: (eb) => eb.ref('excluded.last_name')\n * })\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"id\", \"first_name\", \"last_name\", \"gender\")\n * values ($1, $2, $3, $4)\n * on conflict (\"id\")\n * do update set\n * \"first_name\" = \"excluded\".\"first_name\",\n * \"last_name\" = \"excluded\".\"last_name\"\n * ```\n */\n onConflict(callback) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n onConflict: callback(new OnConflictBuilder({\n onConflictNode: OnConflictNode.create(),\n })).toOperationNode(),\n }),\n });\n }\n /**\n * Adds `on duplicate key update` to the query.\n *\n * If you specify `on duplicate key update`, and a row is inserted that would cause\n * a duplicate value in a unique index or primary key, an update of the old row occurs.\n *\n * This is only implemented by some dialects like MySQL. On most dialects you should\n * use {@link onConflict} instead.\n *\n * ### Examples\n *\n * ```ts\n * await db\n * .insertInto('person')\n * .values({\n * id: 1,\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'male',\n * })\n * .onDuplicateKeyUpdate({ updated_at: new Date().toISOString() })\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * insert into `person` (`id`, `first_name`, `last_name`, `gender`)\n * values (?, ?, ?, ?)\n * on duplicate key update `updated_at` = ?\n * ```\n */\n onDuplicateKeyUpdate(update) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: InsertQueryNode.cloneWith(this.#props.queryNode, {\n onDuplicateKey: OnDuplicateKeyNode.create(parseUpdateObjectExpression(update)),\n }),\n });\n }\n returning(selection) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(selection)),\n });\n }\n returningAll() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll()),\n });\n }\n output(args) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n outputAll(table) {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n /**\n * Clears all `returning` clauses from the query.\n *\n * ### Examples\n *\n * ```ts\n * await db.insertInto('person')\n * .values({ first_name: 'James', last_name: 'Smith', gender: 'male' })\n * .returning(['first_name'])\n * .clearReturning()\n * .execute()\n * ```\n *\n * The generated SQL(PostgreSQL):\n *\n * ```sql\n * insert into \"person\" (\"first_name\", \"last_name\", \"gender\") values ($1, $2, $3)\n * ```\n */\n clearReturning() {\n return new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutReturning(this.#props.queryNode),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n *\n * If you want to conditionally call a method on `this`, see\n * the {@link $if} method.\n *\n * ### Examples\n *\n * The next example uses a helper function `log` to log a query:\n *\n * ```ts\n * import type { Compilable } from 'kysely'\n *\n * function log<T extends Compilable>(qb: T): T {\n * console.log(qb.compile())\n * return qb\n * }\n *\n * await db.insertInto('person')\n * .values({ first_name: 'John', last_name: 'Doe', gender: 'male' })\n * .$call(log)\n * .execute()\n * ```\n */\n $call(func) {\n return func(this);\n }\n /**\n * Call `func(this)` if `condition` is true.\n *\n * This method is especially handy with optional selects. Any `returning` or `returningAll`\n * method calls add columns as optional fields to the output type when called inside\n * the `func` callback. This is because we can't know if those selections were actually\n * made before running the code.\n *\n * You can also call any other methods inside the callback.\n *\n * ### Examples\n *\n * ```ts\n * import type { NewPerson } from 'type-editor' // imaginary module\n *\n * async function insertPerson(values: NewPerson, returnLastName: boolean) {\n * return await db\n * .insertInto('person')\n * .values(values)\n * .returning(['id', 'first_name'])\n * .$if(returnLastName, (qb) => qb.returning('last_name'))\n * .executeTakeFirstOrThrow()\n * }\n * ```\n *\n * Any selections added inside the `if` callback will be added as optional fields to the\n * output type since we can't know if the selections were actually made before running\n * the code. In the example above the return type of the `insertPerson` function is:\n *\n * ```ts\n * Promise<{\n * id: number\n * first_name: string\n * last_name?: string\n * }>\n * ```\n */\n $if(condition, func) {\n if (condition) {\n return func(this);\n }\n return new InsertQueryBuilder({\n ...this.#props,\n });\n }\n /**\n * Change the output type of the query.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `InsertQueryBuilder` with a new output type.\n */\n $castTo() {\n return new InsertQueryBuilder(this.#props);\n }\n /**\n * Narrows (parts of) the output type of the query.\n *\n * Kysely tries to be as type-safe as possible, but in some cases we have to make\n * compromises for better maintainability and compilation performance. At present,\n * Kysely doesn't narrow the output type of the query based on {@link values} input\n * when using {@link returning} or {@link returningAll}.\n *\n * This utility method is very useful for these situations, as it removes unncessary\n * runtime assertion/guard code. Its input type is limited to the output type\n * of the query, so you can't add a column that doesn't exist, or change a column's\n * type to something that doesn't exist in its union type.\n *\n * ### Examples\n *\n * Turn this code:\n *\n * ```ts\n * import type { Person } from 'type-editor' // imaginary module\n *\n * const person = await db.insertInto('person')\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'male',\n * nullable_column: 'hell yeah!'\n * })\n * .returningAll()\n * .executeTakeFirstOrThrow()\n *\n * if (isWithNoNullValue(person)) {\n * functionThatExpectsPersonWithNonNullValue(person)\n * }\n *\n * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {\n * return person.nullable_column != null\n * }\n * ```\n *\n * Into this:\n *\n * ```ts\n * import type { NotNull } from 'kysely'\n *\n * const person = await db.insertInto('person')\n * .values({\n * first_name: 'John',\n * last_name: 'Doe',\n * gender: 'male',\n * nullable_column: 'hell yeah!'\n * })\n * .returningAll()\n * .$narrowType<{ nullable_column: NotNull }>()\n * .executeTakeFirstOrThrow()\n *\n * functionThatExpectsPersonWithNonNullValue(person)\n * ```\n */\n $narrowType() {\n return new InsertQueryBuilder(this.#props);\n }\n /**\n * Asserts that query's output row type equals the given type `T`.\n *\n * This method can be used to simplify excessively complex types to make TypeScript happy\n * and much faster.\n *\n * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much\n * for TypeScript and you get errors like this:\n *\n * ```\n * error TS2589: Type instantiation is excessively deep and possibly infinite.\n * ```\n *\n * In these case you can often use this method to help TypeScript a little bit. When you use this\n * method to assert the output type of a query, Kysely can drop the complex output type that\n * consists of multiple nested helper types and replace it with the simple asserted type.\n *\n * Using this method doesn't reduce type safety at all. You have to pass in a type that is\n * structurally equal to the current type.\n *\n * ### Examples\n *\n * ```ts\n * import type { NewPerson, NewPet, Species } from 'type-editor' // imaginary module\n *\n * async function insertPersonAndPet(person: NewPerson, pet: Omit<NewPet, 'owner_id'>) {\n * return await db\n * .with('new_person', (qb) => qb\n * .insertInto('person')\n * .values(person)\n * .returning('id')\n * .$assertType<{ id: number }>()\n * )\n * .with('new_pet', (qb) => qb\n * .insertInto('pet')\n * .values((eb) => ({\n * owner_id: eb.selectFrom('new_person').select('id'),\n * ...pet\n * }))\n * .returning(['name as pet_name', 'species'])\n * .$assertType<{ pet_name: string, species: Species }>()\n * )\n * .selectFrom(['new_person', 'new_pet'])\n * .selectAll()\n * .executeTakeFirstOrThrow()\n * }\n * ```\n */\n $assertType() {\n return new InsertQueryBuilder(this.#props);\n }\n /**\n * Returns a copy of this InsertQueryBuilder instance with the given plugin installed.\n */\n withPlugin(plugin) {\n return new InsertQueryBuilder({\n ...this.#props,\n executor: this.#props.executor.withPlugin(plugin),\n });\n }\n toOperationNode() {\n return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n }\n compile() {\n return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n }\n /**\n * Executes the query and returns an array of rows.\n *\n * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n */\n async execute() {\n const compiledQuery = this.compile();\n const result = await this.#props.executor.executeQuery(compiledQuery);\n const { adapter } = this.#props.executor;\n const query = compiledQuery.query;\n if ((query.returning && adapter.supportsReturning) ||\n (query.output && adapter.supportsOutput)) {\n return result.rows;\n }\n return [\n new InsertResult(result.insertId, result.numAffectedRows ?? BigInt(0)),\n ];\n }\n /**\n * Executes the query and returns the first result or undefined if\n * the query returned no result.\n */\n async executeTakeFirst() {\n const [result] = await this.execute();\n return result;\n }\n /**\n * Executes the query and returns the first result or throws if\n * the query returned no result.\n *\n * By default an instance of {@link NoResultError} is thrown, but you can\n * provide a custom error class, or callback as the only argument to throw a different\n * error.\n */\n async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n const result = await this.executeTakeFirst();\n if (result === undefined) {\n const error = isNoResultErrorConstructor(errorConstructor)\n ? new errorConstructor(this.toOperationNode())\n : errorConstructor(this.toOperationNode());\n throw error;\n }\n return result;\n }\n async *stream(chunkSize = 100) {\n const compiledQuery = this.compile();\n const stream = this.#props.executor.stream(compiledQuery, chunkSize);\n for await (const item of stream) {\n yield* item.rows;\n }\n }\n async explain(format, options) {\n const builder = new InsertQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n });\n return await builder.execute();\n }\n}\n","/// <reference types=\"./delete-result.d.ts\" />\nexport class DeleteResult {\n numDeletedRows;\n constructor(numDeletedRows) {\n this.numDeletedRows = numDeletedRows;\n }\n}\n","/// <reference types=\"./limit-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const LimitNode = freeze({\n is(node) {\n return node.kind === 'LimitNode';\n },\n create(limit) {\n return freeze({\n kind: 'LimitNode',\n limit,\n });\n },\n});\n","/// <reference types=\"./delete-query-builder.d.ts\" />\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseTableExpressionOrList, } from '../parser/table-parser.js';\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { freeze } from '../util/object-utils.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { DeleteResult } from './delete-result.js';\nimport { DeleteQueryNode } from '../operation-node/delete-query-node.js';\nimport { LimitNode } from '../operation-node/limit-node.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { parseValueExpression, } from '../parser/value-parser.js';\nimport { parseTop } from '../parser/top-parser.js';\nexport class DeleteQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n where(...args) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n whereRef(lhs, op, rhs) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n clearWhere() {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutWhere(this.#props.queryNode),\n });\n }\n /**\n * Changes a `delete from` query into a `delete top from` query.\n *\n * `top` clause is only supported by some dialects like MS SQL Server.\n *\n * ### Examples\n *\n * Delete the first 5 rows:\n *\n * ```ts\n * await db\n * .deleteFrom('person')\n * .top(5)\n * .where('age', '>', 18)\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * delete top(5) from \"person\" where \"age\" > @1\n * ```\n *\n * Delete the first 50% of rows:\n *\n * ```ts\n * await db\n * .deleteFrom('person')\n * .top(50, 'percent')\n * .where('age', '>', 18)\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * delete top(50) percent from \"person\" where \"age\" > @1\n * ```\n */\n top(expression, modifiers) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n });\n }\n using(tables) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: DeleteQueryNode.cloneWithUsing(this.#props.queryNode, parseTableExpressionOrList(tables)),\n });\n }\n innerJoin(...args) {\n return this.#join('InnerJoin', args);\n }\n leftJoin(...args) {\n return this.#join('LeftJoin', args);\n }\n rightJoin(...args) {\n return this.#join('RightJoin', args);\n }\n fullJoin(...args) {\n return this.#join('FullJoin', args);\n }\n #join(joinType, args) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithJoin(this.#props.queryNode, parseJoin(joinType, args)),\n });\n }\n returning(selection) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(selection)),\n });\n }\n returningAll(table) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n output(args) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n outputAll(table) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n /**\n * Clears all `returning` clauses from the query.\n *\n * ### Examples\n *\n * ```ts\n * await db.deleteFrom('pet')\n * .returningAll()\n * .where('name', '=', 'Max')\n * .clearReturning()\n * .execute()\n * ```\n *\n * The generated SQL(PostgreSQL):\n *\n * ```sql\n * delete from \"pet\" where \"name\" = \"Max\"\n * ```\n */\n clearReturning() {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutReturning(this.#props.queryNode),\n });\n }\n /**\n * Clears the `limit` clause from the query.\n *\n * ### Examples\n *\n * ```ts\n * await db.deleteFrom('pet')\n * .returningAll()\n * .where('name', '=', 'Max')\n * .limit(5)\n * .clearLimit()\n * .execute()\n * ```\n *\n * The generated SQL(PostgreSQL):\n *\n * ```sql\n * delete from \"pet\" where \"name\" = \"Max\" returning *\n * ```\n */\n clearLimit() {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: DeleteQueryNode.cloneWithoutLimit(this.#props.queryNode),\n });\n }\n orderBy(...args) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOrderByItems(this.#props.queryNode, parseOrderBy(args)),\n });\n }\n clearOrderBy() {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutOrderBy(this.#props.queryNode),\n });\n }\n /**\n * Adds a limit clause to the query.\n *\n * A limit clause in a delete query is only supported by some dialects\n * like MySQL.\n *\n * ### Examples\n *\n * Delete 5 oldest items in a table:\n *\n * ```ts\n * await db\n * .deleteFrom('pet')\n * .orderBy('created_at')\n * .limit(5)\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * delete from `pet` order by `created_at` limit ?\n * ```\n */\n limit(limit) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: DeleteQueryNode.cloneWithLimit(this.#props.queryNode, LimitNode.create(parseValueExpression(limit))),\n });\n }\n /**\n * This can be used to add any additional SQL to the end of the query.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db.deleteFrom('person')\n * .where('first_name', '=', 'John')\n * .modifyEnd(sql`-- This is a comment`)\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * delete from `person`\n * where `first_name` = \"John\" -- This is a comment\n * ```\n */\n modifyEnd(modifier) {\n return new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n *\n * If you want to conditionally call a method on `this`, see\n * the {@link $if} method.\n *\n * ### Examples\n *\n * The next example uses a helper function `log` to log a query:\n *\n * ```ts\n * import type { Compilable } from 'kysely'\n *\n * function log<T extends Compilable>(qb: T): T {\n * console.log(qb.compile())\n * return qb\n * }\n *\n * await db.deleteFrom('person')\n * .$call(log)\n * .execute()\n * ```\n */\n $call(func) {\n return func(this);\n }\n /**\n * Call `func(this)` if `condition` is true.\n *\n * This method is especially handy with optional selects. Any `returning` or `returningAll`\n * method calls add columns as optional fields to the output type when called inside\n * the `func` callback. This is because we can't know if those selections were actually\n * made before running the code.\n *\n * You can also call any other methods inside the callback.\n *\n * ### Examples\n *\n * ```ts\n * async function deletePerson(id: number, returnLastName: boolean) {\n * return await db\n * .deleteFrom('person')\n * .where('id', '=', id)\n * .returning(['id', 'first_name'])\n * .$if(returnLastName, (qb) => qb.returning('last_name'))\n * .executeTakeFirstOrThrow()\n * }\n * ```\n *\n * Any selections added inside the `if` callback will be added as optional fields to the\n * output type since we can't know if the selections were actually made before running\n * the code. In the example above the return type of the `deletePerson` function is:\n *\n * ```ts\n * Promise<{\n * id: number\n * first_name: string\n * last_name?: string\n * }>\n * ```\n */\n $if(condition, func) {\n if (condition) {\n return func(this);\n }\n return new DeleteQueryBuilder({\n ...this.#props,\n });\n }\n /**\n * Change the output type of the query.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `DeleteQueryBuilder` with a new output type.\n */\n $castTo() {\n return new DeleteQueryBuilder(this.#props);\n }\n /**\n * Narrows (parts of) the output type of the query.\n *\n * Kysely tries to be as type-safe as possible, but in some cases we have to make\n * compromises for better maintainability and compilation performance. At present,\n * Kysely doesn't narrow the output type of the query when using {@link where} and {@link returning} or {@link returningAll}.\n *\n * This utility method is very useful for these situations, as it removes unncessary\n * runtime assertion/guard code. Its input type is limited to the output type\n * of the query, so you can't add a column that doesn't exist, or change a column's\n * type to something that doesn't exist in its union type.\n *\n * ### Examples\n *\n * Turn this code:\n *\n * ```ts\n * import type { Person } from 'type-editor' // imaginary module\n *\n * const person = await db.deleteFrom('person')\n * .where('id', '=', 3)\n * .where('nullable_column', 'is not', null)\n * .returningAll()\n * .executeTakeFirstOrThrow()\n *\n * if (isWithNoNullValue(person)) {\n * functionThatExpectsPersonWithNonNullValue(person)\n * }\n *\n * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {\n * return person.nullable_column != null\n * }\n * ```\n *\n * Into this:\n *\n * ```ts\n * import type { NotNull } from 'kysely'\n *\n * const person = await db.deleteFrom('person')\n * .where('id', '=', 3)\n * .where('nullable_column', 'is not', null)\n * .returningAll()\n * .$narrowType<{ nullable_column: NotNull }>()\n * .executeTakeFirstOrThrow()\n *\n * functionThatExpectsPersonWithNonNullValue(person)\n * ```\n */\n $narrowType() {\n return new DeleteQueryBuilder(this.#props);\n }\n /**\n * Asserts that query's output row type equals the given type `T`.\n *\n * This method can be used to simplify excessively complex types to make TypeScript happy\n * and much faster.\n *\n * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much\n * for TypeScript and you get errors like this:\n *\n * ```\n * error TS2589: Type instantiation is excessively deep and possibly infinite.\n * ```\n *\n * In these case you can often use this method to help TypeScript a little bit. When you use this\n * method to assert the output type of a query, Kysely can drop the complex output type that\n * consists of multiple nested helper types and replace it with the simple asserted type.\n *\n * Using this method doesn't reduce type safety at all. You have to pass in a type that is\n * structurally equal to the current type.\n *\n * ### Examples\n *\n * ```ts\n * import type { Species } from 'type-editor' // imaginary module\n *\n * async function deletePersonAndPets(personId: number) {\n * return await db\n * .with('deleted_person', (qb) => qb\n * .deleteFrom('person')\n * .where('id', '=', personId)\n * .returning('first_name')\n * .$assertType<{ first_name: string }>()\n * )\n * .with('deleted_pets', (qb) => qb\n * .deleteFrom('pet')\n * .where('owner_id', '=', personId)\n * .returning(['name as pet_name', 'species'])\n * .$assertType<{ pet_name: string, species: Species }>()\n * )\n * .selectFrom(['deleted_person', 'deleted_pets'])\n * .selectAll()\n * .execute()\n * }\n * ```\n */\n $assertType() {\n return new DeleteQueryBuilder(this.#props);\n }\n /**\n * Returns a copy of this DeleteQueryBuilder instance with the given plugin installed.\n */\n withPlugin(plugin) {\n return new DeleteQueryBuilder({\n ...this.#props,\n executor: this.#props.executor.withPlugin(plugin),\n });\n }\n toOperationNode() {\n return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n }\n compile() {\n return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n }\n /**\n * Executes the query and returns an array of rows.\n *\n * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n */\n async execute() {\n const compiledQuery = this.compile();\n const result = await this.#props.executor.executeQuery(compiledQuery);\n const { adapter } = this.#props.executor;\n const query = compiledQuery.query;\n if ((query.returning && adapter.supportsReturning) ||\n (query.output && adapter.supportsOutput)) {\n return result.rows;\n }\n return [new DeleteResult(result.numAffectedRows ?? BigInt(0))];\n }\n /**\n * Executes the query and returns the first result or undefined if\n * the query returned no result.\n */\n async executeTakeFirst() {\n const [result] = await this.execute();\n return result;\n }\n /**\n * Executes the query and returns the first result or throws if\n * the query returned no result.\n *\n * By default an instance of {@link NoResultError} is thrown, but you can\n * provide a custom error class, or callback as the only argument to throw a different\n * error.\n */\n async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n const result = await this.executeTakeFirst();\n if (result === undefined) {\n const error = isNoResultErrorConstructor(errorConstructor)\n ? new errorConstructor(this.toOperationNode())\n : errorConstructor(this.toOperationNode());\n throw error;\n }\n return result;\n }\n async *stream(chunkSize = 100) {\n const compiledQuery = this.compile();\n const stream = this.#props.executor.stream(compiledQuery, chunkSize);\n for await (const item of stream) {\n yield* item.rows;\n }\n }\n async explain(format, options) {\n const builder = new DeleteQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n });\n return await builder.execute();\n }\n}\n","/// <reference types=\"./update-result.d.ts\" />\nexport class UpdateResult {\n /**\n * The number of rows the update query updated (even if not changed).\n */\n numUpdatedRows;\n /**\n * The number of rows the update query changed.\n *\n * This is **optional** and only supported in dialects such as MySQL.\n * You would probably use {@link numUpdatedRows} in most cases.\n */\n numChangedRows;\n constructor(numUpdatedRows, numChangedRows) {\n this.numUpdatedRows = numUpdatedRows;\n this.numChangedRows = numChangedRows;\n }\n}\n","/// <reference types=\"./update-query-builder.d.ts\" />\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseTableExpressionOrList, } from '../parser/table-parser.js';\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { UpdateQueryNode } from '../operation-node/update-query-node.js';\nimport { parseUpdate, } from '../parser/update-set-parser.js';\nimport { freeze } from '../util/object-utils.js';\nimport { UpdateResult } from './update-result.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { parseReferentialBinaryOperation, parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { parseValueExpression, } from '../parser/value-parser.js';\nimport { LimitNode } from '../operation-node/limit-node.js';\nimport { parseTop } from '../parser/top-parser.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nexport class UpdateQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n where(...args) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n whereRef(lhs, op, rhs) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n clearWhere() {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutWhere(this.#props.queryNode),\n });\n }\n /**\n * Changes an `update` query into a `update top` query.\n *\n * `top` clause is only supported by some dialects like MS SQL Server.\n *\n * ### Examples\n *\n * Update the first row:\n *\n * ```ts\n * await db.updateTable('person')\n * .top(1)\n * .set({ first_name: 'Foo' })\n * .where('age', '>', 18)\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * update top(1) \"person\" set \"first_name\" = @1 where \"age\" > @2\n * ```\n *\n * Update the 50% first rows:\n *\n * ```ts\n * await db.updateTable('person')\n * .top(50, 'percent')\n * .set({ first_name: 'Foo' })\n * .where('age', '>', 18)\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * update top(50) percent \"person\" set \"first_name\" = @1 where \"age\" > @2\n * ```\n */\n top(expression, modifiers) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n });\n }\n from(from) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: UpdateQueryNode.cloneWithFromItems(this.#props.queryNode, parseTableExpressionOrList(from)),\n });\n }\n innerJoin(...args) {\n return this.#join('InnerJoin', args);\n }\n leftJoin(...args) {\n return this.#join('LeftJoin', args);\n }\n rightJoin(...args) {\n return this.#join('RightJoin', args);\n }\n fullJoin(...args) {\n return this.#join('FullJoin', args);\n }\n #join(joinType, args) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithJoin(this.#props.queryNode, parseJoin(joinType, args)),\n });\n }\n orderBy(...args) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOrderByItems(this.#props.queryNode, parseOrderBy(args)),\n });\n }\n clearOrderBy() {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutOrderBy(this.#props.queryNode),\n });\n }\n /**\n * Adds a limit clause to the update query for supported databases, such as MySQL.\n *\n * ### Examples\n *\n * Update the first 2 rows in the 'person' table:\n *\n * ```ts\n * await db\n * .updateTable('person')\n * .set({ first_name: 'Foo' })\n * .limit(2)\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * update `person` set `first_name` = ? limit ?\n * ```\n */\n limit(limit) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: UpdateQueryNode.cloneWithLimit(this.#props.queryNode, LimitNode.create(parseValueExpression(limit))),\n });\n }\n set(...args) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: UpdateQueryNode.cloneWithUpdates(this.#props.queryNode, parseUpdate(...args)),\n });\n }\n returning(selection) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(selection)),\n });\n }\n returningAll(table) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n output(args) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n outputAll(table) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n /**\n * This can be used to add any additional SQL to the end of the query.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db.updateTable('person')\n * .set({ age: 39 })\n * .where('first_name', '=', 'John')\n * .modifyEnd(sql.raw('-- This is a comment'))\n * .execute()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * update `person`\n * set `age` = 39\n * where `first_name` = \"John\" -- This is a comment\n * ```\n */\n modifyEnd(modifier) {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n });\n }\n /**\n * Clears all `returning` clauses from the query.\n *\n * ### Examples\n *\n * ```ts\n * db.updateTable('person')\n * .returningAll()\n * .set({ age: 39 })\n * .where('first_name', '=', 'John')\n * .clearReturning()\n * ```\n *\n * The generated SQL(PostgreSQL):\n *\n * ```sql\n * update \"person\" set \"age\" = 39 where \"first_name\" = \"John\"\n * ```\n */\n clearReturning() {\n return new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutReturning(this.#props.queryNode),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n *\n * If you want to conditionally call a method on `this`, see\n * the {@link $if} method.\n *\n * ### Examples\n *\n * The next example uses a helper function `log` to log a query:\n *\n * ```ts\n * import type { Compilable } from 'kysely'\n * import type { PersonUpdate } from 'type-editor' // imaginary module\n *\n * function log<T extends Compilable>(qb: T): T {\n * console.log(qb.compile())\n * return qb\n * }\n *\n * const values = {\n * first_name: 'John',\n * } satisfies PersonUpdate\n *\n * db.updateTable('person')\n * .set(values)\n * .$call(log)\n * .execute()\n * ```\n */\n $call(func) {\n return func(this);\n }\n /**\n * Call `func(this)` if `condition` is true.\n *\n * This method is especially handy with optional selects. Any `returning` or `returningAll`\n * method calls add columns as optional fields to the output type when called inside\n * the `func` callback. This is because we can't know if those selections were actually\n * made before running the code.\n *\n * You can also call any other methods inside the callback.\n *\n * ### Examples\n *\n * ```ts\n * import type { PersonUpdate } from 'type-editor' // imaginary module\n *\n * async function updatePerson(id: number, updates: PersonUpdate, returnLastName: boolean) {\n * return await db\n * .updateTable('person')\n * .set(updates)\n * .where('id', '=', id)\n * .returning(['id', 'first_name'])\n * .$if(returnLastName, (qb) => qb.returning('last_name'))\n * .executeTakeFirstOrThrow()\n * }\n * ```\n *\n * Any selections added inside the `if` callback will be added as optional fields to the\n * output type since we can't know if the selections were actually made before running\n * the code. In the example above the return type of the `updatePerson` function is:\n *\n * ```ts\n * Promise<{\n * id: number\n * first_name: string\n * last_name?: string\n * }>\n * ```\n */\n $if(condition, func) {\n if (condition) {\n return func(this);\n }\n return new UpdateQueryBuilder({\n ...this.#props,\n });\n }\n /**\n * Change the output type of the query.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `UpdateQueryBuilder` with a new output type.\n */\n $castTo() {\n return new UpdateQueryBuilder(this.#props);\n }\n /**\n * Narrows (parts of) the output type of the query.\n *\n * Kysely tries to be as type-safe as possible, but in some cases we have to make\n * compromises for better maintainability and compilation performance. At present,\n * Kysely doesn't narrow the output type of the query based on {@link set} input\n * when using {@link where} and/or {@link returning} or {@link returningAll}.\n *\n * This utility method is very useful for these situations, as it removes unncessary\n * runtime assertion/guard code. Its input type is limited to the output type\n * of the query, so you can't add a column that doesn't exist, or change a column's\n * type to something that doesn't exist in its union type.\n *\n * ### Examples\n *\n * Turn this code:\n *\n * ```ts\n * import type { Person } from 'type-editor' // imaginary module\n *\n * const id = 1\n * const now = new Date().toISOString()\n *\n * const person = await db.updateTable('person')\n * .set({ deleted_at: now })\n * .where('id', '=', id)\n * .where('nullable_column', 'is not', null)\n * .returningAll()\n * .executeTakeFirstOrThrow()\n *\n * if (isWithNoNullValue(person)) {\n * functionThatExpectsPersonWithNonNullValue(person)\n * }\n *\n * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {\n * return person.nullable_column != null\n * }\n * ```\n *\n * Into this:\n *\n * ```ts\n * import type { NotNull } from 'kysely'\n *\n * const id = 1\n * const now = new Date().toISOString()\n *\n * const person = await db.updateTable('person')\n * .set({ deleted_at: now })\n * .where('id', '=', id)\n * .where('nullable_column', 'is not', null)\n * .returningAll()\n * .$narrowType<{ deleted_at: Date; nullable_column: NotNull }>()\n * .executeTakeFirstOrThrow()\n *\n * functionThatExpectsPersonWithNonNullValue(person)\n * ```\n */\n $narrowType() {\n return new UpdateQueryBuilder(this.#props);\n }\n /**\n * Asserts that query's output row type equals the given type `T`.\n *\n * This method can be used to simplify excessively complex types to make TypeScript happy\n * and much faster.\n *\n * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much\n * for TypeScript and you get errors like this:\n *\n * ```\n * error TS2589: Type instantiation is excessively deep and possibly infinite.\n * ```\n *\n * In these case you can often use this method to help TypeScript a little bit. When you use this\n * method to assert the output type of a query, Kysely can drop the complex output type that\n * consists of multiple nested helper types and replace it with the simple asserted type.\n *\n * Using this method doesn't reduce type safety at all. You have to pass in a type that is\n * structurally equal to the current type.\n *\n * ### Examples\n *\n * ```ts\n * import type { PersonUpdate, PetUpdate, Species } from 'type-editor' // imaginary module\n *\n * const person = {\n * id: 1,\n * gender: 'other',\n * } satisfies PersonUpdate\n *\n * const pet = {\n * name: 'Fluffy',\n * } satisfies PetUpdate\n *\n * const result = await db\n * .with('updated_person', (qb) => qb\n * .updateTable('person')\n * .set(person)\n * .where('id', '=', person.id)\n * .returning('first_name')\n * .$assertType<{ first_name: string }>()\n * )\n * .with('updated_pet', (qb) => qb\n * .updateTable('pet')\n * .set(pet)\n * .where('owner_id', '=', person.id)\n * .returning(['name as pet_name', 'species'])\n * .$assertType<{ pet_name: string, species: Species }>()\n * )\n * .selectFrom(['updated_person', 'updated_pet'])\n * .selectAll()\n * .executeTakeFirstOrThrow()\n * ```\n */\n $assertType() {\n return new UpdateQueryBuilder(this.#props);\n }\n /**\n * Returns a copy of this UpdateQueryBuilder instance with the given plugin installed.\n */\n withPlugin(plugin) {\n return new UpdateQueryBuilder({\n ...this.#props,\n executor: this.#props.executor.withPlugin(plugin),\n });\n }\n toOperationNode() {\n return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n }\n compile() {\n return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n }\n /**\n * Executes the query and returns an array of rows.\n *\n * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n */\n async execute() {\n const compiledQuery = this.compile();\n const result = await this.#props.executor.executeQuery(compiledQuery);\n const { adapter } = this.#props.executor;\n const query = compiledQuery.query;\n if ((query.returning && adapter.supportsReturning) ||\n (query.output && adapter.supportsOutput)) {\n return result.rows;\n }\n return [\n new UpdateResult(result.numAffectedRows ?? BigInt(0), result.numChangedRows),\n ];\n }\n /**\n * Executes the query and returns the first result or undefined if\n * the query returned no result.\n */\n async executeTakeFirst() {\n const [result] = await this.execute();\n return result;\n }\n /**\n * Executes the query and returns the first result or throws if\n * the query returned no result.\n *\n * By default an instance of {@link NoResultError} is thrown, but you can\n * provide a custom error class, or callback as the only argument to throw a different\n * error.\n */\n async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n const result = await this.executeTakeFirst();\n if (result === undefined) {\n const error = isNoResultErrorConstructor(errorConstructor)\n ? new errorConstructor(this.toOperationNode())\n : errorConstructor(this.toOperationNode());\n throw error;\n }\n return result;\n }\n async *stream(chunkSize = 100) {\n const compiledQuery = this.compile();\n const stream = this.#props.executor.stream(compiledQuery, chunkSize);\n for await (const item of stream) {\n yield* item.rows;\n }\n }\n async explain(format, options) {\n const builder = new UpdateQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n });\n return await builder.execute();\n }\n}\n","/// <reference types=\"./common-table-expression-name-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ColumnNode } from './column-node.js';\nimport { TableNode } from './table-node.js';\n/**\n * @internal\n */\nexport const CommonTableExpressionNameNode = freeze({\n is(node) {\n return node.kind === 'CommonTableExpressionNameNode';\n },\n create(tableName, columnNames) {\n return freeze({\n kind: 'CommonTableExpressionNameNode',\n table: TableNode.create(tableName),\n columns: columnNames\n ? freeze(columnNames.map(ColumnNode.create))\n : undefined,\n });\n },\n});\n","/// <reference types=\"./common-table-expression-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const CommonTableExpressionNode = freeze({\n is(node) {\n return node.kind === 'CommonTableExpressionNode';\n },\n create(name, expression) {\n return freeze({\n kind: 'CommonTableExpressionNode',\n name,\n expression,\n });\n },\n cloneWith(node, props) {\n return freeze({\n ...node,\n ...props,\n });\n },\n});\n","/// <reference types=\"./cte-builder.d.ts\" />\nimport { CommonTableExpressionNode } from '../operation-node/common-table-expression-node.js';\nimport { freeze } from '../util/object-utils.js';\nexport class CTEBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Makes the common table expression materialized.\n */\n materialized() {\n return new CTEBuilder({\n ...this.#props,\n node: CommonTableExpressionNode.cloneWith(this.#props.node, {\n materialized: true,\n }),\n });\n }\n /**\n * Makes the common table expression not materialized.\n */\n notMaterialized() {\n return new CTEBuilder({\n ...this.#props,\n node: CommonTableExpressionNode.cloneWith(this.#props.node, {\n materialized: false,\n }),\n });\n }\n toOperationNode() {\n return this.#props.node;\n }\n}\n","/// <reference types=\"./with-parser.d.ts\" />\nimport { CommonTableExpressionNameNode } from '../operation-node/common-table-expression-name-node.js';\nimport { createQueryCreator } from './parse-utils.js';\nimport { isFunction } from '../util/object-utils.js';\nimport { CTEBuilder, } from '../query-builder/cte-builder.js';\nimport { CommonTableExpressionNode } from '../operation-node/common-table-expression-node.js';\nexport function parseCommonTableExpression(nameOrBuilderCallback, expression) {\n const expressionNode = expression(createQueryCreator()).toOperationNode();\n if (isFunction(nameOrBuilderCallback)) {\n return nameOrBuilderCallback(cteBuilderFactory(expressionNode)).toOperationNode();\n }\n return CommonTableExpressionNode.create(parseCommonTableExpressionName(nameOrBuilderCallback), expressionNode);\n}\nfunction cteBuilderFactory(expressionNode) {\n return (name) => {\n return new CTEBuilder({\n node: CommonTableExpressionNode.create(parseCommonTableExpressionName(name), expressionNode),\n });\n };\n}\nfunction parseCommonTableExpressionName(name) {\n if (name.includes('(')) {\n const parts = name.split(/[\\(\\)]/);\n const table = parts[0];\n const columns = parts[1].split(',').map((it) => it.trim());\n return CommonTableExpressionNameNode.create(table, columns);\n }\n else {\n return CommonTableExpressionNameNode.create(name);\n }\n}\n","/// <reference types=\"./with-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const WithNode = freeze({\n is(node) {\n return node.kind === 'WithNode';\n },\n create(expression, params) {\n return freeze({\n kind: 'WithNode',\n expressions: freeze([expression]),\n ...params,\n });\n },\n cloneWithExpression(withNode, expression) {\n return freeze({\n ...withNode,\n expressions: freeze([...withNode.expressions, expression]),\n });\n },\n});\n","/// <reference types=\"./random-string.d.ts\" />\nconst CHARS = [\n 'A',\n 'B',\n 'C',\n 'D',\n 'E',\n 'F',\n 'G',\n 'H',\n 'I',\n 'J',\n 'K',\n 'L',\n 'M',\n 'N',\n 'O',\n 'P',\n 'Q',\n 'R',\n 'S',\n 'T',\n 'U',\n 'V',\n 'W',\n 'X',\n 'Y',\n 'Z',\n 'a',\n 'b',\n 'c',\n 'd',\n 'e',\n 'f',\n 'g',\n 'h',\n 'i',\n 'j',\n 'k',\n 'l',\n 'm',\n 'n',\n 'o',\n 'p',\n 'q',\n 'r',\n 's',\n 't',\n 'u',\n 'v',\n 'w',\n 'x',\n 'y',\n 'z',\n '0',\n '1',\n '2',\n '3',\n '4',\n '5',\n '6',\n '7',\n '8',\n '9',\n];\nexport function randomString(length) {\n let chars = '';\n for (let i = 0; i < length; ++i) {\n chars += randomChar();\n }\n return chars;\n}\nfunction randomChar() {\n return CHARS[~~(Math.random() * CHARS.length)];\n}\n","/// <reference types=\"./query-id.d.ts\" />\nimport { randomString } from './random-string.js';\nexport function createQueryId() {\n return new LazyQueryId();\n}\nclass LazyQueryId {\n #queryId;\n get queryId() {\n if (this.#queryId === undefined) {\n this.#queryId = randomString(8);\n }\n return this.#queryId;\n }\n}\n","/// <reference types=\"./operation-node-transformer.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { requireAllProps } from '../util/require-all-props.js';\n/**\n * Transforms an operation node tree into another one.\n *\n * Kysely queries are expressed internally as a tree of objects (operation nodes).\n * `OperationNodeTransformer` takes such a tree as its input and returns a\n * transformed deep copy of it. By default the `OperationNodeTransformer`\n * does nothing. You need to override one or more methods to make it do\n * something.\n *\n * There's a method for each node type. For example if you'd like to convert\n * each identifier (table name, column name, alias etc.) from camelCase to\n * snake_case, you'd do something like this:\n *\n * ```ts\n * import { type IdentifierNode, OperationNodeTransformer } from 'kysely'\n * import snakeCase from 'lodash/snakeCase'\n *\n * class CamelCaseTransformer extends OperationNodeTransformer {\n * override transformIdentifier(node: IdentifierNode): IdentifierNode {\n * node = super.transformIdentifier(node)\n *\n * return {\n * ...node,\n * name: snakeCase(node.name),\n * }\n * }\n * }\n *\n * const transformer = new CamelCaseTransformer()\n *\n * const query = db.selectFrom('person').select(['first_name', 'last_name'])\n *\n * const tree = transformer.transformNode(query.toOperationNode())\n * ```\n */\nexport class OperationNodeTransformer {\n nodeStack = [];\n #transformers = freeze({\n AliasNode: this.transformAlias.bind(this),\n ColumnNode: this.transformColumn.bind(this),\n IdentifierNode: this.transformIdentifier.bind(this),\n SchemableIdentifierNode: this.transformSchemableIdentifier.bind(this),\n RawNode: this.transformRaw.bind(this),\n ReferenceNode: this.transformReference.bind(this),\n SelectQueryNode: this.transformSelectQuery.bind(this),\n SelectionNode: this.transformSelection.bind(this),\n TableNode: this.transformTable.bind(this),\n FromNode: this.transformFrom.bind(this),\n SelectAllNode: this.transformSelectAll.bind(this),\n AndNode: this.transformAnd.bind(this),\n OrNode: this.transformOr.bind(this),\n ValueNode: this.transformValue.bind(this),\n ValueListNode: this.transformValueList.bind(this),\n PrimitiveValueListNode: this.transformPrimitiveValueList.bind(this),\n ParensNode: this.transformParens.bind(this),\n JoinNode: this.transformJoin.bind(this),\n OperatorNode: this.transformOperator.bind(this),\n WhereNode: this.transformWhere.bind(this),\n InsertQueryNode: this.transformInsertQuery.bind(this),\n DeleteQueryNode: this.transformDeleteQuery.bind(this),\n ReturningNode: this.transformReturning.bind(this),\n CreateTableNode: this.transformCreateTable.bind(this),\n AddColumnNode: this.transformAddColumn.bind(this),\n ColumnDefinitionNode: this.transformColumnDefinition.bind(this),\n DropTableNode: this.transformDropTable.bind(this),\n DataTypeNode: this.transformDataType.bind(this),\n OrderByNode: this.transformOrderBy.bind(this),\n OrderByItemNode: this.transformOrderByItem.bind(this),\n GroupByNode: this.transformGroupBy.bind(this),\n GroupByItemNode: this.transformGroupByItem.bind(this),\n UpdateQueryNode: this.transformUpdateQuery.bind(this),\n ColumnUpdateNode: this.transformColumnUpdate.bind(this),\n LimitNode: this.transformLimit.bind(this),\n OffsetNode: this.transformOffset.bind(this),\n OnConflictNode: this.transformOnConflict.bind(this),\n OnDuplicateKeyNode: this.transformOnDuplicateKey.bind(this),\n CreateIndexNode: this.transformCreateIndex.bind(this),\n DropIndexNode: this.transformDropIndex.bind(this),\n ListNode: this.transformList.bind(this),\n PrimaryKeyConstraintNode: this.transformPrimaryKeyConstraint.bind(this),\n UniqueConstraintNode: this.transformUniqueConstraint.bind(this),\n ReferencesNode: this.transformReferences.bind(this),\n CheckConstraintNode: this.transformCheckConstraint.bind(this),\n WithNode: this.transformWith.bind(this),\n CommonTableExpressionNode: this.transformCommonTableExpression.bind(this),\n CommonTableExpressionNameNode: this.transformCommonTableExpressionName.bind(this),\n HavingNode: this.transformHaving.bind(this),\n CreateSchemaNode: this.transformCreateSchema.bind(this),\n DropSchemaNode: this.transformDropSchema.bind(this),\n AlterTableNode: this.transformAlterTable.bind(this),\n DropColumnNode: this.transformDropColumn.bind(this),\n RenameColumnNode: this.transformRenameColumn.bind(this),\n AlterColumnNode: this.transformAlterColumn.bind(this),\n ModifyColumnNode: this.transformModifyColumn.bind(this),\n AddConstraintNode: this.transformAddConstraint.bind(this),\n DropConstraintNode: this.transformDropConstraint.bind(this),\n RenameConstraintNode: this.transformRenameConstraint.bind(this),\n ForeignKeyConstraintNode: this.transformForeignKeyConstraint.bind(this),\n CreateViewNode: this.transformCreateView.bind(this),\n RefreshMaterializedViewNode: this.transformRefreshMaterializedView.bind(this),\n DropViewNode: this.transformDropView.bind(this),\n GeneratedNode: this.transformGenerated.bind(this),\n DefaultValueNode: this.transformDefaultValue.bind(this),\n OnNode: this.transformOn.bind(this),\n ValuesNode: this.transformValues.bind(this),\n SelectModifierNode: this.transformSelectModifier.bind(this),\n CreateTypeNode: this.transformCreateType.bind(this),\n DropTypeNode: this.transformDropType.bind(this),\n ExplainNode: this.transformExplain.bind(this),\n DefaultInsertValueNode: this.transformDefaultInsertValue.bind(this),\n AggregateFunctionNode: this.transformAggregateFunction.bind(this),\n OverNode: this.transformOver.bind(this),\n PartitionByNode: this.transformPartitionBy.bind(this),\n PartitionByItemNode: this.transformPartitionByItem.bind(this),\n SetOperationNode: this.transformSetOperation.bind(this),\n BinaryOperationNode: this.transformBinaryOperation.bind(this),\n UnaryOperationNode: this.transformUnaryOperation.bind(this),\n UsingNode: this.transformUsing.bind(this),\n FunctionNode: this.transformFunction.bind(this),\n CaseNode: this.transformCase.bind(this),\n WhenNode: this.transformWhen.bind(this),\n JSONReferenceNode: this.transformJSONReference.bind(this),\n JSONPathNode: this.transformJSONPath.bind(this),\n JSONPathLegNode: this.transformJSONPathLeg.bind(this),\n JSONOperatorChainNode: this.transformJSONOperatorChain.bind(this),\n TupleNode: this.transformTuple.bind(this),\n MergeQueryNode: this.transformMergeQuery.bind(this),\n MatchedNode: this.transformMatched.bind(this),\n AddIndexNode: this.transformAddIndex.bind(this),\n CastNode: this.transformCast.bind(this),\n FetchNode: this.transformFetch.bind(this),\n TopNode: this.transformTop.bind(this),\n OutputNode: this.transformOutput.bind(this),\n OrActionNode: this.transformOrAction.bind(this),\n CollateNode: this.transformCollate.bind(this),\n });\n transformNode(node, queryId) {\n if (!node) {\n return node;\n }\n this.nodeStack.push(node);\n const out = this.transformNodeImpl(node, queryId);\n this.nodeStack.pop();\n return freeze(out);\n }\n transformNodeImpl(node, queryId) {\n return this.#transformers[node.kind](node, queryId);\n }\n transformNodeList(list, queryId) {\n if (!list) {\n return list;\n }\n return freeze(list.map((node) => this.transformNode(node, queryId)));\n }\n transformSelectQuery(node, queryId) {\n return requireAllProps({\n kind: 'SelectQueryNode',\n from: this.transformNode(node.from, queryId),\n selections: this.transformNodeList(node.selections, queryId),\n distinctOn: this.transformNodeList(node.distinctOn, queryId),\n joins: this.transformNodeList(node.joins, queryId),\n groupBy: this.transformNode(node.groupBy, queryId),\n orderBy: this.transformNode(node.orderBy, queryId),\n where: this.transformNode(node.where, queryId),\n frontModifiers: this.transformNodeList(node.frontModifiers, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n limit: this.transformNode(node.limit, queryId),\n offset: this.transformNode(node.offset, queryId),\n with: this.transformNode(node.with, queryId),\n having: this.transformNode(node.having, queryId),\n explain: this.transformNode(node.explain, queryId),\n setOperations: this.transformNodeList(node.setOperations, queryId),\n fetch: this.transformNode(node.fetch, queryId),\n top: this.transformNode(node.top, queryId),\n });\n }\n transformSelection(node, queryId) {\n return requireAllProps({\n kind: 'SelectionNode',\n selection: this.transformNode(node.selection, queryId),\n });\n }\n transformColumn(node, queryId) {\n return requireAllProps({\n kind: 'ColumnNode',\n column: this.transformNode(node.column, queryId),\n });\n }\n transformAlias(node, queryId) {\n return requireAllProps({\n kind: 'AliasNode',\n node: this.transformNode(node.node, queryId),\n alias: this.transformNode(node.alias, queryId),\n });\n }\n transformTable(node, queryId) {\n return requireAllProps({\n kind: 'TableNode',\n table: this.transformNode(node.table, queryId),\n });\n }\n transformFrom(node, queryId) {\n return requireAllProps({\n kind: 'FromNode',\n froms: this.transformNodeList(node.froms, queryId),\n });\n }\n transformReference(node, queryId) {\n return requireAllProps({\n kind: 'ReferenceNode',\n column: this.transformNode(node.column, queryId),\n table: this.transformNode(node.table, queryId),\n });\n }\n transformAnd(node, queryId) {\n return requireAllProps({\n kind: 'AndNode',\n left: this.transformNode(node.left, queryId),\n right: this.transformNode(node.right, queryId),\n });\n }\n transformOr(node, queryId) {\n return requireAllProps({\n kind: 'OrNode',\n left: this.transformNode(node.left, queryId),\n right: this.transformNode(node.right, queryId),\n });\n }\n transformValueList(node, queryId) {\n return requireAllProps({\n kind: 'ValueListNode',\n values: this.transformNodeList(node.values, queryId),\n });\n }\n transformParens(node, queryId) {\n return requireAllProps({\n kind: 'ParensNode',\n node: this.transformNode(node.node, queryId),\n });\n }\n transformJoin(node, queryId) {\n return requireAllProps({\n kind: 'JoinNode',\n joinType: node.joinType,\n table: this.transformNode(node.table, queryId),\n on: this.transformNode(node.on, queryId),\n });\n }\n transformRaw(node, queryId) {\n return requireAllProps({\n kind: 'RawNode',\n sqlFragments: freeze([...node.sqlFragments]),\n parameters: this.transformNodeList(node.parameters, queryId),\n });\n }\n transformWhere(node, queryId) {\n return requireAllProps({\n kind: 'WhereNode',\n where: this.transformNode(node.where, queryId),\n });\n }\n transformInsertQuery(node, queryId) {\n return requireAllProps({\n kind: 'InsertQueryNode',\n into: this.transformNode(node.into, queryId),\n columns: this.transformNodeList(node.columns, queryId),\n values: this.transformNode(node.values, queryId),\n returning: this.transformNode(node.returning, queryId),\n onConflict: this.transformNode(node.onConflict, queryId),\n onDuplicateKey: this.transformNode(node.onDuplicateKey, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n with: this.transformNode(node.with, queryId),\n ignore: node.ignore,\n orAction: this.transformNode(node.orAction, queryId),\n replace: node.replace,\n explain: this.transformNode(node.explain, queryId),\n defaultValues: node.defaultValues,\n top: this.transformNode(node.top, queryId),\n output: this.transformNode(node.output, queryId),\n });\n }\n transformValues(node, queryId) {\n return requireAllProps({\n kind: 'ValuesNode',\n values: this.transformNodeList(node.values, queryId),\n });\n }\n transformDeleteQuery(node, queryId) {\n return requireAllProps({\n kind: 'DeleteQueryNode',\n from: this.transformNode(node.from, queryId),\n using: this.transformNode(node.using, queryId),\n joins: this.transformNodeList(node.joins, queryId),\n where: this.transformNode(node.where, queryId),\n returning: this.transformNode(node.returning, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n with: this.transformNode(node.with, queryId),\n orderBy: this.transformNode(node.orderBy, queryId),\n limit: this.transformNode(node.limit, queryId),\n explain: this.transformNode(node.explain, queryId),\n top: this.transformNode(node.top, queryId),\n output: this.transformNode(node.output, queryId),\n });\n }\n transformReturning(node, queryId) {\n return requireAllProps({\n kind: 'ReturningNode',\n selections: this.transformNodeList(node.selections, queryId),\n });\n }\n transformCreateTable(node, queryId) {\n return requireAllProps({\n kind: 'CreateTableNode',\n table: this.transformNode(node.table, queryId),\n columns: this.transformNodeList(node.columns, queryId),\n constraints: this.transformNodeList(node.constraints, queryId),\n temporary: node.temporary,\n ifNotExists: node.ifNotExists,\n onCommit: node.onCommit,\n frontModifiers: this.transformNodeList(node.frontModifiers, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n selectQuery: this.transformNode(node.selectQuery, queryId),\n });\n }\n transformColumnDefinition(node, queryId) {\n return requireAllProps({\n kind: 'ColumnDefinitionNode',\n column: this.transformNode(node.column, queryId),\n dataType: this.transformNode(node.dataType, queryId),\n references: this.transformNode(node.references, queryId),\n primaryKey: node.primaryKey,\n autoIncrement: node.autoIncrement,\n unique: node.unique,\n notNull: node.notNull,\n unsigned: node.unsigned,\n defaultTo: this.transformNode(node.defaultTo, queryId),\n check: this.transformNode(node.check, queryId),\n generated: this.transformNode(node.generated, queryId),\n frontModifiers: this.transformNodeList(node.frontModifiers, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n nullsNotDistinct: node.nullsNotDistinct,\n identity: node.identity,\n ifNotExists: node.ifNotExists,\n });\n }\n transformAddColumn(node, queryId) {\n return requireAllProps({\n kind: 'AddColumnNode',\n column: this.transformNode(node.column, queryId),\n });\n }\n transformDropTable(node, queryId) {\n return requireAllProps({\n kind: 'DropTableNode',\n table: this.transformNode(node.table, queryId),\n ifExists: node.ifExists,\n cascade: node.cascade,\n });\n }\n transformOrderBy(node, queryId) {\n return requireAllProps({\n kind: 'OrderByNode',\n items: this.transformNodeList(node.items, queryId),\n });\n }\n transformOrderByItem(node, queryId) {\n return requireAllProps({\n kind: 'OrderByItemNode',\n orderBy: this.transformNode(node.orderBy, queryId),\n direction: this.transformNode(node.direction, queryId),\n collation: this.transformNode(node.collation, queryId),\n nulls: node.nulls,\n });\n }\n transformGroupBy(node, queryId) {\n return requireAllProps({\n kind: 'GroupByNode',\n items: this.transformNodeList(node.items, queryId),\n });\n }\n transformGroupByItem(node, queryId) {\n return requireAllProps({\n kind: 'GroupByItemNode',\n groupBy: this.transformNode(node.groupBy, queryId),\n });\n }\n transformUpdateQuery(node, queryId) {\n return requireAllProps({\n kind: 'UpdateQueryNode',\n table: this.transformNode(node.table, queryId),\n from: this.transformNode(node.from, queryId),\n joins: this.transformNodeList(node.joins, queryId),\n where: this.transformNode(node.where, queryId),\n updates: this.transformNodeList(node.updates, queryId),\n returning: this.transformNode(node.returning, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n with: this.transformNode(node.with, queryId),\n explain: this.transformNode(node.explain, queryId),\n limit: this.transformNode(node.limit, queryId),\n top: this.transformNode(node.top, queryId),\n output: this.transformNode(node.output, queryId),\n orderBy: this.transformNode(node.orderBy, queryId),\n });\n }\n transformColumnUpdate(node, queryId) {\n return requireAllProps({\n kind: 'ColumnUpdateNode',\n column: this.transformNode(node.column, queryId),\n value: this.transformNode(node.value, queryId),\n });\n }\n transformLimit(node, queryId) {\n return requireAllProps({\n kind: 'LimitNode',\n limit: this.transformNode(node.limit, queryId),\n });\n }\n transformOffset(node, queryId) {\n return requireAllProps({\n kind: 'OffsetNode',\n offset: this.transformNode(node.offset, queryId),\n });\n }\n transformOnConflict(node, queryId) {\n return requireAllProps({\n kind: 'OnConflictNode',\n columns: this.transformNodeList(node.columns, queryId),\n constraint: this.transformNode(node.constraint, queryId),\n indexExpression: this.transformNode(node.indexExpression, queryId),\n indexWhere: this.transformNode(node.indexWhere, queryId),\n updates: this.transformNodeList(node.updates, queryId),\n updateWhere: this.transformNode(node.updateWhere, queryId),\n doNothing: node.doNothing,\n });\n }\n transformOnDuplicateKey(node, queryId) {\n return requireAllProps({\n kind: 'OnDuplicateKeyNode',\n updates: this.transformNodeList(node.updates, queryId),\n });\n }\n transformCreateIndex(node, queryId) {\n return requireAllProps({\n kind: 'CreateIndexNode',\n name: this.transformNode(node.name, queryId),\n table: this.transformNode(node.table, queryId),\n columns: this.transformNodeList(node.columns, queryId),\n unique: node.unique,\n using: this.transformNode(node.using, queryId),\n ifNotExists: node.ifNotExists,\n where: this.transformNode(node.where, queryId),\n nullsNotDistinct: node.nullsNotDistinct,\n });\n }\n transformList(node, queryId) {\n return requireAllProps({\n kind: 'ListNode',\n items: this.transformNodeList(node.items, queryId),\n });\n }\n transformDropIndex(node, queryId) {\n return requireAllProps({\n kind: 'DropIndexNode',\n name: this.transformNode(node.name, queryId),\n table: this.transformNode(node.table, queryId),\n ifExists: node.ifExists,\n cascade: node.cascade,\n });\n }\n transformPrimaryKeyConstraint(node, queryId) {\n return requireAllProps({\n kind: 'PrimaryKeyConstraintNode',\n columns: this.transformNodeList(node.columns, queryId),\n name: this.transformNode(node.name, queryId),\n deferrable: node.deferrable,\n initiallyDeferred: node.initiallyDeferred,\n });\n }\n transformUniqueConstraint(node, queryId) {\n return requireAllProps({\n kind: 'UniqueConstraintNode',\n columns: this.transformNodeList(node.columns, queryId),\n name: this.transformNode(node.name, queryId),\n nullsNotDistinct: node.nullsNotDistinct,\n deferrable: node.deferrable,\n initiallyDeferred: node.initiallyDeferred,\n });\n }\n transformForeignKeyConstraint(node, queryId) {\n return requireAllProps({\n kind: 'ForeignKeyConstraintNode',\n columns: this.transformNodeList(node.columns, queryId),\n references: this.transformNode(node.references, queryId),\n name: this.transformNode(node.name, queryId),\n onDelete: node.onDelete,\n onUpdate: node.onUpdate,\n deferrable: node.deferrable,\n initiallyDeferred: node.initiallyDeferred,\n });\n }\n transformSetOperation(node, queryId) {\n return requireAllProps({\n kind: 'SetOperationNode',\n operator: node.operator,\n expression: this.transformNode(node.expression, queryId),\n all: node.all,\n });\n }\n transformReferences(node, queryId) {\n return requireAllProps({\n kind: 'ReferencesNode',\n table: this.transformNode(node.table, queryId),\n columns: this.transformNodeList(node.columns, queryId),\n onDelete: node.onDelete,\n onUpdate: node.onUpdate,\n });\n }\n transformCheckConstraint(node, queryId) {\n return requireAllProps({\n kind: 'CheckConstraintNode',\n expression: this.transformNode(node.expression, queryId),\n name: this.transformNode(node.name, queryId),\n });\n }\n transformWith(node, queryId) {\n return requireAllProps({\n kind: 'WithNode',\n expressions: this.transformNodeList(node.expressions, queryId),\n recursive: node.recursive,\n });\n }\n transformCommonTableExpression(node, queryId) {\n return requireAllProps({\n kind: 'CommonTableExpressionNode',\n name: this.transformNode(node.name, queryId),\n materialized: node.materialized,\n expression: this.transformNode(node.expression, queryId),\n });\n }\n transformCommonTableExpressionName(node, queryId) {\n return requireAllProps({\n kind: 'CommonTableExpressionNameNode',\n table: this.transformNode(node.table, queryId),\n columns: this.transformNodeList(node.columns, queryId),\n });\n }\n transformHaving(node, queryId) {\n return requireAllProps({\n kind: 'HavingNode',\n having: this.transformNode(node.having, queryId),\n });\n }\n transformCreateSchema(node, queryId) {\n return requireAllProps({\n kind: 'CreateSchemaNode',\n schema: this.transformNode(node.schema, queryId),\n ifNotExists: node.ifNotExists,\n });\n }\n transformDropSchema(node, queryId) {\n return requireAllProps({\n kind: 'DropSchemaNode',\n schema: this.transformNode(node.schema, queryId),\n ifExists: node.ifExists,\n cascade: node.cascade,\n });\n }\n transformAlterTable(node, queryId) {\n return requireAllProps({\n kind: 'AlterTableNode',\n table: this.transformNode(node.table, queryId),\n renameTo: this.transformNode(node.renameTo, queryId),\n setSchema: this.transformNode(node.setSchema, queryId),\n columnAlterations: this.transformNodeList(node.columnAlterations, queryId),\n addConstraint: this.transformNode(node.addConstraint, queryId),\n dropConstraint: this.transformNode(node.dropConstraint, queryId),\n renameConstraint: this.transformNode(node.renameConstraint, queryId),\n addIndex: this.transformNode(node.addIndex, queryId),\n dropIndex: this.transformNode(node.dropIndex, queryId),\n });\n }\n transformDropColumn(node, queryId) {\n return requireAllProps({\n kind: 'DropColumnNode',\n column: this.transformNode(node.column, queryId),\n });\n }\n transformRenameColumn(node, queryId) {\n return requireAllProps({\n kind: 'RenameColumnNode',\n column: this.transformNode(node.column, queryId),\n renameTo: this.transformNode(node.renameTo, queryId),\n });\n }\n transformAlterColumn(node, queryId) {\n return requireAllProps({\n kind: 'AlterColumnNode',\n column: this.transformNode(node.column, queryId),\n dataType: this.transformNode(node.dataType, queryId),\n dataTypeExpression: this.transformNode(node.dataTypeExpression, queryId),\n setDefault: this.transformNode(node.setDefault, queryId),\n dropDefault: node.dropDefault,\n setNotNull: node.setNotNull,\n dropNotNull: node.dropNotNull,\n });\n }\n transformModifyColumn(node, queryId) {\n return requireAllProps({\n kind: 'ModifyColumnNode',\n column: this.transformNode(node.column, queryId),\n });\n }\n transformAddConstraint(node, queryId) {\n return requireAllProps({\n kind: 'AddConstraintNode',\n constraint: this.transformNode(node.constraint, queryId),\n });\n }\n transformDropConstraint(node, queryId) {\n return requireAllProps({\n kind: 'DropConstraintNode',\n constraintName: this.transformNode(node.constraintName, queryId),\n ifExists: node.ifExists,\n modifier: node.modifier,\n });\n }\n transformRenameConstraint(node, queryId) {\n return requireAllProps({\n kind: 'RenameConstraintNode',\n oldName: this.transformNode(node.oldName, queryId),\n newName: this.transformNode(node.newName, queryId),\n });\n }\n transformCreateView(node, queryId) {\n return requireAllProps({\n kind: 'CreateViewNode',\n name: this.transformNode(node.name, queryId),\n temporary: node.temporary,\n orReplace: node.orReplace,\n ifNotExists: node.ifNotExists,\n materialized: node.materialized,\n columns: this.transformNodeList(node.columns, queryId),\n as: this.transformNode(node.as, queryId),\n });\n }\n transformRefreshMaterializedView(node, queryId) {\n return requireAllProps({\n kind: 'RefreshMaterializedViewNode',\n name: this.transformNode(node.name, queryId),\n concurrently: node.concurrently,\n withNoData: node.withNoData,\n });\n }\n transformDropView(node, queryId) {\n return requireAllProps({\n kind: 'DropViewNode',\n name: this.transformNode(node.name, queryId),\n ifExists: node.ifExists,\n materialized: node.materialized,\n cascade: node.cascade,\n });\n }\n transformGenerated(node, queryId) {\n return requireAllProps({\n kind: 'GeneratedNode',\n byDefault: node.byDefault,\n always: node.always,\n identity: node.identity,\n stored: node.stored,\n expression: this.transformNode(node.expression, queryId),\n });\n }\n transformDefaultValue(node, queryId) {\n return requireAllProps({\n kind: 'DefaultValueNode',\n defaultValue: this.transformNode(node.defaultValue, queryId),\n });\n }\n transformOn(node, queryId) {\n return requireAllProps({\n kind: 'OnNode',\n on: this.transformNode(node.on, queryId),\n });\n }\n transformSelectModifier(node, queryId) {\n return requireAllProps({\n kind: 'SelectModifierNode',\n modifier: node.modifier,\n rawModifier: this.transformNode(node.rawModifier, queryId),\n of: this.transformNodeList(node.of, queryId),\n });\n }\n transformCreateType(node, queryId) {\n return requireAllProps({\n kind: 'CreateTypeNode',\n name: this.transformNode(node.name, queryId),\n enum: this.transformNode(node.enum, queryId),\n });\n }\n transformDropType(node, queryId) {\n return requireAllProps({\n kind: 'DropTypeNode',\n name: this.transformNode(node.name, queryId),\n ifExists: node.ifExists,\n });\n }\n transformExplain(node, queryId) {\n return requireAllProps({\n kind: 'ExplainNode',\n format: node.format,\n options: this.transformNode(node.options, queryId),\n });\n }\n transformSchemableIdentifier(node, queryId) {\n return requireAllProps({\n kind: 'SchemableIdentifierNode',\n schema: this.transformNode(node.schema, queryId),\n identifier: this.transformNode(node.identifier, queryId),\n });\n }\n transformAggregateFunction(node, queryId) {\n return requireAllProps({\n kind: 'AggregateFunctionNode',\n func: node.func,\n aggregated: this.transformNodeList(node.aggregated, queryId),\n distinct: node.distinct,\n orderBy: this.transformNode(node.orderBy, queryId),\n withinGroup: this.transformNode(node.withinGroup, queryId),\n filter: this.transformNode(node.filter, queryId),\n over: this.transformNode(node.over, queryId),\n });\n }\n transformOver(node, queryId) {\n return requireAllProps({\n kind: 'OverNode',\n orderBy: this.transformNode(node.orderBy, queryId),\n partitionBy: this.transformNode(node.partitionBy, queryId),\n });\n }\n transformPartitionBy(node, queryId) {\n return requireAllProps({\n kind: 'PartitionByNode',\n items: this.transformNodeList(node.items, queryId),\n });\n }\n transformPartitionByItem(node, queryId) {\n return requireAllProps({\n kind: 'PartitionByItemNode',\n partitionBy: this.transformNode(node.partitionBy, queryId),\n });\n }\n transformBinaryOperation(node, queryId) {\n return requireAllProps({\n kind: 'BinaryOperationNode',\n leftOperand: this.transformNode(node.leftOperand, queryId),\n operator: this.transformNode(node.operator, queryId),\n rightOperand: this.transformNode(node.rightOperand, queryId),\n });\n }\n transformUnaryOperation(node, queryId) {\n return requireAllProps({\n kind: 'UnaryOperationNode',\n operator: this.transformNode(node.operator, queryId),\n operand: this.transformNode(node.operand, queryId),\n });\n }\n transformUsing(node, queryId) {\n return requireAllProps({\n kind: 'UsingNode',\n tables: this.transformNodeList(node.tables, queryId),\n });\n }\n transformFunction(node, queryId) {\n return requireAllProps({\n kind: 'FunctionNode',\n func: node.func,\n arguments: this.transformNodeList(node.arguments, queryId),\n });\n }\n transformCase(node, queryId) {\n return requireAllProps({\n kind: 'CaseNode',\n value: this.transformNode(node.value, queryId),\n when: this.transformNodeList(node.when, queryId),\n else: this.transformNode(node.else, queryId),\n isStatement: node.isStatement,\n });\n }\n transformWhen(node, queryId) {\n return requireAllProps({\n kind: 'WhenNode',\n condition: this.transformNode(node.condition, queryId),\n result: this.transformNode(node.result, queryId),\n });\n }\n transformJSONReference(node, queryId) {\n return requireAllProps({\n kind: 'JSONReferenceNode',\n reference: this.transformNode(node.reference, queryId),\n traversal: this.transformNode(node.traversal, queryId),\n });\n }\n transformJSONPath(node, queryId) {\n return requireAllProps({\n kind: 'JSONPathNode',\n inOperator: this.transformNode(node.inOperator, queryId),\n pathLegs: this.transformNodeList(node.pathLegs, queryId),\n });\n }\n transformJSONPathLeg(node, _queryId) {\n return requireAllProps({\n kind: 'JSONPathLegNode',\n type: node.type,\n value: node.value,\n });\n }\n transformJSONOperatorChain(node, queryId) {\n return requireAllProps({\n kind: 'JSONOperatorChainNode',\n operator: this.transformNode(node.operator, queryId),\n values: this.transformNodeList(node.values, queryId),\n });\n }\n transformTuple(node, queryId) {\n return requireAllProps({\n kind: 'TupleNode',\n values: this.transformNodeList(node.values, queryId),\n });\n }\n transformMergeQuery(node, queryId) {\n return requireAllProps({\n kind: 'MergeQueryNode',\n into: this.transformNode(node.into, queryId),\n using: this.transformNode(node.using, queryId),\n whens: this.transformNodeList(node.whens, queryId),\n with: this.transformNode(node.with, queryId),\n top: this.transformNode(node.top, queryId),\n endModifiers: this.transformNodeList(node.endModifiers, queryId),\n output: this.transformNode(node.output, queryId),\n returning: this.transformNode(node.returning, queryId),\n });\n }\n transformMatched(node, _queryId) {\n return requireAllProps({\n kind: 'MatchedNode',\n not: node.not,\n bySource: node.bySource,\n });\n }\n transformAddIndex(node, queryId) {\n return requireAllProps({\n kind: 'AddIndexNode',\n name: this.transformNode(node.name, queryId),\n columns: this.transformNodeList(node.columns, queryId),\n unique: node.unique,\n using: this.transformNode(node.using, queryId),\n ifNotExists: node.ifNotExists,\n });\n }\n transformCast(node, queryId) {\n return requireAllProps({\n kind: 'CastNode',\n expression: this.transformNode(node.expression, queryId),\n dataType: this.transformNode(node.dataType, queryId),\n });\n }\n transformFetch(node, queryId) {\n return requireAllProps({\n kind: 'FetchNode',\n rowCount: this.transformNode(node.rowCount, queryId),\n modifier: node.modifier,\n });\n }\n transformTop(node, _queryId) {\n return requireAllProps({\n kind: 'TopNode',\n expression: node.expression,\n modifiers: node.modifiers,\n });\n }\n transformOutput(node, queryId) {\n return requireAllProps({\n kind: 'OutputNode',\n selections: this.transformNodeList(node.selections, queryId),\n });\n }\n transformDataType(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformSelectAll(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformIdentifier(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformValue(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformPrimitiveValueList(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformOperator(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformDefaultInsertValue(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformOrAction(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n transformCollate(node, _queryId) {\n // An Object.freezed leaf node. No need to clone.\n return node;\n }\n}\n","/// <reference types=\"./with-schema-transformer.d.ts\" />\nimport { AliasNode } from '../../operation-node/alias-node.js';\nimport { IdentifierNode } from '../../operation-node/identifier-node.js';\nimport { JoinNode } from '../../operation-node/join-node.js';\nimport { ListNode } from '../../operation-node/list-node.js';\nimport { OperationNodeTransformer } from '../../operation-node/operation-node-transformer.js';\nimport { SchemableIdentifierNode } from '../../operation-node/schemable-identifier-node.js';\nimport { TableNode } from '../../operation-node/table-node.js';\nimport { UsingNode } from '../../operation-node/using-node.js';\nimport { freeze } from '../../util/object-utils.js';\n// This object exist only so that we get a type error when a new RootOperationNode\n// is added. If you get a type error here, make sure to add the new root node and\n// handle it correctly in the transformer.\n//\n// DO NOT REFACTOR THIS EVEN IF IT SEEMS USELESS TO YOU!\nconst ROOT_OPERATION_NODES = freeze({\n AlterTableNode: true,\n CreateIndexNode: true,\n CreateSchemaNode: true,\n CreateTableNode: true,\n CreateTypeNode: true,\n CreateViewNode: true,\n RefreshMaterializedViewNode: true,\n DeleteQueryNode: true,\n DropIndexNode: true,\n DropSchemaNode: true,\n DropTableNode: true,\n DropTypeNode: true,\n DropViewNode: true,\n InsertQueryNode: true,\n RawNode: true,\n SelectQueryNode: true,\n UpdateQueryNode: true,\n MergeQueryNode: true,\n});\nconst SCHEMALESS_FUNCTIONS = {\n json_agg: true,\n to_json: true,\n};\nexport class WithSchemaTransformer extends OperationNodeTransformer {\n #schema;\n #schemableIds = new Set();\n #ctes = new Set();\n constructor(schema) {\n super();\n this.#schema = schema;\n }\n transformNodeImpl(node, queryId) {\n if (!this.#isRootOperationNode(node)) {\n return super.transformNodeImpl(node, queryId);\n }\n const ctes = this.#collectCTEs(node);\n for (const cte of ctes) {\n this.#ctes.add(cte);\n }\n const tables = this.#collectSchemableIds(node);\n for (const table of tables) {\n this.#schemableIds.add(table);\n }\n const transformed = super.transformNodeImpl(node, queryId);\n for (const table of tables) {\n this.#schemableIds.delete(table);\n }\n for (const cte of ctes) {\n this.#ctes.delete(cte);\n }\n return transformed;\n }\n transformSchemableIdentifier(node, queryId) {\n const transformed = super.transformSchemableIdentifier(node, queryId);\n if (transformed.schema || !this.#schemableIds.has(node.identifier.name)) {\n return transformed;\n }\n return {\n ...transformed,\n schema: IdentifierNode.create(this.#schema),\n };\n }\n transformReferences(node, queryId) {\n const transformed = super.transformReferences(node, queryId);\n if (transformed.table.table.schema) {\n return transformed;\n }\n return {\n ...transformed,\n table: TableNode.createWithSchema(this.#schema, transformed.table.table.identifier.name),\n };\n }\n transformAggregateFunction(node, queryId) {\n return {\n ...super.transformAggregateFunction({ ...node, aggregated: [] }, queryId),\n aggregated: this.#transformTableArgsWithoutSchemas(node, queryId, 'aggregated'),\n };\n }\n transformFunction(node, queryId) {\n return {\n ...super.transformFunction({ ...node, arguments: [] }, queryId),\n arguments: this.#transformTableArgsWithoutSchemas(node, queryId, 'arguments'),\n };\n }\n transformSelectModifier(node, queryId) {\n return {\n ...super.transformSelectModifier({ ...node, of: undefined }, queryId),\n of: node.of?.map((item) => TableNode.is(item) && !item.table.schema\n ? {\n ...item,\n table: this.transformIdentifier(item.table.identifier, queryId),\n }\n : this.transformNode(item, queryId)),\n };\n }\n #transformTableArgsWithoutSchemas(node, queryId, argsKey) {\n return SCHEMALESS_FUNCTIONS[node.func]\n ? node[argsKey].map((arg) => !TableNode.is(arg) || arg.table.schema\n ? this.transformNode(arg, queryId)\n : {\n ...arg,\n table: this.transformIdentifier(arg.table.identifier, queryId),\n })\n : this.transformNodeList(node[argsKey], queryId);\n }\n #isRootOperationNode(node) {\n return node.kind in ROOT_OPERATION_NODES;\n }\n #collectSchemableIds(node) {\n const schemableIds = new Set();\n if ('name' in node && node.name && SchemableIdentifierNode.is(node.name)) {\n this.#collectSchemableId(node.name, schemableIds);\n }\n if ('from' in node && node.from) {\n for (const from of node.from.froms) {\n this.#collectSchemableIdsFromTableExpr(from, schemableIds);\n }\n }\n if ('into' in node && node.into) {\n this.#collectSchemableIdsFromTableExpr(node.into, schemableIds);\n }\n if ('table' in node && node.table) {\n this.#collectSchemableIdsFromTableExpr(node.table, schemableIds);\n }\n if ('joins' in node && node.joins) {\n for (const join of node.joins) {\n this.#collectSchemableIdsFromTableExpr(join.table, schemableIds);\n }\n }\n if ('using' in node && node.using) {\n if (JoinNode.is(node.using)) {\n this.#collectSchemableIdsFromTableExpr(node.using.table, schemableIds);\n }\n else {\n this.#collectSchemableIdsFromTableExpr(node.using, schemableIds);\n }\n }\n return schemableIds;\n }\n #collectCTEs(node) {\n const ctes = new Set();\n if ('with' in node && node.with) {\n this.#collectCTEIds(node.with, ctes);\n }\n return ctes;\n }\n #collectSchemableIdsFromTableExpr(node, schemableIds) {\n if (TableNode.is(node)) {\n return this.#collectSchemableId(node.table, schemableIds);\n }\n if (AliasNode.is(node) && TableNode.is(node.node)) {\n return this.#collectSchemableId(node.node.table, schemableIds);\n }\n if (ListNode.is(node)) {\n for (const table of node.items) {\n this.#collectSchemableIdsFromTableExpr(table, schemableIds);\n }\n return;\n }\n if (UsingNode.is(node)) {\n for (const table of node.tables) {\n this.#collectSchemableIdsFromTableExpr(table, schemableIds);\n }\n return;\n }\n }\n #collectSchemableId(node, schemableIds) {\n const id = node.identifier.name;\n if (!this.#schemableIds.has(id) && !this.#ctes.has(id)) {\n schemableIds.add(id);\n }\n }\n #collectCTEIds(node, ctes) {\n for (const expr of node.expressions) {\n const cteId = expr.name.table.table.identifier.name;\n if (!this.#ctes.has(cteId)) {\n ctes.add(cteId);\n }\n }\n }\n}\n","/// <reference types=\"./with-schema-plugin.d.ts\" />\nimport { WithSchemaTransformer } from './with-schema-transformer.js';\nexport class WithSchemaPlugin {\n #transformer;\n constructor(schema) {\n this.#transformer = new WithSchemaTransformer(schema);\n }\n transformQuery(args) {\n return this.#transformer.transformNode(args.node, args.queryId);\n }\n async transformResult(args) {\n return args.result;\n }\n}\n","/// <reference types=\"./matched-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const MatchedNode = freeze({\n is(node) {\n return node.kind === 'MatchedNode';\n },\n create(not, bySource = false) {\n return freeze({\n kind: 'MatchedNode',\n not,\n bySource,\n });\n },\n});\n","/// <reference types=\"./merge-parser.d.ts\" />\nimport { MatchedNode } from '../operation-node/matched-node.js';\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { WhenNode } from '../operation-node/when-node.js';\nimport { isString } from '../util/object-utils.js';\nimport { parseFilterList, parseReferentialBinaryOperation, parseValueBinaryOperationOrExpression, } from './binary-operation-parser.js';\nexport function parseMergeWhen(type, args, refRight) {\n return WhenNode.create(parseFilterList([\n MatchedNode.create(!type.isMatched, type.bySource),\n ...(args && args.length > 0\n ? [\n args.length === 3 && refRight\n ? parseReferentialBinaryOperation(args[0], args[1], args[2])\n : parseValueBinaryOperationOrExpression(args),\n ]\n : []),\n ], 'and', false));\n}\nexport function parseMergeThen(result) {\n if (isString(result)) {\n return RawNode.create([result], []);\n }\n if (isOperationNodeSource(result)) {\n return result.toOperationNode();\n }\n return result;\n}\n","/// <reference types=\"./deferred.d.ts\" />\nexport class Deferred {\n #promise;\n #resolve;\n #reject;\n constructor() {\n this.#promise = new Promise((resolve, reject) => {\n this.#reject = reject;\n this.#resolve = resolve;\n });\n }\n get promise() {\n return this.#promise;\n }\n resolve = (value) => {\n if (this.#resolve) {\n this.#resolve(value);\n }\n };\n reject = (reason) => {\n if (this.#reject) {\n this.#reject(reason);\n }\n };\n}\n","/// <reference types=\"./provide-controlled-connection.d.ts\" />\nimport { Deferred } from './deferred.js';\nimport { freeze } from './object-utils.js';\nexport async function provideControlledConnection(connectionProvider) {\n const connectionDefer = new Deferred();\n const connectionReleaseDefer = new Deferred();\n connectionProvider\n .provideConnection(async (connection) => {\n connectionDefer.resolve(connection);\n return await connectionReleaseDefer.promise;\n })\n .catch((ex) => connectionDefer.reject(ex));\n // Create composite of the connection and the release method instead of\n // modifying the connection or creating a new nesting `DatabaseConnection`.\n // This way we don't accidentally override any methods of 3rd party\n // connections and don't return wrapped connections to drivers that\n // expect a certain specific connection class.\n return freeze({\n connection: await connectionDefer.promise,\n release: connectionReleaseDefer.resolve,\n });\n}\n","/// <reference types=\"./query-executor-base.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { provideControlledConnection } from '../util/provide-controlled-connection.js';\nimport { logOnce } from '../util/log-once.js';\nconst NO_PLUGINS = freeze([]);\nexport class QueryExecutorBase {\n #plugins;\n constructor(plugins = NO_PLUGINS) {\n this.#plugins = plugins;\n }\n get plugins() {\n return this.#plugins;\n }\n transformQuery(node, queryId) {\n for (const plugin of this.#plugins) {\n const transformedNode = plugin.transformQuery({ node, queryId });\n // We need to do a runtime check here. There is no good way\n // to write types that enforce this constraint.\n if (transformedNode.kind === node.kind) {\n node = transformedNode;\n }\n else {\n throw new Error([\n `KyselyPlugin.transformQuery must return a node`,\n `of the same kind that was given to it.`,\n `The plugin was given a ${node.kind}`,\n `but it returned a ${transformedNode.kind}`,\n ].join(' '));\n }\n }\n return node;\n }\n async executeQuery(compiledQuery) {\n return await this.provideConnection(async (connection) => {\n const result = await connection.executeQuery(compiledQuery);\n if ('numUpdatedOrDeletedRows' in result) {\n logOnce('kysely:warning: outdated driver/plugin detected! `QueryResult.numUpdatedOrDeletedRows` has been replaced with `QueryResult.numAffectedRows`.');\n }\n return await this.#transformResult(result, compiledQuery.queryId);\n });\n }\n async *stream(compiledQuery, chunkSize) {\n const { connection, release } = await provideControlledConnection(this);\n try {\n for await (const result of connection.streamQuery(compiledQuery, chunkSize)) {\n yield await this.#transformResult(result, compiledQuery.queryId);\n }\n }\n finally {\n release();\n }\n }\n async #transformResult(result, queryId) {\n for (const plugin of this.#plugins) {\n result = await plugin.transformResult({ result, queryId });\n }\n return result;\n }\n}\n","/// <reference types=\"./noop-query-executor.d.ts\" />\nimport { QueryExecutorBase } from './query-executor-base.js';\n/**\n * A {@link QueryExecutor} subclass that can be used when you don't\n * have a {@link QueryCompiler}, {@link ConnectionProvider} or any\n * other needed things to actually execute queries.\n */\nexport class NoopQueryExecutor extends QueryExecutorBase {\n get adapter() {\n throw new Error('this query cannot be compiled to SQL');\n }\n compileQuery() {\n throw new Error('this query cannot be compiled to SQL');\n }\n provideConnection() {\n throw new Error('this query cannot be executed');\n }\n withConnectionProvider() {\n throw new Error('this query cannot have a connection provider');\n }\n withPlugin(plugin) {\n return new NoopQueryExecutor([...this.plugins, plugin]);\n }\n withPlugins(plugins) {\n return new NoopQueryExecutor([...this.plugins, ...plugins]);\n }\n withPluginAtFront(plugin) {\n return new NoopQueryExecutor([plugin, ...this.plugins]);\n }\n withoutPlugins() {\n return new NoopQueryExecutor([]);\n }\n}\nexport const NOOP_QUERY_EXECUTOR = new NoopQueryExecutor();\n","/// <reference types=\"./merge-result.d.ts\" />\nexport class MergeResult {\n numChangedRows;\n constructor(numChangedRows) {\n this.numChangedRows = numChangedRows;\n }\n}\n","/// <reference types=\"./merge-query-builder.d.ts\" />\nimport { InsertQueryNode } from '../operation-node/insert-query-node.js';\nimport { MergeQueryNode } from '../operation-node/merge-query-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { UpdateQueryNode } from '../operation-node/update-query-node.js';\nimport { parseInsertExpression, } from '../parser/insert-values-parser.js';\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseMergeThen, parseMergeWhen } from '../parser/merge-parser.js';\nimport { parseSelectAll, parseSelectArg, } from '../parser/select-parser.js';\nimport { parseTop } from '../parser/top-parser.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { freeze } from '../util/object-utils.js';\nimport { MergeResult } from './merge-result.js';\nimport { NoResultError, isNoResultErrorConstructor, } from './no-result-error.js';\nimport { UpdateQueryBuilder } from './update-query-builder.js';\nexport class MergeQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * This can be used to add any additional SQL to the end of the query.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db\n * .mergeInto('person')\n * .using('pet', 'pet.owner_id', 'person.id')\n * .whenMatched()\n * .thenDelete()\n * .modifyEnd(sql.raw('-- this is a comment'))\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\" using \"pet\" on \"pet\".\"owner_id\" = \"person\".\"id\" when matched then delete -- this is a comment\n * ```\n */\n modifyEnd(modifier) {\n return new MergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n });\n }\n /**\n * Changes a `merge into` query to an `merge top into` query.\n *\n * `top` clause is only supported by some dialects like MS SQL Server.\n *\n * ### Examples\n *\n * Affect 5 matched rows at most:\n *\n * ```ts\n * await db.mergeInto('person')\n * .top(5)\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenMatched()\n * .thenDelete()\n * .execute()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * merge top(5) into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when matched then\n * delete\n * ```\n *\n * Affect 50% of matched rows:\n *\n * ```ts\n * await db.mergeInto('person')\n * .top(50, 'percent')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenMatched()\n * .thenDelete()\n * .execute()\n * ```\n *\n * The generated SQL (MS SQL Server):\n *\n * ```sql\n * merge top(50) percent into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when matched then\n * delete\n * ```\n */\n top(expression, modifiers) {\n return new MergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n });\n }\n using(...args) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithUsing(this.#props.queryNode, parseJoin('Using', args)),\n });\n }\n returning(args) {\n return new MergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n returningAll(table) {\n return new MergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n output(args) {\n return new MergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n outputAll(table) {\n return new MergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n}\nexport class WheneableMergeQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * This can be used to add any additional SQL to the end of the query.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * await db\n * .mergeInto('person')\n * .using('pet', 'pet.owner_id', 'person.id')\n * .whenMatched()\n * .thenDelete()\n * .modifyEnd(sql.raw('-- this is a comment'))\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\" using \"pet\" on \"pet\".\"owner_id\" = \"person\".\"id\" when matched then delete -- this is a comment\n * ```\n */\n modifyEnd(modifier) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),\n });\n }\n /**\n * See {@link MergeQueryBuilder.top}.\n */\n top(expression, modifiers) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n });\n }\n /**\n * Adds a simple `when matched` clause to the query.\n *\n * For a `when matched` clause with an `and` condition, see {@link whenMatchedAnd}.\n *\n * For a simple `when not matched` clause, see {@link whenNotMatched}.\n *\n * For a `when not matched` clause with an `and` condition, see {@link whenNotMatchedAnd}.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db.mergeInto('person')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenMatched()\n * .thenDelete()\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when matched then\n * delete\n * ```\n */\n whenMatched() {\n return this.#whenMatched([]);\n }\n whenMatchedAnd(...args) {\n return this.#whenMatched(args);\n }\n /**\n * Adds the `when matched` clause to the query with an `and` condition. But unlike\n * {@link whenMatchedAnd}, this method accepts a column reference as the 3rd argument.\n *\n * This method is similar to {@link SelectQueryBuilder.whereRef}, so see the documentation\n * for that method for more examples.\n */\n whenMatchedAndRef(lhs, op, rhs) {\n return this.#whenMatched([lhs, op, rhs], true);\n }\n #whenMatched(args, refRight) {\n return new MatchedThenableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithWhen(this.#props.queryNode, parseMergeWhen({ isMatched: true }, args, refRight)),\n });\n }\n /**\n * Adds a simple `when not matched` clause to the query.\n *\n * For a `when not matched` clause with an `and` condition, see {@link whenNotMatchedAnd}.\n *\n * For a simple `when matched` clause, see {@link whenMatched}.\n *\n * For a `when matched` clause with an `and` condition, see {@link whenMatchedAnd}.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db.mergeInto('person')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenNotMatched()\n * .thenInsertValues({\n * first_name: 'John',\n * last_name: 'Doe',\n * })\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when not matched then\n * insert (\"first_name\", \"last_name\") values ($1, $2)\n * ```\n */\n whenNotMatched() {\n return this.#whenNotMatched([]);\n }\n whenNotMatchedAnd(...args) {\n return this.#whenNotMatched(args);\n }\n /**\n * Adds the `when not matched` clause to the query with an `and` condition. But unlike\n * {@link whenNotMatchedAnd}, this method accepts a column reference as the 3rd argument.\n *\n * Unlike {@link whenMatchedAndRef}, you cannot reference columns from the target table.\n *\n * This method is similar to {@link SelectQueryBuilder.whereRef}, so see the documentation\n * for that method for more examples.\n */\n whenNotMatchedAndRef(lhs, op, rhs) {\n return this.#whenNotMatched([lhs, op, rhs], true);\n }\n /**\n * Adds a simple `when not matched by source` clause to the query.\n *\n * Supported in MS SQL Server.\n *\n * Similar to {@link whenNotMatched}, but returns a {@link MatchedThenableMergeQueryBuilder}.\n */\n whenNotMatchedBySource() {\n return this.#whenNotMatched([], false, true);\n }\n whenNotMatchedBySourceAnd(...args) {\n return this.#whenNotMatched(args, false, true);\n }\n /**\n * Adds the `when not matched by source` clause to the query with an `and` condition.\n *\n * Similar to {@link whenNotMatchedAndRef}, but you can reference columns from\n * the target table, and not from source table and returns a {@link MatchedThenableMergeQueryBuilder}.\n */\n whenNotMatchedBySourceAndRef(lhs, op, rhs) {\n return this.#whenNotMatched([lhs, op, rhs], true, true);\n }\n returning(args) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n returningAll(table) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithReturning(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n output(args) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectArg(args)),\n });\n }\n outputAll(table) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: QueryNode.cloneWithOutput(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n #whenNotMatched(args, refRight = false, bySource = false) {\n const props = {\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithWhen(this.#props.queryNode, parseMergeWhen({ isMatched: false, bySource }, args, refRight)),\n };\n const Builder = bySource\n ? MatchedThenableMergeQueryBuilder\n : NotMatchedThenableMergeQueryBuilder;\n return new Builder(props);\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n *\n * If you want to conditionally call a method on `this`, see\n * the {@link $if} method.\n *\n * ### Examples\n *\n * The next example uses a helper function `log` to log a query:\n *\n * ```ts\n * import type { Compilable } from 'kysely'\n *\n * function log<T extends Compilable>(qb: T): T {\n * console.log(qb.compile())\n * return qb\n * }\n *\n * await db.updateTable('person')\n * .set({ first_name: 'John' })\n * .$call(log)\n * .execute()\n * ```\n */\n $call(func) {\n return func(this);\n }\n /**\n * Call `func(this)` if `condition` is true.\n *\n * This method is especially handy with optional selects. Any `returning` or `returningAll`\n * method calls add columns as optional fields to the output type when called inside\n * the `func` callback. This is because we can't know if those selections were actually\n * made before running the code.\n *\n * You can also call any other methods inside the callback.\n *\n * ### Examples\n *\n * ```ts\n * import type { PersonUpdate } from 'type-editor' // imaginary module\n *\n * async function updatePerson(id: number, updates: PersonUpdate, returnLastName: boolean) {\n * return await db\n * .updateTable('person')\n * .set(updates)\n * .where('id', '=', id)\n * .returning(['id', 'first_name'])\n * .$if(returnLastName, (qb) => qb.returning('last_name'))\n * .executeTakeFirstOrThrow()\n * }\n * ```\n *\n * Any selections added inside the `if` callback will be added as optional fields to the\n * output type since we can't know if the selections were actually made before running\n * the code. In the example above the return type of the `updatePerson` function is:\n *\n * ```ts\n * Promise<{\n * id: number\n * first_name: string\n * last_name?: string\n * }>\n * ```\n */\n $if(condition, func) {\n if (condition) {\n return func(this);\n }\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n });\n }\n toOperationNode() {\n return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n }\n compile() {\n return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n }\n /**\n * Executes the query and returns an array of rows.\n *\n * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.\n */\n async execute() {\n const compiledQuery = this.compile();\n const result = await this.#props.executor.executeQuery(compiledQuery);\n const { adapter } = this.#props.executor;\n const query = compiledQuery.query;\n if ((query.returning && adapter.supportsReturning) ||\n (query.output && adapter.supportsOutput)) {\n return result.rows;\n }\n return [new MergeResult(result.numAffectedRows)];\n }\n /**\n * Executes the query and returns the first result or undefined if\n * the query returned no result.\n */\n async executeTakeFirst() {\n const [result] = await this.execute();\n return result;\n }\n /**\n * Executes the query and returns the first result or throws if\n * the query returned no result.\n *\n * By default an instance of {@link NoResultError} is thrown, but you can\n * provide a custom error class, or callback as the only argument to throw a different\n * error.\n */\n async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n const result = await this.executeTakeFirst();\n if (result === undefined) {\n const error = isNoResultErrorConstructor(errorConstructor)\n ? new errorConstructor(this.toOperationNode())\n : errorConstructor(this.toOperationNode());\n throw error;\n }\n return result;\n }\n}\nexport class MatchedThenableMergeQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Performs the `delete` action.\n *\n * To perform the `do nothing` action, see {@link thenDoNothing}.\n *\n * To perform the `update` action, see {@link thenUpdate} or {@link thenUpdateSet}.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db.mergeInto('person')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenMatched()\n * .thenDelete()\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when matched then\n * delete\n * ```\n */\n thenDelete() {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen('delete')),\n });\n }\n /**\n * Performs the `do nothing` action.\n *\n * This is supported in PostgreSQL.\n *\n * To perform the `delete` action, see {@link thenDelete}.\n *\n * To perform the `update` action, see {@link thenUpdate} or {@link thenUpdateSet}.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db.mergeInto('person')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenMatched()\n * .thenDoNothing()\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when matched then\n * do nothing\n * ```\n */\n thenDoNothing() {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen('do nothing')),\n });\n }\n /**\n * Perform an `update` operation with a full-fledged {@link UpdateQueryBuilder}.\n * This is handy when multiple `set` invocations are needed.\n *\n * For a shorthand version of this method, see {@link thenUpdateSet}.\n *\n * To perform the `delete` action, see {@link thenDelete}.\n *\n * To perform the `do nothing` action, see {@link thenDoNothing}.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * const result = await db.mergeInto('person')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenMatched()\n * .thenUpdate((ub) => ub\n * .set(sql`metadata['has_pets']`, 'Y')\n * .set({\n * updated_at: new Date().toISOString(),\n * })\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when matched then\n * update set metadata['has_pets'] = $1, \"updated_at\" = $2\n * ```\n */\n thenUpdate(set) {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen(set(new UpdateQueryBuilder({\n queryId: this.#props.queryId,\n executor: NOOP_QUERY_EXECUTOR,\n queryNode: UpdateQueryNode.createWithoutTable(),\n })))),\n });\n }\n thenUpdateSet(...args) {\n // @ts-ignore not sure how to type this so it won't complain about set(...args).\n return this.thenUpdate((ub) => ub.set(...args));\n }\n}\nexport class NotMatchedThenableMergeQueryBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Performs the `do nothing` action.\n *\n * This is supported in PostgreSQL.\n *\n * To perform the `insert` action, see {@link thenInsertValues}.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db.mergeInto('person')\n * .using('pet', 'person.id', 'pet.owner_id')\n * .whenNotMatched()\n * .thenDoNothing()\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\" on \"person\".\"id\" = \"pet\".\"owner_id\"\n * when not matched then\n * do nothing\n * ```\n */\n thenDoNothing() {\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen('do nothing')),\n });\n }\n thenInsertValues(insert) {\n const [columns, values] = parseInsertExpression(insert);\n return new WheneableMergeQueryBuilder({\n ...this.#props,\n queryNode: MergeQueryNode.cloneWithThen(this.#props.queryNode, parseMergeThen(InsertQueryNode.cloneWith(InsertQueryNode.createWithoutInto(), {\n columns,\n values,\n }))),\n });\n }\n}\n","/// <reference types=\"./query-creator.d.ts\" />\nimport { createSelectQueryBuilder, } from './query-builder/select-query-builder.js';\nimport { InsertQueryBuilder } from './query-builder/insert-query-builder.js';\nimport { DeleteQueryBuilder } from './query-builder/delete-query-builder.js';\nimport { UpdateQueryBuilder } from './query-builder/update-query-builder.js';\nimport { DeleteQueryNode } from './operation-node/delete-query-node.js';\nimport { InsertQueryNode } from './operation-node/insert-query-node.js';\nimport { SelectQueryNode } from './operation-node/select-query-node.js';\nimport { UpdateQueryNode } from './operation-node/update-query-node.js';\nimport { parseTable, parseTableExpressionOrList, parseAliasedTable, } from './parser/table-parser.js';\nimport { parseCommonTableExpression, } from './parser/with-parser.js';\nimport { WithNode } from './operation-node/with-node.js';\nimport { createQueryId } from './util/query-id.js';\nimport { WithSchemaPlugin } from './plugin/with-schema/with-schema-plugin.js';\nimport { freeze } from './util/object-utils.js';\nimport { parseSelectArg, } from './parser/select-parser.js';\nimport { MergeQueryBuilder } from './query-builder/merge-query-builder.js';\nimport { MergeQueryNode } from './operation-node/merge-query-node.js';\nexport class QueryCreator {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Creates a `select` query builder for the given table or tables.\n *\n * The tables passed to this method are built as the query's `from` clause.\n *\n * ### Examples\n *\n * Create a select query for one table:\n *\n * ```ts\n * db.selectFrom('person').selectAll()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select * from \"person\"\n * ```\n *\n * Create a select query for one table with an alias:\n *\n * ```ts\n * const persons = await db.selectFrom('person as p')\n * .select(['p.id', 'first_name'])\n * .execute()\n *\n * console.log(persons[0].id)\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"p\".\"id\", \"first_name\" from \"person\" as \"p\"\n * ```\n *\n * Create a select query from a subquery:\n *\n * ```ts\n * const persons = await db.selectFrom(\n * (eb) => eb.selectFrom('person').select('person.id as identifier').as('p')\n * )\n * .select('p.identifier')\n * .execute()\n *\n * console.log(persons[0].identifier)\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"p\".\"identifier\",\n * from (\n * select \"person\".\"id\" as \"identifier\" from \"person\"\n * ) as p\n * ```\n *\n * Create a select query from raw sql:\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * const items = await db\n * .selectFrom(sql<{ one: number }>`(select 1 as one)`.as('q'))\n * .select('q.one')\n * .execute()\n *\n * console.log(items[0].one)\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"q\".\"one\",\n * from (\n * select 1 as one\n * ) as q\n * ```\n *\n * When you use the `sql` tag you need to also provide the result type of the\n * raw snippet / query so that Kysely can figure out what columns are\n * available for the rest of the query.\n *\n * The `selectFrom` method also accepts an array for multiple tables. All\n * the above examples can also be used in an array.\n *\n * ```ts\n * import { sql } from 'kysely'\n *\n * const items = await db.selectFrom([\n * 'person as p',\n * db.selectFrom('pet').select('pet.species').as('a'),\n * sql<{ one: number }>`(select 1 as one)`.as('q')\n * ])\n * .select(['p.id', 'a.species', 'q.one'])\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"p\".id, \"a\".\"species\", \"q\".\"one\"\n * from\n * \"person\" as \"p\",\n * (select \"pet\".\"species\" from \"pet\") as a,\n * (select 1 as one) as \"q\"\n * ```\n */\n selectFrom(from) {\n return createSelectQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: SelectQueryNode.createFrom(parseTableExpressionOrList(from), this.#props.withNode),\n });\n }\n selectNoFrom(selection) {\n return createSelectQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: SelectQueryNode.cloneWithSelections(SelectQueryNode.create(this.#props.withNode), parseSelectArg(selection)),\n });\n }\n /**\n * Creates an insert query.\n *\n * The return value of this query is an instance of {@link InsertResult}. {@link InsertResult}\n * has the {@link InsertResult.insertId | insertId} field that holds the auto incremented id of\n * the inserted row if the db returned one.\n *\n * See the {@link InsertQueryBuilder.values | values} method for more info and examples. Also see\n * the {@link ReturningInterface.returning | returning} method for a way to return columns\n * on supported databases like PostgreSQL.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n * .insertInto('person')\n * .values({\n * first_name: 'Jennifer',\n * last_name: 'Aniston'\n * })\n * .executeTakeFirst()\n *\n * console.log(result.insertId)\n * ```\n *\n * Some databases like PostgreSQL support the `returning` method:\n *\n * ```ts\n * const { id } = await db\n * .insertInto('person')\n * .values({\n * first_name: 'Jennifer',\n * last_name: 'Aniston'\n * })\n * .returning('id')\n * .executeTakeFirstOrThrow()\n * ```\n */\n insertInto(table) {\n return new InsertQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: InsertQueryNode.create(parseTable(table), this.#props.withNode),\n });\n }\n /**\n * Creates a \"replace into\" query.\n *\n * This is only supported by some dialects like MySQL or SQLite.\n *\n * Similar to MySQL's {@link InsertQueryBuilder.onDuplicateKeyUpdate} that deletes\n * and inserts values on collision instead of updating existing rows.\n *\n * An alias of SQLite's {@link InsertQueryBuilder.orReplace}.\n *\n * The return value of this query is an instance of {@link InsertResult}. {@link InsertResult}\n * has the {@link InsertResult.insertId | insertId} field that holds the auto incremented id of\n * the inserted row if the db returned one.\n *\n * See the {@link InsertQueryBuilder.values | values} method for more info and examples.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n * .replaceInto('person')\n * .values({\n * first_name: 'Jennifer',\n * last_name: 'Aniston'\n * })\n * .executeTakeFirstOrThrow()\n *\n * console.log(result.insertId)\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * replace into `person` (`first_name`, `last_name`) values (?, ?)\n * ```\n */\n replaceInto(table) {\n return new InsertQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: InsertQueryNode.create(parseTable(table), this.#props.withNode, true),\n });\n }\n /**\n * Creates a delete query.\n *\n * See the {@link DeleteQueryBuilder.where} method for examples on how to specify\n * a where clause for the delete operation.\n *\n * The return value of the query is an instance of {@link DeleteResult}.\n *\n * ### Examples\n *\n * <!-- siteExample(\"delete\", \"Single row\", 10) -->\n *\n * Delete a single row:\n *\n * ```ts\n * const result = await db\n * .deleteFrom('person')\n * .where('person.id', '=', 1)\n * .executeTakeFirst()\n *\n * console.log(result.numDeletedRows)\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * delete from \"person\" where \"person\".\"id\" = $1\n * ```\n *\n * Some databases such as MySQL support deleting from multiple tables:\n *\n * ```ts\n * const result = await db\n * .deleteFrom(['person', 'pet'])\n * .using('person')\n * .innerJoin('pet', 'pet.owner_id', 'person.id')\n * .where('person.id', '=', 1)\n * .executeTakeFirst()\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * delete from `person`, `pet`\n * using `person`\n * inner join `pet` on `pet`.`owner_id` = `person`.`id`\n * where `person`.`id` = ?\n * ```\n */\n deleteFrom(from) {\n return new DeleteQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: DeleteQueryNode.create(parseTableExpressionOrList(from), this.#props.withNode),\n });\n }\n /**\n * Creates an update query.\n *\n * See the {@link UpdateQueryBuilder.where} method for examples on how to specify\n * a where clause for the update operation.\n *\n * See the {@link UpdateQueryBuilder.set} method for examples on how to\n * specify the updates.\n *\n * The return value of the query is an {@link UpdateResult}.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n * .updateTable('person')\n * .set({ first_name: 'Jennifer' })\n * .where('person.id', '=', 1)\n * .executeTakeFirst()\n *\n * console.log(result.numUpdatedRows)\n * ```\n */\n updateTable(tables) {\n return new UpdateQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: UpdateQueryNode.create(parseTableExpressionOrList(tables), this.#props.withNode),\n });\n }\n /**\n * Creates a merge query.\n *\n * The return value of the query is a {@link MergeResult}.\n *\n * See the {@link MergeQueryBuilder.using} method for examples on how to specify\n * the other table.\n *\n * ### Examples\n *\n * <!-- siteExample(\"merge\", \"Source row existence\", 10) -->\n *\n * Update a target column based on the existence of a source row:\n *\n * ```ts\n * const result = await db\n * .mergeInto('person as target')\n * .using('pet as source', 'source.owner_id', 'target.id')\n * .whenMatchedAnd('target.has_pets', '!=', 'Y')\n * .thenUpdateSet({ has_pets: 'Y' })\n * .whenNotMatchedBySourceAnd('target.has_pets', '=', 'Y')\n * .thenUpdateSet({ has_pets: 'N' })\n * .executeTakeFirstOrThrow()\n *\n * console.log(result.numChangedRows)\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\"\n * using \"pet\"\n * on \"pet\".\"owner_id\" = \"person\".\"id\"\n * when matched and \"has_pets\" != $1\n * then update set \"has_pets\" = $2\n * when not matched by source and \"has_pets\" = $3\n * then update set \"has_pets\" = $4\n * ```\n *\n * <!-- siteExample(\"merge\", \"Temporary changes table\", 20) -->\n *\n * Merge new entries from a temporary changes table:\n *\n * ```ts\n * const result = await db\n * .mergeInto('wine as target')\n * .using(\n * 'wine_stock_change as source',\n * 'source.wine_name',\n * 'target.name',\n * )\n * .whenNotMatchedAnd('source.stock_delta', '>', 0)\n * .thenInsertValues(({ ref }) => ({\n * name: ref('source.wine_name'),\n * stock: ref('source.stock_delta'),\n * }))\n * .whenMatchedAnd(\n * (eb) => eb('target.stock', '+', eb.ref('source.stock_delta')),\n * '>',\n * 0,\n * )\n * .thenUpdateSet('stock', (eb) =>\n * eb('target.stock', '+', eb.ref('source.stock_delta')),\n * )\n * .whenMatched()\n * .thenDelete()\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"wine\" as \"target\"\n * using \"wine_stock_change\" as \"source\"\n * on \"source\".\"wine_name\" = \"target\".\"name\"\n * when not matched and \"source\".\"stock_delta\" > $1\n * then insert (\"name\", \"stock\") values (\"source\".\"wine_name\", \"source\".\"stock_delta\")\n * when matched and \"target\".\"stock\" + \"source\".\"stock_delta\" > $2\n * then update set \"stock\" = \"target\".\"stock\" + \"source\".\"stock_delta\"\n * when matched\n * then delete\n * ```\n */\n mergeInto(targetTable) {\n return new MergeQueryBuilder({\n queryId: createQueryId(),\n executor: this.#props.executor,\n queryNode: MergeQueryNode.create(parseAliasedTable(targetTable), this.#props.withNode),\n });\n }\n /**\n * Creates a `with` query (Common Table Expression).\n *\n * ### Examples\n *\n * <!-- siteExample(\"cte\", \"Simple selects\", 10) -->\n *\n * Common table expressions (CTE) are a great way to modularize complex queries.\n * Essentially they allow you to run multiple separate queries within a\n * single roundtrip to the DB.\n *\n * Since CTEs are a part of the main query, query optimizers inside DB\n * engines are able to optimize the overall query. For example, postgres\n * is able to inline the CTEs inside the using queries if it decides it's\n * faster.\n *\n * ```ts\n * const result = await db\n * // Create a CTE called `jennifers` that selects all\n * // persons named 'Jennifer'.\n * .with('jennifers', (db) => db\n * .selectFrom('person')\n * .where('first_name', '=', 'Jennifer')\n * .select(['id', 'age'])\n * )\n * // Select all rows from the `jennifers` CTE and\n * // further filter it.\n * .with('adult_jennifers', (db) => db\n * .selectFrom('jennifers')\n * .where('age', '>', 18)\n * .select(['id', 'age'])\n * )\n * // Finally select all adult jennifers that are\n * // also younger than 60.\n * .selectFrom('adult_jennifers')\n * .where('age', '<', 60)\n * .selectAll()\n * .execute()\n * ```\n *\n * <!-- siteExample(\"cte\", \"Inserts, updates and deletions\", 20) -->\n *\n * Some databases like postgres also allow you to run other queries than selects\n * in CTEs. On these databases CTEs are extremely powerful:\n *\n * ```ts\n * const result = await db\n * .with('new_person', (db) => db\n * .insertInto('person')\n * .values({\n * first_name: 'Jennifer',\n * age: 35,\n * })\n * .returning('id')\n * )\n * .with('new_pet', (db) => db\n * .insertInto('pet')\n * .values({\n * name: 'Doggo',\n * species: 'dog',\n * is_favorite: true,\n * // Use the id of the person we just inserted.\n * owner_id: db\n * .selectFrom('new_person')\n * .select('id')\n * })\n * .returning('id')\n * )\n * .selectFrom(['new_person', 'new_pet'])\n * .select([\n * 'new_person.id as person_id',\n * 'new_pet.id as pet_id'\n * ])\n * .execute()\n * ```\n *\n * The CTE name can optionally specify column names in addition to\n * a name. In that case Kysely requires the expression to retun\n * rows with the same columns.\n *\n * ```ts\n * await db\n * .with('jennifers(id, age)', (db) => db\n * .selectFrom('person')\n * .where('first_name', '=', 'Jennifer')\n * // This is ok since we return columns with the same\n * // names as specified by `jennifers(id, age)`.\n * .select(['id', 'age'])\n * )\n * .selectFrom('jennifers')\n * .selectAll()\n * .execute()\n * ```\n *\n * The first argument can also be a callback. The callback is passed\n * a `CTEBuilder` instance that can be used to configure the CTE:\n *\n * ```ts\n * await db\n * .with(\n * (cte) => cte('jennifers').materialized(),\n * (db) => db\n * .selectFrom('person')\n * .where('first_name', '=', 'Jennifer')\n * .select(['id', 'age'])\n * )\n * .selectFrom('jennifers')\n * .selectAll()\n * .execute()\n * ```\n */\n with(nameOrBuilder, expression) {\n const cte = parseCommonTableExpression(nameOrBuilder, expression);\n return new QueryCreator({\n ...this.#props,\n withNode: this.#props.withNode\n ? WithNode.cloneWithExpression(this.#props.withNode, cte)\n : WithNode.create(cte),\n });\n }\n /**\n * Creates a recursive `with` query (Common Table Expression).\n *\n * Note that recursiveness is a property of the whole `with` statement.\n * You cannot have recursive and non-recursive CTEs in a same `with` statement.\n * Therefore the recursiveness is determined by the **first** `with` or\n * `withRecusive` call you make.\n *\n * See the {@link with} method for examples and more documentation.\n */\n withRecursive(nameOrBuilder, expression) {\n const cte = parseCommonTableExpression(nameOrBuilder, expression);\n return new QueryCreator({\n ...this.#props,\n withNode: this.#props.withNode\n ? WithNode.cloneWithExpression(this.#props.withNode, cte)\n : WithNode.create(cte, { recursive: true }),\n });\n }\n /**\n * Returns a copy of this query creator instance with the given plugin installed.\n */\n withPlugin(plugin) {\n return new QueryCreator({\n ...this.#props,\n executor: this.#props.executor.withPlugin(plugin),\n });\n }\n /**\n * Returns a copy of this query creator instance without any plugins.\n */\n withoutPlugins() {\n return new QueryCreator({\n ...this.#props,\n executor: this.#props.executor.withoutPlugins(),\n });\n }\n /**\n * Sets the schema to be used for all table references that don't explicitly\n * specify a schema.\n *\n * This only affects the query created through the builder returned from\n * this method and doesn't modify the `db` instance.\n *\n * See [this recipe](https://github.com/kysely-org/kysely/blob/master/site/docs/recipes/0007-schemas.md)\n * for a more detailed explanation.\n *\n * ### Examples\n *\n * ```\n * await db\n * .withSchema('mammals')\n * .selectFrom('pet')\n * .selectAll()\n * .innerJoin('public.person', 'public.person.id', 'pet.owner_id')\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select * from \"mammals\".\"pet\"\n * inner join \"public\".\"person\"\n * on \"public\".\"person\".\"id\" = \"mammals\".\"pet\".\"owner_id\"\n * ```\n *\n * `withSchema` is smart enough to not add schema for aliases,\n * common table expressions or other places where the schema\n * doesn't belong to:\n *\n * ```\n * await db\n * .withSchema('mammals')\n * .selectFrom('pet as p')\n * .select('p.name')\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"p\".\"name\" from \"mammals\".\"pet\" as \"p\"\n * ```\n */\n withSchema(schema) {\n return new QueryCreator({\n ...this.#props,\n executor: this.#props.executor.withPluginAtFront(new WithSchemaPlugin(schema)),\n });\n }\n}\n","/// <reference types=\"./parse-utils.d.ts\" />\nimport { JoinNode } from '../operation-node/join-node.js';\nimport { OverNode } from '../operation-node/over-node.js';\nimport { SelectQueryNode } from '../operation-node/select-query-node.js';\nimport { JoinBuilder } from '../query-builder/join-builder.js';\nimport { OverBuilder } from '../query-builder/over-builder.js';\nimport { createSelectQueryBuilder as newSelectQueryBuilder, } from '../query-builder/select-query-builder.js';\nimport { QueryCreator } from '../query-creator.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { parseTableExpression, parseTableExpressionOrList, } from './table-parser.js';\nexport function createSelectQueryBuilder() {\n return newSelectQueryBuilder({\n queryId: createQueryId(),\n executor: NOOP_QUERY_EXECUTOR,\n queryNode: SelectQueryNode.createFrom(parseTableExpressionOrList([])),\n });\n}\nexport function createQueryCreator() {\n return new QueryCreator({\n executor: NOOP_QUERY_EXECUTOR,\n });\n}\nexport function createJoinBuilder(joinType, table) {\n return new JoinBuilder({\n joinNode: JoinNode.create(joinType, parseTableExpression(table)),\n });\n}\nexport function createOverBuilder() {\n return new OverBuilder({\n overNode: OverNode.create(),\n });\n}\n","/// <reference types=\"./join-parser.d.ts\" />\nimport { JoinNode } from '../operation-node/join-node.js';\nimport { parseReferentialBinaryOperation } from './binary-operation-parser.js';\nimport { createJoinBuilder } from './parse-utils.js';\nimport { parseTableExpression, } from './table-parser.js';\nexport function parseJoin(joinType, args) {\n if (args.length === 3) {\n return parseSingleOnJoin(joinType, args[0], args[1], args[2]);\n }\n else if (args.length === 2) {\n return parseCallbackJoin(joinType, args[0], args[1]);\n }\n else if (args.length === 1) {\n return parseOnlessJoin(joinType, args[0]);\n }\n else {\n throw new Error('not implemented');\n }\n}\nfunction parseCallbackJoin(joinType, from, callback) {\n return callback(createJoinBuilder(joinType, from)).toOperationNode();\n}\nfunction parseSingleOnJoin(joinType, from, lhsColumn, rhsColumn) {\n return JoinNode.createWithOn(joinType, parseTableExpression(from), parseReferentialBinaryOperation(lhsColumn, '=', rhsColumn));\n}\nfunction parseOnlessJoin(joinType, from) {\n return JoinNode.create(joinType, parseTableExpression(from));\n}\n","/// <reference types=\"./offset-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const OffsetNode = freeze({\n is(node) {\n return node.kind === 'OffsetNode';\n },\n create(offset) {\n return freeze({\n kind: 'OffsetNode',\n offset,\n });\n },\n});\n","/// <reference types=\"./group-by-item-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const GroupByItemNode = freeze({\n is(node) {\n return node.kind === 'GroupByItemNode';\n },\n create(groupBy) {\n return freeze({\n kind: 'GroupByItemNode',\n groupBy,\n });\n },\n});\n","/// <reference types=\"./group-by-parser.d.ts\" />\nimport { GroupByItemNode } from '../operation-node/group-by-item-node.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nimport { isFunction } from '../util/object-utils.js';\nimport { parseReferenceExpressionOrList, } from './reference-parser.js';\nexport function parseGroupBy(groupBy) {\n groupBy = isFunction(groupBy) ? groupBy(expressionBuilder()) : groupBy;\n return parseReferenceExpressionOrList(groupBy).map(GroupByItemNode.create);\n}\n","/// <reference types=\"./set-operation-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const SetOperationNode = freeze({\n is(node) {\n return node.kind === 'SetOperationNode';\n },\n create(operator, expression, all) {\n return freeze({\n kind: 'SetOperationNode',\n operator,\n expression,\n all,\n });\n },\n});\n","/// <reference types=\"./set-operation-parser.d.ts\" />\nimport { createExpressionBuilder, } from '../expression/expression-builder.js';\nimport { SetOperationNode, } from '../operation-node/set-operation-node.js';\nimport { isFunction, isReadonlyArray } from '../util/object-utils.js';\nimport { parseExpression } from './expression-parser.js';\nexport function parseSetOperations(operator, expression, all) {\n if (isFunction(expression)) {\n expression = expression(createExpressionBuilder());\n }\n if (!isReadonlyArray(expression)) {\n expression = [expression];\n }\n return expression.map((expr) => SetOperationNode.create(operator, parseExpression(expr), all));\n}\n","/// <reference types=\"./expression-wrapper.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { AndNode } from '../operation-node/and-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { OrNode } from '../operation-node/or-node.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nexport class ExpressionWrapper {\n #node;\n constructor(node) {\n this.#node = node;\n }\n /** @private */\n get expressionType() {\n return undefined;\n }\n as(alias) {\n return new AliasedExpressionWrapper(this, alias);\n }\n or(...args) {\n return new OrWrapper(OrNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n }\n and(...args) {\n return new AndWrapper(AndNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n }\n /**\n * Change the output type of the expression.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `ExpressionWrapper` with a new output type.\n */\n $castTo() {\n return new ExpressionWrapper(this.#node);\n }\n /**\n * Omit null from the expression's type.\n *\n * This function can be useful in cases where you know an expression can't be\n * null, but Kysely is unable to infer it.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of `this` with a new output type.\n */\n $notNull() {\n return new ExpressionWrapper(this.#node);\n }\n toOperationNode() {\n return this.#node;\n }\n}\nexport class AliasedExpressionWrapper {\n #expr;\n #alias;\n constructor(expr, alias) {\n this.#expr = expr;\n this.#alias = alias;\n }\n /** @private */\n get expression() {\n return this.#expr;\n }\n /** @private */\n get alias() {\n return this.#alias;\n }\n toOperationNode() {\n return AliasNode.create(this.#expr.toOperationNode(), isOperationNodeSource(this.#alias)\n ? this.#alias.toOperationNode()\n : IdentifierNode.create(this.#alias));\n }\n}\nexport class OrWrapper {\n #node;\n constructor(node) {\n this.#node = node;\n }\n /** @private */\n get expressionType() {\n return undefined;\n }\n as(alias) {\n return new AliasedExpressionWrapper(this, alias);\n }\n or(...args) {\n return new OrWrapper(OrNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n }\n /**\n * Change the output type of the expression.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `OrWrapper` with a new output type.\n */\n $castTo() {\n return new OrWrapper(this.#node);\n }\n toOperationNode() {\n return ParensNode.create(this.#node);\n }\n}\nexport class AndWrapper {\n #node;\n constructor(node) {\n this.#node = node;\n }\n /** @private */\n get expressionType() {\n return undefined;\n }\n as(alias) {\n return new AliasedExpressionWrapper(this, alias);\n }\n and(...args) {\n return new AndWrapper(AndNode.create(this.#node, parseValueBinaryOperationOrExpression(args)));\n }\n /**\n * Change the output type of the expression.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `AndWrapper` with a new output type.\n */\n $castTo() {\n return new AndWrapper(this.#node);\n }\n toOperationNode() {\n return ParensNode.create(this.#node);\n }\n}\n","/// <reference types=\"./fetch-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { ValueNode } from './value-node.js';\n/**\n * @internal\n */\nexport const FetchNode = freeze({\n is(node) {\n return node.kind === 'FetchNode';\n },\n create(rowCount, modifier) {\n return {\n kind: 'FetchNode',\n rowCount: ValueNode.create(rowCount),\n modifier,\n };\n },\n});\n","/// <reference types=\"./fetch-parser.d.ts\" />\nimport { FetchNode } from '../operation-node/fetch-node.js';\nimport { isBigInt, isNumber } from '../util/object-utils.js';\nexport function parseFetch(rowCount, modifier) {\n if (!isNumber(rowCount) && !isBigInt(rowCount)) {\n throw new Error(`Invalid fetch row count: ${rowCount}`);\n }\n if (!isFetchModifier(modifier)) {\n throw new Error(`Invalid fetch modifier: ${modifier}`);\n }\n return FetchNode.create(rowCount, modifier);\n}\nfunction isFetchModifier(value) {\n return value === 'only' || value === 'with ties';\n}\n","/// <reference types=\"./select-query-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { SelectModifierNode } from '../operation-node/select-modifier-node.js';\nimport { parseJoin, } from '../parser/join-parser.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { parseSelectArg, parseSelectAll, } from '../parser/select-parser.js';\nimport { parseReferenceExpressionOrList, } from '../parser/reference-parser.js';\nimport { SelectQueryNode } from '../operation-node/select-query-node.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { LimitNode } from '../operation-node/limit-node.js';\nimport { OffsetNode } from '../operation-node/offset-node.js';\nimport { asArray, freeze } from '../util/object-utils.js';\nimport { parseGroupBy } from '../parser/group-by-parser.js';\nimport { isNoResultErrorConstructor, NoResultError, } from './no-result-error.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { parseSetOperations, } from '../parser/set-operation-parser.js';\nimport { parseValueBinaryOperationOrExpression, parseReferentialBinaryOperation, } from '../parser/binary-operation-parser.js';\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { parseValueExpression, } from '../parser/value-parser.js';\nimport { parseFetch } from '../parser/fetch-parser.js';\nimport { parseTop } from '../parser/top-parser.js';\nclass SelectQueryBuilderImpl {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n get expressionType() {\n return undefined;\n }\n get isSelectQueryBuilder() {\n return true;\n }\n where(...args) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n whereRef(lhs, op, rhs) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithWhere(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n having(...args) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithHaving(this.#props.queryNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n havingRef(lhs, op, rhs) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithHaving(this.#props.queryNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n select(selection) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSelections(this.#props.queryNode, parseSelectArg(selection)),\n });\n }\n distinctOn(selection) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithDistinctOn(this.#props.queryNode, parseReferenceExpressionOrList(selection)),\n });\n }\n modifyFront(modifier) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithFrontModifier(this.#props.queryNode, SelectModifierNode.createWithExpression(modifier.toOperationNode())),\n });\n }\n modifyEnd(modifier) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.createWithExpression(modifier.toOperationNode())),\n });\n }\n distinct() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithFrontModifier(this.#props.queryNode, SelectModifierNode.create('Distinct')),\n });\n }\n forUpdate(of) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForUpdate', of ? asArray(of).map(parseTable) : undefined)),\n });\n }\n forShare(of) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForShare', of ? asArray(of).map(parseTable) : undefined)),\n });\n }\n forKeyShare(of) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForKeyShare', of ? asArray(of).map(parseTable) : undefined)),\n });\n }\n forNoKeyUpdate(of) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('ForNoKeyUpdate', of ? asArray(of).map(parseTable) : undefined)),\n });\n }\n skipLocked() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('SkipLocked')),\n });\n }\n noWait() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithEndModifier(this.#props.queryNode, SelectModifierNode.create('NoWait')),\n });\n }\n selectAll(table) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSelections(this.#props.queryNode, parseSelectAll(table)),\n });\n }\n innerJoin(...args) {\n return this.#join('InnerJoin', args);\n }\n leftJoin(...args) {\n return this.#join('LeftJoin', args);\n }\n rightJoin(...args) {\n return this.#join('RightJoin', args);\n }\n fullJoin(...args) {\n return this.#join('FullJoin', args);\n }\n crossJoin(...args) {\n return this.#join('CrossJoin', args);\n }\n innerJoinLateral(...args) {\n return this.#join('LateralInnerJoin', args);\n }\n leftJoinLateral(...args) {\n return this.#join('LateralLeftJoin', args);\n }\n crossJoinLateral(...args) {\n return this.#join('LateralCrossJoin', args);\n }\n crossApply(...args) {\n return this.#join('CrossApply', args);\n }\n outerApply(...args) {\n return this.#join('OuterApply', args);\n }\n #join(joinType, args) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithJoin(this.#props.queryNode, parseJoin(joinType, args)),\n });\n }\n orderBy(...args) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithOrderByItems(this.#props.queryNode, parseOrderBy(args)),\n });\n }\n groupBy(groupBy) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithGroupByItems(this.#props.queryNode, parseGroupBy(groupBy)),\n });\n }\n limit(limit) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithLimit(this.#props.queryNode, LimitNode.create(parseValueExpression(limit))),\n });\n }\n offset(offset) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithOffset(this.#props.queryNode, OffsetNode.create(parseValueExpression(offset))),\n });\n }\n fetch(rowCount, modifier = 'only') {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithFetch(this.#props.queryNode, parseFetch(rowCount, modifier)),\n });\n }\n top(expression, modifiers) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithTop(this.#props.queryNode, parseTop(expression, modifiers)),\n });\n }\n union(expression) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('union', expression, false)),\n });\n }\n unionAll(expression) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('union', expression, true)),\n });\n }\n intersect(expression) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('intersect', expression, false)),\n });\n }\n intersectAll(expression) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('intersect', expression, true)),\n });\n }\n except(expression) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('except', expression, false)),\n });\n }\n exceptAll(expression) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithSetOperations(this.#props.queryNode, parseSetOperations('except', expression, true)),\n });\n }\n as(alias) {\n return new AliasedSelectQueryBuilderImpl(this, alias);\n }\n clearSelect() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithoutSelections(this.#props.queryNode),\n });\n }\n clearWhere() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutWhere(this.#props.queryNode),\n });\n }\n clearLimit() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithoutLimit(this.#props.queryNode),\n });\n }\n clearOffset() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithoutOffset(this.#props.queryNode),\n });\n }\n clearOrderBy() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithoutOrderBy(this.#props.queryNode),\n });\n }\n clearGroupBy() {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: SelectQueryNode.cloneWithoutGroupBy(this.#props.queryNode),\n });\n }\n $call(func) {\n return func(this);\n }\n $if(condition, func) {\n if (condition) {\n return func(this);\n }\n return new SelectQueryBuilderImpl({\n ...this.#props,\n });\n }\n $castTo() {\n return new SelectQueryBuilderImpl(this.#props);\n }\n $narrowType() {\n return new SelectQueryBuilderImpl(this.#props);\n }\n $assertType() {\n return new SelectQueryBuilderImpl(this.#props);\n }\n $asTuple() {\n return new ExpressionWrapper(this.toOperationNode());\n }\n $asScalar() {\n return new ExpressionWrapper(this.toOperationNode());\n }\n withPlugin(plugin) {\n return new SelectQueryBuilderImpl({\n ...this.#props,\n executor: this.#props.executor.withPlugin(plugin),\n });\n }\n toOperationNode() {\n return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);\n }\n compile() {\n return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);\n }\n async execute() {\n const compiledQuery = this.compile();\n const result = await this.#props.executor.executeQuery(compiledQuery);\n return result.rows;\n }\n async executeTakeFirst() {\n const [result] = await this.execute();\n return result;\n }\n async executeTakeFirstOrThrow(errorConstructor = NoResultError) {\n const result = await this.executeTakeFirst();\n if (result === undefined) {\n const error = isNoResultErrorConstructor(errorConstructor)\n ? new errorConstructor(this.toOperationNode())\n : errorConstructor(this.toOperationNode());\n throw error;\n }\n return result;\n }\n async *stream(chunkSize = 100) {\n const compiledQuery = this.compile();\n const stream = this.#props.executor.stream(compiledQuery, chunkSize);\n for await (const item of stream) {\n yield* item.rows;\n }\n }\n async explain(format, options) {\n const builder = new SelectQueryBuilderImpl({\n ...this.#props,\n queryNode: QueryNode.cloneWithExplain(this.#props.queryNode, format, options),\n });\n return await builder.execute();\n }\n}\nexport function createSelectQueryBuilder(props) {\n return new SelectQueryBuilderImpl(props);\n}\n/**\n * {@link SelectQueryBuilder} with an alias. The result of calling {@link SelectQueryBuilder.as}.\n */\nclass AliasedSelectQueryBuilderImpl {\n #queryBuilder;\n #alias;\n constructor(queryBuilder, alias) {\n this.#queryBuilder = queryBuilder;\n this.#alias = alias;\n }\n get expression() {\n return this.#queryBuilder;\n }\n get alias() {\n return this.#alias;\n }\n get isAliasedSelectQueryBuilder() {\n return true;\n }\n toOperationNode() {\n return AliasNode.create(this.#queryBuilder.toOperationNode(), IdentifierNode.create(this.#alias));\n }\n}\n","/// <reference types=\"./aggregate-function-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhereNode } from './where-node.js';\nimport { OrderByNode } from './order-by-node.js';\n/**\n * @internal\n */\nexport const AggregateFunctionNode = freeze({\n is(node) {\n return node.kind === 'AggregateFunctionNode';\n },\n create(aggregateFunction, aggregated = []) {\n return freeze({\n kind: 'AggregateFunctionNode',\n func: aggregateFunction,\n aggregated,\n });\n },\n cloneWithDistinct(aggregateFunctionNode) {\n return freeze({\n ...aggregateFunctionNode,\n distinct: true,\n });\n },\n cloneWithOrderBy(aggregateFunctionNode, orderItems, withinGroup = false) {\n const prop = withinGroup ? 'withinGroup' : 'orderBy';\n return freeze({\n ...aggregateFunctionNode,\n [prop]: aggregateFunctionNode[prop]\n ? OrderByNode.cloneWithItems(aggregateFunctionNode[prop], orderItems)\n : OrderByNode.create(orderItems),\n });\n },\n cloneWithFilter(aggregateFunctionNode, filter) {\n return freeze({\n ...aggregateFunctionNode,\n filter: aggregateFunctionNode.filter\n ? WhereNode.cloneWithOperation(aggregateFunctionNode.filter, 'And', filter)\n : WhereNode.create(filter),\n });\n },\n cloneWithOrFilter(aggregateFunctionNode, filter) {\n return freeze({\n ...aggregateFunctionNode,\n filter: aggregateFunctionNode.filter\n ? WhereNode.cloneWithOperation(aggregateFunctionNode.filter, 'Or', filter)\n : WhereNode.create(filter),\n });\n },\n cloneWithOver(aggregateFunctionNode, over) {\n return freeze({\n ...aggregateFunctionNode,\n over,\n });\n },\n});\n","/// <reference types=\"./function-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const FunctionNode = freeze({\n is(node) {\n return node.kind === 'FunctionNode';\n },\n create(func, args) {\n return freeze({\n kind: 'FunctionNode',\n func,\n arguments: args,\n });\n },\n});\n","/// <reference types=\"./aggregate-function-builder.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { AggregateFunctionNode } from '../operation-node/aggregate-function-node.js';\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { createOverBuilder } from '../parser/parse-utils.js';\nimport { parseReferentialBinaryOperation, parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { parseOrderBy, } from '../parser/order-by-parser.js';\nimport { QueryNode } from '../operation-node/query-node.js';\nexport class AggregateFunctionBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /** @private */\n get expressionType() {\n return undefined;\n }\n /**\n * Returns an aliased version of the function.\n *\n * In addition to slapping `as \"the_alias\"` to the end of the SQL,\n * this method also provides strict typing:\n *\n * ```ts\n * const result = await db\n * .selectFrom('person')\n * .select(\n * (eb) => eb.fn.count<number>('id').as('person_count')\n * )\n * .executeTakeFirstOrThrow()\n *\n * // `person_count: number` field exists in the result type.\n * console.log(result.person_count)\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select count(\"id\") as \"person_count\"\n * from \"person\"\n * ```\n */\n as(alias) {\n return new AliasedAggregateFunctionBuilder(this, alias);\n }\n /**\n * Adds a `distinct` clause inside the function.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n * .selectFrom('person')\n * .select((eb) =>\n * eb.fn.count<number>('first_name').distinct().as('first_name_count')\n * )\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select count(distinct \"first_name\") as \"first_name_count\"\n * from \"person\"\n * ```\n */\n distinct() {\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: AggregateFunctionNode.cloneWithDistinct(this.#props.aggregateFunctionNode),\n });\n }\n orderBy(...args) {\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: QueryNode.cloneWithOrderByItems(this.#props.aggregateFunctionNode, parseOrderBy(args)),\n });\n }\n clearOrderBy() {\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: QueryNode.cloneWithoutOrderBy(this.#props.aggregateFunctionNode),\n });\n }\n withinGroupOrderBy(...args) {\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: AggregateFunctionNode.cloneWithOrderBy(this.#props.aggregateFunctionNode, parseOrderBy(args), true),\n });\n }\n filterWhere(...args) {\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: AggregateFunctionNode.cloneWithFilter(this.#props.aggregateFunctionNode, parseValueBinaryOperationOrExpression(args)),\n });\n }\n /**\n * Adds a `filter` clause with a nested `where` clause after the function, where\n * both sides of the operator are references to columns.\n *\n * Similar to {@link WhereInterface}'s `whereRef` method.\n *\n * ### Examples\n *\n * Count people with same first and last names versus general public:\n *\n * ```ts\n * const result = await db\n * .selectFrom('person')\n * .select((eb) => [\n * eb.fn\n * .count<number>('id')\n * .filterWhereRef('first_name', '=', 'last_name')\n * .as('repeat_name_count'),\n * eb.fn.count<number>('id').as('total_count'),\n * ])\n * .executeTakeFirstOrThrow()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select\n * count(\"id\") filter(where \"first_name\" = \"last_name\") as \"repeat_name_count\",\n * count(\"id\") as \"total_count\"\n * from \"person\"\n * ```\n */\n filterWhereRef(lhs, op, rhs) {\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: AggregateFunctionNode.cloneWithFilter(this.#props.aggregateFunctionNode, parseReferentialBinaryOperation(lhs, op, rhs)),\n });\n }\n /**\n * Adds an `over` clause (window functions) after the function.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n * .selectFrom('person')\n * .select(\n * (eb) => eb.fn.avg<number>('age').over().as('average_age')\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select avg(\"age\") over() as \"average_age\"\n * from \"person\"\n * ```\n *\n * Also supports passing a callback that returns an over builder,\n * allowing to add partition by and sort by clauses inside over.\n *\n * ```ts\n * const result = await db\n * .selectFrom('person')\n * .select(\n * (eb) => eb.fn.avg<number>('age').over(\n * ob => ob.partitionBy('last_name').orderBy('first_name', 'asc')\n * ).as('average_age')\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select avg(\"age\") over(partition by \"last_name\" order by \"first_name\" asc) as \"average_age\"\n * from \"person\"\n * ```\n */\n over(over) {\n const builder = createOverBuilder();\n return new AggregateFunctionBuilder({\n ...this.#props,\n aggregateFunctionNode: AggregateFunctionNode.cloneWithOver(this.#props.aggregateFunctionNode, (over ? over(builder) : builder).toOperationNode()),\n });\n }\n /**\n * Simply calls the provided function passing `this` as the only argument. `$call` returns\n * what the provided function returns.\n */\n $call(func) {\n return func(this);\n }\n /**\n * Casts the expression to the given type.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `AggregateFunctionBuilder` with a new output type.\n */\n $castTo() {\n return new AggregateFunctionBuilder(this.#props);\n }\n /**\n * Omit null from the expression's type.\n *\n * This function can be useful in cases where you know an expression can't be\n * null, but Kysely is unable to infer it.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of `this` with a new output type.\n */\n $notNull() {\n return new AggregateFunctionBuilder(this.#props);\n }\n toOperationNode() {\n return this.#props.aggregateFunctionNode;\n }\n}\n/**\n * {@link AggregateFunctionBuilder} with an alias. The result of calling {@link AggregateFunctionBuilder.as}.\n */\nexport class AliasedAggregateFunctionBuilder {\n #aggregateFunctionBuilder;\n #alias;\n constructor(aggregateFunctionBuilder, alias) {\n this.#aggregateFunctionBuilder = aggregateFunctionBuilder;\n this.#alias = alias;\n }\n /** @private */\n get expression() {\n return this.#aggregateFunctionBuilder;\n }\n /** @private */\n get alias() {\n return this.#alias;\n }\n toOperationNode() {\n return AliasNode.create(this.#aggregateFunctionBuilder.toOperationNode(), IdentifierNode.create(this.#alias));\n }\n}\n","/// <reference types=\"./function-module.d.ts\" />\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { AggregateFunctionNode } from '../operation-node/aggregate-function-node.js';\nimport { FunctionNode } from '../operation-node/function-node.js';\nimport { parseReferenceExpressionOrList, } from '../parser/reference-parser.js';\nimport { parseSelectAll } from '../parser/select-parser.js';\nimport { AggregateFunctionBuilder } from './aggregate-function-builder.js';\nimport { isString } from '../util/object-utils.js';\nimport { parseTable } from '../parser/table-parser.js';\nexport function createFunctionModule() {\n const fn = (name, args) => {\n return new ExpressionWrapper(FunctionNode.create(name, parseReferenceExpressionOrList(args ?? [])));\n };\n const agg = (name, args) => {\n return new AggregateFunctionBuilder({\n aggregateFunctionNode: AggregateFunctionNode.create(name, args ? parseReferenceExpressionOrList(args) : undefined),\n });\n };\n return Object.assign(fn, {\n agg,\n avg(column) {\n return agg('avg', [column]);\n },\n coalesce(...values) {\n return fn('coalesce', values);\n },\n count(column) {\n return agg('count', [column]);\n },\n countAll(table) {\n return new AggregateFunctionBuilder({\n aggregateFunctionNode: AggregateFunctionNode.create('count', parseSelectAll(table)),\n });\n },\n max(column) {\n return agg('max', [column]);\n },\n min(column) {\n return agg('min', [column]);\n },\n sum(column) {\n return agg('sum', [column]);\n },\n any(column) {\n return fn('any', [column]);\n },\n jsonAgg(table) {\n return new AggregateFunctionBuilder({\n aggregateFunctionNode: AggregateFunctionNode.create('json_agg', [\n isString(table) ? parseTable(table) : table.toOperationNode(),\n ]),\n });\n },\n toJson(table) {\n return new ExpressionWrapper(FunctionNode.create('to_json', [\n isString(table) ? parseTable(table) : table.toOperationNode(),\n ]));\n },\n });\n}\n","/// <reference types=\"./unary-operation-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const UnaryOperationNode = freeze({\n is(node) {\n return node.kind === 'UnaryOperationNode';\n },\n create(operator, operand) {\n return freeze({\n kind: 'UnaryOperationNode',\n operator,\n operand,\n });\n },\n});\n","/// <reference types=\"./unary-operation-parser.d.ts\" />\nimport { OperatorNode, } from '../operation-node/operator-node.js';\nimport { UnaryOperationNode } from '../operation-node/unary-operation-node.js';\nimport { parseReferenceExpression, } from './reference-parser.js';\nexport function parseExists(operand) {\n return parseUnaryOperation('exists', operand);\n}\nexport function parseNotExists(operand) {\n return parseUnaryOperation('not exists', operand);\n}\nexport function parseUnaryOperation(operator, operand) {\n return UnaryOperationNode.create(OperatorNode.create(operator), parseReferenceExpression(operand));\n}\n","/// <reference types=\"./case-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nimport { WhenNode } from './when-node.js';\n/**\n * @internal\n */\nexport const CaseNode = freeze({\n is(node) {\n return node.kind === 'CaseNode';\n },\n create(value) {\n return freeze({\n kind: 'CaseNode',\n value,\n });\n },\n cloneWithWhen(caseNode, when) {\n return freeze({\n ...caseNode,\n when: freeze(caseNode.when ? [...caseNode.when, when] : [when]),\n });\n },\n cloneWithThen(caseNode, then) {\n return freeze({\n ...caseNode,\n when: caseNode.when\n ? freeze([\n ...caseNode.when.slice(0, -1),\n WhenNode.cloneWithResult(caseNode.when[caseNode.when.length - 1], then),\n ])\n : undefined,\n });\n },\n cloneWith(caseNode, props) {\n return freeze({\n ...caseNode,\n ...props,\n });\n },\n});\n","/// <reference types=\"./case-builder.d.ts\" />\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { freeze } from '../util/object-utils.js';\nimport { CaseNode } from '../operation-node/case-node.js';\nimport { WhenNode } from '../operation-node/when-node.js';\nimport { parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { isSafeImmediateValue, parseSafeImmediateValue, parseValueExpression, } from '../parser/value-parser.js';\nexport class CaseBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n when(...args) {\n return new CaseThenBuilder({\n ...this.#props,\n node: CaseNode.cloneWithWhen(this.#props.node, WhenNode.create(parseValueBinaryOperationOrExpression(args))),\n });\n }\n}\nexport class CaseThenBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n then(valueExpression) {\n return new CaseWhenBuilder({\n ...this.#props,\n node: CaseNode.cloneWithThen(this.#props.node, isSafeImmediateValue(valueExpression)\n ? parseSafeImmediateValue(valueExpression)\n : parseValueExpression(valueExpression)),\n });\n }\n}\nexport class CaseWhenBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n when(...args) {\n return new CaseThenBuilder({\n ...this.#props,\n node: CaseNode.cloneWithWhen(this.#props.node, WhenNode.create(parseValueBinaryOperationOrExpression(args))),\n });\n }\n else(valueExpression) {\n return new CaseEndBuilder({\n ...this.#props,\n node: CaseNode.cloneWith(this.#props.node, {\n else: isSafeImmediateValue(valueExpression)\n ? parseSafeImmediateValue(valueExpression)\n : parseValueExpression(valueExpression),\n }),\n });\n }\n end() {\n return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: false }));\n }\n endCase() {\n return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: true }));\n }\n}\nexport class CaseEndBuilder {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n end() {\n return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: false }));\n }\n endCase() {\n return new ExpressionWrapper(CaseNode.cloneWith(this.#props.node, { isStatement: true }));\n }\n}\n","/// <reference types=\"./json-path-leg-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const JSONPathLegNode = freeze({\n is(node) {\n return node.kind === 'JSONPathLegNode';\n },\n create(type, value) {\n return freeze({\n kind: 'JSONPathLegNode',\n type,\n value,\n });\n },\n});\n","/// <reference types=\"./json-path-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { JSONOperatorChainNode } from '../operation-node/json-operator-chain-node.js';\nimport { JSONPathLegNode, } from '../operation-node/json-path-leg-node.js';\nimport { JSONPathNode } from '../operation-node/json-path-node.js';\nimport { JSONReferenceNode } from '../operation-node/json-reference-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nexport class JSONPathBuilder {\n #node;\n constructor(node) {\n this.#node = node;\n }\n /**\n * Access an element of a JSON array in a specific location.\n *\n * Since there's no guarantee an element exists in the given array location, the\n * resulting type is always nullable. If you're sure the element exists, you\n * should use {@link SelectQueryBuilder.$assertType} to narrow the type safely.\n *\n * See also {@link key} to access properties of JSON objects.\n *\n * ### Examples\n *\n * ```ts\n * await db.selectFrom('person')\n * .select(eb =>\n * eb.ref('nicknames', '->').at(0).as('primary_nickname')\n * )\n * .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"nicknames\"->0 as \"primary_nickname\" from \"person\"\n *```\n *\n * Combined with {@link key}:\n *\n * ```ts\n * db.selectFrom('person').select(eb =>\n * eb.ref('experience', '->').at(0).key('role').as('first_role')\n * )\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"experience\"->0->'role' as \"first_role\" from \"person\"\n * ```\n *\n * You can use `'last'` to access the last element of the array in MySQL:\n *\n * ```ts\n * db.selectFrom('person').select(eb =>\n * eb.ref('nicknames', '->$').at('last').as('last_nickname')\n * )\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select `nicknames`->'$[last]' as `last_nickname` from `person`\n * ```\n *\n * Or `'#-1'` in SQLite:\n *\n * ```ts\n * db.selectFrom('person').select(eb =>\n * eb.ref('nicknames', '->>$').at('#-1').as('last_nickname')\n * )\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * select \"nicknames\"->>'$[#-1]' as `last_nickname` from `person`\n * ```\n */\n at(index) {\n return this.#createBuilderWithPathLeg('ArrayLocation', index);\n }\n /**\n * Access a property of a JSON object.\n *\n * If a field is optional, the resulting type will be nullable.\n *\n * See also {@link at} to access elements of JSON arrays.\n *\n * ### Examples\n *\n * ```ts\n * db.selectFrom('person').select(eb =>\n * eb.ref('address', '->').key('city').as('city')\n * )\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"address\"->'city' as \"city\" from \"person\"\n * ```\n *\n * Going deeper:\n *\n * ```ts\n * db.selectFrom('person').select(eb =>\n * eb.ref('profile', '->$').key('website').key('url').as('website_url')\n * )\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select `profile`->'$.website.url' as `website_url` from `person`\n * ```\n *\n * Combined with {@link at}:\n *\n * ```ts\n * db.selectFrom('person').select(eb =>\n * eb.ref('profile', '->').key('addresses').at(0).key('city').as('city')\n * )\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"profile\"->'addresses'->0->'city' as \"city\" from \"person\"\n * ```\n */\n key(key) {\n return this.#createBuilderWithPathLeg('Member', key);\n }\n #createBuilderWithPathLeg(legType, value) {\n if (JSONReferenceNode.is(this.#node)) {\n return new TraversedJSONPathBuilder(JSONReferenceNode.cloneWithTraversal(this.#node, JSONPathNode.is(this.#node.traversal)\n ? JSONPathNode.cloneWithLeg(this.#node.traversal, JSONPathLegNode.create(legType, value))\n : JSONOperatorChainNode.cloneWithValue(this.#node.traversal, ValueNode.createImmediate(value))));\n }\n return new TraversedJSONPathBuilder(JSONPathNode.cloneWithLeg(this.#node, JSONPathLegNode.create(legType, value)));\n }\n}\nexport class TraversedJSONPathBuilder extends JSONPathBuilder {\n #node;\n constructor(node) {\n super(node);\n this.#node = node;\n }\n /** @private */\n get expressionType() {\n return undefined;\n }\n as(alias) {\n return new AliasedJSONPathBuilder(this, alias);\n }\n /**\n * Change the output type of the json path.\n *\n * This method call doesn't change the SQL in any way. This methods simply\n * returns a copy of this `JSONPathBuilder` with a new output type.\n */\n $castTo() {\n return new TraversedJSONPathBuilder(this.#node);\n }\n $notNull() {\n return new TraversedJSONPathBuilder(this.#node);\n }\n toOperationNode() {\n return this.#node;\n }\n}\nexport class AliasedJSONPathBuilder {\n #jsonPath;\n #alias;\n constructor(jsonPath, alias) {\n this.#jsonPath = jsonPath;\n this.#alias = alias;\n }\n /** @private */\n get expression() {\n return this.#jsonPath;\n }\n /** @private */\n get alias() {\n return this.#alias;\n }\n toOperationNode() {\n return AliasNode.create(this.#jsonPath.toOperationNode(), isOperationNodeSource(this.#alias)\n ? this.#alias.toOperationNode()\n : IdentifierNode.create(this.#alias));\n }\n}\n","/// <reference types=\"./tuple-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const TupleNode = freeze({\n is(node) {\n return node.kind === 'TupleNode';\n },\n create(values) {\n return freeze({\n kind: 'TupleNode',\n values: freeze(values),\n });\n },\n});\n","/// <reference types=\"./data-type-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\nconst SIMPLE_COLUMN_DATA_TYPES = [\n 'varchar',\n 'char',\n 'text',\n 'integer',\n 'int2',\n 'int4',\n 'int8',\n 'smallint',\n 'bigint',\n 'boolean',\n 'real',\n 'double precision',\n 'float4',\n 'float8',\n 'decimal',\n 'numeric',\n 'binary',\n 'bytea',\n 'date',\n 'datetime',\n 'time',\n 'timetz',\n 'timestamp',\n 'timestamptz',\n 'serial',\n 'bigserial',\n 'uuid',\n 'json',\n 'jsonb',\n 'blob',\n 'varbinary',\n 'int4range',\n 'int4multirange',\n 'int8range',\n 'int8multirange',\n 'numrange',\n 'nummultirange',\n 'tsrange',\n 'tsmultirange',\n 'tstzrange',\n 'tstzmultirange',\n 'daterange',\n 'datemultirange',\n];\nconst COLUMN_DATA_TYPE_REGEX = [\n /^varchar\\(\\d+\\)$/,\n /^char\\(\\d+\\)$/,\n /^decimal\\(\\d+, \\d+\\)$/,\n /^numeric\\(\\d+, \\d+\\)$/,\n /^binary\\(\\d+\\)$/,\n /^datetime\\(\\d+\\)$/,\n /^time\\(\\d+\\)$/,\n /^timetz\\(\\d+\\)$/,\n /^timestamp\\(\\d+\\)$/,\n /^timestamptz\\(\\d+\\)$/,\n /^varbinary\\(\\d+\\)$/,\n];\n/**\n * @internal\n */\nexport const DataTypeNode = freeze({\n is(node) {\n return node.kind === 'DataTypeNode';\n },\n create(dataType) {\n return freeze({\n kind: 'DataTypeNode',\n dataType,\n });\n },\n});\nexport function isColumnDataType(dataType) {\n if (SIMPLE_COLUMN_DATA_TYPES.includes(dataType)) {\n return true;\n }\n if (COLUMN_DATA_TYPE_REGEX.some((r) => r.test(dataType))) {\n return true;\n }\n return false;\n}\n","/// <reference types=\"./data-type-parser.d.ts\" />\nimport { DataTypeNode, isColumnDataType, } from '../operation-node/data-type-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nexport function parseDataTypeExpression(dataType) {\n if (isOperationNodeSource(dataType)) {\n return dataType.toOperationNode();\n }\n if (isColumnDataType(dataType)) {\n return DataTypeNode.create(dataType);\n }\n throw new Error(`invalid column data type ${JSON.stringify(dataType)}`);\n}\n","/// <reference types=\"./cast-node.d.ts\" />\nimport { freeze } from '../util/object-utils.js';\n/**\n * @internal\n */\nexport const CastNode = freeze({\n is(node) {\n return node.kind === 'CastNode';\n },\n create(expression, dataType) {\n return freeze({\n kind: 'CastNode',\n expression,\n dataType,\n });\n },\n});\n","/// <reference types=\"./expression-builder.d.ts\" />\nimport { createSelectQueryBuilder, } from '../query-builder/select-query-builder.js';\nimport { SelectQueryNode } from '../operation-node/select-query-node.js';\nimport { parseTableExpressionOrList, parseTable, } from '../parser/table-parser.js';\nimport { WithSchemaPlugin } from '../plugin/with-schema/with-schema-plugin.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { createFunctionModule, } from '../query-builder/function-module.js';\nimport { parseJSONReference, parseReferenceExpression, parseStringReference, } from '../parser/reference-parser.js';\nimport { parseFilterList, parseFilterObject, parseValueBinaryOperation, parseValueBinaryOperationOrExpression, } from '../parser/binary-operation-parser.js';\nimport { ParensNode } from '../operation-node/parens-node.js';\nimport { ExpressionWrapper } from './expression-wrapper.js';\nimport { OperatorNode, } from '../operation-node/operator-node.js';\nimport { parseUnaryOperation } from '../parser/unary-operation-parser.js';\nimport { parseSafeImmediateValue, parseValueExpression, } from '../parser/value-parser.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { CaseBuilder } from '../query-builder/case-builder.js';\nimport { CaseNode } from '../operation-node/case-node.js';\nimport { isReadonlyArray, isUndefined } from '../util/object-utils.js';\nimport { JSONPathBuilder } from '../query-builder/json-path-builder.js';\nimport { BinaryOperationNode } from '../operation-node/binary-operation-node.js';\nimport { AndNode } from '../operation-node/and-node.js';\nimport { TupleNode } from '../operation-node/tuple-node.js';\nimport { JSONPathNode } from '../operation-node/json-path-node.js';\nimport { parseDataTypeExpression, } from '../parser/data-type-parser.js';\nimport { CastNode } from '../operation-node/cast-node.js';\nexport function createExpressionBuilder(executor = NOOP_QUERY_EXECUTOR) {\n function binary(lhs, op, rhs) {\n return new ExpressionWrapper(parseValueBinaryOperation(lhs, op, rhs));\n }\n function unary(op, expr) {\n return new ExpressionWrapper(parseUnaryOperation(op, expr));\n }\n const eb = Object.assign(binary, {\n fn: undefined,\n eb: undefined,\n selectFrom(table) {\n return createSelectQueryBuilder({\n queryId: createQueryId(),\n executor,\n queryNode: SelectQueryNode.createFrom(parseTableExpressionOrList(table)),\n });\n },\n case(reference) {\n return new CaseBuilder({\n node: CaseNode.create(isUndefined(reference)\n ? undefined\n : parseReferenceExpression(reference)),\n });\n },\n ref(reference, op) {\n if (isUndefined(op)) {\n return new ExpressionWrapper(parseStringReference(reference));\n }\n return new JSONPathBuilder(parseJSONReference(reference, op));\n },\n jsonPath() {\n return new JSONPathBuilder(JSONPathNode.create());\n },\n table(table) {\n return new ExpressionWrapper(parseTable(table));\n },\n val(value) {\n return new ExpressionWrapper(parseValueExpression(value));\n },\n refTuple(...values) {\n return new ExpressionWrapper(TupleNode.create(values.map(parseReferenceExpression)));\n },\n tuple(...values) {\n return new ExpressionWrapper(TupleNode.create(values.map(parseValueExpression)));\n },\n lit(value) {\n return new ExpressionWrapper(parseSafeImmediateValue(value));\n },\n unary,\n not(expr) {\n return unary('not', expr);\n },\n exists(expr) {\n return unary('exists', expr);\n },\n neg(expr) {\n return unary('-', expr);\n },\n between(expr, start, end) {\n return new ExpressionWrapper(BinaryOperationNode.create(parseReferenceExpression(expr), OperatorNode.create('between'), AndNode.create(parseValueExpression(start), parseValueExpression(end))));\n },\n betweenSymmetric(expr, start, end) {\n return new ExpressionWrapper(BinaryOperationNode.create(parseReferenceExpression(expr), OperatorNode.create('between symmetric'), AndNode.create(parseValueExpression(start), parseValueExpression(end))));\n },\n and(exprs) {\n if (isReadonlyArray(exprs)) {\n return new ExpressionWrapper(parseFilterList(exprs, 'and'));\n }\n return new ExpressionWrapper(parseFilterObject(exprs, 'and'));\n },\n or(exprs) {\n if (isReadonlyArray(exprs)) {\n return new ExpressionWrapper(parseFilterList(exprs, 'or'));\n }\n return new ExpressionWrapper(parseFilterObject(exprs, 'or'));\n },\n parens(...args) {\n const node = parseValueBinaryOperationOrExpression(args);\n if (ParensNode.is(node)) {\n // No double wrapping.\n return new ExpressionWrapper(node);\n }\n else {\n return new ExpressionWrapper(ParensNode.create(node));\n }\n },\n cast(expr, dataType) {\n return new ExpressionWrapper(CastNode.create(parseReferenceExpression(expr), parseDataTypeExpression(dataType)));\n },\n withSchema(schema) {\n return createExpressionBuilder(executor.withPluginAtFront(new WithSchemaPlugin(schema)));\n },\n });\n eb.fn = createFunctionModule();\n eb.eb = eb;\n return eb;\n}\nexport function expressionBuilder(_) {\n return createExpressionBuilder();\n}\n","/// <reference types=\"./expression-parser.d.ts\" />\nimport { isAliasedExpression, isExpression, } from '../expression/expression.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { expressionBuilder, } from '../expression/expression-builder.js';\nimport { isFunction } from '../util/object-utils.js';\nexport function parseExpression(exp) {\n if (isOperationNodeSource(exp)) {\n return exp.toOperationNode();\n }\n else if (isFunction(exp)) {\n return exp(expressionBuilder()).toOperationNode();\n }\n throw new Error(`invalid expression: ${JSON.stringify(exp)}`);\n}\nexport function parseAliasedExpression(exp) {\n if (isOperationNodeSource(exp)) {\n return exp.toOperationNode();\n }\n else if (isFunction(exp)) {\n return exp(expressionBuilder()).toOperationNode();\n }\n throw new Error(`invalid aliased expression: ${JSON.stringify(exp)}`);\n}\nexport function isExpressionOrFactory(obj) {\n return isExpression(obj) || isAliasedExpression(obj) || isFunction(obj);\n}\n","/// <reference types=\"./dynamic-table-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource, } from '../operation-node/operation-node-source.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { isObject, isString } from '../util/object-utils.js';\nexport class DynamicTableBuilder {\n #table;\n get table() {\n return this.#table;\n }\n constructor(table) {\n this.#table = table;\n }\n as(alias) {\n return new AliasedDynamicTableBuilder(this.#table, alias);\n }\n}\nexport class AliasedDynamicTableBuilder {\n #table;\n #alias;\n get table() {\n return this.#table;\n }\n get alias() {\n return this.#alias;\n }\n constructor(table, alias) {\n this.#table = table;\n this.#alias = alias;\n }\n toOperationNode() {\n return AliasNode.create(parseTable(this.#table), IdentifierNode.create(this.#alias));\n }\n}\nexport function isAliasedDynamicTableBuilder(obj) {\n return (isObject(obj) &&\n isOperationNodeSource(obj) &&\n isString(obj.table) &&\n isString(obj.alias));\n}\n","/// <reference types=\"./table-parser.d.ts\" />\nimport { isReadonlyArray, isString } from '../util/object-utils.js';\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { TableNode } from '../operation-node/table-node.js';\nimport { parseAliasedExpression, } from './expression-parser.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isAliasedDynamicTableBuilder, } from '../dynamic/dynamic-table-builder.js';\nexport function parseTableExpressionOrList(table) {\n if (isReadonlyArray(table)) {\n return table.map((it) => parseTableExpression(it));\n }\n else {\n return [parseTableExpression(table)];\n }\n}\nexport function parseTableExpression(table) {\n if (isString(table)) {\n return parseAliasedTable(table);\n }\n else if (isAliasedDynamicTableBuilder(table)) {\n return table.toOperationNode();\n }\n else {\n return parseAliasedExpression(table);\n }\n}\nexport function parseAliasedTable(from) {\n const ALIAS_SEPARATOR = ' as ';\n if (from.includes(ALIAS_SEPARATOR)) {\n const [table, alias] = from.split(ALIAS_SEPARATOR).map(trim);\n return AliasNode.create(parseTable(table), IdentifierNode.create(alias));\n }\n else {\n return parseTable(from);\n }\n}\nexport function parseTable(from) {\n const SCHEMA_SEPARATOR = '.';\n if (from.includes(SCHEMA_SEPARATOR)) {\n const [schema, table] = from.split(SCHEMA_SEPARATOR).map(trim);\n return TableNode.createWithSchema(schema, table);\n }\n else {\n return TableNode.create(from);\n }\n}\nfunction trim(str) {\n return str.trim();\n}\n","/// <reference types=\"./raw-builder.d.ts\" />\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { freeze } from '../util/object-utils.js';\nimport { NOOP_QUERY_EXECUTOR } from '../query-executor/noop-query-executor.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nclass RawBuilderImpl {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n get expressionType() {\n return undefined;\n }\n get isRawBuilder() {\n return true;\n }\n as(alias) {\n return new AliasedRawBuilderImpl(this, alias);\n }\n $castTo() {\n return new RawBuilderImpl({ ...this.#props });\n }\n $notNull() {\n return new RawBuilderImpl(this.#props);\n }\n withPlugin(plugin) {\n return new RawBuilderImpl({\n ...this.#props,\n plugins: this.#props.plugins !== undefined\n ? freeze([...this.#props.plugins, plugin])\n : freeze([plugin]),\n });\n }\n toOperationNode() {\n return this.#toOperationNode(this.#getExecutor());\n }\n compile(executorProvider) {\n return this.#compile(this.#getExecutor(executorProvider));\n }\n async execute(executorProvider) {\n const executor = this.#getExecutor(executorProvider);\n return executor.executeQuery(this.#compile(executor));\n }\n #getExecutor(executorProvider) {\n const executor = executorProvider !== undefined\n ? executorProvider.getExecutor()\n : NOOP_QUERY_EXECUTOR;\n return this.#props.plugins !== undefined\n ? executor.withPlugins(this.#props.plugins)\n : executor;\n }\n #toOperationNode(executor) {\n return executor.transformQuery(this.#props.rawNode, this.#props.queryId);\n }\n #compile(executor) {\n return executor.compileQuery(this.#toOperationNode(executor), this.#props.queryId);\n }\n}\nexport function createRawBuilder(props) {\n return new RawBuilderImpl(props);\n}\nclass AliasedRawBuilderImpl {\n #rawBuilder;\n #alias;\n constructor(rawBuilder, alias) {\n this.#rawBuilder = rawBuilder;\n this.#alias = alias;\n }\n get expression() {\n return this.#rawBuilder;\n }\n get alias() {\n return this.#alias;\n }\n get rawBuilder() {\n return this.#rawBuilder;\n }\n toOperationNode() {\n return AliasNode.create(this.#rawBuilder.toOperationNode(), isOperationNodeSource(this.#alias)\n ? this.#alias.toOperationNode()\n : IdentifierNode.create(this.#alias));\n }\n}\n","/// <reference types=\"./sql.d.ts\" />\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { isOperationNodeSource } from '../operation-node/operation-node-source.js';\nimport { RawNode } from '../operation-node/raw-node.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nimport { parseStringReference } from '../parser/reference-parser.js';\nimport { parseTable } from '../parser/table-parser.js';\nimport { parseValueExpression } from '../parser/value-parser.js';\nimport { createQueryId } from '../util/query-id.js';\nimport { createRawBuilder } from './raw-builder.js';\nexport const sql = Object.assign((sqlFragments, ...parameters) => {\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.create(sqlFragments, parameters?.map(parseParameter) ?? []),\n });\n}, {\n ref(columnReference) {\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.createWithChild(parseStringReference(columnReference)),\n });\n },\n val(value) {\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.createWithChild(parseValueExpression(value)),\n });\n },\n value(value) {\n return this.val(value);\n },\n table(tableReference) {\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.createWithChild(parseTable(tableReference)),\n });\n },\n id(...ids) {\n const fragments = new Array(ids.length + 1).fill('.');\n fragments[0] = '';\n fragments[fragments.length - 1] = '';\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.create(fragments, ids.map(IdentifierNode.create)),\n });\n },\n lit(value) {\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.createWithChild(ValueNode.createImmediate(value)),\n });\n },\n literal(value) {\n return this.lit(value);\n },\n raw(sql) {\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.createWithSql(sql),\n });\n },\n join(array, separator = sql `, `) {\n const nodes = new Array(Math.max(2 * array.length - 1, 0));\n const sep = separator.toOperationNode();\n for (let i = 0; i < array.length; ++i) {\n nodes[2 * i] = parseParameter(array[i]);\n if (i !== array.length - 1) {\n nodes[2 * i + 1] = sep;\n }\n }\n return createRawBuilder({\n queryId: createQueryId(),\n rawNode: RawNode.createWithChildren(nodes),\n });\n },\n});\nfunction parseParameter(param) {\n if (isOperationNodeSource(param)) {\n return param.toOperationNode();\n }\n return parseValueExpression(param);\n}\n","/// <reference types=\"./noop-plugin.d.ts\" />\nexport class NoopPlugin {\n transformQuery(args) {\n return args.node;\n }\n async transformResult(args) {\n return args.result;\n }\n}\n","/// <reference types=\"./migrator.d.ts\" />\nimport { NoopPlugin } from '../plugin/noop-plugin.js';\nimport { WithSchemaPlugin } from '../plugin/with-schema/with-schema-plugin.js';\nimport { freeze, getLast, isObject } from '../util/object-utils.js';\nexport const DEFAULT_MIGRATION_TABLE = 'kysely_migration';\nexport const DEFAULT_MIGRATION_LOCK_TABLE = 'kysely_migration_lock';\nexport const DEFAULT_ALLOW_UNORDERED_MIGRATIONS = false;\nexport const MIGRATION_LOCK_ID = 'migration_lock';\nexport const NO_MIGRATIONS = freeze({ __noMigrations__: true });\n/**\n * A class for running migrations.\n *\n * ### Example\n *\n * This example uses the {@link FileMigrationProvider} that reads migrations\n * files from a single folder. You can easily implement your own\n * {@link MigrationProvider} if you want to provide migrations some\n * other way.\n *\n * ```ts\n * import { promises as fs } from 'node:fs'\n * import path from 'node:path'\n * import * as Sqlite from 'better-sqlite3'\n * import {\n * FileMigrationProvider,\n * Kysely,\n * Migrator,\n * SqliteDialect\n * } from 'kysely'\n *\n * const db = new Kysely<any>({\n * dialect: new SqliteDialect({\n * database: Sqlite(':memory:')\n * })\n * })\n *\n * const migrator = new Migrator({\n * db,\n * provider: new FileMigrationProvider({\n * fs,\n * // Path to the folder that contains all your migrations.\n * migrationFolder: 'some/path/to/migrations',\n * path,\n * })\n * })\n * ```\n */\nexport class Migrator {\n #props;\n constructor(props) {\n this.#props = freeze(props);\n }\n /**\n * Returns a {@link MigrationInfo} object for each migration.\n *\n * The returned array is sorted by migration name.\n */\n async getMigrations() {\n const tableExists = await this.#doesTableExist(this.#migrationTable);\n const executedMigrations = tableExists\n ? await this.#props.db\n .withPlugin(this.#schemaPlugin)\n .selectFrom(this.#migrationTable)\n .select(['name', 'timestamp'])\n .$narrowType()\n .execute()\n : [];\n const migrations = await this.#resolveMigrations();\n return migrations.map(({ name, ...migration }) => {\n const executed = executedMigrations.find((it) => it.name === name);\n return {\n name,\n migration,\n executedAt: executed ? new Date(executed.timestamp) : undefined,\n };\n });\n }\n /**\n * Runs all migrations that have not yet been run.\n *\n * This method returns a {@link MigrationResultSet} instance and _never_ throws.\n * {@link MigrationResultSet.error} holds the error if something went wrong.\n * {@link MigrationResultSet.results} contains information about which migrations\n * were executed and which failed. See the examples below.\n *\n * This method goes through all possible migrations provided by the provider and runs the\n * ones whose names come alphabetically after the last migration that has been run. If the\n * list of executed migrations doesn't match the beginning of the list of possible migrations\n * an error is returned.\n *\n * ### Examples\n *\n * ```ts\n * import { promises as fs } from 'node:fs'\n * import path from 'node:path'\n * import * as Sqlite from 'better-sqlite3'\n * import { FileMigrationProvider, Migrator } from 'kysely'\n *\n * const migrator = new Migrator({\n * db,\n * provider: new FileMigrationProvider({\n * fs,\n * migrationFolder: 'some/path/to/migrations',\n * path,\n * })\n * })\n *\n * const { error, results } = await migrator.migrateToLatest()\n *\n * results?.forEach((it) => {\n * if (it.status === 'Success') {\n * console.log(`migration \"${it.migrationName}\" was executed successfully`)\n * } else if (it.status === 'Error') {\n * console.error(`failed to execute migration \"${it.migrationName}\"`)\n * }\n * })\n *\n * if (error) {\n * console.error('failed to run `migrateToLatest`')\n * console.error(error)\n * }\n * ```\n */\n async migrateToLatest() {\n return this.#migrate(() => ({ direction: 'Up', step: Infinity }));\n }\n /**\n * Migrate up/down to a specific migration.\n *\n * This method returns a {@link MigrationResultSet} instance and _never_ throws.\n * {@link MigrationResultSet.error} holds the error if something went wrong.\n * {@link MigrationResultSet.results} contains information about which migrations\n * were executed and which failed.\n *\n * ### Examples\n *\n * ```ts\n * import { promises as fs } from 'node:fs'\n * import path from 'node:path'\n * import { FileMigrationProvider, Migrator } from 'kysely'\n *\n * const migrator = new Migrator({\n * db,\n * provider: new FileMigrationProvider({\n * fs,\n * // Path to the folder that contains all your migrations.\n * migrationFolder: 'some/path/to/migrations',\n * path,\n * })\n * })\n *\n * await migrator.migrateTo('some_migration')\n * ```\n *\n * If you specify the name of the first migration, this method migrates\n * down to the first migration, but doesn't run the `down` method of\n * the first migration. In case you want to migrate all the way down,\n * you can use a special constant `NO_MIGRATIONS`:\n *\n * ```ts\n * import { promises as fs } from 'node:fs'\n * import path from 'node:path'\n * import { FileMigrationProvider, Migrator, NO_MIGRATIONS } from 'kysely'\n *\n * const migrator = new Migrator({\n * db,\n * provider: new FileMigrationProvider({\n * fs,\n * // Path to the folder that contains all your migrations.\n * migrationFolder: 'some/path/to/migrations',\n * path,\n * })\n * })\n *\n * await migrator.migrateTo(NO_MIGRATIONS)\n * ```\n */\n async migrateTo(targetMigrationName) {\n return this.#migrate(({ migrations, executedMigrations, pendingMigrations, }) => {\n if (isObject(targetMigrationName) &&\n targetMigrationName.__noMigrations__ === true) {\n return { direction: 'Down', step: Infinity };\n }\n if (!migrations.find((m) => m.name === targetMigrationName)) {\n throw new Error(`migration \"${targetMigrationName}\" doesn't exist`);\n }\n const executedIndex = executedMigrations.indexOf(targetMigrationName);\n const pendingIndex = pendingMigrations.findIndex((m) => m.name === targetMigrationName);\n if (executedIndex !== -1) {\n return {\n direction: 'Down',\n step: executedMigrations.length - executedIndex - 1,\n };\n }\n else if (pendingIndex !== -1) {\n return { direction: 'Up', step: pendingIndex + 1 };\n }\n else {\n throw new Error(`migration \"${targetMigrationName}\" isn't executed or pending`);\n }\n });\n }\n /**\n * Migrate one step up.\n *\n * This method returns a {@link MigrationResultSet} instance and _never_ throws.\n * {@link MigrationResultSet.error} holds the error if something went wrong.\n * {@link MigrationResultSet.results} contains information about which migrations\n * were executed and which failed.\n *\n * ### Examples\n *\n * ```ts\n * import { promises as fs } from 'node:fs'\n * import path from 'node:path'\n * import { FileMigrationProvider, Migrator } from 'kysely'\n *\n * const migrator = new Migrator({\n * db,\n * provider: new FileMigrationProvider({\n * fs,\n * // Path to the folder that contains all your migrations.\n * migrationFolder: 'some/path/to/migrations',\n * path,\n * })\n * })\n *\n * await migrator.migrateUp()\n * ```\n */\n async migrateUp() {\n return this.#migrate(() => ({ direction: 'Up', step: 1 }));\n }\n /**\n * Migrate one step down.\n *\n * This method returns a {@link MigrationResultSet} instance and _never_ throws.\n * {@link MigrationResultSet.error} holds the error if something went wrong.\n * {@link MigrationResultSet.results} contains information about which migrations\n * were executed and which failed.\n *\n * ### Examples\n *\n * ```ts\n * import { promises as fs } from 'node:fs'\n * import path from 'node:path'\n * import { FileMigrationProvider, Migrator } from 'kysely'\n *\n * const migrator = new Migrator({\n * db,\n * provider: new FileMigrationProvider({\n * fs,\n * // Path to the folder that contains all your migrations.\n * migrationFolder: 'some/path/to/migrations',\n * path,\n * })\n * })\n *\n * await migrator.migrateDown()\n * ```\n */\n async migrateDown() {\n return this.#migrate(() => ({ direction: 'Down', step: 1 }));\n }\n async #migrate(getMigrationDirectionAndStep) {\n try {\n await this.#ensureMigrationTableSchemaExists();\n await this.#ensureMigrationTableExists();\n await this.#ensureMigrationLockTableExists();\n await this.#ensureLockRowExists();\n return await this.#runMigrations(getMigrationDirectionAndStep);\n }\n catch (error) {\n if (error instanceof MigrationResultSetError) {\n return error.resultSet;\n }\n return { error };\n }\n }\n get #migrationTableSchema() {\n return this.#props.migrationTableSchema;\n }\n get #migrationTable() {\n return this.#props.migrationTableName ?? DEFAULT_MIGRATION_TABLE;\n }\n get #migrationLockTable() {\n return this.#props.migrationLockTableName ?? DEFAULT_MIGRATION_LOCK_TABLE;\n }\n get #allowUnorderedMigrations() {\n return (this.#props.allowUnorderedMigrations ?? DEFAULT_ALLOW_UNORDERED_MIGRATIONS);\n }\n get #schemaPlugin() {\n if (this.#migrationTableSchema) {\n return new WithSchemaPlugin(this.#migrationTableSchema);\n }\n return new NoopPlugin();\n }\n async #ensureMigrationTableSchemaExists() {\n if (!this.#migrationTableSchema) {\n // Use default schema. Nothing to do.\n return;\n }\n const schemaExists = await this.#doesSchemaExist();\n if (schemaExists) {\n return;\n }\n try {\n await this.#createIfNotExists(this.#props.db.schema.createSchema(this.#migrationTableSchema));\n }\n catch (error) {\n const schemaExists = await this.#doesSchemaExist();\n // At least on PostgreSQL, `if not exists` doesn't guarantee the `create schema`\n // query doesn't throw if the schema already exits. That's why we check if\n // the schema exist here and ignore the error if it does.\n if (!schemaExists) {\n throw error;\n }\n }\n }\n async #ensureMigrationTableExists() {\n const tableExists = await this.#doesTableExist(this.#migrationTable);\n if (tableExists) {\n return;\n }\n try {\n await this.#createIfNotExists(this.#props.db.schema\n .withPlugin(this.#schemaPlugin)\n .createTable(this.#migrationTable)\n .addColumn('name', 'varchar(255)', (col) => col.notNull().primaryKey())\n // The migration run time as ISO string. This is not a real date type as we\n // can't know which data type is supported by all future dialects.\n .addColumn('timestamp', 'varchar(255)', (col) => col.notNull()));\n }\n catch (error) {\n const tableExists = await this.#doesTableExist(this.#migrationTable);\n // At least on PostgreSQL, `if not exists` doesn't guarantee the `create table`\n // query doesn't throw if the table already exits. That's why we check if\n // the table exist here and ignore the error if it does.\n if (!tableExists) {\n throw error;\n }\n }\n }\n async #ensureMigrationLockTableExists() {\n const tableExists = await this.#doesTableExist(this.#migrationLockTable);\n if (tableExists) {\n return;\n }\n try {\n await this.#createIfNotExists(this.#props.db.schema\n .withPlugin(this.#schemaPlugin)\n .createTable(this.#migrationLockTable)\n .addColumn('id', 'varchar(255)', (col) => col.notNull().primaryKey())\n .addColumn('is_locked', 'integer', (col) => col.notNull().defaultTo(0)));\n }\n catch (error) {\n const tableExists = await this.#doesTableExist(this.#migrationLockTable);\n // At least on PostgreSQL, `if not exists` doesn't guarantee the `create table`\n // query doesn't throw if the table already exits. That's why we check if\n // the table exist here and ignore the error if it does.\n if (!tableExists) {\n throw error;\n }\n }\n }\n async #ensureLockRowExists() {\n const lockRowExists = await this.#doesLockRowExists();\n if (lockRowExists) {\n return;\n }\n try {\n await this.#props.db\n .withPlugin(this.#schemaPlugin)\n .insertInto(this.#migrationLockTable)\n .values({ id: MIGRATION_LOCK_ID, is_locked: 0 })\n .execute();\n }\n catch (error) {\n const lockRowExists = await this.#doesLockRowExists();\n if (!lockRowExists) {\n throw error;\n }\n }\n }\n async #doesSchemaExist() {\n const schemas = await this.#props.db.introspection.getSchemas();\n return schemas.some((it) => it.name === this.#migrationTableSchema);\n }\n async #doesTableExist(tableName) {\n const schema = this.#migrationTableSchema;\n const tables = await this.#props.db.introspection.getTables({\n withInternalKyselyTables: true,\n });\n return tables.some((it) => it.name === tableName && (!schema || it.schema === schema));\n }\n async #doesLockRowExists() {\n const lockRow = await this.#props.db\n .withPlugin(this.#schemaPlugin)\n .selectFrom(this.#migrationLockTable)\n .where('id', '=', MIGRATION_LOCK_ID)\n .select('id')\n .executeTakeFirst();\n return !!lockRow;\n }\n async #runMigrations(getMigrationDirectionAndStep) {\n const adapter = this.#props.db.getExecutor().adapter;\n const lockOptions = freeze({\n lockTable: this.#props.migrationLockTableName ?? DEFAULT_MIGRATION_LOCK_TABLE,\n lockRowId: MIGRATION_LOCK_ID,\n lockTableSchema: this.#props.migrationTableSchema,\n });\n const run = async (db) => {\n try {\n await adapter.acquireMigrationLock(db, lockOptions);\n const state = await this.#getState(db);\n if (state.migrations.length === 0) {\n return { results: [] };\n }\n const { direction, step } = getMigrationDirectionAndStep(state);\n if (step <= 0) {\n return { results: [] };\n }\n if (direction === 'Down') {\n return await this.#migrateDown(db, state, step);\n }\n else if (direction === 'Up') {\n return await this.#migrateUp(db, state, step);\n }\n return { results: [] };\n }\n finally {\n await adapter.releaseMigrationLock(db, lockOptions);\n }\n };\n if (adapter.supportsTransactionalDdl && !this.#props.disableTransactions) {\n return this.#props.db.transaction().execute(run);\n }\n else {\n return this.#props.db.connection().execute(run);\n }\n }\n async #getState(db) {\n const migrations = await this.#resolveMigrations();\n const executedMigrations = await this.#getExecutedMigrations(db);\n this.#ensureNoMissingMigrations(migrations, executedMigrations);\n if (!this.#allowUnorderedMigrations) {\n this.#ensureMigrationsInOrder(migrations, executedMigrations);\n }\n const pendingMigrations = this.#getPendingMigrations(migrations, executedMigrations);\n return freeze({\n migrations,\n executedMigrations,\n lastMigration: getLast(executedMigrations),\n pendingMigrations,\n });\n }\n #getPendingMigrations(migrations, executedMigrations) {\n return migrations.filter((migration) => {\n return !executedMigrations.includes(migration.name);\n });\n }\n async #resolveMigrations() {\n const allMigrations = await this.#props.provider.getMigrations();\n return Object.keys(allMigrations)\n .sort()\n .map((name) => ({\n ...allMigrations[name],\n name,\n }));\n }\n async #getExecutedMigrations(db) {\n const executedMigrations = await db\n .withPlugin(this.#schemaPlugin)\n .selectFrom(this.#migrationTable)\n .select(['name', 'timestamp'])\n .$narrowType()\n .execute();\n const nameComparator = this.#props.nameComparator || ((a, b) => a.localeCompare(b));\n return (executedMigrations\n // https://github.com/kysely-org/kysely/issues/843\n .sort((a, b) => {\n if (a.timestamp === b.timestamp) {\n return nameComparator(a.name, b.name);\n }\n return (new Date(a.timestamp).getTime() - new Date(b.timestamp).getTime());\n })\n .map((it) => it.name));\n }\n #ensureNoMissingMigrations(migrations, executedMigrations) {\n // Ensure all executed migrations exist in the `migrations` list.\n for (const executed of executedMigrations) {\n if (!migrations.some((it) => it.name === executed)) {\n throw new Error(`corrupted migrations: previously executed migration ${executed} is missing`);\n }\n }\n }\n #ensureMigrationsInOrder(migrations, executedMigrations) {\n // Ensure the executed migrations are the first ones in the migration list.\n for (let i = 0; i < executedMigrations.length; ++i) {\n if (migrations[i].name !== executedMigrations[i]) {\n throw new Error(`corrupted migrations: expected previously executed migration ${executedMigrations[i]} to be at index ${i} but ${migrations[i].name} was found in its place. New migrations must always have a name that comes alphabetically after the last executed migration.`);\n }\n }\n }\n async #migrateDown(db, state, step) {\n const migrationsToRollback = state.executedMigrations\n .slice()\n .reverse()\n .slice(0, step)\n .map((name) => {\n return state.migrations.find((it) => it.name === name);\n });\n const results = migrationsToRollback.map((migration) => {\n return {\n migrationName: migration.name,\n direction: 'Down',\n status: 'NotExecuted',\n };\n });\n for (let i = 0; i < results.length; ++i) {\n const migration = migrationsToRollback[i];\n try {\n if (migration.down) {\n await migration.down(db);\n await db\n .withPlugin(this.#schemaPlugin)\n .deleteFrom(this.#migrationTable)\n .where('name', '=', migration.name)\n .execute();\n results[i] = {\n migrationName: migration.name,\n direction: 'Down',\n status: 'Success',\n };\n }\n }\n catch (error) {\n results[i] = {\n migrationName: migration.name,\n direction: 'Down',\n status: 'Error',\n };\n throw new MigrationResultSetError({\n error,\n results,\n });\n }\n }\n return { results };\n }\n async #migrateUp(db, state, step) {\n const migrationsToRun = state.pendingMigrations.slice(0, step);\n const results = migrationsToRun.map((migration) => {\n return {\n migrationName: migration.name,\n direction: 'Up',\n status: 'NotExecuted',\n };\n });\n for (let i = 0; i < results.length; i++) {\n const migration = state.pendingMigrations[i];\n try {\n await migration.up(db);\n await db\n .withPlugin(this.#schemaPlugin)\n .insertInto(this.#migrationTable)\n .values({\n name: migration.name,\n timestamp: new Date().toISOString(),\n })\n .execute();\n results[i] = {\n migrationName: migration.name,\n direction: 'Up',\n status: 'Success',\n };\n }\n catch (error) {\n results[i] = {\n migrationName: migration.name,\n direction: 'Up',\n status: 'Error',\n };\n throw new MigrationResultSetError({\n error,\n results,\n });\n }\n }\n return { results };\n }\n async #createIfNotExists(qb) {\n if (this.#props.db.getExecutor().adapter.supportsCreateIfNotExists) {\n qb = qb.ifNotExists();\n }\n await qb.execute();\n }\n}\nclass MigrationResultSetError extends Error {\n #resultSet;\n constructor(result) {\n super();\n this.#resultSet = result;\n }\n get resultSet() {\n return this.#resultSet;\n }\n}\n","export var ChannelScheme;\n(function (ChannelScheme) {\n ChannelScheme[\"CONNECT\"] = \"connect\";\n ChannelScheme[\"SWITCHBOARD\"] = \"switchboard\";\n})(ChannelScheme || (ChannelScheme = {}));\nexport var SyncOperationStatus;\n(function (SyncOperationStatus) {\n SyncOperationStatus[SyncOperationStatus[\"Unknown\"] = -1] = \"Unknown\";\n SyncOperationStatus[SyncOperationStatus[\"TransportPending\"] = 0] = \"TransportPending\";\n SyncOperationStatus[SyncOperationStatus[\"ExecutionPending\"] = 1] = \"ExecutionPending\";\n SyncOperationStatus[SyncOperationStatus[\"Applied\"] = 2] = \"Applied\";\n SyncOperationStatus[SyncOperationStatus[\"Error\"] = 3] = \"Error\";\n})(SyncOperationStatus || (SyncOperationStatus = {}));\nexport var ChannelErrorSource;\n(function (ChannelErrorSource) {\n ChannelErrorSource[\"None\"] = \"none\";\n ChannelErrorSource[\"Channel\"] = \"channel\";\n ChannelErrorSource[\"Inbox\"] = \"inbox\";\n ChannelErrorSource[\"Outbox\"] = \"outbox\";\n})(ChannelErrorSource || (ChannelErrorSource = {}));\n/**\n * Event types for sync lifecycle events.\n * These events track the sync progress of a job's operations to remotes.\n * Uses a separate namespace (20000 range) from ReactorEventTypes (10000 range).\n */\nexport const SyncEventTypes = {\n SYNC_PENDING: 20001,\n SYNC_SUCCEEDED: 20002,\n SYNC_FAILED: 20003,\n};\n//# sourceMappingURL=types.js.map","import { SyncOperationStatus } from \"./types.js\";\nexport class MailboxAggregateError extends Error {\n errors;\n constructor(errors) {\n const messages = errors.map((e) => e.message).join(\"; \");\n super(`Mailbox callback failed with ${errors.length} error(s): ${messages}`);\n this.name = \"MailboxAggregateError\";\n this.errors = errors;\n }\n}\nexport class Mailbox {\n itemsMap = new Map();\n addedCallbacks = [];\n removedCallbacks = [];\n paused = false;\n addedBuffer = [];\n removedBuffer = [];\n _ack = 0;\n _latestOrdinal = 0;\n init(ackOrdinal) {\n this._ack = this._latestOrdinal = ackOrdinal;\n }\n get items() {\n return Array.from(this.itemsMap.values());\n }\n get ackOrdinal() {\n return this._ack;\n }\n get latestOrdinal() {\n return this._latestOrdinal;\n }\n get(id) {\n return this.itemsMap.get(id);\n }\n add(...items) {\n for (const item of items) {\n this.itemsMap.set(item.id, item);\n // update latest ordinal\n for (const op of item.operations) {\n this._latestOrdinal = Math.max(this._latestOrdinal, op.context.ordinal);\n }\n // listen for updates to the syncop status\n item.on((syncOp, _, next) => {\n if (next === SyncOperationStatus.Applied) {\n for (const op of syncOp.operations) {\n this._ack = Math.max(this._ack, op.context.ordinal);\n }\n }\n });\n }\n if (this.paused) {\n this.addedBuffer.push(...items);\n return;\n }\n const callbacks = [...this.addedCallbacks];\n const errors = [];\n for (const callback of callbacks) {\n try {\n callback(items);\n }\n catch (error) {\n errors.push(error instanceof Error ? error : new Error(String(error)));\n }\n }\n if (errors.length > 0) {\n throw new MailboxAggregateError(errors);\n }\n }\n remove(...items) {\n for (const item of items) {\n this.itemsMap.delete(item.id);\n }\n if (this.paused) {\n this.removedBuffer.push(...items);\n return;\n }\n const callbacks = [...this.removedCallbacks];\n const errors = [];\n for (const callback of callbacks) {\n try {\n callback(items);\n }\n catch (error) {\n errors.push(error instanceof Error ? error : new Error(String(error)));\n }\n }\n if (errors.length > 0) {\n throw new MailboxAggregateError(errors);\n }\n }\n onAdded(callback) {\n this.addedCallbacks.push(callback);\n }\n onRemoved(callback) {\n this.removedCallbacks.push(callback);\n }\n pause() {\n this.paused = true;\n }\n resume() {\n this.paused = false;\n this.flush();\n }\n flush() {\n if (this.addedBuffer.length > 0) {\n const items = this.addedBuffer.splice(0);\n const callbacks = [...this.addedCallbacks];\n const errors = [];\n for (const callback of callbacks) {\n try {\n callback(items);\n }\n catch (error) {\n errors.push(error instanceof Error ? error : new Error(String(error)));\n }\n }\n if (errors.length > 0) {\n throw new MailboxAggregateError(errors);\n }\n }\n if (this.removedBuffer.length > 0) {\n const items = this.removedBuffer.splice(0);\n const callbacks = [...this.removedCallbacks];\n const errors = [];\n for (const callback of callbacks) {\n try {\n callback(items);\n }\n catch (error) {\n errors.push(error instanceof Error ? error : new Error(String(error)));\n }\n }\n if (errors.length > 0) {\n throw new MailboxAggregateError(errors);\n }\n }\n }\n isPaused() {\n return this.paused;\n }\n}\n//# sourceMappingURL=mailbox.js.map","import { MailboxAggregateError, } from \"./mailbox.js\";\nimport { SyncOperationStatus } from \"./types.js\";\nexport class BufferedMailbox {\n itemsMap = new Map();\n addedCallbacks = [];\n removedCallbacks = [];\n addedBuffer = [];\n removedBuffer = [];\n addedTimer = null;\n removedTimer = null;\n milliseconds;\n maxQueued;\n paused = false;\n _ack = 0;\n _latestOrdinal = 0;\n constructor(milliseconds, maxQueued) {\n this.milliseconds = milliseconds;\n this.maxQueued = maxQueued;\n }\n init(ackOrdinal) {\n this._ack = this._latestOrdinal = ackOrdinal;\n }\n get items() {\n return Array.from(this.itemsMap.values());\n }\n get ackOrdinal() {\n return this._ack;\n }\n get latestOrdinal() {\n return this._latestOrdinal;\n }\n get(id) {\n return this.itemsMap.get(id);\n }\n add(...items) {\n for (const item of items) {\n this.itemsMap.set(item.id, item);\n // update latest ordinal\n for (const op of item.operations) {\n this._latestOrdinal = Math.max(this._latestOrdinal, op.context.ordinal);\n }\n // listen for updates to the syncop status\n item.on((syncOp, _, next) => {\n if (next === SyncOperationStatus.Applied) {\n for (const op of syncOp.operations) {\n this._ack = Math.max(this._ack, op.context.ordinal);\n }\n }\n });\n }\n this.addedBuffer.push(...items);\n if (this.paused) {\n return;\n }\n if (this.addedBuffer.length >= this.maxQueued) {\n this.flushAdded();\n }\n else {\n this.scheduleAddedFlush();\n }\n }\n remove(...items) {\n for (const item of items) {\n this.itemsMap.delete(item.id);\n }\n this.removedBuffer.push(...items);\n if (this.paused) {\n return;\n }\n if (this.removedBuffer.length >= this.maxQueued) {\n this.flushRemoved();\n }\n else {\n this.scheduleRemovedFlush();\n }\n }\n onAdded(callback) {\n this.addedCallbacks.push(callback);\n }\n onRemoved(callback) {\n this.removedCallbacks.push(callback);\n }\n pause() {\n this.paused = true;\n if (this.addedTimer !== null) {\n clearTimeout(this.addedTimer);\n this.addedTimer = null;\n }\n if (this.removedTimer !== null) {\n clearTimeout(this.removedTimer);\n this.removedTimer = null;\n }\n }\n resume() {\n this.paused = false;\n if (this.addedBuffer.length > 0) {\n this.scheduleAddedFlush();\n }\n if (this.removedBuffer.length > 0) {\n this.scheduleRemovedFlush();\n }\n }\n isPaused() {\n return this.paused;\n }\n flush() {\n this.flushAdded();\n this.flushRemoved();\n }\n scheduleAddedFlush() {\n if (this.addedTimer !== null) {\n clearTimeout(this.addedTimer);\n }\n this.addedTimer = setTimeout(() => {\n this.flushAdded();\n }, this.milliseconds);\n }\n scheduleRemovedFlush() {\n if (this.removedTimer !== null) {\n clearTimeout(this.removedTimer);\n }\n this.removedTimer = setTimeout(() => {\n this.flushRemoved();\n }, this.milliseconds);\n }\n flushAdded() {\n if (this.addedTimer !== null) {\n clearTimeout(this.addedTimer);\n this.addedTimer = null;\n }\n const items = this.addedBuffer;\n this.addedBuffer = [];\n if (items.length > 0) {\n this.invokeCallbacks(this.addedCallbacks, items);\n }\n }\n flushRemoved() {\n if (this.removedTimer !== null) {\n clearTimeout(this.removedTimer);\n this.removedTimer = null;\n }\n const items = this.removedBuffer;\n this.removedBuffer = [];\n if (items.length > 0) {\n this.invokeCallbacks(this.removedCallbacks, items);\n }\n }\n invokeCallbacks(callbacks, items) {\n const callbacksCopy = [...callbacks];\n const errors = [];\n for (const callback of callbacksCopy) {\n try {\n callback(items);\n }\n catch (error) {\n errors.push(error instanceof Error ? error : new Error(String(error)));\n }\n }\n if (errors.length > 0) {\n throw new MailboxAggregateError(errors);\n }\n }\n}\n//# sourceMappingURL=buffered-mailbox.js.map","export class PollingChannelError extends Error {\n constructor(message) {\n super(message);\n this.name = \"PollingChannelError\";\n }\n}\nexport class ChannelError extends Error {\n source;\n error;\n constructor(source, error) {\n super(`ChannelError[${source}]: ${error.message}`);\n this.name = \"ChannelError\";\n this.source = source;\n this.error = error;\n }\n}\n//# sourceMappingURL=errors.js.map","import { SyncOperationStatus } from \"./types.js\";\nexport class SyncOperationAggregateError extends Error {\n errors;\n constructor(errors) {\n const messages = errors.map((e) => e.message).join(\"; \");\n super(`SyncOperation callback failed with ${errors.length} error(s): ${messages}`);\n this.name = \"SyncOperationAggregateError\";\n this.errors = errors;\n }\n}\nexport class SyncOperation {\n id;\n jobId;\n jobDependencies;\n remoteName;\n documentId;\n scopes;\n branch;\n operations;\n status;\n error;\n callbacks = [];\n constructor(id, jobId, jobDependencies, remoteName, documentId, scopes, branch, operations) {\n this.id = id;\n this.jobId = jobId;\n this.jobDependencies = jobDependencies;\n this.remoteName = remoteName;\n this.documentId = documentId;\n this.scopes = scopes;\n this.branch = branch;\n this.operations = operations;\n this.status = SyncOperationStatus.Unknown;\n }\n on(callback) {\n this.callbacks.push(callback);\n }\n started() {\n this.transition(SyncOperationStatus.TransportPending);\n }\n transported() {\n this.transition(SyncOperationStatus.ExecutionPending);\n }\n executed() {\n this.transition(SyncOperationStatus.Applied);\n }\n failed(error) {\n this.error = error;\n this.transition(SyncOperationStatus.Error);\n }\n transition(next) {\n const prev = this.status;\n if (next <= prev) {\n return;\n }\n this.status = next;\n const errors = [];\n for (const callback of this.callbacks) {\n try {\n callback(this, prev, next);\n }\n catch (error) {\n errors.push(error instanceof Error ? error : new Error(String(error)));\n }\n }\n if (errors.length > 0) {\n throw new SyncOperationAggregateError(errors);\n }\n }\n}\n//# sourceMappingURL=sync-operation.js.map","import { driveCollectionId, } from \"../cache/operation-index-types.js\";\n/**\n * Trims a mailbox using the jobIds from a batch.\n */\nexport function trimMailboxFromBatch(mailbox, batch) {\n const toRemove = [];\n // we want to guarantee:\n //\n // 1. sync ops are still in the inbox when marked as executed\n // 2. we remove syncops as a batch after they have been executed\n for (const syncOp of batch.entries) {\n for (const item of mailbox.items) {\n if (syncOp.event.jobId === item.jobId) {\n toRemove.push(item);\n break;\n }\n }\n }\n if (toRemove.length > 0) {\n for (const syncOp of toRemove) {\n syncOp.executed();\n }\n mailbox.remove(...toRemove);\n }\n}\n/**\n * Trims a mailbox using the ack ordinal.\n */\nexport function trimMailboxFromAckOrdinal(mailbox, ackOrdinal) {\n const toRemove = [];\n // we want to guarantee:\n //\n // 1. sync ops are still in the mailbox when marked as applied\n // 2. we remove syncops as a single batch\n for (const syncOp of mailbox.items) {\n let maxOrdinal = 0;\n for (const op of syncOp.operations) {\n maxOrdinal = Math.max(maxOrdinal, op.context.ordinal);\n }\n if (maxOrdinal <= ackOrdinal) {\n toRemove.push(syncOp);\n }\n }\n if (toRemove.length > 0) {\n for (const syncOp of toRemove) {\n syncOp.executed();\n }\n mailbox.remove(...toRemove);\n }\n}\n/**\n * Filters operations based on a remote's filter criteria.\n *\n * @param operations - The operations to filter\n * @param filter - The filter criteria to apply\n * @returns The filtered operations that match the criteria\n */\nexport function filterOperations(operations, filter) {\n return operations.filter((op) => {\n if (filter.branch && op.context.branch !== filter.branch) {\n return false;\n }\n if (filter.documentId.length > 0 &&\n !filter.documentId.includes(op.context.documentId)) {\n return false;\n }\n if (filter.scope.length > 0 && !filter.scope.includes(op.context.scope)) {\n return false;\n }\n return true;\n });\n}\n/**\n * Creates an idle channel health status.\n *\n * @returns A new idle channel health object\n */\nexport function createIdleHealth() {\n return {\n state: \"idle\",\n failureCount: 0,\n };\n}\n/**\n * Batches consecutive operations by documentId and scope, preserving ordering.\n *\n * For operations [a1_doc, a1_global, a2_doc, b1_global], this returns:\n * - Batch 1: [a1_doc] for doc-a, document scope\n * - Batch 2: [a1_global] for doc-a, global scope\n * - Batch 3: [a2_doc] for doc-a, document scope\n * - Batch 4: [b1_global] for doc-b, global scope\n *\n * This ensures operations are grouped for efficient processing while maintaining\n * causality across documents and scopes.\n */\n/**\n * Sorts envelopes by the timestamp of their first operation.\n * Envelopes without operations are placed at the end.\n */\nexport function sortEnvelopesByFirstOperationTimestamp(envelopes) {\n return envelopes.slice().sort((a, b) => {\n const aTimestamp = a.operations?.[0]?.operation.timestampUtcMs;\n const bTimestamp = b.operations?.[0]?.operation.timestampUtcMs;\n if (!aTimestamp && !bTimestamp)\n return 0;\n if (!aTimestamp)\n return 1;\n if (!bTimestamp)\n return -1;\n return new Date(aTimestamp).getTime() - new Date(bTimestamp).getTime();\n });\n}\nexport function batchOperationsByDocument(operations) {\n const batches = [];\n let currentDocId = null;\n let currentScope = null;\n let currentBatch = [];\n const flushBatch = () => {\n if (currentBatch.length === 0 ||\n currentDocId === null ||\n currentScope === null) {\n return;\n }\n batches.push({\n documentId: currentDocId,\n branch: currentBatch[0].context.branch,\n scope: currentScope,\n operations: currentBatch,\n });\n currentBatch = [];\n };\n for (const op of operations) {\n const docId = op.context.documentId;\n const scope = op.context.scope;\n if (docId !== currentDocId || scope !== currentScope) {\n flushBatch();\n currentDocId = docId;\n currentScope = scope;\n }\n currentBatch.push(op);\n }\n flushBatch();\n return batches;\n}\nexport function getMaxOrdinal(operations) {\n return operations.reduce((maxOrdinal, operation) => Math.max(maxOrdinal, operation.context.ordinal), 0);\n}\nexport function filterByCollectionMembership(operations, collectionId, collectionMemberships) {\n if (!collectionMemberships) {\n return [];\n }\n return operations.filter((op) => {\n const documentId = op.context.documentId;\n if (!(documentId in collectionMemberships)) {\n return false;\n }\n return collectionMemberships[documentId].includes(collectionId);\n });\n}\nexport function toOperationWithContext(entry) {\n return {\n operation: {\n id: entry.id,\n index: entry.index,\n skip: entry.skip,\n hash: entry.hash,\n timestampUtcMs: entry.timestampUtcMs,\n action: entry.action,\n },\n context: {\n documentId: entry.documentId,\n documentType: entry.documentType,\n scope: entry.scope,\n branch: entry.branch,\n ordinal: entry.ordinal ?? 0,\n },\n };\n}\nexport function mergeCollectionMemberships(events) {\n const mergedMemberships = {};\n for (const event of events) {\n if (event.collectionMemberships) {\n for (const [docId, collections] of Object.entries(event.collectionMemberships)) {\n if (!(docId in mergedMemberships)) {\n mergedMemberships[docId] = [];\n }\n for (const c of collections) {\n if (!mergedMemberships[docId].includes(c)) {\n mergedMemberships[docId].push(c);\n }\n }\n }\n }\n for (const op of event.operations) {\n const action = op.operation.action;\n if (action.type !== \"ADD_RELATIONSHIP\") {\n continue;\n }\n const input = action.input;\n if (!input?.sourceId || !input.targetId) {\n continue;\n }\n const collectionId = driveCollectionId(op.context.branch, input.sourceId);\n if (!(input.targetId in mergedMemberships)) {\n mergedMemberships[input.targetId] = [];\n }\n if (!mergedMemberships[input.targetId].includes(collectionId)) {\n mergedMemberships[input.targetId].push(collectionId);\n }\n }\n }\n return mergedMemberships;\n}\n//# sourceMappingURL=utils.js.map","const DEFAULT_CONFIG = {\n intervalMs: 2000,\n maxQueueDepth: 100,\n backpressureCheckIntervalMs: 500,\n retryBaseDelayMs: 1000,\n retryMaxDelayMs: 300000,\n};\nexport function calculateBackoffDelay(consecutiveFailures, retryBaseDelayMs, retryMaxDelayMs, random) {\n const backoff = Math.min(retryMaxDelayMs, retryBaseDelayMs * Math.pow(2, consecutiveFailures - 1));\n return backoff / 2 + random * (backoff / 2);\n}\n/**\n * Default poll timer using setTimeout.\n * Waits for delegate completion before scheduling next tick.\n * Checks queue depth and defers polling when backpressure is detected.\n */\nexport class IntervalPollTimer {\n delegate;\n timer;\n running;\n paused;\n consecutiveFailures;\n queue;\n config;\n constructor(queue, config = {}) {\n this.queue = queue;\n this.config = { ...DEFAULT_CONFIG, ...config };\n this.running = false;\n this.paused = false;\n this.consecutiveFailures = 0;\n }\n setDelegate(delegate) {\n this.delegate = delegate;\n }\n start() {\n this.running = true;\n this.consecutiveFailures = 0;\n this.tick();\n }\n stop() {\n this.running = false;\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = undefined;\n }\n }\n tick() {\n if (!this.delegate || !this.running)\n return;\n const delegate = this.delegate;\n void this.queue\n .totalSize()\n .then((size) => {\n if (!this.running)\n return;\n if (size > this.config.maxQueueDepth) {\n this.scheduleBackpressureRecheck();\n }\n else {\n void delegate()\n .then(() => {\n this.consecutiveFailures = 0;\n this.scheduleNext();\n })\n .catch(() => {\n this.consecutiveFailures++;\n this.scheduleRetry();\n });\n }\n })\n .catch(() => {\n // Fail-open: schedule next at normal interval when totalSize() throws\n this.scheduleNext();\n });\n }\n scheduleNext() {\n if (!this.running || this.paused)\n return;\n this.timer = setTimeout(() => this.tick(), this.config.intervalMs);\n }\n scheduleRetry() {\n if (!this.running || this.paused)\n return;\n const delay = calculateBackoffDelay(this.consecutiveFailures, this.config.retryBaseDelayMs, this.config.retryMaxDelayMs, Math.random());\n this.timer = setTimeout(() => this.tick(), delay);\n }\n scheduleBackpressureRecheck() {\n if (!this.running || this.paused)\n return;\n this.timer = setTimeout(() => this.tick(), this.config.backpressureCheckIntervalMs);\n }\n pause() {\n this.paused = true;\n if (this.timer) {\n clearTimeout(this.timer);\n this.timer = undefined;\n }\n }\n resume() {\n this.paused = false;\n if (this.running) {\n this.scheduleNext();\n }\n }\n triggerNow() {\n if (this.running && this.delegate) {\n this.tick();\n }\n }\n isPaused() {\n return this.paused;\n }\n isRunning() {\n return this.running;\n }\n getIntervalMs() {\n return this.config.intervalMs;\n }\n setIntervalMs(ms) {\n this.config.intervalMs = ms;\n }\n}\n//# sourceMappingURL=interval-poll-timer.js.map","import { SyncOperation } from \"../sync-operation.js\";\nimport { SyncOperationStatus } from \"../types.js\";\nimport { batchOperationsByDocument } from \"../utils.js\";\nlet syncOpCounter = 0;\n/**\n * Serializes an action for GraphQL transport, converting signature tuples to strings.\n */\nexport function serializeAction(action) {\n const signer = action.context?.signer;\n if (!signer?.signatures) {\n return action;\n }\n return {\n ...action,\n context: {\n ...action.context,\n signer: {\n ...signer,\n signatures: signer.signatures.map((sig) => Array.isArray(sig) ? sig.join(\", \") : sig),\n },\n },\n };\n}\n/**\n * Serializes a SyncEnvelope for GraphQL transport.\n *\n * Signatures are serialized as comma-separated strings since GraphQL schema\n * defines them as [String!]!. The resultingState context field is stripped\n * since it is not defined in OperationContextInput.\n */\nexport function serializeEnvelope(envelope) {\n return {\n type: envelope.type.toUpperCase(),\n channelMeta: envelope.channelMeta,\n operations: envelope.operations?.map((opWithContext) => ({\n operation: {\n index: opWithContext.operation.index,\n timestampUtcMs: opWithContext.operation.timestampUtcMs,\n hash: opWithContext.operation.hash,\n skip: opWithContext.operation.skip,\n error: opWithContext.operation.error,\n id: opWithContext.operation.id,\n action: serializeAction(opWithContext.operation.action),\n },\n context: {\n documentId: opWithContext.context.documentId,\n documentType: opWithContext.context.documentType,\n scope: opWithContext.context.scope,\n branch: opWithContext.context.branch,\n ordinal: opWithContext.context.ordinal,\n },\n })),\n cursor: envelope.cursor,\n key: envelope.key,\n dependsOn: envelope.dependsOn,\n };\n}\n/**\n * Deserializes a signature from a comma-separated string back to a tuple.\n *\n * GraphQL serializes Signature tuples as comma-separated strings for transport.\n * This function converts them back to the expected [string, string, string, string, string] format.\n */\nfunction deserializeSignature(sig) {\n if (Array.isArray(sig)) {\n return sig;\n }\n return sig.split(\", \");\n}\n/**\n * Deserializes signatures in an operation's signer context from strings back to tuples.\n *\n * When operations are transported via GraphQL, signatures are serialized as comma-separated\n * strings. This function restores them to the Signature tuple format required for verification.\n */\nfunction deserializeOperationSignatures(opWithContext) {\n const signer = opWithContext.operation.action.context?.signer;\n if (!signer?.signatures || signer.signatures.length === 0) {\n return opWithContext;\n }\n const deserializedSignatures = signer.signatures.map(deserializeSignature);\n const deserializedOperation = {\n ...opWithContext.operation,\n action: {\n ...opWithContext.operation.action,\n context: {\n ...opWithContext.operation.action.context,\n signer: {\n ...signer,\n signatures: deserializedSignatures,\n },\n },\n },\n };\n return {\n ...opWithContext,\n operation: deserializedOperation,\n };\n}\n/**\n * Converts a SyncEnvelope containing operations into a SyncOperation.\n *\n * Extracts the necessary metadata from the envelope's operations to create\n * a sync operation that can be processed by the receiving channel. Also\n * deserializes any signatures from comma-separated strings back to tuples,\n * as GraphQL transport serializes Signature tuples for compatibility.\n *\n * @param envelope - The sync envelope containing operations\n * @param remoteName - The name of the remote this sync operation is associated with\n * @returns A new SyncOperation containing the envelope's operations with deserialized signatures\n * @throws Error if envelope has no operations or operations array is empty\n */\nexport function envelopeToSyncOperation(envelope, remoteName) {\n if (!envelope.operations || envelope.operations.length === 0) {\n throw new Error(\"Cannot create SyncOperation from envelope without operations\");\n }\n const deserializedOperations = envelope.operations.map(deserializeOperationSignatures);\n const firstOp = deserializedOperations[0];\n const documentId = firstOp.context.documentId;\n const branch = firstOp.context.branch;\n const scopes = [\n ...new Set(deserializedOperations.map((op) => op.context.scope)),\n ];\n const syncOpId = `syncop-${envelope.channelMeta.id}-${Date.now()}-${syncOpCounter++}`;\n return new SyncOperation(syncOpId, envelope.key ?? \"\", (envelope.dependsOn ?? []).filter(Boolean), remoteName, documentId, scopes, branch, deserializedOperations);\n}\n/**\n * Converts a SyncEnvelope containing operations into multiple SyncOperations.\n *\n * This function batches operations by documentId, preserving cross-document ordering.\n * For operations [a1, a2, a3, b1, b2, a4], it returns:\n * - SyncOperation 1: [a1, a2, a3] for doc-a\n * - SyncOperation 2: [b1, b2] for doc-b\n * - SyncOperation 3: [a4] for doc-a\n *\n * This ensures operations are grouped for efficient processing while maintaining\n * causality across documents.\n */\nexport function envelopesToSyncOperations(envelope, remoteName) {\n if (!envelope.operations || envelope.operations.length === 0) {\n return [];\n }\n const deserializedOps = envelope.operations.map(deserializeOperationSignatures);\n const batches = batchOperationsByDocument(deserializedOps);\n return batches.map((batch) => {\n const syncOpId = `syncop-${envelope.channelMeta.id}-${Date.now()}-${syncOpCounter++}`;\n return new SyncOperation(syncOpId, envelope.key ?? \"\", (envelope.dependsOn ?? []).filter(Boolean), remoteName, batch.documentId, [batch.scope], batch.branch, batch.operations);\n });\n}\nexport const getLatestAppliedOrdinal = (syncOps) => {\n let maxOrdinal = 0;\n for (const syncOp of syncOps) {\n if (syncOp.status === SyncOperationStatus.Applied) {\n for (const op of syncOp.operations) {\n maxOrdinal = Math.max(maxOrdinal, op.context.ordinal);\n }\n }\n }\n return maxOrdinal;\n};\n//# sourceMappingURL=utils.js.map","import { BufferedMailbox } from \"../buffered-mailbox.js\";\nimport { ChannelError } from \"../errors.js\";\nimport { Mailbox } from \"../mailbox.js\";\nimport { SyncOperation } from \"../sync-operation.js\";\nimport { ChannelErrorSource } from \"../types.js\";\nimport { sortEnvelopesByFirstOperationTimestamp, trimMailboxFromAckOrdinal, } from \"../utils.js\";\nimport { calculateBackoffDelay } from \"./interval-poll-timer.js\";\nimport { envelopesToSyncOperations, getLatestAppliedOrdinal, serializeEnvelope, } from \"./utils.js\";\n/**\n * GraphQL-based synchronization channel for network communication between reactors.\n */\nexport class GqlRequestChannel {\n logger;\n inbox;\n outbox;\n deadLetter;\n config;\n bufferedOutbox;\n channelId;\n remoteName;\n cursorStorage;\n operationIndex;\n pollTimer;\n isShutdown;\n failureCount;\n lastSuccessUtcMs;\n lastFailureUtcMs;\n lastPersistedInboxOrdinal = 0;\n lastPersistedOutboxOrdinal = 0;\n pushFailureCount = 0;\n pushRetryTimer = null;\n pushBlocked = false;\n constructor(logger, channelId, remoteName, cursorStorage, config, operationIndex, pollTimer) {\n this.logger = logger;\n this.channelId = channelId;\n this.remoteName = remoteName;\n this.cursorStorage = cursorStorage;\n this.operationIndex = operationIndex;\n this.pollTimer = pollTimer;\n this.config = {\n url: config.url,\n jwtHandler: config.jwtHandler,\n fetchFn: config.fetchFn,\n collectionId: config.collectionId,\n filter: config.filter,\n retryBaseDelayMs: config.retryBaseDelayMs,\n retryMaxDelayMs: config.retryMaxDelayMs,\n };\n this.isShutdown = false;\n this.failureCount = 0;\n this.inbox = new Mailbox();\n this.bufferedOutbox = new BufferedMailbox(500, 25);\n this.outbox = this.bufferedOutbox;\n this.deadLetter = new Mailbox();\n // when a dead letter is added, stop polling and cancel any pending push retry\n this.deadLetter.onAdded(() => {\n this.pollTimer.stop();\n if (this.pushRetryTimer) {\n clearTimeout(this.pushRetryTimer);\n this.pushRetryTimer = null;\n }\n });\n // when sync ops are added to the outbox, push them to the remote\n this.outbox.onAdded((syncOps) => {\n if (this.isShutdown)\n return;\n if (this.pushBlocked)\n return; // ops stay in outbox, included in next retry\n if (this.deadLetter.items.length > 0)\n return;\n this.attemptPush(syncOps);\n });\n // Instead of listening to syncops directly for cursor updates, we listen\n // to the mailbox. This is for efficiency: many syncops may fire on a trim,\n // but only one onRemoved callback will be fired for the batch.\n this.outbox.onRemoved((syncOps) => {\n const maxOrdinal = getLatestAppliedOrdinal(syncOps);\n if (maxOrdinal > this.lastPersistedOutboxOrdinal) {\n this.lastPersistedOutboxOrdinal = maxOrdinal;\n this.cursorStorage\n .upsert({\n remoteName: this.remoteName,\n cursorType: \"outbox\",\n cursorOrdinal: maxOrdinal,\n lastSyncedAtUtcMs: Date.now(),\n })\n .catch((error) => {\n this.logger.error(\"Failed to update outbox cursor for @ChannelId! This means that future application runs may resend duplicate operations. This is recoverable (with deduplication protection), but not-optimal: @Error\", this.channelId, error);\n });\n }\n });\n this.inbox.onRemoved((syncOps) => {\n const maxOrdinal = getLatestAppliedOrdinal(syncOps);\n if (maxOrdinal > this.lastPersistedInboxOrdinal) {\n this.lastPersistedInboxOrdinal = maxOrdinal;\n this.cursorStorage\n .upsert({\n remoteName: this.remoteName,\n cursorType: \"inbox\",\n cursorOrdinal: maxOrdinal,\n lastSyncedAtUtcMs: Date.now(),\n })\n .catch((error) => {\n this.logger.error(\"Failed to update inbox cursor for @ChannelId! This is unlikely to cause a problem, but not-optimal: @Error\", this.channelId, error);\n });\n }\n });\n }\n /**\n * Shuts down the channel and prevents further operations.\n */\n shutdown() {\n this.bufferedOutbox.flush();\n this.isShutdown = true;\n this.pollTimer.stop();\n if (this.pushRetryTimer) {\n clearTimeout(this.pushRetryTimer);\n this.pushRetryTimer = null;\n }\n return Promise.resolve();\n }\n /**\n * Initializes the channel by registering it on the remote server and starting polling.\n */\n async init() {\n await this.touchRemoteChannel();\n // get cursors -- these are the last acknowledged ordinals for the inbox and outbox\n const cursors = await this.cursorStorage.list(this.remoteName);\n const inboxOrdinal = cursors.find((c) => c.cursorType === \"inbox\")?.cursorOrdinal ?? 0;\n const outboxOrdinal = cursors.find((c) => c.cursorType === \"outbox\")?.cursorOrdinal ?? 0;\n this.inbox.init(inboxOrdinal);\n this.outbox.init(outboxOrdinal);\n this.lastPersistedInboxOrdinal = inboxOrdinal;\n this.lastPersistedOutboxOrdinal = outboxOrdinal;\n this.pollTimer.setDelegate(() => this.poll());\n this.pollTimer.start();\n }\n /**\n * Polls the remote for new sync envelopes.\n */\n async poll() {\n if (this.isShutdown) {\n return;\n }\n let response;\n try {\n response = await this.pollSyncEnvelopes(this.inbox.ackOrdinal, this.inbox.latestOrdinal);\n }\n catch (error) {\n if (!this.handlePollError(error)) {\n throw error;\n }\n return;\n }\n const { envelopes, ackOrdinal, deadLetters } = response;\n // first: trim outbox\n if (ackOrdinal > 0) {\n trimMailboxFromAckOrdinal(this.outbox, ackOrdinal);\n }\n // todo: Is this necessary? Outbox items should have been sorted when returned.\n const sortedEnvelopes = sortEnvelopesByFirstOperationTimestamp(envelopes);\n // convert the envelopes to sync operations\n const allSyncOps = [];\n for (const envelope of sortedEnvelopes) {\n if (envelope.type.toLowerCase() === \"operations\" && envelope.operations) {\n const syncOps = envelopesToSyncOperations(envelope, this.remoteName);\n for (const syncOp of syncOps) {\n syncOp.transported();\n }\n allSyncOps.push(...syncOps);\n }\n }\n // add all of them to the inbox\n if (allSyncOps.length > 0) {\n this.inbox.add(...allSyncOps);\n }\n // handle dead letters from the remote\n if (deadLetters.length > 0) {\n this.handleRemoteDeadLetters(deadLetters);\n }\n this.lastSuccessUtcMs = Date.now();\n this.failureCount = 0;\n }\n /**\n * Handles dead letters reported by the remote server.\n * Creates local dead letter SyncOperations so the channel quiesces.\n */\n handleRemoteDeadLetters(deadLetters) {\n for (const dl of deadLetters) {\n this.logger.error(\"Remote dead letter on @ChannelId: document @DocumentId failed with: @Error\", this.channelId, dl.documentId, dl.error);\n }\n const syncOps = [];\n for (const dl of deadLetters) {\n const syncOp = new SyncOperation(crypto.randomUUID(), \"\", [], this.remoteName, dl.documentId, [], \"\", []);\n syncOp.failed(new ChannelError(ChannelErrorSource.Outbox, new Error(dl.error)));\n syncOps.push(syncOp);\n }\n this.deadLetter.add(...syncOps);\n }\n /**\n * Handles polling errors with exponential backoff.\n */\n handlePollError(error) {\n const err = error instanceof Error ? error : new Error(String(error));\n if (err.message.includes(\"Channel not found\")) {\n this.recoverFromChannelNotFound();\n return true;\n }\n this.failureCount++;\n this.lastFailureUtcMs = Date.now();\n const channelError = new ChannelError(ChannelErrorSource.Inbox, err);\n this.logger.error(\"GqlChannel poll error (@FailureCount): @Error\", this.failureCount, channelError);\n return false;\n }\n /**\n * Recovers from a \"Channel not found\" error by re-registering and restarting polling.\n */\n recoverFromChannelNotFound() {\n this.logger.info(\"GqlChannel @ChannelId not found on remote, re-registering...\", this.channelId);\n this.pollTimer.stop();\n void this.touchRemoteChannel()\n .then(() => {\n this.logger.info(\"GqlChannel @ChannelId re-registered successfully\", this.channelId);\n this.failureCount = 0;\n this.pollTimer.start();\n })\n .catch((recoveryError) => {\n this.logger.error(\"GqlChannel @ChannelId failed to re-register: @Error\", this.channelId, recoveryError);\n this.failureCount++;\n this.lastFailureUtcMs = Date.now();\n this.pollTimer.start();\n });\n }\n /**\n * Queries the remote GraphQL endpoint for sync envelopes.\n */\n async pollSyncEnvelopes(ackOrdinal, latestOrdinal) {\n const query = `\n query PollSyncEnvelopes($channelId: String!, $outboxAck: Int!, $outboxLatest: Int!) {\n pollSyncEnvelopes(channelId: $channelId, outboxAck: $outboxAck, outboxLatest: $outboxLatest) {\n envelopes {\n type\n channelMeta {\n id\n }\n operations {\n operation {\n index\n timestampUtcMs\n hash\n skip\n error\n id\n action {\n id\n type\n timestampUtcMs\n input\n scope\n attachments {\n data\n mimeType\n hash\n extension\n fileName\n }\n context {\n signer {\n user {\n address\n networkId\n chainId\n }\n app {\n name\n key\n }\n signatures\n }\n }\n }\n }\n context {\n documentId\n documentType\n scope\n branch\n ordinal\n }\n }\n cursor {\n remoteName\n cursorOrdinal\n lastSyncedAtUtcMs\n }\n key\n dependsOn\n }\n ackOrdinal\n deadLetters {\n documentId\n error\n }\n }\n }\n `;\n const variables = {\n channelId: this.channelId,\n outboxAck: ackOrdinal,\n outboxLatest: latestOrdinal,\n };\n const response = await this.executeGraphQL(query, variables);\n return {\n envelopes: response.pollSyncEnvelopes.envelopes,\n ackOrdinal: response.pollSyncEnvelopes.ackOrdinal,\n deadLetters: response.pollSyncEnvelopes.deadLetters ?? [],\n };\n }\n /**\n * Registers or updates this channel on the remote server via GraphQL mutation.\n */\n async touchRemoteChannel() {\n let sinceTimestampUtcMs = \"0\";\n try {\n const result = await this.operationIndex.getLatestTimestampForCollection(this.config.collectionId);\n if (result) {\n sinceTimestampUtcMs = result;\n }\n }\n catch {\n // If query fails, use default \"0\" (sends all operations)\n }\n const mutation = `\n mutation TouchChannel($input: TouchChannelInput!) {\n touchChannel(input: $input)\n }\n `;\n const variables = {\n input: {\n id: this.channelId,\n name: this.channelId,\n collectionId: this.config.collectionId,\n filter: {\n documentId: this.config.filter.documentId,\n scope: this.config.filter.scope,\n branch: this.config.filter.branch,\n },\n sinceTimestampUtcMs,\n },\n };\n await this.executeGraphQL(mutation, variables);\n }\n /**\n * Fire-and-forget push with retry on recoverable errors.\n * On success, clears push blocked state. On recoverable error, blocks\n * further pushes and schedules a retry. On unrecoverable error, moves\n * ops to deadLetter.\n */\n attemptPush(syncOps) {\n this.pushSyncOperations(syncOps)\n .then(() => {\n this.pushBlocked = false;\n this.pushFailureCount = 0;\n })\n .catch((error) => {\n const err = error instanceof Error ? error : new Error(String(error));\n if (this.isRecoverablePushError(err)) {\n this.pushFailureCount++;\n this.pushBlocked = true;\n this.logger.error(\"GqlChannel push failed (attempt @FailureCount), will retry: @Error\", this.pushFailureCount, err);\n this.schedulePushRetry();\n }\n else {\n const channelError = new ChannelError(ChannelErrorSource.Outbox, err);\n for (const syncOp of syncOps) {\n syncOp.failed(channelError);\n }\n this.deadLetter.add(...syncOps);\n this.outbox.remove(...syncOps);\n }\n });\n }\n /**\n * Schedules a retry of all current outbox items using exponential backoff.\n */\n schedulePushRetry() {\n if (this.pushRetryTimer)\n return;\n const delay = calculateBackoffDelay(this.pushFailureCount, this.config.retryBaseDelayMs, this.config.retryMaxDelayMs, Math.random());\n this.pushRetryTimer = setTimeout(() => {\n this.pushRetryTimer = null;\n if (this.isShutdown)\n return;\n const allItems = this.outbox.items;\n if (allItems.length === 0) {\n this.pushBlocked = false;\n this.pushFailureCount = 0;\n return;\n }\n this.attemptPush([...allItems]);\n }, delay);\n }\n /**\n * Returns true if the error is recoverable (transient network/HTTP/parse\n * failure). Returns false for explicit GraphQL server rejections.\n */\n isRecoverablePushError(error) {\n if (error.message.startsWith(\"GraphQL errors:\"))\n return false;\n if (error.message === \"GraphQL response missing data field\")\n return false;\n return true;\n }\n /**\n * Pushes multiple sync operations to the remote via a single GraphQL mutation.\n * Creates one SyncEnvelope per SyncOperation with key/dependsOn for batch ordering.\n */\n async pushSyncOperations(syncOps) {\n for (const syncOp of syncOps) {\n syncOp.started();\n }\n const jobIdToKeys = new Map();\n const envelopes = [];\n for (let i = 0; i < syncOps.length; i++) {\n const syncOp = syncOps[i];\n const key = String(i);\n if (syncOp.jobId) {\n if (!jobIdToKeys.has(syncOp.jobId)) {\n jobIdToKeys.set(syncOp.jobId, []);\n }\n jobIdToKeys.get(syncOp.jobId).push(key);\n }\n const dependsOn = [];\n for (const dep of syncOp.jobDependencies) {\n const depKeys = jobIdToKeys.get(dep);\n if (depKeys) {\n dependsOn.push(...depKeys);\n }\n }\n this.logger.debug(\"[PUSH]: @Operations\", syncOp.operations.map((op) => `(${op.context.documentId}, ${op.context.branch}, ${op.context.scope}, ${op.operation.index})`));\n envelopes.push({\n type: \"operations\",\n channelMeta: { id: this.channelId },\n operations: syncOp.operations,\n key,\n dependsOn,\n });\n }\n const mutation = `\n mutation PushSyncEnvelopes($envelopes: [SyncEnvelopeInput!]!) {\n pushSyncEnvelopes(envelopes: $envelopes)\n }\n `;\n const variables = {\n envelopes: envelopes.map((e) => serializeEnvelope(e)),\n };\n await this.executeGraphQL(mutation, variables);\n }\n /**\n * Gets the authorization header value using jwtHandler.\n */\n async getAuthorizationHeader() {\n if (!this.config.jwtHandler) {\n return undefined;\n }\n try {\n const token = await this.config.jwtHandler(this.config.url);\n if (token) {\n return `Bearer ${token}`;\n }\n }\n catch (error) {\n this.logger.error(\"JWT handler failed: @Error\", error);\n }\n return undefined;\n }\n /**\n * Executes a GraphQL query or mutation against the remote endpoint.\n */\n async executeGraphQL(query, variables) {\n const headers = {\n \"Content-Type\": \"application/json\",\n };\n const authHeader = await this.getAuthorizationHeader();\n if (authHeader) {\n headers[\"Authorization\"] = authHeader;\n }\n const fetchFn = this.config.fetchFn ?? fetch;\n let response;\n try {\n response = await fetchFn(this.config.url, {\n method: \"POST\",\n headers,\n body: JSON.stringify({\n query,\n variables,\n }),\n });\n }\n catch (error) {\n throw new Error(`GraphQL request failed: ${error instanceof Error ? error.message : String(error)}`);\n }\n if (!response.ok) {\n throw new Error(`GraphQL request failed: ${response.status} ${response.statusText}`);\n }\n let result;\n try {\n result = (await response.json());\n }\n catch (error) {\n throw new Error(`Failed to parse GraphQL response: ${error instanceof Error ? error.message : String(error)}`);\n }\n if (result.errors) {\n throw new Error(`GraphQL errors: ${JSON.stringify(result.errors, null, 2)}`);\n }\n if (!result.data) {\n throw new Error(\"GraphQL response missing data field\");\n }\n return result.data;\n }\n /**\n * Gets the current health status of the channel.\n */\n getHealth() {\n return {\n state: this.failureCount > 0 ? \"error\" : \"idle\",\n lastSuccessUtcMs: this.lastSuccessUtcMs,\n lastFailureUtcMs: this.lastFailureUtcMs,\n failureCount: this.failureCount,\n };\n }\n get poller() {\n return this.pollTimer;\n }\n}\n//# sourceMappingURL=gql-req-channel.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"Operation\")\n .addColumn(\"id\", \"serial\", (col) => col.primaryKey())\n .addColumn(\"jobId\", \"text\", (col) => col.notNull())\n .addColumn(\"opId\", \"text\", (col) => col.notNull())\n .addColumn(\"prevOpId\", \"text\", (col) => col.notNull())\n .addColumn(\"writeTimestampUtcMs\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"documentId\", \"text\", (col) => col.notNull())\n .addColumn(\"documentType\", \"text\", (col) => col.notNull())\n .addColumn(\"scope\", \"text\", (col) => col.notNull())\n .addColumn(\"branch\", \"text\", (col) => col.notNull())\n .addColumn(\"timestampUtcMs\", \"timestamptz\", (col) => col.notNull())\n .addColumn(\"index\", \"integer\", (col) => col.notNull())\n .addColumn(\"action\", \"jsonb\", (col) => col.notNull())\n .addColumn(\"skip\", \"integer\", (col) => col.notNull())\n .addColumn(\"error\", \"text\")\n .addColumn(\"hash\", \"text\", (col) => col.notNull())\n .addUniqueConstraint(\"unique_revision\", [\n \"documentId\",\n \"scope\",\n \"branch\",\n \"index\",\n ])\n .addUniqueConstraint(\"unique_operation_instance\", [\"opId\", \"index\", \"skip\"])\n .execute();\n // Create index for streaming operations\n await db.schema\n .createIndex(\"streamOperations\")\n .on(\"Operation\")\n .columns([\"documentId\", \"scope\", \"branch\", \"id\"])\n .execute();\n // Create index for branchless streaming operations\n await db.schema\n .createIndex(\"branchlessStreamOperations\")\n .on(\"Operation\")\n .columns([\"documentId\", \"scope\", \"id\"])\n .execute();\n}\n//# sourceMappingURL=001_create_operation_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"Keyframe\")\n .addColumn(\"id\", \"serial\", (col) => col.primaryKey())\n .addColumn(\"documentId\", \"text\", (col) => col.notNull())\n .addColumn(\"documentType\", \"text\", (col) => col.notNull())\n .addColumn(\"scope\", \"text\", (col) => col.notNull())\n .addColumn(\"branch\", \"text\", (col) => col.notNull())\n .addColumn(\"revision\", \"integer\", (col) => col.notNull())\n .addColumn(\"document\", \"jsonb\", (col) => col.notNull())\n .addColumn(\"createdAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addUniqueConstraint(\"unique_keyframe\", [\n \"documentId\",\n \"scope\",\n \"branch\",\n \"revision\",\n ])\n .execute();\n // Create index for keyframe lookup\n await db.schema\n .createIndex(\"keyframe_lookup\")\n .on(\"Keyframe\")\n .columns([\"documentId\", \"scope\", \"branch\", \"revision\"])\n .execute();\n}\n//# sourceMappingURL=002_create_keyframe_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"Document\")\n .addColumn(\"id\", \"text\", (col) => col.primaryKey())\n .addColumn(\"createdAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"updatedAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .execute();\n}\n//# sourceMappingURL=003_create_document_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"DocumentRelationship\")\n .addColumn(\"id\", \"text\", (col) => col.primaryKey())\n .addColumn(\"sourceId\", \"text\", (col) => col.notNull().references(\"Document.id\").onDelete(\"cascade\"))\n .addColumn(\"targetId\", \"text\", (col) => col.notNull().references(\"Document.id\").onDelete(\"cascade\"))\n .addColumn(\"relationshipType\", \"text\", (col) => col.notNull())\n .addColumn(\"metadata\", \"jsonb\")\n .addColumn(\"createdAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"updatedAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addUniqueConstraint(\"unique_source_target_type\", [\n \"sourceId\",\n \"targetId\",\n \"relationshipType\",\n ])\n .execute();\n // Create indexes for efficient graph traversal\n await db.schema\n .createIndex(\"idx_relationship_source\")\n .on(\"DocumentRelationship\")\n .column(\"sourceId\")\n .execute();\n await db.schema\n .createIndex(\"idx_relationship_target\")\n .on(\"DocumentRelationship\")\n .column(\"targetId\")\n .execute();\n await db.schema\n .createIndex(\"idx_relationship_type\")\n .on(\"DocumentRelationship\")\n .column(\"relationshipType\")\n .execute();\n}\n//# sourceMappingURL=004_create_document_relationship_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"IndexerState\")\n .addColumn(\"id\", \"integer\", (col) => col.primaryKey().generatedAlwaysAsIdentity())\n .addColumn(\"lastOperationId\", \"integer\", (col) => col.notNull())\n .addColumn(\"lastOperationTimestamp\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .execute();\n}\n//# sourceMappingURL=005_create_indexer_state_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"DocumentSnapshot\")\n .addColumn(\"id\", \"text\", (col) => col.primaryKey())\n .addColumn(\"documentId\", \"text\", (col) => col.notNull())\n .addColumn(\"slug\", \"text\")\n .addColumn(\"name\", \"text\")\n .addColumn(\"scope\", \"text\", (col) => col.notNull())\n .addColumn(\"branch\", \"text\", (col) => col.notNull())\n .addColumn(\"content\", \"jsonb\", (col) => col.notNull())\n .addColumn(\"documentType\", \"text\", (col) => col.notNull())\n .addColumn(\"lastOperationIndex\", \"integer\", (col) => col.notNull())\n .addColumn(\"lastOperationHash\", \"text\", (col) => col.notNull())\n .addColumn(\"lastUpdatedAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"snapshotVersion\", \"integer\", (col) => col.notNull().defaultTo(1))\n .addColumn(\"identifiers\", \"jsonb\")\n .addColumn(\"metadata\", \"jsonb\")\n .addColumn(\"isDeleted\", \"boolean\", (col) => col.notNull().defaultTo(false))\n .addColumn(\"deletedAt\", \"timestamptz\")\n .addUniqueConstraint(\"unique_doc_scope_branch\", [\n \"documentId\",\n \"scope\",\n \"branch\",\n ])\n .execute();\n // Create indexes for query optimization\n await db.schema\n .createIndex(\"idx_slug_scope_branch\")\n .on(\"DocumentSnapshot\")\n .columns([\"slug\", \"scope\", \"branch\"])\n .execute();\n await db.schema\n .createIndex(\"idx_doctype_scope_branch\")\n .on(\"DocumentSnapshot\")\n .columns([\"documentType\", \"scope\", \"branch\"])\n .execute();\n await db.schema\n .createIndex(\"idx_last_updated\")\n .on(\"DocumentSnapshot\")\n .column(\"lastUpdatedAt\")\n .execute();\n await db.schema\n .createIndex(\"idx_is_deleted\")\n .on(\"DocumentSnapshot\")\n .column(\"isDeleted\")\n .execute();\n}\n//# sourceMappingURL=006_create_document_snapshot_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"SlugMapping\")\n .addColumn(\"slug\", \"text\", (col) => col.primaryKey())\n .addColumn(\"documentId\", \"text\", (col) => col.notNull())\n .addColumn(\"scope\", \"text\", (col) => col.notNull())\n .addColumn(\"branch\", \"text\", (col) => col.notNull())\n .addColumn(\"createdAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"updatedAt\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addUniqueConstraint(\"unique_docid_scope_branch\", [\n \"documentId\",\n \"scope\",\n \"branch\",\n ])\n .execute();\n // Create index for reverse lookup (documentId -> slug)\n await db.schema\n .createIndex(\"idx_slug_documentid\")\n .on(\"SlugMapping\")\n .column(\"documentId\")\n .execute();\n}\n//# sourceMappingURL=007_create_slug_mapping_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"ViewState\")\n .addColumn(\"readModelId\", \"text\", (col) => col.primaryKey())\n .addColumn(\"lastOrdinal\", \"integer\", (col) => col.notNull().defaultTo(0))\n .addColumn(\"lastOperationTimestamp\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .execute();\n}\n//# sourceMappingURL=008_create_view_state_table.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"document_collections\")\n .addColumn(\"documentId\", \"text\", (col) => col.notNull())\n .addColumn(\"collectionId\", \"text\", (col) => col.notNull())\n .addColumn(\"joinedOrdinal\", \"bigint\", (col) => col.notNull().defaultTo(0))\n .addColumn(\"leftOrdinal\", \"bigint\")\n .addPrimaryKeyConstraint(\"document_collections_pkey\", [\n \"documentId\",\n \"collectionId\",\n ])\n .execute();\n await db.schema\n .createIndex(\"idx_document_collections_collectionId\")\n .on(\"document_collections\")\n .column(\"collectionId\")\n .execute();\n await db.schema\n .createIndex(\"idx_doc_collections_collection_range\")\n .on(\"document_collections\")\n .columns([\"collectionId\", \"joinedOrdinal\"])\n .execute();\n await db.schema\n .createTable(\"operation_index_operations\")\n .addColumn(\"ordinal\", \"serial\", (col) => col.primaryKey())\n .addColumn(\"opId\", \"text\", (col) => col.notNull())\n .addColumn(\"documentId\", \"text\", (col) => col.notNull())\n .addColumn(\"documentType\", \"text\", (col) => col.notNull())\n .addColumn(\"scope\", \"text\", (col) => col.notNull())\n .addColumn(\"branch\", \"text\", (col) => col.notNull())\n .addColumn(\"timestampUtcMs\", \"text\", (col) => col.notNull())\n .addColumn(\"writeTimestampUtcMs\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"index\", \"integer\", (col) => col.notNull())\n .addColumn(\"skip\", \"integer\", (col) => col.notNull())\n .addColumn(\"hash\", \"text\", (col) => col.notNull())\n .addColumn(\"action\", \"jsonb\", (col) => col.notNull())\n .execute();\n await db.schema\n .createIndex(\"idx_operation_index_operations_document\")\n .on(\"operation_index_operations\")\n .columns([\"documentId\", \"branch\", \"scope\"])\n .execute();\n await db.schema\n .createIndex(\"idx_operation_index_operations_ordinal\")\n .on(\"operation_index_operations\")\n .column(\"ordinal\")\n .execute();\n}\n//# sourceMappingURL=009_create_operation_index_tables.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n await db.schema\n .createTable(\"sync_remotes\")\n .addColumn(\"name\", \"text\", (col) => col.primaryKey())\n .addColumn(\"collection_id\", \"text\", (col) => col.notNull())\n .addColumn(\"channel_type\", \"text\", (col) => col.notNull())\n .addColumn(\"channel_id\", \"text\", (col) => col.notNull().defaultTo(\"\"))\n .addColumn(\"remote_name\", \"text\", (col) => col.notNull().defaultTo(\"\"))\n .addColumn(\"channel_parameters\", \"jsonb\", (col) => col.notNull().defaultTo(sql `'{}'::jsonb`))\n .addColumn(\"filter_document_ids\", \"jsonb\")\n .addColumn(\"filter_scopes\", \"jsonb\")\n .addColumn(\"filter_branch\", \"text\", (col) => col.notNull().defaultTo(\"main\"))\n .addColumn(\"push_state\", \"text\", (col) => col.notNull().defaultTo(\"idle\"))\n .addColumn(\"push_last_success_utc_ms\", \"text\")\n .addColumn(\"push_last_failure_utc_ms\", \"text\")\n .addColumn(\"push_failure_count\", \"integer\", (col) => col.notNull().defaultTo(0))\n .addColumn(\"pull_state\", \"text\", (col) => col.notNull().defaultTo(\"idle\"))\n .addColumn(\"pull_last_success_utc_ms\", \"text\")\n .addColumn(\"pull_last_failure_utc_ms\", \"text\")\n .addColumn(\"pull_failure_count\", \"integer\", (col) => col.notNull().defaultTo(0))\n .addColumn(\"created_at\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addColumn(\"updated_at\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .execute();\n await db.schema\n .createIndex(\"idx_sync_remotes_collection\")\n .on(\"sync_remotes\")\n .column(\"collection_id\")\n .execute();\n await db.schema\n .createTable(\"sync_cursors\")\n .addColumn(\"remote_name\", \"text\", (col) => col.primaryKey().references(\"sync_remotes.name\").onDelete(\"cascade\"))\n .addColumn(\"cursor_ordinal\", \"bigint\", (col) => col.notNull().defaultTo(0))\n .addColumn(\"last_synced_at_utc_ms\", \"text\")\n .addColumn(\"updated_at\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .execute();\n await db.schema\n .createIndex(\"idx_sync_cursors_ordinal\")\n .on(\"sync_cursors\")\n .column(\"cursor_ordinal\")\n .execute();\n}\n//# sourceMappingURL=010_create_sync_tables.js.map","import { sql } from \"kysely\";\nexport async function up(db) {\n // Delete any leftover fake \"outbox::\" cursor rows and remote records\n await db\n .deleteFrom(\"sync_cursors\")\n .where(\"remote_name\", \"like\", \"outbox::%\")\n .execute();\n await db\n .deleteFrom(\"sync_remotes\")\n .where(\"name\", \"like\", \"outbox::%\")\n .execute();\n // Recreate sync_cursors with cursor_type column and composite PK (no FK)\n await db.schema.dropTable(\"sync_cursors\").execute();\n await db.schema\n .createTable(\"sync_cursors\")\n .addColumn(\"remote_name\", \"text\", (col) => col.notNull())\n .addColumn(\"cursor_type\", \"text\", (col) => col.notNull().defaultTo(\"inbox\"))\n .addColumn(\"cursor_ordinal\", \"bigint\", (col) => col.notNull().defaultTo(0))\n .addColumn(\"last_synced_at_utc_ms\", \"text\")\n .addColumn(\"updated_at\", \"timestamptz\", (col) => col.notNull().defaultTo(sql `NOW()`))\n .addPrimaryKeyConstraint(\"sync_cursors_pk\", [\"remote_name\", \"cursor_type\"])\n .execute();\n await db.schema\n .createIndex(\"idx_sync_cursors_ordinal\")\n .on(\"sync_cursors\")\n .column(\"cursor_ordinal\")\n .execute();\n}\n//# sourceMappingURL=011_add_cursor_type_column.js.map","export async function up(db) {\n await db.schema\n .alterTable(\"operation_index_operations\")\n .addColumn(\"sourceRemote\", \"text\", (col) => col.notNull().defaultTo(\"\"))\n .execute();\n}\n//# sourceMappingURL=012_add_source_remote_column.js.map","import { Migrator, sql } from \"kysely\";\nexport const REACTOR_SCHEMA = \"reactor\";\nimport * as migration001 from \"./001_create_operation_table.js\";\nimport * as migration002 from \"./002_create_keyframe_table.js\";\nimport * as migration003 from \"./003_create_document_table.js\";\nimport * as migration004 from \"./004_create_document_relationship_table.js\";\nimport * as migration005 from \"./005_create_indexer_state_table.js\";\nimport * as migration006 from \"./006_create_document_snapshot_table.js\";\nimport * as migration007 from \"./007_create_slug_mapping_table.js\";\nimport * as migration008 from \"./008_create_view_state_table.js\";\nimport * as migration009 from \"./009_create_operation_index_tables.js\";\nimport * as migration010 from \"./010_create_sync_tables.js\";\nimport * as migration011 from \"./011_add_cursor_type_column.js\";\nimport * as migration012 from \"./012_add_source_remote_column.js\";\nconst migrations = {\n \"001_create_operation_table\": migration001,\n \"002_create_keyframe_table\": migration002,\n \"003_create_document_table\": migration003,\n \"004_create_document_relationship_table\": migration004,\n \"005_create_indexer_state_table\": migration005,\n \"006_create_document_snapshot_table\": migration006,\n \"007_create_slug_mapping_table\": migration007,\n \"008_create_view_state_table\": migration008,\n \"009_create_operation_index_tables\": migration009,\n \"010_create_sync_tables\": migration010,\n \"011_add_cursor_type_column\": migration011,\n \"012_add_source_remote_column\": migration012,\n};\nclass ProgrammaticMigrationProvider {\n getMigrations() {\n return Promise.resolve(migrations);\n }\n}\nexport async function runMigrations(db, schema = REACTOR_SCHEMA) {\n try {\n await sql `CREATE SCHEMA IF NOT EXISTS ${sql.id(schema)}`.execute(db);\n }\n catch (error) {\n return {\n success: false,\n migrationsExecuted: [],\n error: error instanceof Error ? error : new Error(\"Failed to create schema\"),\n };\n }\n const migrator = new Migrator({\n db: db.withSchema(schema),\n provider: new ProgrammaticMigrationProvider(),\n migrationTableSchema: schema,\n });\n let error;\n let results;\n try {\n const result = await migrator.migrateToLatest();\n error = result.error;\n results = result.results;\n }\n catch (e) {\n error = e;\n results = [];\n }\n const migrationsExecuted = results?.map((result) => result.migrationName) ?? [];\n if (error) {\n return {\n success: false,\n migrationsExecuted,\n error: error instanceof Error ? error : new Error(\"Unknown migration error\"),\n };\n }\n return {\n success: true,\n migrationsExecuted,\n };\n}\nexport async function getMigrationStatus(db, schema = REACTOR_SCHEMA) {\n const migrator = new Migrator({\n db: db.withSchema(schema),\n provider: new ProgrammaticMigrationProvider(),\n migrationTableSchema: schema,\n });\n return await migrator.getMigrations();\n}\n//# sourceMappingURL=migrator.js.map"],"names":["isUndefined","obj","isString","isNumber","isBoolean","isNull","isDate","isBigInt","isFunction","isObject","getLast","arr","freeze","asArray","arg","isReadonlyArray","noop","IdentifierNode","node","name","SchemableIdentifierNode","identifier","schema","AliasNode","alias","TableNode","table","isOperationNodeSource","isExpression","isAliasedExpression","SelectModifierNode","modifier","of","AndNode","left","right","OrNode","OnNode","filter","onNode","operator","operation","JoinNode","joinType","on","joinNode","BinaryOperationNode","leftOperand","rightOperand","COMPARISON_OPERATORS","ARITHMETIC_OPERATORS","JSON_OPERATORS","BINARY_OPERATORS","UNARY_FILTER_OPERATORS","UNARY_OPERATORS","OPERATORS","OperatorNode","isJSONOperator","op","ColumnNode","column","SelectAllNode","ReferenceNode","DynamicReferenceBuilder","#dynamicReference","reference","parseSimpleReferenceExpression","isDynamicReferenceBuilder","OrderByItemNode","orderBy","direction","props","RawNode","sqlFragments","parameters","sql","child","children","CollateNode","collation","OrderByItemBuilder","#props","LOGGED_MESSAGES","logOnce","message","isOrderByDirection","thing","parseOrderBy","args","parseOrderByItem","item","expr","modifiers","parsedRef","parseOrderByExpression","parseOrderByWithModifiers","isExpressionOrFactory","parseExpression","ref","parseStringReference","JSONReferenceNode","traversal","JSONOperatorChainNode","value","JSONPathNode","inOperator","jsonPathNode","pathLeg","exp","parseReferenceExpressionOrList","it","parseReferenceExpression","parseJSONReference","referenceNode","opWithoutLastChar","parts","trim","parseStringReferenceWithTableAndSchema","parseStringReferenceWithTable","parseAliasedStringReference","ALIAS_SEPARATOR","columnRef","parseColumnName","parseOrderedColumnName","columnName","order","str","PrimitiveValueListNode","values","ValueListNode","ValueNode","parseValueExpressionOrList","parseValueExpressionList","parseValueExpression","isSafeImmediateValue","parseSafeImmediateValue","ParensNode","parseValueBinaryOperationOrExpression","parseValueBinaryOperation","isIsOperator","needsIsOperator","parseOperator","parseReferentialBinaryOperation","parseFilterObject","combinator","parseFilterList","v","k","list","withParens","combine","toOperationNode","i","nodeOrSource","OrderByNode","items","PartitionByNode","partitionBy","OverNode","overNode","FromNode","froms","from","GroupByNode","groupBy","HavingNode","havingNode","InsertQueryNode","into","withNode","replace","insertQuery","ListNode","UpdateQueryNode","tables","updateQuery","fromItems","updates","limit","UsingNode","using","DeleteQueryNode","QueryNode","deleteNode","WhereNode","whereNode","ReturningNode","selections","returning","ExplainNode","format","options","WhenNode","condition","whenNode","result","MergeQueryNode","mergeNode","when","then","OutputNode","output","SelectQueryNode","join","top","select","expressions","selectNode","offset","fetch","setOperations","JoinBuilder","lhs","rhs","func","PartitionByItemNode","parsePartitionBy","OverBuilder","SelectionNode","selection","parseSelectArg","expressionBuilder","parseSelectExpression","parseAliasedExpression","parseSelectAll","parseSelectAllArg","parseTable","ValuesNode","DefaultInsertValueNode","parseInsertExpression","objectOrList","parseInsertColumnsAndValues","rows","columns","parseColumnNamesAndIndexes","row","parseRowValues","cols","col","rowColumns","rowValues","hasUndefinedOrComplexColumns","indexedRowColumns","columnIdx","defaultValue","ColumnUpdateNode","parseUpdate","parseUpdateObjectExpression","update","updateObj","_","key","OnDuplicateKeyNode","InsertResult","insertId","numInsertedOrUpdatedRows","NoResultError","isNoResultErrorConstructor","fn","OnConflictNode","OnConflictBuilder","columnNode","columnNodes","constraintName","expression","OnConflictDoNothingBuilder","OnConflictUpdateBuilder","TopNode","parseTop","isTopModifiers","OrActionNode","action","InsertQueryBuilder","insert","callback","plugin","compiledQuery","adapter","query","errorConstructor","chunkSize","stream","DeleteResult","numDeletedRows","LimitNode","DeleteQueryBuilder","parseTableExpressionOrList","#join","parseJoin","UpdateResult","numUpdatedRows","numChangedRows","UpdateQueryBuilder","CommonTableExpressionNameNode","tableName","columnNames","CommonTableExpressionNode","CTEBuilder","parseCommonTableExpression","nameOrBuilderCallback","expressionNode","createQueryCreator","cteBuilderFactory","parseCommonTableExpressionName","WithNode","params","CHARS","randomString","length","chars","randomChar","createQueryId","LazyQueryId","#queryId","OperationNodeTransformer","#transformers","queryId","out","_queryId","ROOT_OPERATION_NODES","SCHEMALESS_FUNCTIONS","WithSchemaTransformer","#schema","#schemableIds","#ctes","#isRootOperationNode","ctes","#collectCTEs","cte","#collectSchemableIds","transformed","#transformTableArgsWithoutSchemas","argsKey","schemableIds","#collectSchemableId","#collectSchemableIdsFromTableExpr","#collectCTEIds","id","cteId","WithSchemaPlugin","#transformer","MatchedNode","not","bySource","parseMergeWhen","type","refRight","parseMergeThen","Deferred","#promise","#resolve","#reject","resolve","reject","reason","provideControlledConnection","connectionProvider","connectionDefer","connectionReleaseDefer","connection","ex","NO_PLUGINS","QueryExecutorBase","#plugins","plugins","transformedNode","#transformResult","release","NoopQueryExecutor","NOOP_QUERY_EXECUTOR","MergeResult","MergeQueryBuilder","WheneableMergeQueryBuilder","#whenMatched","MatchedThenableMergeQueryBuilder","#whenNotMatched","Builder","NotMatchedThenableMergeQueryBuilder","set","ub","QueryCreator","createSelectQueryBuilder","targetTable","parseAliasedTable","nameOrBuilder","createJoinBuilder","parseTableExpression","createOverBuilder","parseSingleOnJoin","parseCallbackJoin","parseOnlessJoin","lhsColumn","rhsColumn","OffsetNode","GroupByItemNode","parseGroupBy","SetOperationNode","all","parseSetOperations","createExpressionBuilder","ExpressionWrapper","#node","AliasedExpressionWrapper","OrWrapper","AndWrapper","#expr","#alias","FetchNode","rowCount","parseFetch","isFetchModifier","SelectQueryBuilderImpl","AliasedSelectQueryBuilderImpl","#queryBuilder","queryBuilder","AggregateFunctionNode","aggregateFunction","aggregated","aggregateFunctionNode","orderItems","withinGroup","prop","over","FunctionNode","AggregateFunctionBuilder","AliasedAggregateFunctionBuilder","builder","#aggregateFunctionBuilder","aggregateFunctionBuilder","createFunctionModule","agg","UnaryOperationNode","operand","parseUnaryOperation","CaseNode","caseNode","CaseBuilder","CaseThenBuilder","valueExpression","CaseWhenBuilder","CaseEndBuilder","JSONPathLegNode","JSONPathBuilder","index","#createBuilderWithPathLeg","legType","TraversedJSONPathBuilder","AliasedJSONPathBuilder","#jsonPath","jsonPath","TupleNode","SIMPLE_COLUMN_DATA_TYPES","COLUMN_DATA_TYPE_REGEX","DataTypeNode","dataType","isColumnDataType","r","parseDataTypeExpression","CastNode","executor","binary","unary","eb","start","end","exprs","DynamicTableBuilder","#table","AliasedDynamicTableBuilder","isAliasedDynamicTableBuilder","RawBuilderImpl","AliasedRawBuilderImpl","#toOperationNode","#getExecutor","executorProvider","#compile","createRawBuilder","#rawBuilder","rawBuilder","parseParameter","columnReference","tableReference","ids","fragments","array","separator","nodes","sep","param","NoopPlugin","DEFAULT_MIGRATION_TABLE","DEFAULT_MIGRATION_LOCK_TABLE","DEFAULT_ALLOW_UNORDERED_MIGRATIONS","MIGRATION_LOCK_ID","Migrator","executedMigrations","#doesTableExist","#migrationTable","#schemaPlugin","#resolveMigrations","migration","executed","#migrate","targetMigrationName","migrations","pendingMigrations","m","executedIndex","pendingIndex","getMigrationDirectionAndStep","#ensureMigrationTableSchemaExists","#ensureMigrationTableExists","#ensureMigrationLockTableExists","#ensureLockRowExists","#runMigrations","error","MigrationResultSetError","#migrationTableSchema","#migrationLockTable","#allowUnorderedMigrations","#doesSchemaExist","#createIfNotExists","#doesLockRowExists","lockOptions","run","db","state","#getState","step","#migrateDown","#migrateUp","#getExecutedMigrations","#ensureNoMissingMigrations","#ensureMigrationsInOrder","#getPendingMigrations","allMigrations","nameComparator","a","b","migrationsToRollback","results","qb","#resultSet","ChannelScheme","SyncOperationStatus","ChannelErrorSource","SyncEventTypes","MailboxAggregateError","errors","messages","e","Mailbox","ackOrdinal","syncOp","next","callbacks","BufferedMailbox","milliseconds","maxQueued","callbacksCopy","ChannelError","source","SyncOperationAggregateError","SyncOperation","jobId","jobDependencies","remoteName","documentId","scopes","branch","operations","prev","trimMailboxFromBatch","mailbox","batch","toRemove","trimMailboxFromAckOrdinal","maxOrdinal","filterOperations","createIdleHealth","sortEnvelopesByFirstOperationTimestamp","envelopes","aTimestamp","bTimestamp","batchOperationsByDocument","batches","currentDocId","currentScope","currentBatch","flushBatch","docId","scope","toOperationWithContext","entry","mergeCollectionMemberships","events","mergedMemberships","event","collections","c","input","collectionId","driveCollectionId","DEFAULT_CONFIG","calculateBackoffDelay","consecutiveFailures","retryBaseDelayMs","retryMaxDelayMs","random","backoff","IntervalPollTimer","queue","config","delegate","size","delay","ms","syncOpCounter","serializeAction","signer","sig","serializeEnvelope","envelope","opWithContext","deserializeSignature","deserializeOperationSignatures","deserializedSignatures","deserializedOperation","envelopesToSyncOperations","deserializedOps","syncOpId","getLatestAppliedOrdinal","syncOps","GqlRequestChannel","logger","channelId","cursorStorage","operationIndex","pollTimer","cursors","inboxOrdinal","outboxOrdinal","response","deadLetters","sortedEnvelopes","allSyncOps","dl","err","channelError","recoveryError","latestOrdinal","variables","sinceTimestampUtcMs","mutation","allItems","jobIdToKeys","dependsOn","dep","depKeys","token","headers","authHeader","fetchFn","up","REACTOR_SCHEMA","migration001","migration002","migration003","migration004","migration005","migration006","migration007","migration008","migration009","migration010","migration011","migration012","ProgrammaticMigrationProvider","runMigrations","migrator","migrationsExecuted"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129]}
|