@prisma/studio-core 0.0.0-dev.202511180420 → 0.0.0-dev.202511181242

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/dist/{chunk-NQGSK3IM.js → chunk-SXTJF4PD.js} +1 -1
  2. package/dist/data/accelerate/index.d.cts +1 -1
  3. package/dist/data/accelerate/index.d.ts +1 -1
  4. package/dist/data/bff/index.cjs +2 -2
  5. package/dist/data/bff/index.d.cts +15 -3
  6. package/dist/data/bff/index.d.ts +15 -3
  7. package/dist/data/bff/index.js +2 -2
  8. package/dist/data/index.d.cts +1 -1
  9. package/dist/data/index.d.ts +1 -1
  10. package/dist/data/mysql-core/index.d.cts +1 -1
  11. package/dist/data/mysql-core/index.d.ts +1 -1
  12. package/dist/data/mysql2/index.cjs +2 -2
  13. package/dist/data/mysql2/index.d.cts +2 -2
  14. package/dist/data/mysql2/index.d.ts +2 -2
  15. package/dist/data/mysql2/index.js +2 -2
  16. package/dist/data/node-sqlite/index.d.cts +1 -1
  17. package/dist/data/node-sqlite/index.d.ts +1 -1
  18. package/dist/data/pglite/index.cjs +1 -1
  19. package/dist/data/pglite/index.d.cts +1 -1
  20. package/dist/data/pglite/index.d.ts +1 -1
  21. package/dist/data/pglite/index.js +1 -1
  22. package/dist/data/postgres-core/index.d.cts +1 -1
  23. package/dist/data/postgres-core/index.d.ts +1 -1
  24. package/dist/data/postgresjs/index.cjs +1 -1
  25. package/dist/data/postgresjs/index.d.cts +1 -1
  26. package/dist/data/postgresjs/index.d.ts +1 -1
  27. package/dist/data/postgresjs/index.js +1 -1
  28. package/dist/data/ppg/index.d.cts +1 -1
  29. package/dist/data/ppg/index.d.ts +1 -1
  30. package/dist/data/sqlite-core/index.d.cts +1 -1
  31. package/dist/data/sqlite-core/index.d.ts +1 -1
  32. package/dist/{index-CV9DQF9a.d.cts → index-CW6rqTos.d.cts} +2 -2
  33. package/dist/{index-CV9DQF9a.d.ts → index-CW6rqTos.d.ts} +2 -2
  34. package/dist/metafile-cjs.json +1 -1
  35. package/dist/metafile-esm.json +1 -1
  36. package/dist/ui/index.d.cts +1 -1
  37. package/dist/ui/index.d.ts +1 -1
  38. package/package.json +1 -1
@@ -1,5 +1,5 @@
1
1
  import { PGlite } from '@electric-sql/pglite';
2
- import { Q as Query, E as Executor, A as Adapter } from '../../index-CV9DQF9a.cjs';
2
+ import { Q as Query, c as Executor, A as Adapter } from '../../index-CW6rqTos.cjs';
3
3
  import 'kysely';
4
4
 
5
5
  interface PGLiteExecutorOptions {
@@ -1,5 +1,5 @@
1
1
  import { PGlite } from '@electric-sql/pglite';
2
- import { Q as Query, E as Executor, A as Adapter } from '../../index-CV9DQF9a.js';
2
+ import { Q as Query, c as Executor, A as Adapter } from '../../index-CW6rqTos.js';
3
3
  import 'kysely';
4
4
 
5
5
  interface PGLiteExecutorOptions {
@@ -6,5 +6,5 @@ function require(mod) {
6
6
  if (mod === 'react-dom') return ___react_dom___;
7
7
  throw new Error(`Unknown module ${mod}`);
8
8
  }
9
- import{a as y}from"../../chunk-NQGSK3IM.js";import{j as m}from"../../chunk-RYYSZZYL.js";import"../../chunk-M7E5UEO3.js";import"../../chunk-24UZSKGU.js";import"../../chunk-A6CVKSUD.js";import{e as d}from"../../chunk-GDQBQ7MK.js";d();function G(r,n){let{addDelay:i=0,logging:a=!1}=n??{};return{execute:async(t,P)=>{let{abortSignal:s}=P||{},c,f=new Promise((e,o)=>c=o);function u(){c(new y)}s?.addEventListener("abort",u);let l=typeof i=="function"?i(t):i,p=()=>r.query(t.sql,t.parameters,{rowMode:"object"}),g=l>0?()=>new Promise(e=>setTimeout(e,l)).then(()=>p()):p;try{let e=typeof a=="function"?a(t):a,o;e&&console.log("PGLiteExecutor: Executing query:",o=JSON.stringify(t,null,2));let x=Date.now(),L=await Promise.race([g(),f]),b=Date.now()-x;return e&&console.log("PGLiteExecutor: Query executed in",b,"ms:",o),[null,L.rows]}catch(e){return[e]}finally{s?.removeEventListener("abort",u)}}}}function A(r,n){return m({executor:G(r,n)})}export{A as createPGLiteAdapter,G as createPGLiteExecutor};
9
+ import{a as y}from"../../chunk-SXTJF4PD.js";import{j as m}from"../../chunk-RYYSZZYL.js";import"../../chunk-M7E5UEO3.js";import"../../chunk-24UZSKGU.js";import"../../chunk-A6CVKSUD.js";import{e as d}from"../../chunk-GDQBQ7MK.js";d();function G(r,n){let{addDelay:i=0,logging:a=!1}=n??{};return{execute:async(t,P)=>{let{abortSignal:s}=P||{},c,f=new Promise((e,o)=>c=o);function u(){c(new y)}s?.addEventListener("abort",u);let l=typeof i=="function"?i(t):i,p=()=>r.query(t.sql,t.parameters,{rowMode:"object"}),g=l>0?()=>new Promise(e=>setTimeout(e,l)).then(()=>p()):p;try{let e=typeof a=="function"?a(t):a,o;e&&console.log("PGLiteExecutor: Executing query:",o=JSON.stringify(t,null,2));let x=Date.now(),L=await Promise.race([g(),f]),b=Date.now()-x;return e&&console.log("PGLiteExecutor: Query executed in",b,"ms:",o),[null,L.rows]}catch(e){return[e]}finally{s?.removeEventListener("abort",u)}}}}function A(r,n){return m({executor:G(r,n)})}export{A as createPGLiteAdapter,G as createPGLiteExecutor};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9wZ2xpdGUvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB0eXBlIHsgUEdsaXRlIH0gZnJvbSBcIkBlbGVjdHJpYy1zcWwvcGdsaXRlXCI7XG5cbmltcG9ydCB0eXBlIHsgQWRhcHRlciB9IGZyb20gXCIuLi9hZGFwdGVyXCI7XG5pbXBvcnQgeyBBYm9ydEVycm9yLCB0eXBlIEV4ZWN1dG9yIH0gZnJvbSBcIi4uL2V4ZWN1dG9yXCI7XG5pbXBvcnQgeyBjcmVhdGVQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tIFwiLi4vcG9zdGdyZXMtY29yZVwiO1xuaW1wb3J0IHsgUXVlcnkgfSBmcm9tIFwiLi4vcXVlcnlcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQR0xpdGVFeGVjdXRvck9wdGlvbnMge1xuICAvKipcbiAgICogRGVsYXkgaW4gbWlsbGlzZWNvbmRzIHRvIGFkZCBiZWZvcmUgZXhlY3V0aW5nIHRoZSBxdWVyeS5cbiAgICogVGhpcyBjYW4gYmUgYSBzdGF0aWMgbnVtYmVyIG9yIGEgZnVuY3Rpb24gdGhhdCB0YWtlcyB0aGUgcXVlcnkgYXMgYW4gYXJndW1lbnQgYW5kIHJldHVybnMgYSBudW1iZXIuXG4gICAqXG4gICAqIFRoaXMgaXMgdXNlZnVsIGZvciBzaW11bGF0aW5nIG5ldHdvcmsgbGF0ZW5jeSBvciBmb3IgZGVidWdnaW5nIHB1cnBvc2VzLlxuICAgKi9cbiAgYWRkRGVsYXk/OiBudW1iZXIgfCAoKHF1ZXJ5OiBRdWVyeTx1bmtub3duPikgPT4gbnVtYmVyKTtcblxuICAvKipcbiAgICogV2hldGhlciB0byBsb2cgdGhlIHF1ZXJ5IGFuZCBpdHMgcGFyYW1ldGVycy5cbiAgICpcbiAgICogRGVmYXVsdHMgdG8gYGZhbHNlYC5cbiAgICovXG4gIGxvZ2dpbmc/OiBib29sZWFuIHwgKChxdWVyeTogUXVlcnk8dW5rbm93bj4pID0+IGJvb2xlYW4pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUEdMaXRlRXhlY3V0b3IocGdsaXRlOiBQR2xpdGUsIG9wdGlvbnM/OiBQR0xpdGVFeGVjdXRvck9wdGlvbnMpOiBFeGVjdXRvciB7XG4gIGNvbnN0IHsgYWRkRGVsYXkgPSAwLCBsb2dnaW5nID0gZmFsc2UgfSA9IG9wdGlvbnMgPz8ge307XG5cbiAgcmV0dXJuIHtcbiAgICBleGVjdXRlOiBhc3luYyAocXVlcnksIG9wdGlvbnMpID0+IHtcbiAgICAgIGNvbnN0IHsgYWJvcnRTaWduYWwgfSA9IG9wdGlvbnMgfHwge307XG5cbiAgICAgIGxldCBhYm9ydDogKHJlYXNvbj86IHVua25vd24pID0+IHZvaWQ7XG4gICAgICBjb25zdCBhYm9ydGlvblByb21pc2UgPSBuZXcgUHJvbWlzZTxuZXZlcj4oKF8sIHJlamVjdCkgPT4gKGFib3J0ID0gcmVqZWN0KSk7XG5cbiAgICAgIGZ1bmN0aW9uIGFib3J0TGlzdGVuZXIoKTogdm9pZCB7XG4gICAgICAgIGFib3J0KG5ldyBBYm9ydEVycm9yKCkpO1xuICAgICAgfVxuXG4gICAgICBhYm9ydFNpZ25hbD8uYWRkRXZlbnRMaXN0ZW5lcihcImFib3J0XCIsIGFib3J0TGlzdGVuZXIpO1xuXG4gICAgICBjb25zdCBhZGRlZERlbGF5ID0gdHlwZW9mIGFkZERlbGF5ID09PSBcImZ1bmN0aW9uXCIgPyBhZGREZWxheShxdWVyeSkgOiBhZGREZWxheTtcblxuICAgICAgY29uc3QgcXVlcnlQR0xpdGUgPSAoKSA9PiBwZ2xpdGUucXVlcnkocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyW10sIHsgcm93TW9kZTogXCJvYmplY3RcIiB9KTtcblxuICAgICAgY29uc3QgcXVlcnlQR0xpdGVQb3NzaWJseURlbGF5ZWQgPVxuICAgICAgICBhZGRlZERlbGF5ID4gMFxuICAgICAgICAgID8gKCkgPT4gbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHNldFRpbWVvdXQocmVzb2x2ZSwgYWRkZWREZWxheSkpLnRoZW4oKCkgPT4gcXVlcnlQR0xpdGUoKSlcbiAgICAgICAgICA6IHF1ZXJ5UEdMaXRlO1xuXG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCBzaG91bGRMb2cgPSB0eXBlb2YgbG9nZ2luZyA9PT0gXCJmdW5jdGlvblwiID8gbG9nZ2luZyhxdWVyeSkgOiBsb2dnaW5nO1xuXG4gICAgICAgIGxldCBsb2dnYWJsZVF1ZXJ5OiBzdHJpbmc7XG4gICAgICAgIGlmIChzaG91bGRMb2cpIHtcbiAgICAgICAgICBjb25zb2xlLmxvZyhcIlBHTGl0ZUV4ZWN1dG9yOiBFeGVjdXRpbmcgcXVlcnk6XCIsIChsb2dnYWJsZVF1ZXJ5ID0gSlNPTi5zdHJpbmdpZnkocXVlcnksIG51bGwsIDIpKSk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuXG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IFByb21pc2UucmFjZShbcXVlcnlQR0xpdGVQb3NzaWJseURlbGF5ZWQoKSwgYWJvcnRpb25Qcm9taXNlXSk7XG5cbiAgICAgICAgY29uc3QgZHVyYXRpb24gPSBEYXRlLm5vdygpIC0gbm93O1xuXG4gICAgICAgIGlmIChzaG91bGRMb2cpIHtcbiAgICAgICAgICBjb25zb2xlLmxvZyhcIlBHTGl0ZUV4ZWN1dG9yOiBRdWVyeSBleGVjdXRlZCBpblwiLCBkdXJhdGlvbiwgXCJtczpcIiwgbG9nZ2FibGVRdWVyeSEpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCByZXN1bHQucm93cyBhcyBuZXZlcl07XG4gICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgIH0gZmluYWxseSB7XG4gICAgICAgIGFib3J0U2lnbmFsPy5yZW1vdmVFdmVudExpc3RlbmVyKFwiYWJvcnRcIiwgYWJvcnRMaXN0ZW5lcik7XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbn1cblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1vYmplY3QtdHlwZVxuZXhwb3J0IGludGVyZmFjZSBQR0xpdGVBZGFwdGVyT3B0aW9ucyBleHRlbmRzIFBHTGl0ZUV4ZWN1dG9yT3B0aW9ucyB7fVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUEdMaXRlQWRhcHRlcihwZ2xpdGU6IFBHbGl0ZSwgb3B0aW9ucz86IFBHTGl0ZUFkYXB0ZXJPcHRpb25zKTogQWRhcHRlciB7XG4gIHJldHVybiBjcmVhdGVQb3N0Z3Jlc0FkYXB0ZXIoe1xuICAgIGV4ZWN1dG9yOiBjcmVhdGVQR0xpdGVFeGVjdXRvcihwZ2xpdGUsIG9wdGlvbnMpLFxuICB9KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7O29PQUFBQSxJQXdCTyxTQUFTQyxFQUFxQkMsRUFBZ0JDLEVBQTJDLENBQzlGLEdBQU0sQ0FBRSxTQUFBQyxFQUFXLEVBQUcsUUFBQUMsRUFBVSxFQUFNLEVBQUlGLEdBQVcsQ0FBQyxFQUV0RCxNQUFPLENBQ0wsUUFBUyxNQUFPRyxFQUFPSCxJQUFZLENBQ2pDLEdBQU0sQ0FBRSxZQUFBSSxDQUFZLEVBQUlKLEdBQVcsQ0FBQyxFQUVoQ0ssRUFDRUMsRUFBa0IsSUFBSSxRQUFlLENBQUNDLEVBQUdDLElBQVlILEVBQVFHLENBQU8sRUFFMUUsU0FBU0MsR0FBc0IsQ0FDN0JKLEVBQU0sSUFBSUssQ0FBWSxDQUN4QixDQUVBTixHQUFhLGlCQUFpQixRQUFTSyxDQUFhLEVBRXBELElBQU1FLEVBQWEsT0FBT1YsR0FBYSxXQUFhQSxFQUFTRSxDQUFLLEVBQUlGLEVBRWhFVyxFQUFjLElBQU1iLEVBQU8sTUFBTUksRUFBTSxJQUFLQSxFQUFNLFdBQXVCLENBQUUsUUFBUyxRQUFTLENBQUMsRUFFOUZVLEVBQ0pGLEVBQWEsRUFDVCxJQUFNLElBQUksUUFBU0csR0FBWSxXQUFXQSxFQUFTSCxDQUFVLENBQUMsRUFBRSxLQUFLLElBQU1DLEVBQVksQ0FBQyxFQUN4RkEsRUFFTixHQUFJLENBQ0YsSUFBTUcsRUFBWSxPQUFPYixHQUFZLFdBQWFBLEVBQVFDLENBQUssRUFBSUQsRUFFL0RjLEVBQ0FELEdBQ0YsUUFBUSxJQUFJLG1DQUFxQ0MsRUFBZ0IsS0FBSyxVQUFVYixFQUFPLEtBQU0sQ0FBQyxDQUFFLEVBR2xHLElBQU1jLEVBQU0sS0FBSyxJQUFJLEVBRWZDLEVBQVMsTUFBTSxRQUFRLEtBQUssQ0FBQ0wsRUFBMkIsRUFBR1AsQ0FBZSxDQUFDLEVBRTNFYSxFQUFXLEtBQUssSUFBSSxFQUFJRixFQUU5QixPQUFJRixHQUNGLFFBQVEsSUFBSSxvQ0FBcUNJLEVBQVUsTUFBT0gsQ0FBYyxFQUczRSxDQUFDLEtBQU1FLEVBQU8sSUFBYSxDQUNwQyxPQUFTRSxFQUFnQixDQUN2QixNQUFPLENBQUNBLENBQWMsQ0FDeEIsUUFBRSxDQUNBaEIsR0FBYSxvQkFBb0IsUUFBU0ssQ0FBYSxDQUN6RCxDQUNGLENBQ0YsQ0FDRixDQUtPLFNBQVNZLEVBQW9CdEIsRUFBZ0JDLEVBQXlDLENBQzNGLE9BQU9zQixFQUFzQixDQUMzQixTQUFVeEIsRUFBcUJDLEVBQVFDLENBQU8sQ0FDaEQsQ0FBQyxDQUNIIiwKICAibmFtZXMiOiBbImluaXRfZGVmaW5lX0FDQ0VMRVJBVEVfU0NIRU1BX0JZX1BST1ZJREVSIiwgImNyZWF0ZVBHTGl0ZUV4ZWN1dG9yIiwgInBnbGl0ZSIsICJvcHRpb25zIiwgImFkZERlbGF5IiwgImxvZ2dpbmciLCAicXVlcnkiLCAiYWJvcnRTaWduYWwiLCAiYWJvcnQiLCAiYWJvcnRpb25Qcm9taXNlIiwgIl8iLCAicmVqZWN0IiwgImFib3J0TGlzdGVuZXIiLCAiQWJvcnRFcnJvciIsICJhZGRlZERlbGF5IiwgInF1ZXJ5UEdMaXRlIiwgInF1ZXJ5UEdMaXRlUG9zc2libHlEZWxheWVkIiwgInJlc29sdmUiLCAic2hvdWxkTG9nIiwgImxvZ2dhYmxlUXVlcnkiLCAibm93IiwgInJlc3VsdCIsICJkdXJhdGlvbiIsICJlcnJvciIsICJjcmVhdGVQR0xpdGVBZGFwdGVyIiwgImNyZWF0ZVBvc3RncmVzQWRhcHRlciJdCn0K
@@ -1,4 +1,4 @@
1
- import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-CV9DQF9a.cjs';
1
+ import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-CW6rqTos.cjs';
2
2
  import 'kysely';
3
3
 
4
4
  type PostgresAdapterRequirements = AdapterRequirements;
@@ -1,4 +1,4 @@
1
- import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-CV9DQF9a.js';
1
+ import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, g as AdapterInsertDetails, B as BuilderRequirements, e as AdapterQueryDetails, h as AdapterUpdateDetails, f as AdapterDeleteDetails } from '../../index-CW6rqTos.js';
2
2
  import 'kysely';
3
3
 
4
4
  type PostgresAdapterRequirements = AdapterRequirements;
@@ -1,2 +1,2 @@
1
1
  "use strict";var l=Object.defineProperty;var E=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var v=Object.prototype.hasOwnProperty;var T=(e,r)=>{for(var n in r)l(e,n,{get:r[n],enumerable:!0})},k=(e,r,n,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of P(r))!v.call(e,o)&&o!==n&&l(e,o,{get:()=>r[o],enumerable:!(t=E(r,o))||t.enumerable});return e};var q=e=>k(l({},"__esModule",{value:!0}),e);var C={};T(C,{createPostgresJSExecutor:()=>h});module.exports=q(C);var c=class extends Error{constructor(){super("This operation was aborted"),this.name="AbortError"}};function i(){return[new c]}function R(e){return typeof e=="string"?{parameters:[],sql:e}:e}function g(){return R("select pg_backend_pid() as pid")}function b(e){return{parameters:[e],sql:"select pg_cancel_backend($1);"}}function h(e){return{execute:async(r,n)=>{let{abortSignal:t}=n||{};if(!t)try{return[null,await e.unsafe(r.sql,r.parameters)]}catch(a){return[a]}if(t.aborted)return i();let o,s;try{let a,u=new Promise(Q=>a=Q);t.addEventListener("abort",o=()=>a());let y=e.reserve(),d=await Promise.race([y,u]);if(!d)return y.catch(()=>{}),i();if(s=d,t.aborted)return s.release(),i();let m=O(s),f=await Promise.race([m,u]);if(f===void 0)return m.catch(()=>{}).finally(()=>s?.release()),i();if(t.aborted)return s.release(),i();let x=s.unsafe(r.sql,r.parameters),w=await Promise.race([x,u]);return w?(s.release(),[null,w]):(Promise.allSettled([B(e,f),x]).finally(()=>s?.release()),i())}catch(a){return s?.release(),[a]}finally{o&&t?.removeEventListener("abort",o)}}}}async function B(e,r){let n=b(r);try{await e.unsafe(n.sql,n.parameters)}catch(t){console.error("Failed to cancel query:",t)}}async function O(e){let r=g();try{let[n]=await e.unsafe(r.sql,r.parameters);return n?.pid}catch(n){console.error("Failed to get connection PID:",n);return}}
2
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/postgresjs/index.ts", "../../../data/executor.ts", "../../../data/query.ts", "../../../data/postgres-core/utility.ts"],
  "sourcesContent": ["import type { ReservedSql, Sql } from \"postgres\";\n\nimport { type Executor, getAbortResult } from \"../executor\";\nimport { getCancelQuery, getPIDQuery } from \"../postgres-core/utility\";\nimport type { QueryResult } from \"../query\";\n\nexport function createPostgresJSExecutor(postgresjs: Sql): Executor {\n  return {\n    execute: async (query, options) => {\n      const { abortSignal } = options || {};\n\n      if (!abortSignal) {\n        try {\n          const result = await postgresjs.unsafe(query.sql, query.parameters as never);\n\n          return [null, result as never];\n        } catch (error: unknown) {\n          return [error as Error];\n        }\n      }\n\n      if (abortSignal.aborted) {\n        return getAbortResult();\n      }\n\n      let abortListener: (() => void) | undefined;\n      let connection: ReservedSql | undefined;\n\n      try {\n        let aborted: () => void;\n        const abortionPromise = new Promise<void>((resolve) => (aborted = resolve));\n\n        abortSignal.addEventListener(\"abort\", (abortListener = () => aborted()));\n\n        const connectionPromise = postgresjs.reserve();\n\n        const connectionResult = await Promise.race([connectionPromise, abortionPromise]);\n\n        if (!connectionResult) {\n          void connectionPromise.catch(() => {});\n\n          return getAbortResult();\n        }\n\n        connection = connectionResult;\n\n        if (abortSignal.aborted) {\n          connection.release();\n\n          return getAbortResult();\n        }\n\n        const pidPromise = getConnectionPID(connection);\n\n        const pidResult = await Promise.race([pidPromise, abortionPromise]);\n\n        if (pidResult === undefined) {\n          void pidPromise.catch(() => {}).finally(() => connection?.release());\n\n          return getAbortResult();\n        }\n\n        if (abortSignal.aborted) {\n          connection.release();\n\n          return getAbortResult();\n        }\n\n        const queryPromise = connection.unsafe(query.sql, query.parameters as never);\n\n        const queryResult = await Promise.race([queryPromise, abortionPromise]);\n\n        if (!queryResult) {\n          void Promise.allSettled([cancelQuery(postgresjs, pidResult!), queryPromise]).finally(() =>\n            connection?.release(),\n          );\n\n          return getAbortResult();\n        }\n\n        connection.release();\n\n        return [null, queryResult as never];\n      } catch (error: unknown) {\n        connection?.release();\n\n        return [error as Error];\n      } finally {\n        if (abortListener) {\n          abortSignal?.removeEventListener(\"abort\", abortListener);\n        }\n      }\n    },\n  };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nasync function cancelQuery(postgresjs: Sql, pid: {}): Promise<void> {\n  const query = getCancelQuery(pid);\n\n  try {\n    await postgresjs.unsafe(query.sql, query.parameters as never);\n  } catch (error) {\n    console.error(\"Failed to cancel query:\", error);\n  }\n}\n\nasync function getConnectionPID(connection: ReservedSql): Promise<unknown> {\n  const query = getPIDQuery();\n\n  try {\n    const [result] = await connection.unsafe<QueryResult<typeof query>>(query.sql, query.parameters as never);\n\n    return result?.pid;\n  } catch (error) {\n    console.error(\"Failed to get connection PID:\", error);\n\n    return undefined;\n  }\n}\n", "import type { Query, QueryResult } from \"./query\";\nimport type { Either } from \"./type-utils\";\n\nexport interface Executor {\n  execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport interface SequenceExecutor extends Executor {\n  executeSequence<T, S>(\n    query: [Query<T>, Query<S>],\n    options?: ExecuteOptions,\n  ): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;\n}\n\nexport interface ExecuteOptions {\n  abortSignal?: AbortSignal;\n}\n\nexport class AbortError extends Error {\n  constructor() {\n    super(\"This operation was aborted\");\n    this.name = \"AbortError\";\n  }\n}\n\nexport function getAbortResult(): [AbortError] {\n  return [new AbortError()];\n}\n", "import {\n  type Compilable,\n  type DialectAdapter,\n  DummyDriver,\n  type Expression,\n  type ExpressionBuilder,\n  expressionBuilder,\n  type ExpressionWrapper,\n  type InsertObject,\n  Kysely,\n  type KyselyPlugin,\n  OperationNodeTransformer,\n  type PluginTransformQueryArgs,\n  type PluginTransformResultArgs,\n  type PrimitiveValueListNode,\n  type QueryCompiler,\n  type QueryResult as KyselyQueryResult,\n  type RootOperationNode,\n  sql,\n  type SqlBool,\n  type UnknownRow,\n  type UpdateObject,\n  ValueListNode,\n  ValueNode,\n  type WhereInterface,\n} from \"kysely\";\n\nimport type { Column, ColumnFilter, FilterGroup, Table } from \"./adapter\";\n\nexport interface BuilderRequirements {\n  Adapter: { new (): DialectAdapter };\n  noParameters?: boolean;\n  QueryCompiler: { new (): QueryCompiler };\n}\n\nexport function getBuilder<DB>(requirements: BuilderRequirements): Kysely<DB> {\n  return new Kysely({\n    dialect: {\n      createAdapter: () => new requirements.Adapter(),\n      createDriver: () => new DummyDriver(),\n      // @ts-expect-error - we don't need built-in introspection in this case\n      createIntrospector: () => null,\n      createQueryCompiler: () => new requirements.QueryCompiler(),\n    },\n    plugins: [...(requirements.noParameters ? [new ImmediateValuePlugin()] : [])],\n  });\n}\n\n/**\n * A plugin that transforms all values to immediate values. This means their injected into the SQL string instead of populating the parameters array.\n * In some situations, a database driver might not support parameters, and this plugin can be used to work around that.\n */\nclass ImmediateValuePlugin implements KyselyPlugin {\n  readonly #transformer = new ImmediateValueTransformer();\n\n  transformQuery(args: PluginTransformQueryArgs): RootOperationNode {\n    return this.#transformer.transformNode(args.node);\n  }\n\n  transformResult(args: PluginTransformResultArgs): Promise<KyselyQueryResult<UnknownRow>> {\n    return Promise.resolve(args.result);\n  }\n}\n\nclass ImmediateValueTransformer extends OperationNodeTransformer {\n  protected override transformPrimitiveValueList(node: PrimitiveValueListNode): PrimitiveValueListNode {\n    return ValueListNode.create(node.values.map(ValueNode.createImmediate)) as never;\n  }\n\n  override transformValue(node: ValueNode): ValueNode {\n    return { ...super.transformValue(node), immediate: true };\n  }\n}\n\ndeclare const queryType: unique symbol;\nexport interface Query<T = Record<string, unknown>> {\n  [queryType]?: T;\n  parameters: readonly unknown[];\n  sql: string;\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function asQuery<T>(query: string | Query<unknown>): Query<T> {\n  if (typeof query === \"string\") {\n    return { parameters: [], sql: query } as never;\n  }\n\n  return query as never;\n}\n\nexport type QueryResult<T> =\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  T extends Query<infer R> ? R[] : T extends (...args: any[]) => Query<infer R> ? R[] : never;\n\nexport interface CompileOptions<T> {\n  /**\n   * A mapping of column names to transformations that should be applied to the result.\n   * Currently supported transformation is \"json-parse\", which parses a JSON string into an object.\n   */\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function compile<T = Record<string, unknown>>(\n  compileable: Compilable<T>,\n  options?: CompileOptions<T>,\n): Query<T> {\n  const compiledQuery = compileable.compile();\n\n  return {\n    parameters: compiledQuery.parameters,\n    sql: compiledQuery.sql,\n    transformations: options?.transformations,\n  };\n}\n\n/**\n * Applies a filter to the given rows based on the primary key columns of the table.\n *\n * @example db.selectFrom(\"users\").$call(applyInferredRowFilters(rows, columns)).selectAll()\n */\nexport function applyInferredRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]) {\n  const rowFilters = inferRowFilters(rows, columns);\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return <QB extends WhereInterface<any, any>>(qb: QB): QB =>\n    qb.where((eb) => {\n      return eb.or(\n        rowFilters.map((rowFilter) => {\n          return eb.and(\n            rowFilter.map(([columnName, value]) =>\n              eb(columnName, value === null ? \"is\" : Array.isArray(value) ? \"in\" : \"=\", value),\n            ),\n          );\n        }),\n      );\n    }) as never;\n}\n\n/**\n * Part of a filter that predicts a match.\n * ie. ... WHERE $ColumName = $Value ...\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype RowFilterPredicate = [ColumnName: string | Expression<any>, Value: unknown];\n\n/**\n * A row filter is comprised of one or more predicates.\n */\ntype RowFilter = RowFilterPredicate[];\n\n/**\n * Row filters is simply a set of multiple {@link RowFilter}.\n */\ntype RowFilters = RowFilter[];\n\n/**\n * Infers the filter that is necessary to uniquely identify a given row\n * individually.\n */\nexport function inferFilterObject(row: Record<string, unknown>, columns: Table[\"columns\"]): Record<string, unknown> {\n  const filter: Record<string, unknown> = {};\n\n  for (const column of Object.values(columns)) {\n    const { isInPrimaryKey, name: columnName } = column;\n\n    if (!isInPrimaryKey) {\n      continue;\n    }\n\n    filter[columnName] = row[columnName] ?? null;\n  }\n\n  return filter;\n}\n\n/**\n * Infers the filter that is necessary to uniquely identify multiple rows\n * individually.\n *\n * Elegantly infers the best possible statement to filter with.\n * TODO: introspect primary key ordinal numbers so the tuple is in the correct order.\n * TODO: if we ever support MSSQL, we'll need to drop to dumb (... and ...) or (... and ...) like in the old way just for MSSQL.\n *\n * For single column primary key:\n *\n * 1. if only 1 row: col = value\n * 2. if multiple rows: col IN (value1, value2, ...)\n *\n * For composite primary key:\n *\n * 1. if only 1 row: (col1, col2, ...) = (value1, value2, ...)\n * 2. if multiple rows: (col1, col2, ...) IN ((value1a, value2a, ...), (value1b, value2b, ...), ...)\n */\nexport function inferRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]): RowFilters {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const refs: ExpressionWrapper<any, any, any>[] = [];\n  const values: unknown[] = [];\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const eb = expressionBuilder<any, any>();\n\n  for (const row of rows) {\n    const valuesForRow: unknown[] = [];\n\n    for (const column of Object.values(columns)) {\n      const { isInPrimaryKey, name: columnName } = column;\n\n      if (!isInPrimaryKey) {\n        continue;\n      }\n\n      if (row === rows.at(0)) {\n        refs.push(eb.ref(columnName));\n      }\n\n      valuesForRow.push(transformValue(row[columnName] ?? null, column));\n    }\n\n    values.push(refs.length === 1 ? valuesForRow.at(0)! : tupleFrom(valuesForRow));\n  }\n\n  const lhs = refs.length === 1 ? refs.at(0)! : tupleFrom(refs);\n  const rhs = values.length === 1 ? values.at(0)! : values;\n\n  return [[[lhs, rhs]]];\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction tupleFrom(items: unknown[]): Expression<any> {\n  return sql`(${sql.join(items, sql`, `)})`;\n}\n\nexport function applyTransformations<C extends \"insert\" | \"update\">(\n  _context: C,\n  values: C extends \"update\" ? Record<string, unknown> : Record<string, unknown> | Record<string, unknown>[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): C extends \"update\" ? () => UpdateObject<any, any> : () => InsertObject<any, any> | InsertObject<any, any>[] {\n  return () =>\n    Array.isArray(values) ? values.map((row) => transformValues(row, columns)) : transformValues(values, columns);\n}\n\nfunction transformValues(\n  values: Record<string, unknown>,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): InsertObject<any, any> | UpdateObject<any, any> {\n  if (Object.keys(values).length === 0) {\n    return { [Object.keys(columns).at(0)!]: sql`default` };\n  }\n\n  return Object.entries(values).reduce(\n    (obj, [key, value]) => ({ ...obj, [key]: transformValue(value, columns[key]!) }),\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    {} as InsertObject<any, any> | UpdateObject<any, any>,\n  );\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function transformValue(value: unknown, column: Column): ExpressionWrapper<any, any, any> {\n  const { datatype } = column;\n\n  const eb = expressionBuilder();\n\n  if (value === null) {\n    return eb.lit(null);\n  }\n\n  if (!datatype.isNative) {\n    return eb.cast(eb.val(value), sql.id(datatype.schema, datatype.name));\n  }\n\n  return eb.val(value);\n}\n\nexport function getSelectFilterExpression(\n  filters: (ColumnFilter | FilterGroup)[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (filters.length === 0) return (eb) => eb.lit(true); // no filters, always true\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const orGroupsOfAndBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[][] = [];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let currentAndGroupBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[] = [];\n\n  for (let i = 0; i < filters.length; i++) {\n    currentAndGroupBuilders.push(buildBaseExpressionBuilder(filters[i]!, columns));\n\n    // &n AND group ends if it's the last filter, or the item is followed by an 'or'\n    if (i === filters.length - 1 || filters[i]!.after === \"or\") {\n      orGroupsOfAndBuilders.push(currentAndGroupBuilders);\n      currentAndGroupBuilders = []; // start a new group\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return (eb: ExpressionBuilder<any, any>) => {\n    const andExpressions = orGroupsOfAndBuilders.map((group) => {\n      return eb.and(group.map((builder) => builder(eb)));\n    });\n\n    return eb.or(andExpressions);\n  };\n}\n\n// Helper to build an expression builder for a single filter or a group\nfunction buildBaseExpressionBuilder(\n  spec: ColumnFilter | FilterGroup,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (spec.kind === \"ColumnFilter\") {\n    return (eb) => {\n      const { column, operator, value } = spec;\n\n      const columnMeta = columns[column]!;\n\n      return eb(\n        columnMeta.datatype.group === \"raw\" ? eb.cast(column, \"text\") : column,\n        operator,\n        transformValue(value, columnMeta),\n      );\n    };\n  }\n\n  return getSelectFilterExpression(spec.filters, columns);\n}\n", "import { asQuery, type Query } from \"../query\";\n\nexport function getPIDQuery(): Query<{ pid: unknown }> {\n  return asQuery(\"select pg_backend_pid() as pid\");\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport function getCancelQuery(pid: {}): Query<unknown> {\n  return {\n    parameters: [pid],\n    sql: \"select pg_cancel_backend($1);\",\n  };\n}\n"],
  "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,8BAAAE,IAAA,eAAAC,EAAAH,GCkBO,IAAMI,EAAN,cAAyB,KAAM,CACpC,aAAc,CACZ,MAAM,4BAA4B,EAClC,KAAK,KAAO,YACd,CACF,EAEO,SAASC,GAA+B,CAC7C,MAAO,CAAC,IAAID,CAAY,CAC1B,CCuDO,SAASE,EAAWC,EAA0C,CACnE,OAAI,OAAOA,GAAU,SACZ,CAAE,WAAY,CAAC,EAAG,IAAKA,CAAM,EAG/BA,CACT,CCtFO,SAASC,GAAuC,CACrD,OAAOC,EAAQ,gCAAgC,CACjD,CAGO,SAASC,EAAeC,EAAyB,CACtD,MAAO,CACL,WAAY,CAACA,CAAG,EAChB,IAAK,+BACP,CACF,CHNO,SAASC,EAAyBC,EAA2B,CAClE,MAAO,CACL,QAAS,MAAOC,EAAOC,IAAY,CACjC,GAAM,CAAE,YAAAC,CAAY,EAAID,GAAW,CAAC,EAEpC,GAAI,CAACC,EACH,GAAI,CAGF,MAAO,CAAC,KAFO,MAAMH,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAE9C,CAC/B,OAASG,EAAgB,CACvB,MAAO,CAACA,CAAc,CACxB,CAGF,GAAID,EAAY,QACd,OAAOE,EAAe,EAGxB,IAAIC,EACAC,EAEJ,GAAI,CACF,IAAIC,EACEC,EAAkB,IAAI,QAAeC,GAAaF,EAAUE,CAAQ,EAE1EP,EAAY,iBAAiB,QAAUG,EAAgB,IAAME,EAAQ,CAAE,EAEvE,IAAMG,EAAoBX,EAAW,QAAQ,EAEvCY,EAAmB,MAAM,QAAQ,KAAK,CAACD,EAAmBF,CAAe,CAAC,EAEhF,GAAI,CAACG,EACH,OAAKD,EAAkB,MAAM,IAAM,CAAC,CAAC,EAE9BN,EAAe,EAKxB,GAFAE,EAAaK,EAETT,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMQ,EAAaC,EAAiBP,CAAU,EAExCQ,EAAY,MAAM,QAAQ,KAAK,CAACF,EAAYJ,CAAe,CAAC,EAElE,GAAIM,IAAc,OAChB,OAAKF,EAAW,MAAM,IAAM,CAAC,CAAC,EAAE,QAAQ,IAAMN,GAAY,QAAQ,CAAC,EAE5DF,EAAe,EAGxB,GAAIF,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMW,EAAeT,EAAW,OAAON,EAAM,IAAKA,EAAM,UAAmB,EAErEgB,EAAc,MAAM,QAAQ,KAAK,CAACD,EAAcP,CAAe,CAAC,EAEtE,OAAKQ,GAQLV,EAAW,QAAQ,EAEZ,CAAC,KAAMU,CAAoB,IAT3B,QAAQ,WAAW,CAACC,EAAYlB,EAAYe,CAAU,EAAGC,CAAY,CAAC,EAAE,QAAQ,IACnFT,GAAY,QAAQ,CACtB,EAEOF,EAAe,EAM1B,OAASD,EAAgB,CACvB,OAAAG,GAAY,QAAQ,EAEb,CAACH,CAAc,CACxB,QAAE,CACIE,GACFH,GAAa,oBAAoB,QAASG,CAAa,CAE3D,CACF,CACF,CACF,CAGA,eAAeY,EAAYlB,EAAiBmB,EAAwB,CAClE,IAAMlB,EAAQmB,EAAeD,CAAG,EAEhC,GAAI,CACF,MAAMnB,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAC9D,OAASG,EAAO,CACd,QAAQ,MAAM,0BAA2BA,CAAK,CAChD,CACF,CAEA,eAAeU,EAAiBP,EAA2C,CACzE,IAAMN,EAAQoB,EAAY,EAE1B,GAAI,CACF,GAAM,CAACC,CAAM,EAAI,MAAMf,EAAW,OAAkCN,EAAM,IAAKA,EAAM,UAAmB,EAExG,OAAOqB,GAAQ,GACjB,OAASlB,EAAO,CACd,QAAQ,MAAM,gCAAiCA,CAAK,EAEpD,MACF,CACF",
  "names": ["postgresjs_exports", "__export", "createPostgresJSExecutor", "__toCommonJS", "AbortError", "getAbortResult", "asQuery", "query", "getPIDQuery", "asQuery", "getCancelQuery", "pid", "createPostgresJSExecutor", "postgresjs", "query", "options", "abortSignal", "error", "getAbortResult", "abortListener", "connection", "aborted", "abortionPromise", "resolve", "connectionPromise", "connectionResult", "pidPromise", "getConnectionPID", "pidResult", "queryPromise", "queryResult", "cancelQuery", "pid", "getCancelQuery", "getPIDQuery", "result"]
}

2
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/postgresjs/index.ts", "../../../data/executor.ts", "../../../data/query.ts", "../../../data/postgres-core/utility.ts"],
  "sourcesContent": ["import type { ReservedSql, Sql } from \"postgres\";\n\nimport { type Executor, getAbortResult } from \"../executor\";\nimport { getCancelQuery, getPIDQuery } from \"../postgres-core/utility\";\nimport type { QueryResult } from \"../query\";\n\nexport function createPostgresJSExecutor(postgresjs: Sql): Executor {\n  return {\n    execute: async (query, options) => {\n      const { abortSignal } = options || {};\n\n      if (!abortSignal) {\n        try {\n          const result = await postgresjs.unsafe(query.sql, query.parameters as never);\n\n          return [null, result as never];\n        } catch (error: unknown) {\n          return [error as Error];\n        }\n      }\n\n      if (abortSignal.aborted) {\n        return getAbortResult();\n      }\n\n      let abortListener: (() => void) | undefined;\n      let connection: ReservedSql | undefined;\n\n      try {\n        let aborted: () => void;\n        const abortionPromise = new Promise<void>((resolve) => (aborted = resolve));\n\n        abortSignal.addEventListener(\"abort\", (abortListener = () => aborted()));\n\n        const connectionPromise = postgresjs.reserve();\n\n        const connectionResult = await Promise.race([connectionPromise, abortionPromise]);\n\n        if (!connectionResult) {\n          void connectionPromise.catch(() => {});\n\n          return getAbortResult();\n        }\n\n        connection = connectionResult;\n\n        if (abortSignal.aborted) {\n          connection.release();\n\n          return getAbortResult();\n        }\n\n        const pidPromise = getConnectionPID(connection);\n\n        const pidResult = await Promise.race([pidPromise, abortionPromise]);\n\n        if (pidResult === undefined) {\n          void pidPromise.catch(() => {}).finally(() => connection?.release());\n\n          return getAbortResult();\n        }\n\n        if (abortSignal.aborted) {\n          connection.release();\n\n          return getAbortResult();\n        }\n\n        const queryPromise = connection.unsafe(query.sql, query.parameters as never);\n\n        const queryResult = await Promise.race([queryPromise, abortionPromise]);\n\n        if (!queryResult) {\n          void Promise.allSettled([cancelQuery(postgresjs, pidResult!), queryPromise]).finally(() =>\n            connection?.release(),\n          );\n\n          return getAbortResult();\n        }\n\n        connection.release();\n\n        return [null, queryResult as never];\n      } catch (error: unknown) {\n        connection?.release();\n\n        return [error as Error];\n      } finally {\n        if (abortListener) {\n          abortSignal?.removeEventListener(\"abort\", abortListener);\n        }\n      }\n    },\n  };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nasync function cancelQuery(postgresjs: Sql, pid: {}): Promise<void> {\n  const query = getCancelQuery(pid);\n\n  try {\n    await postgresjs.unsafe(query.sql, query.parameters as never);\n  } catch (error) {\n    console.error(\"Failed to cancel query:\", error);\n  }\n}\n\nasync function getConnectionPID(connection: ReservedSql): Promise<unknown> {\n  const query = getPIDQuery();\n\n  try {\n    const [result] = await connection.unsafe<QueryResult<typeof query>>(query.sql, query.parameters as never);\n\n    return result?.pid;\n  } catch (error) {\n    console.error(\"Failed to get connection PID:\", error);\n\n    return undefined;\n  }\n}\n", "import type { Query, QueryResult } from \"./query\";\nimport type { Either } from \"./type-utils\";\n\nexport interface Executor {\n  execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;\n}\n\nexport interface SequenceExecutor extends Executor {\n  executeSequence<T, S>(\n    sequence: readonly [Query<T>, Query<S>],\n    options?: ExecuteOptions,\n  ): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;\n}\n\nexport interface ExecuteOptions {\n  abortSignal?: AbortSignal;\n}\n\nexport class AbortError extends Error {\n  constructor() {\n    super(\"This operation was aborted\");\n    this.name = \"AbortError\";\n  }\n}\n\nexport function getAbortResult(): [AbortError] {\n  return [new AbortError()];\n}\n", "import {\n  type Compilable,\n  type DialectAdapter,\n  DummyDriver,\n  type Expression,\n  type ExpressionBuilder,\n  expressionBuilder,\n  type ExpressionWrapper,\n  type InsertObject,\n  Kysely,\n  type KyselyPlugin,\n  OperationNodeTransformer,\n  type PluginTransformQueryArgs,\n  type PluginTransformResultArgs,\n  type PrimitiveValueListNode,\n  type QueryCompiler,\n  type QueryResult as KyselyQueryResult,\n  type RootOperationNode,\n  sql,\n  type SqlBool,\n  type UnknownRow,\n  type UpdateObject,\n  ValueListNode,\n  ValueNode,\n  type WhereInterface,\n} from \"kysely\";\n\nimport type { Column, ColumnFilter, FilterGroup, Table } from \"./adapter\";\n\nexport interface BuilderRequirements {\n  Adapter: { new (): DialectAdapter };\n  noParameters?: boolean;\n  QueryCompiler: { new (): QueryCompiler };\n}\n\nexport function getBuilder<DB>(requirements: BuilderRequirements): Kysely<DB> {\n  return new Kysely({\n    dialect: {\n      createAdapter: () => new requirements.Adapter(),\n      createDriver: () => new DummyDriver(),\n      // @ts-expect-error - we don't need built-in introspection in this case\n      createIntrospector: () => null,\n      createQueryCompiler: () => new requirements.QueryCompiler(),\n    },\n    plugins: [...(requirements.noParameters ? [new ImmediateValuePlugin()] : [])],\n  });\n}\n\n/**\n * A plugin that transforms all values to immediate values. This means their injected into the SQL string instead of populating the parameters array.\n * In some situations, a database driver might not support parameters, and this plugin can be used to work around that.\n */\nclass ImmediateValuePlugin implements KyselyPlugin {\n  readonly #transformer = new ImmediateValueTransformer();\n\n  transformQuery(args: PluginTransformQueryArgs): RootOperationNode {\n    return this.#transformer.transformNode(args.node);\n  }\n\n  transformResult(args: PluginTransformResultArgs): Promise<KyselyQueryResult<UnknownRow>> {\n    return Promise.resolve(args.result);\n  }\n}\n\nclass ImmediateValueTransformer extends OperationNodeTransformer {\n  protected override transformPrimitiveValueList(node: PrimitiveValueListNode): PrimitiveValueListNode {\n    return ValueListNode.create(node.values.map(ValueNode.createImmediate)) as never;\n  }\n\n  override transformValue(node: ValueNode): ValueNode {\n    return { ...super.transformValue(node), immediate: true };\n  }\n}\n\ndeclare const queryType: unique symbol;\nexport interface Query<T = Record<string, unknown>> {\n  [queryType]?: T;\n  parameters: readonly unknown[];\n  sql: string;\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function asQuery<T>(query: string | Query<unknown>): Query<T> {\n  if (typeof query === \"string\") {\n    return { parameters: [], sql: query } as never;\n  }\n\n  return query as never;\n}\n\nexport type QueryResult<T> =\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  T extends Query<infer R> ? R[] : T extends (...args: any[]) => Query<infer R> ? R[] : never;\n\nexport interface CompileOptions<T> {\n  /**\n   * A mapping of column names to transformations that should be applied to the result.\n   * Currently supported transformation is \"json-parse\", which parses a JSON string into an object.\n   */\n  transformations?: Partial<Record<keyof T, \"json-parse\">>;\n}\n\nexport function compile<T = Record<string, unknown>>(\n  compileable: Compilable<T>,\n  options?: CompileOptions<T>,\n): Query<T> {\n  const compiledQuery = compileable.compile();\n\n  return {\n    parameters: compiledQuery.parameters,\n    sql: compiledQuery.sql,\n    transformations: options?.transformations,\n  };\n}\n\n/**\n * Applies a filter to the given rows based on the primary key columns of the table.\n *\n * @example db.selectFrom(\"users\").$call(applyInferredRowFilters(rows, columns)).selectAll()\n */\nexport function applyInferredRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]) {\n  const rowFilters = inferRowFilters(rows, columns);\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return <QB extends WhereInterface<any, any>>(qb: QB): QB =>\n    qb.where((eb) => {\n      return eb.or(\n        rowFilters.map((rowFilter) => {\n          return eb.and(\n            rowFilter.map(([columnName, value]) =>\n              eb(columnName, value === null ? \"is\" : Array.isArray(value) ? \"in\" : \"=\", value),\n            ),\n          );\n        }),\n      );\n    }) as never;\n}\n\n/**\n * Part of a filter that predicts a match.\n * ie. ... WHERE $ColumName = $Value ...\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype RowFilterPredicate = [ColumnName: string | Expression<any>, Value: unknown];\n\n/**\n * A row filter is comprised of one or more predicates.\n */\ntype RowFilter = RowFilterPredicate[];\n\n/**\n * Row filters is simply a set of multiple {@link RowFilter}.\n */\ntype RowFilters = RowFilter[];\n\n/**\n * Infers the filter that is necessary to uniquely identify a given row\n * individually.\n */\nexport function inferFilterObject(row: Record<string, unknown>, columns: Table[\"columns\"]): Record<string, unknown> {\n  const filter: Record<string, unknown> = {};\n\n  for (const column of Object.values(columns)) {\n    const { isInPrimaryKey, name: columnName } = column;\n\n    if (!isInPrimaryKey) {\n      continue;\n    }\n\n    filter[columnName] = row[columnName] ?? null;\n  }\n\n  return filter;\n}\n\n/**\n * Infers the filter that is necessary to uniquely identify multiple rows\n * individually.\n *\n * Elegantly infers the best possible statement to filter with.\n * TODO: introspect primary key ordinal numbers so the tuple is in the correct order.\n * TODO: if we ever support MSSQL, we'll need to drop to dumb (... and ...) or (... and ...) like in the old way just for MSSQL.\n *\n * For single column primary key:\n *\n * 1. if only 1 row: col = value\n * 2. if multiple rows: col IN (value1, value2, ...)\n *\n * For composite primary key:\n *\n * 1. if only 1 row: (col1, col2, ...) = (value1, value2, ...)\n * 2. if multiple rows: (col1, col2, ...) IN ((value1a, value2a, ...), (value1b, value2b, ...), ...)\n */\nexport function inferRowFilters(rows: Record<string, unknown>[], columns: Table[\"columns\"]): RowFilters {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const refs: ExpressionWrapper<any, any, any>[] = [];\n  const values: unknown[] = [];\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const eb = expressionBuilder<any, any>();\n\n  for (const row of rows) {\n    const valuesForRow: unknown[] = [];\n\n    for (const column of Object.values(columns)) {\n      const { isInPrimaryKey, name: columnName } = column;\n\n      if (!isInPrimaryKey) {\n        continue;\n      }\n\n      if (row === rows.at(0)) {\n        refs.push(eb.ref(columnName));\n      }\n\n      valuesForRow.push(transformValue(row[columnName] ?? null, column));\n    }\n\n    values.push(refs.length === 1 ? valuesForRow.at(0)! : tupleFrom(valuesForRow));\n  }\n\n  const lhs = refs.length === 1 ? refs.at(0)! : tupleFrom(refs);\n  const rhs = values.length === 1 ? values.at(0)! : values;\n\n  return [[[lhs, rhs]]];\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction tupleFrom(items: unknown[]): Expression<any> {\n  return sql`(${sql.join(items, sql`, `)})`;\n}\n\nexport function applyTransformations<C extends \"insert\" | \"update\">(\n  _context: C,\n  values: C extends \"update\" ? Record<string, unknown> : Record<string, unknown> | Record<string, unknown>[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): C extends \"update\" ? () => UpdateObject<any, any> : () => InsertObject<any, any> | InsertObject<any, any>[] {\n  return () =>\n    Array.isArray(values) ? values.map((row) => transformValues(row, columns)) : transformValues(values, columns);\n}\n\nfunction transformValues(\n  values: Record<string, unknown>,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): InsertObject<any, any> | UpdateObject<any, any> {\n  if (Object.keys(values).length === 0) {\n    return { [Object.keys(columns).at(0)!]: sql`default` };\n  }\n\n  return Object.entries(values).reduce(\n    (obj, [key, value]) => ({ ...obj, [key]: transformValue(value, columns[key]!) }),\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    {} as InsertObject<any, any> | UpdateObject<any, any>,\n  );\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function transformValue(value: unknown, column: Column): ExpressionWrapper<any, any, any> {\n  const { datatype } = column;\n\n  const eb = expressionBuilder();\n\n  if (value === null) {\n    return eb.lit(null);\n  }\n\n  if (!datatype.isNative) {\n    return eb.cast(eb.val(value), sql.id(datatype.schema, datatype.name));\n  }\n\n  return eb.val(value);\n}\n\nexport function getSelectFilterExpression(\n  filters: (ColumnFilter | FilterGroup)[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (filters.length === 0) return (eb) => eb.lit(true); // no filters, always true\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const orGroupsOfAndBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[][] = [];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let currentAndGroupBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[] = [];\n\n  for (let i = 0; i < filters.length; i++) {\n    currentAndGroupBuilders.push(buildBaseExpressionBuilder(filters[i]!, columns));\n\n    // &n AND group ends if it's the last filter, or the item is followed by an 'or'\n    if (i === filters.length - 1 || filters[i]!.after === \"or\") {\n      orGroupsOfAndBuilders.push(currentAndGroupBuilders);\n      currentAndGroupBuilders = []; // start a new group\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return (eb: ExpressionBuilder<any, any>) => {\n    const andExpressions = orGroupsOfAndBuilders.map((group) => {\n      return eb.and(group.map((builder) => builder(eb)));\n    });\n\n    return eb.or(andExpressions);\n  };\n}\n\n// Helper to build an expression builder for a single filter or a group\nfunction buildBaseExpressionBuilder(\n  spec: ColumnFilter | FilterGroup,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (spec.kind === \"ColumnFilter\") {\n    return (eb) => {\n      const { column, operator, value } = spec;\n\n      const columnMeta = columns[column]!;\n\n      return eb(\n        columnMeta.datatype.group === \"raw\" ? eb.cast(column, \"text\") : column,\n        operator,\n        transformValue(value, columnMeta),\n      );\n    };\n  }\n\n  return getSelectFilterExpression(spec.filters, columns);\n}\n", "import { asQuery, type Query } from \"../query\";\n\nexport function getPIDQuery(): Query<{ pid: unknown }> {\n  return asQuery(\"select pg_backend_pid() as pid\");\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport function getCancelQuery(pid: {}): Query<unknown> {\n  return {\n    parameters: [pid],\n    sql: \"select pg_cancel_backend($1);\",\n  };\n}\n"],
  "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,8BAAAE,IAAA,eAAAC,EAAAH,GCkBO,IAAMI,EAAN,cAAyB,KAAM,CACpC,aAAc,CACZ,MAAM,4BAA4B,EAClC,KAAK,KAAO,YACd,CACF,EAEO,SAASC,GAA+B,CAC7C,MAAO,CAAC,IAAID,CAAY,CAC1B,CCuDO,SAASE,EAAWC,EAA0C,CACnE,OAAI,OAAOA,GAAU,SACZ,CAAE,WAAY,CAAC,EAAG,IAAKA,CAAM,EAG/BA,CACT,CCtFO,SAASC,GAAuC,CACrD,OAAOC,EAAQ,gCAAgC,CACjD,CAGO,SAASC,EAAeC,EAAyB,CACtD,MAAO,CACL,WAAY,CAACA,CAAG,EAChB,IAAK,+BACP,CACF,CHNO,SAASC,EAAyBC,EAA2B,CAClE,MAAO,CACL,QAAS,MAAOC,EAAOC,IAAY,CACjC,GAAM,CAAE,YAAAC,CAAY,EAAID,GAAW,CAAC,EAEpC,GAAI,CAACC,EACH,GAAI,CAGF,MAAO,CAAC,KAFO,MAAMH,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAE9C,CAC/B,OAASG,EAAgB,CACvB,MAAO,CAACA,CAAc,CACxB,CAGF,GAAID,EAAY,QACd,OAAOE,EAAe,EAGxB,IAAIC,EACAC,EAEJ,GAAI,CACF,IAAIC,EACEC,EAAkB,IAAI,QAAeC,GAAaF,EAAUE,CAAQ,EAE1EP,EAAY,iBAAiB,QAAUG,EAAgB,IAAME,EAAQ,CAAE,EAEvE,IAAMG,EAAoBX,EAAW,QAAQ,EAEvCY,EAAmB,MAAM,QAAQ,KAAK,CAACD,EAAmBF,CAAe,CAAC,EAEhF,GAAI,CAACG,EACH,OAAKD,EAAkB,MAAM,IAAM,CAAC,CAAC,EAE9BN,EAAe,EAKxB,GAFAE,EAAaK,EAETT,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMQ,EAAaC,EAAiBP,CAAU,EAExCQ,EAAY,MAAM,QAAQ,KAAK,CAACF,EAAYJ,CAAe,CAAC,EAElE,GAAIM,IAAc,OAChB,OAAKF,EAAW,MAAM,IAAM,CAAC,CAAC,EAAE,QAAQ,IAAMN,GAAY,QAAQ,CAAC,EAE5DF,EAAe,EAGxB,GAAIF,EAAY,QACd,OAAAI,EAAW,QAAQ,EAEZF,EAAe,EAGxB,IAAMW,EAAeT,EAAW,OAAON,EAAM,IAAKA,EAAM,UAAmB,EAErEgB,EAAc,MAAM,QAAQ,KAAK,CAACD,EAAcP,CAAe,CAAC,EAEtE,OAAKQ,GAQLV,EAAW,QAAQ,EAEZ,CAAC,KAAMU,CAAoB,IAT3B,QAAQ,WAAW,CAACC,EAAYlB,EAAYe,CAAU,EAAGC,CAAY,CAAC,EAAE,QAAQ,IACnFT,GAAY,QAAQ,CACtB,EAEOF,EAAe,EAM1B,OAASD,EAAgB,CACvB,OAAAG,GAAY,QAAQ,EAEb,CAACH,CAAc,CACxB,QAAE,CACIE,GACFH,GAAa,oBAAoB,QAASG,CAAa,CAE3D,CACF,CACF,CACF,CAGA,eAAeY,EAAYlB,EAAiBmB,EAAwB,CAClE,IAAMlB,EAAQmB,EAAeD,CAAG,EAEhC,GAAI,CACF,MAAMnB,EAAW,OAAOC,EAAM,IAAKA,EAAM,UAAmB,CAC9D,OAASG,EAAO,CACd,QAAQ,MAAM,0BAA2BA,CAAK,CAChD,CACF,CAEA,eAAeU,EAAiBP,EAA2C,CACzE,IAAMN,EAAQoB,EAAY,EAE1B,GAAI,CACF,GAAM,CAACC,CAAM,EAAI,MAAMf,EAAW,OAAkCN,EAAM,IAAKA,EAAM,UAAmB,EAExG,OAAOqB,GAAQ,GACjB,OAASlB,EAAO,CACd,QAAQ,MAAM,gCAAiCA,CAAK,EAEpD,MACF,CACF",
  "names": ["postgresjs_exports", "__export", "createPostgresJSExecutor", "__toCommonJS", "AbortError", "getAbortResult", "asQuery", "query", "getPIDQuery", "asQuery", "getCancelQuery", "pid", "createPostgresJSExecutor", "postgresjs", "query", "options", "abortSignal", "error", "getAbortResult", "abortListener", "connection", "aborted", "abortionPromise", "resolve", "connectionPromise", "connectionResult", "pidPromise", "getConnectionPID", "pidResult", "queryPromise", "queryResult", "cancelQuery", "pid", "getCancelQuery", "getPIDQuery", "result"]
}

@@ -1,5 +1,5 @@
1
1
  import { Sql } from 'postgres';
2
- import { E as Executor } from '../../index-CV9DQF9a.cjs';
2
+ import { c as Executor } from '../../index-CW6rqTos.cjs';
3
3
  import 'kysely';
4
4
 
5
5
  declare function createPostgresJSExecutor(postgresjs: Sql): Executor;
@@ -1,5 +1,5 @@
1
1
  import { Sql } from 'postgres';
2
- import { E as Executor } from '../../index-CV9DQF9a.js';
2
+ import { c as Executor } from '../../index-CW6rqTos.js';
3
3
  import 'kysely';
4
4
 
5
5
  declare function createPostgresJSExecutor(postgresjs: Sql): Executor;
@@ -6,5 +6,5 @@ function require(mod) {
6
6
  if (mod === 'react-dom') return ___react_dom___;
7
7
  throw new Error(`Unknown module ${mod}`);
8
8
  }
9
- import{b as s}from"../../chunk-NQGSK3IM.js";import{a as p,b as P}from"../../chunk-M7E5UEO3.js";import"../../chunk-A6CVKSUD.js";import{e as v}from"../../chunk-GDQBQ7MK.js";v();function g(o){return{execute:async(e,t)=>{let{abortSignal:n}=t||{};if(!n)try{return[null,await o.unsafe(e.sql,e.parameters)]}catch(a){return[a]}if(n.aborted)return s();let i,r;try{let a,c=new Promise(q=>a=q);n.addEventListener("abort",i=()=>a());let u=o.reserve(),l=await Promise.race([u,c]);if(!l)return u.catch(()=>{}),s();if(r=l,n.aborted)return r.release(),s();let d=w(r),f=await Promise.race([d,c]);if(f===void 0)return d.catch(()=>{}).finally(()=>r?.release()),s();if(n.aborted)return r.release(),s();let m=r.unsafe(e.sql,e.parameters),y=await Promise.race([m,c]);return y?(r.release(),[null,y]):(Promise.allSettled([b(o,f),m]).finally(()=>r?.release()),s())}catch(a){return r?.release(),[a]}finally{i&&n?.removeEventListener("abort",i)}}}}async function b(o,e){let t=P(e);try{await o.unsafe(t.sql,t.parameters)}catch(n){console.error("Failed to cancel query:",n)}}async function w(o){let e=p();try{let[t]=await o.unsafe(e.sql,e.parameters);return t?.pid}catch(t){console.error("Failed to get connection PID:",t);return}}export{g as createPostgresJSExecutor};
9
+ import{b as s}from"../../chunk-SXTJF4PD.js";import{a as p,b as P}from"../../chunk-M7E5UEO3.js";import"../../chunk-A6CVKSUD.js";import{e as v}from"../../chunk-GDQBQ7MK.js";v();function g(o){return{execute:async(e,t)=>{let{abortSignal:n}=t||{};if(!n)try{return[null,await o.unsafe(e.sql,e.parameters)]}catch(a){return[a]}if(n.aborted)return s();let i,r;try{let a,c=new Promise(q=>a=q);n.addEventListener("abort",i=()=>a());let u=o.reserve(),l=await Promise.race([u,c]);if(!l)return u.catch(()=>{}),s();if(r=l,n.aborted)return r.release(),s();let d=w(r),f=await Promise.race([d,c]);if(f===void 0)return d.catch(()=>{}).finally(()=>r?.release()),s();if(n.aborted)return r.release(),s();let m=r.unsafe(e.sql,e.parameters),y=await Promise.race([m,c]);return y?(r.release(),[null,y]):(Promise.allSettled([b(o,f),m]).finally(()=>r?.release()),s())}catch(a){return r?.release(),[a]}finally{i&&n?.removeEventListener("abort",i)}}}}async function b(o,e){let t=P(e);try{await o.unsafe(t.sql,t.parameters)}catch(n){console.error("Failed to cancel query:",n)}}async function w(o){let e=p();try{let[t]=await o.unsafe(e.sql,e.parameters);return t?.pid}catch(t){console.error("Failed to get connection PID:",t);return}}export{g as createPostgresJSExecutor};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9wb3N0Z3Jlc2pzL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgdHlwZSB7IFJlc2VydmVkU3FsLCBTcWwgfSBmcm9tIFwicG9zdGdyZXNcIjtcblxuaW1wb3J0IHsgdHlwZSBFeGVjdXRvciwgZ2V0QWJvcnRSZXN1bHQgfSBmcm9tIFwiLi4vZXhlY3V0b3JcIjtcbmltcG9ydCB7IGdldENhbmNlbFF1ZXJ5LCBnZXRQSURRdWVyeSB9IGZyb20gXCIuLi9wb3N0Z3Jlcy1jb3JlL3V0aWxpdHlcIjtcbmltcG9ydCB0eXBlIHsgUXVlcnlSZXN1bHQgfSBmcm9tIFwiLi4vcXVlcnlcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVBvc3RncmVzSlNFeGVjdXRvcihwb3N0Z3Jlc2pzOiBTcWwpOiBFeGVjdXRvciB7XG4gIHJldHVybiB7XG4gICAgZXhlY3V0ZTogYXN5bmMgKHF1ZXJ5LCBvcHRpb25zKSA9PiB7XG4gICAgICBjb25zdCB7IGFib3J0U2lnbmFsIH0gPSBvcHRpb25zIHx8IHt9O1xuXG4gICAgICBpZiAoIWFib3J0U2lnbmFsKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcG9zdGdyZXNqcy51bnNhZmUocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyKTtcblxuICAgICAgICAgIHJldHVybiBbbnVsbCwgcmVzdWx0IGFzIG5ldmVyXTtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoYWJvcnRTaWduYWwuYWJvcnRlZCkge1xuICAgICAgICByZXR1cm4gZ2V0QWJvcnRSZXN1bHQoKTtcbiAgICAgIH1cblxuICAgICAgbGV0IGFib3J0TGlzdGVuZXI6ICgoKSA9PiB2b2lkKSB8IHVuZGVmaW5lZDtcbiAgICAgIGxldCBjb25uZWN0aW9uOiBSZXNlcnZlZFNxbCB8IHVuZGVmaW5lZDtcblxuICAgICAgdHJ5IHtcbiAgICAgICAgbGV0IGFib3J0ZWQ6ICgpID0+IHZvaWQ7XG4gICAgICAgIGNvbnN0IGFib3J0aW9uUHJvbWlzZSA9IG5ldyBQcm9taXNlPHZvaWQ+KChyZXNvbHZlKSA9PiAoYWJvcnRlZCA9IHJlc29sdmUpKTtcblxuICAgICAgICBhYm9ydFNpZ25hbC5hZGRFdmVudExpc3RlbmVyKFwiYWJvcnRcIiwgKGFib3J0TGlzdGVuZXIgPSAoKSA9PiBhYm9ydGVkKCkpKTtcblxuICAgICAgICBjb25zdCBjb25uZWN0aW9uUHJvbWlzZSA9IHBvc3RncmVzanMucmVzZXJ2ZSgpO1xuXG4gICAgICAgIGNvbnN0IGNvbm5lY3Rpb25SZXN1bHQgPSBhd2FpdCBQcm9taXNlLnJhY2UoW2Nvbm5lY3Rpb25Qcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAoIWNvbm5lY3Rpb25SZXN1bHQpIHtcbiAgICAgICAgICB2b2lkIGNvbm5lY3Rpb25Qcm9taXNlLmNhdGNoKCgpID0+IHt9KTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29ubmVjdGlvbiA9IGNvbm5lY3Rpb25SZXN1bHQ7XG5cbiAgICAgICAgaWYgKGFib3J0U2lnbmFsLmFib3J0ZWQpIHtcbiAgICAgICAgICBjb25uZWN0aW9uLnJlbGVhc2UoKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcGlkUHJvbWlzZSA9IGdldENvbm5lY3Rpb25QSUQoY29ubmVjdGlvbik7XG5cbiAgICAgICAgY29uc3QgcGlkUmVzdWx0ID0gYXdhaXQgUHJvbWlzZS5yYWNlKFtwaWRQcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAocGlkUmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICB2b2lkIHBpZFByb21pc2UuY2F0Y2goKCkgPT4ge30pLmZpbmFsbHkoKCkgPT4gY29ubmVjdGlvbj8ucmVsZWFzZSgpKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGFib3J0U2lnbmFsLmFib3J0ZWQpIHtcbiAgICAgICAgICBjb25uZWN0aW9uLnJlbGVhc2UoKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcXVlcnlQcm9taXNlID0gY29ubmVjdGlvbi51bnNhZmUocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyKTtcblxuICAgICAgICBjb25zdCBxdWVyeVJlc3VsdCA9IGF3YWl0IFByb21pc2UucmFjZShbcXVlcnlQcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAoIXF1ZXJ5UmVzdWx0KSB7XG4gICAgICAgICAgdm9pZCBQcm9taXNlLmFsbFNldHRsZWQoW2NhbmNlbFF1ZXJ5KHBvc3RncmVzanMsIHBpZFJlc3VsdCEpLCBxdWVyeVByb21pc2VdKS5maW5hbGx5KCgpID0+XG4gICAgICAgICAgICBjb25uZWN0aW9uPy5yZWxlYXNlKCksXG4gICAgICAgICAgKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29ubmVjdGlvbi5yZWxlYXNlKCk7XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCBxdWVyeVJlc3VsdCBhcyBuZXZlcl07XG4gICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICBjb25uZWN0aW9uPy5yZWxlYXNlKCk7XG5cbiAgICAgICAgcmV0dXJuIFtlcnJvciBhcyBFcnJvcl07XG4gICAgICB9IGZpbmFsbHkge1xuICAgICAgICBpZiAoYWJvcnRMaXN0ZW5lcikge1xuICAgICAgICAgIGFib3J0U2lnbmFsPy5yZW1vdmVFdmVudExpc3RlbmVyKFwiYWJvcnRcIiwgYWJvcnRMaXN0ZW5lcik7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICB9O1xufVxuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LW9iamVjdC10eXBlXG5hc3luYyBmdW5jdGlvbiBjYW5jZWxRdWVyeShwb3N0Z3Jlc2pzOiBTcWwsIHBpZDoge30pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgcXVlcnkgPSBnZXRDYW5jZWxRdWVyeShwaWQpO1xuXG4gIHRyeSB7XG4gICAgYXdhaXQgcG9zdGdyZXNqcy51bnNhZmUocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzIGFzIG5ldmVyKTtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBjb25zb2xlLmVycm9yKFwiRmFpbGVkIHRvIGNhbmNlbCBxdWVyeTpcIiwgZXJyb3IpO1xuICB9XG59XG5cbmFzeW5jIGZ1bmN0aW9uIGdldENvbm5lY3Rpb25QSUQoY29ubmVjdGlvbjogUmVzZXJ2ZWRTcWwpOiBQcm9taXNlPHVua25vd24+IHtcbiAgY29uc3QgcXVlcnkgPSBnZXRQSURRdWVyeSgpO1xuXG4gIHRyeSB7XG4gICAgY29uc3QgW3Jlc3VsdF0gPSBhd2FpdCBjb25uZWN0aW9uLnVuc2FmZTxRdWVyeVJlc3VsdDx0eXBlb2YgcXVlcnk+PihxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMgYXMgbmV2ZXIpO1xuXG4gICAgcmV0dXJuIHJlc3VsdD8ucGlkO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoXCJGYWlsZWQgdG8gZ2V0IGNvbm5lY3Rpb24gUElEOlwiLCBlcnJvcik7XG5cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7OzsyS0FBQUEsSUFNTyxTQUFTQyxFQUF5QkMsRUFBMkIsQ0FDbEUsTUFBTyxDQUNMLFFBQVMsTUFBT0MsRUFBT0MsSUFBWSxDQUNqQyxHQUFNLENBQUUsWUFBQUMsQ0FBWSxFQUFJRCxHQUFXLENBQUMsRUFFcEMsR0FBSSxDQUFDQyxFQUNILEdBQUksQ0FHRixNQUFPLENBQUMsS0FGTyxNQUFNSCxFQUFXLE9BQU9DLEVBQU0sSUFBS0EsRUFBTSxVQUFtQixDQUU5QyxDQUMvQixPQUFTRyxFQUFnQixDQUN2QixNQUFPLENBQUNBLENBQWMsQ0FDeEIsQ0FHRixHQUFJRCxFQUFZLFFBQ2QsT0FBT0UsRUFBZSxFQUd4QixJQUFJQyxFQUNBQyxFQUVKLEdBQUksQ0FDRixJQUFJQyxFQUNFQyxFQUFrQixJQUFJLFFBQWVDLEdBQWFGLEVBQVVFLENBQVEsRUFFMUVQLEVBQVksaUJBQWlCLFFBQVVHLEVBQWdCLElBQU1FLEVBQVEsQ0FBRSxFQUV2RSxJQUFNRyxFQUFvQlgsRUFBVyxRQUFRLEVBRXZDWSxFQUFtQixNQUFNLFFBQVEsS0FBSyxDQUFDRCxFQUFtQkYsQ0FBZSxDQUFDLEVBRWhGLEdBQUksQ0FBQ0csRUFDSCxPQUFLRCxFQUFrQixNQUFNLElBQU0sQ0FBQyxDQUFDLEVBRTlCTixFQUFlLEVBS3hCLEdBRkFFLEVBQWFLLEVBRVRULEVBQVksUUFDZCxPQUFBSSxFQUFXLFFBQVEsRUFFWkYsRUFBZSxFQUd4QixJQUFNUSxFQUFhQyxFQUFpQlAsQ0FBVSxFQUV4Q1EsRUFBWSxNQUFNLFFBQVEsS0FBSyxDQUFDRixFQUFZSixDQUFlLENBQUMsRUFFbEUsR0FBSU0sSUFBYyxPQUNoQixPQUFLRixFQUFXLE1BQU0sSUFBTSxDQUFDLENBQUMsRUFBRSxRQUFRLElBQU1OLEdBQVksUUFBUSxDQUFDLEVBRTVERixFQUFlLEVBR3hCLEdBQUlGLEVBQVksUUFDZCxPQUFBSSxFQUFXLFFBQVEsRUFFWkYsRUFBZSxFQUd4QixJQUFNVyxFQUFlVCxFQUFXLE9BQU9OLEVBQU0sSUFBS0EsRUFBTSxVQUFtQixFQUVyRWdCLEVBQWMsTUFBTSxRQUFRLEtBQUssQ0FBQ0QsRUFBY1AsQ0FBZSxDQUFDLEVBRXRFLE9BQUtRLEdBUUxWLEVBQVcsUUFBUSxFQUVaLENBQUMsS0FBTVUsQ0FBb0IsSUFUM0IsUUFBUSxXQUFXLENBQUNDLEVBQVlsQixFQUFZZSxDQUFVLEVBQUdDLENBQVksQ0FBQyxFQUFFLFFBQVEsSUFDbkZULEdBQVksUUFBUSxDQUN0QixFQUVPRixFQUFlLEVBTTFCLE9BQVNELEVBQWdCLENBQ3ZCLE9BQUFHLEdBQVksUUFBUSxFQUViLENBQUNILENBQWMsQ0FDeEIsUUFBRSxDQUNJRSxHQUNGSCxHQUFhLG9CQUFvQixRQUFTRyxDQUFhLENBRTNELENBQ0YsQ0FDRixDQUNGLENBR0EsZUFBZVksRUFBWWxCLEVBQWlCbUIsRUFBd0IsQ0FDbEUsSUFBTWxCLEVBQVFtQixFQUFlRCxDQUFHLEVBRWhDLEdBQUksQ0FDRixNQUFNbkIsRUFBVyxPQUFPQyxFQUFNLElBQUtBLEVBQU0sVUFBbUIsQ0FDOUQsT0FBU0csRUFBTyxDQUNkLFFBQVEsTUFBTSwwQkFBMkJBLENBQUssQ0FDaEQsQ0FDRixDQUVBLGVBQWVVLEVBQWlCUCxFQUEyQyxDQUN6RSxJQUFNTixFQUFRb0IsRUFBWSxFQUUxQixHQUFJLENBQ0YsR0FBTSxDQUFDQyxDQUFNLEVBQUksTUFBTWYsRUFBVyxPQUFrQ04sRUFBTSxJQUFLQSxFQUFNLFVBQW1CLEVBRXhHLE9BQU9xQixHQUFRLEdBQ2pCLE9BQVNsQixFQUFPLENBQ2QsUUFBUSxNQUFNLGdDQUFpQ0EsQ0FBSyxFQUVwRCxNQUNGLENBQ0YiLAogICJuYW1lcyI6IFsiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiLCAiY3JlYXRlUG9zdGdyZXNKU0V4ZWN1dG9yIiwgInBvc3RncmVzanMiLCAicXVlcnkiLCAib3B0aW9ucyIsICJhYm9ydFNpZ25hbCIsICJlcnJvciIsICJnZXRBYm9ydFJlc3VsdCIsICJhYm9ydExpc3RlbmVyIiwgImNvbm5lY3Rpb24iLCAiYWJvcnRlZCIsICJhYm9ydGlvblByb21pc2UiLCAicmVzb2x2ZSIsICJjb25uZWN0aW9uUHJvbWlzZSIsICJjb25uZWN0aW9uUmVzdWx0IiwgInBpZFByb21pc2UiLCAiZ2V0Q29ubmVjdGlvblBJRCIsICJwaWRSZXN1bHQiLCAicXVlcnlQcm9taXNlIiwgInF1ZXJ5UmVzdWx0IiwgImNhbmNlbFF1ZXJ5IiwgInBpZCIsICJnZXRDYW5jZWxRdWVyeSIsICJnZXRQSURRdWVyeSIsICJyZXN1bHQiXQp9Cg==
@@ -1,6 +1,6 @@
1
1
  import { RawResponse, AccelerateHttpClient } from '../accelerate/index.cjs';
2
2
  export { DeserializedResponse, QueryIntrospectionBuiltinType, deserializeRawResult } from '../accelerate/index.cjs';
3
- import '../../index-CV9DQF9a.cjs';
3
+ import '../../index-CW6rqTos.cjs';
4
4
  import 'kysely';
5
5
 
6
6
  interface PrismaPostgresHttpClientParams {
@@ -1,6 +1,6 @@
1
1
  import { RawResponse, AccelerateHttpClient } from '../accelerate/index.js';
2
2
  export { DeserializedResponse, QueryIntrospectionBuiltinType, deserializeRawResult } from '../accelerate/index.js';
3
- import '../../index-CV9DQF9a.js';
3
+ import '../../index-CW6rqTos.js';
4
4
  import 'kysely';
5
5
 
6
6
  interface PrismaPostgresHttpClientParams {
@@ -1,4 +1,4 @@
1
- import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-CV9DQF9a.cjs';
1
+ import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-CW6rqTos.cjs';
2
2
  import * as kysely from 'kysely';
3
3
 
4
4
  type SQLIteAdapterRequirements = AdapterRequirements;
@@ -1,4 +1,4 @@
1
- import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-CV9DQF9a.js';
1
+ import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-CW6rqTos.js';
2
2
  import * as kysely from 'kysely';
3
3
 
4
4
  type SQLIteAdapterRequirements = AdapterRequirements;
@@ -288,7 +288,7 @@ interface Executor {
288
288
  execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;
289
289
  }
290
290
  interface SequenceExecutor extends Executor {
291
- executeSequence<T, S>(query: [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
291
+ executeSequence<T, S>(sequence: readonly [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
292
292
  }
293
293
  interface ExecuteOptions {
294
294
  abortSignal?: AbortSignal;
@@ -298,4 +298,4 @@ declare class AbortError extends Error {
298
298
  }
299
299
  declare function getAbortResult(): [AbortError];
300
300
 
301
- export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type Executor as E, type FilterOperator as F, type AdapterDeleteResult as G, createAdapterError as H, AbortError as I, getAbortResult as J, type BigIntString as K, type NumericString as N, type Query as Q, type SequenceExecutor as S, type Table as T, type ExecuteOptions as a, type Either as b, type QueryResult as c, type AdapterRequirements as d, type AdapterQueryDetails as e, type AdapterDeleteDetails as f, type AdapterInsertDetails as g, type AdapterUpdateDetails as h, AdapterError as i, applyInferredRowFilters as j, type AdapterBaseOptions as k, type AdapterIntrospectOptions as l, type AdapterQueryOptions as m, type AdapterInsertOptions as n, type AdapterUpdateOptions as o, type AdapterDeleteOptions as p, type AdapterIntrospectResult as q, type Schema as r, type DataTypeGroup as s, type ColumnFilter as t, type FilterGroup as u, type SortOrderItem as v, type SortDirection as w, type AdapterQueryResult as x, type AdapterInsertResult as y, type AdapterUpdateResult as z };
301
+ export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type ExecuteOptions as E, type FilterOperator as F, type AdapterDeleteResult as G, createAdapterError as H, AbortError as I, getAbortResult as J, type BigIntString as K, type NumericString as N, type Query as Q, type SequenceExecutor as S, type Table as T, type Either as a, type QueryResult as b, type Executor as c, type AdapterRequirements as d, type AdapterQueryDetails as e, type AdapterDeleteDetails as f, type AdapterInsertDetails as g, type AdapterUpdateDetails as h, AdapterError as i, applyInferredRowFilters as j, type AdapterBaseOptions as k, type AdapterIntrospectOptions as l, type AdapterQueryOptions as m, type AdapterInsertOptions as n, type AdapterUpdateOptions as o, type AdapterDeleteOptions as p, type AdapterIntrospectResult as q, type Schema as r, type DataTypeGroup as s, type ColumnFilter as t, type FilterGroup as u, type SortOrderItem as v, type SortDirection as w, type AdapterQueryResult as x, type AdapterInsertResult as y, type AdapterUpdateResult as z };
@@ -288,7 +288,7 @@ interface Executor {
288
288
  execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;
289
289
  }
290
290
  interface SequenceExecutor extends Executor {
291
- executeSequence<T, S>(query: [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
291
+ executeSequence<T, S>(sequence: readonly [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
292
292
  }
293
293
  interface ExecuteOptions {
294
294
  abortSignal?: AbortSignal;
@@ -298,4 +298,4 @@ declare class AbortError extends Error {
298
298
  }
299
299
  declare function getAbortResult(): [AbortError];
300
300
 
301
- export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type Executor as E, type FilterOperator as F, type AdapterDeleteResult as G, createAdapterError as H, AbortError as I, getAbortResult as J, type BigIntString as K, type NumericString as N, type Query as Q, type SequenceExecutor as S, type Table as T, type ExecuteOptions as a, type Either as b, type QueryResult as c, type AdapterRequirements as d, type AdapterQueryDetails as e, type AdapterDeleteDetails as f, type AdapterInsertDetails as g, type AdapterUpdateDetails as h, AdapterError as i, applyInferredRowFilters as j, type AdapterBaseOptions as k, type AdapterIntrospectOptions as l, type AdapterQueryOptions as m, type AdapterInsertOptions as n, type AdapterUpdateOptions as o, type AdapterDeleteOptions as p, type AdapterIntrospectResult as q, type Schema as r, type DataTypeGroup as s, type ColumnFilter as t, type FilterGroup as u, type SortOrderItem as v, type SortDirection as w, type AdapterQueryResult as x, type AdapterInsertResult as y, type AdapterUpdateResult as z };
301
+ export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type ExecuteOptions as E, type FilterOperator as F, type AdapterDeleteResult as G, createAdapterError as H, AbortError as I, getAbortResult as J, type BigIntString as K, type NumericString as N, type Query as Q, type SequenceExecutor as S, type Table as T, type Either as a, type QueryResult as b, type Executor as c, type AdapterRequirements as d, type AdapterQueryDetails as e, type AdapterDeleteDetails as f, type AdapterInsertDetails as g, type AdapterUpdateDetails as h, AdapterError as i, applyInferredRowFilters as j, type AdapterBaseOptions as k, type AdapterIntrospectOptions as l, type AdapterQueryOptions as m, type AdapterInsertOptions as n, type AdapterUpdateOptions as o, type AdapterDeleteOptions as p, type AdapterIntrospectResult as q, type Schema as r, type DataTypeGroup as s, type ColumnFilter as t, type FilterGroup as u, type SortOrderItem as v, type SortDirection as w, type AdapterQueryResult as x, type AdapterInsertResult as y, type AdapterUpdateResult as z };