@prisma/studio-core-licensed 0.0.0-dev.202511180328 → 0.0.0-dev.202511180420

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 (48) hide show
  1. package/dist/{chunk-OTK4ZF2W.js → chunk-24UZSKGU.js} +1 -1
  2. package/dist/chunk-NQGSK3IM.js +10 -0
  3. package/dist/chunk-RYYSZZYL.js +10 -0
  4. package/dist/data/accelerate/index.d.cts +1 -1
  5. package/dist/data/accelerate/index.d.ts +1 -1
  6. package/dist/data/bff/index.d.cts +1 -1
  7. package/dist/data/bff/index.d.ts +1 -1
  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.cjs +2 -2
  11. package/dist/data/mysql-core/index.d.cts +9 -3
  12. package/dist/data/mysql-core/index.d.ts +9 -3
  13. package/dist/data/mysql-core/index.js +2 -2
  14. package/dist/data/mysql2/index.cjs +2 -2
  15. package/dist/data/mysql2/index.d.cts +1 -1
  16. package/dist/data/mysql2/index.d.ts +1 -1
  17. package/dist/data/mysql2/index.js +1 -1
  18. package/dist/data/node-sqlite/index.d.cts +1 -1
  19. package/dist/data/node-sqlite/index.d.ts +1 -1
  20. package/dist/data/pglite/index.cjs +1 -1
  21. package/dist/data/pglite/index.d.cts +1 -1
  22. package/dist/data/pglite/index.d.ts +1 -1
  23. package/dist/data/pglite/index.js +1 -1
  24. package/dist/data/postgres-core/index.cjs +1 -1
  25. package/dist/data/postgres-core/index.d.cts +1 -1
  26. package/dist/data/postgres-core/index.d.ts +1 -1
  27. package/dist/data/postgres-core/index.js +1 -1
  28. package/dist/data/postgresjs/index.cjs +2 -2
  29. package/dist/data/postgresjs/index.d.cts +1 -1
  30. package/dist/data/postgresjs/index.d.ts +1 -1
  31. package/dist/data/postgresjs/index.js +1 -1
  32. package/dist/data/ppg/index.d.cts +1 -1
  33. package/dist/data/ppg/index.d.ts +1 -1
  34. package/dist/data/sqlite-core/index.cjs +1 -1
  35. package/dist/data/sqlite-core/index.d.cts +1 -1
  36. package/dist/data/sqlite-core/index.d.ts +1 -1
  37. package/dist/data/sqlite-core/index.js +1 -1
  38. package/dist/{index-2horhMcs.d.ts → index-CV9DQF9a.d.cts} +5 -2
  39. package/dist/{index-2horhMcs.d.cts → index-CV9DQF9a.d.ts} +5 -2
  40. package/dist/metafile-cjs.json +1 -1
  41. package/dist/metafile-esm.json +1 -1
  42. package/dist/ui/index.cjs +1 -1
  43. package/dist/ui/index.d.cts +1 -1
  44. package/dist/ui/index.d.ts +1 -1
  45. package/dist/ui/index.js +1 -1
  46. package/package.json +1 -1
  47. package/dist/chunk-AHIV4VYN.js +0 -10
  48. package/dist/chunk-CM36Z3XQ.js +0 -10
@@ -1,7 +1,9 @@
1
- import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, f as AdapterDeleteDetails, B as BuilderRequirements, g as AdapterInsertDetails, e as AdapterQueryDetails, h as AdapterUpdateDetails } from '../../index-2horhMcs.cjs';
1
+ import { d as AdapterRequirements, S as SequenceExecutor, A as Adapter, T as Table, F as FilterOperator, Q as Query, f as AdapterDeleteDetails, B as BuilderRequirements, g as AdapterInsertDetails, h as AdapterUpdateDetails, e as AdapterQueryDetails } from '../../index-CV9DQF9a.cjs';
2
2
  import * as kysely from 'kysely';
3
3
 
4
- type MySQLAdapterRequirements = AdapterRequirements;
4
+ type MySQLAdapterRequirements = Omit<AdapterRequirements, "executor"> & {
5
+ executor: SequenceExecutor;
6
+ };
5
7
  declare function createMySQLAdapter(requirements: MySQLAdapterRequirements): Adapter;
6
8
  /**
7
9
  * For testing purposes.
@@ -18,6 +20,10 @@ declare function mockIntrospect(): {
18
20
 
19
21
  declare function getDeleteQuery(details: AdapterDeleteDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<kysely.DeleteResult>;
20
22
  declare function getInsertQuery(_details: AdapterInsertDetails, _requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): void;
23
+ declare function getUpdateRefetchQuery(details: AdapterUpdateDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
24
+ [x: string]: unknown;
25
+ __ps_updated_at__: string | number;
26
+ }>;
21
27
  declare function getSelectQuery(details: AdapterQueryDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
22
28
  [x: string]: unknown;
23
29
  __ps_count__: `${bigint}`;
@@ -144,4 +150,4 @@ declare function mockTimezoneQuery(): [{
144
150
 
145
151
  declare function getCancelQuery(threadId: unknown): Query<unknown>;
146
152
 
147
- export { type MySQLAdapterRequirements, createMySQLAdapter, getCancelQuery, getDeleteQuery, getInsertQuery, getSelectQuery, getTablesQuery, getTimezoneQuery, getUpdateQuery, mockIntrospect, mockSelectQuery, mockTablesQuery, mockTimezoneQuery };
153
+ export { type MySQLAdapterRequirements, createMySQLAdapter, getCancelQuery, getDeleteQuery, getInsertQuery, getSelectQuery, getTablesQuery, getTimezoneQuery, getUpdateQuery, getUpdateRefetchQuery, mockIntrospect, mockSelectQuery, mockTablesQuery, mockTimezoneQuery };
@@ -1,7 +1,9 @@
1
- import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, f as AdapterDeleteDetails, B as BuilderRequirements, g as AdapterInsertDetails, e as AdapterQueryDetails, h as AdapterUpdateDetails } from '../../index-2horhMcs.js';
1
+ import { d as AdapterRequirements, S as SequenceExecutor, A as Adapter, T as Table, F as FilterOperator, Q as Query, f as AdapterDeleteDetails, B as BuilderRequirements, g as AdapterInsertDetails, h as AdapterUpdateDetails, e as AdapterQueryDetails } from '../../index-CV9DQF9a.js';
2
2
  import * as kysely from 'kysely';
3
3
 
4
- type MySQLAdapterRequirements = AdapterRequirements;
4
+ type MySQLAdapterRequirements = Omit<AdapterRequirements, "executor"> & {
5
+ executor: SequenceExecutor;
6
+ };
5
7
  declare function createMySQLAdapter(requirements: MySQLAdapterRequirements): Adapter;
6
8
  /**
7
9
  * For testing purposes.
@@ -18,6 +20,10 @@ declare function mockIntrospect(): {
18
20
 
19
21
  declare function getDeleteQuery(details: AdapterDeleteDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<kysely.DeleteResult>;
20
22
  declare function getInsertQuery(_details: AdapterInsertDetails, _requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): void;
23
+ declare function getUpdateRefetchQuery(details: AdapterUpdateDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
24
+ [x: string]: unknown;
25
+ __ps_updated_at__: string | number;
26
+ }>;
21
27
  declare function getSelectQuery(details: AdapterQueryDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
22
28
  [x: string]: unknown;
23
29
  __ps_count__: `${bigint}`;
@@ -144,4 +150,4 @@ declare function mockTimezoneQuery(): [{
144
150
 
145
151
  declare function getCancelQuery(threadId: unknown): Query<unknown>;
146
152
 
147
- export { type MySQLAdapterRequirements, createMySQLAdapter, getCancelQuery, getDeleteQuery, getInsertQuery, getSelectQuery, getTablesQuery, getTimezoneQuery, getUpdateQuery, mockIntrospect, mockSelectQuery, mockTablesQuery, mockTimezoneQuery };
153
+ export { type MySQLAdapterRequirements, createMySQLAdapter, getCancelQuery, getDeleteQuery, getInsertQuery, getSelectQuery, getTablesQuery, getTimezoneQuery, getUpdateQuery, getUpdateRefetchQuery, mockIntrospect, mockSelectQuery, mockTablesQuery, mockTimezoneQuery };
@@ -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 I}from"../../chunk-32BUC7NR.js";import{a as F}from"../../chunk-ZUEQ555M.js";import{a as y}from"../../chunk-OTK4ZF2W.js";import{i as m,n as M,o as L,p as S,r as A,s as b,u as B,v as O}from"../../chunk-A6CVKSUD.js";import{e as a}from"../../chunk-GDQBQ7MK.js";a();a();a();var k={bigint:{group:"numeric"},binary:{group:"string"},bit:{group:"raw"},blob:{group:"string"},char:{group:"string"},"char binary":{group:"string"},date:{group:"datetime"},datetime:{group:"datetime"},dec:{group:"numeric"},decimal:{group:"numeric"},double:{group:"numeric"},"double precision":{group:"numeric"},enum:{group:"enum"},fixed:{group:"numeric"},float:{group:"numeric"},geometry:{group:"raw"},geometrycollection:{group:"raw"},int:{group:"numeric"},integer:{group:"numeric"},json:{group:"json"},linestring:{group:"raw"},long:{group:"string"},"long varchar":{group:"string"},longblob:{group:"string"},longtext:{group:"string"},longvarbinary:{group:"string"},longvarchar:{group:"string"},mediumblob:{group:"string"},mediumint:{group:"numeric"},mediumtext:{group:"string"},multilinestring:{group:"raw"},multipoint:{group:"raw"},multipolygon:{group:"raw"},numeric:{group:"numeric"},point:{group:"raw"},polygon:{group:"raw"},real:{group:"numeric"},set:{group:"raw"},smallint:{group:"numeric"},text:{group:"string"},time:{group:"time"},timestamp:{group:"datetime"},tinyblob:{group:"string"},tinyint:{group:"numeric"},tinytext:{group:"string"},varbinary:{group:"string"},varchar:{group:"string"},"varchar binary":{group:"string"},vector:{group:"raw"},year:{group:"numeric"}};a();a();function g(e){return S({...e,Adapter:L,QueryCompiler:M})}function C(e,r){let{rows:o,table:{columns:i,name:n}}=e,t=g(r);return A(t.deleteFrom(n).$call(b(o,i)))}function X(e,r){throw new Error("Not implemented")}function h(e,r){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},pageIndex:i,pageSize:n,sortOrder:t,table:{columns:s,name:l}}=e,c=g(r),u=O(o.filters,s),_=c.selectFrom(l).where(u).select(E=>E.cast(E.fn.coalesce(E.fn.countAll(),m.lit(0)),"text").as("value"));return A(c.with("count",()=>_).selectFrom([l,"count"]).where(u).select(Object.keys(s)).select(m.ref("count.value").as("__ps_count__")).$call(E=>t.reduce((p,d)=>p.orderBy(d.column,d.direction),E)).limit(n).offset(m.lit(BigInt(i)*BigInt(n))))}function J(){return[]}function Z(e,r){let{changes:o,row:i,table:{columns:n,name:t,schema:s}}=e,l=g(r);return A(l.withSchema(s).updateTable(t).set(B("update",o,n)).$call(b([i],n)))}a();a();function Q(e){return m`(select cast(coalesce(json_arrayagg(json_object(${m.join(j(e.toOperationNode(),"agg"))})), '[]') as json) from ${e} as agg)`}function j(e,r){try{return I(e,r)}catch{throw new Error("MySQL jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}function w(e){return A(g(e).selectFrom("information_schema.tables as t").where("t.TABLE_SCHEMA","=",m`database()`).where("t.TABLE_TYPE","in",["BASE TABLE","VIEW"]).select(["t.TABLE_SCHEMA as schema","t.TABLE_NAME as name","t.TABLE_TYPE as type"]).$narrowType().select(r=>Q(r.selectFrom("information_schema.columns as c").leftJoin("information_schema.KEY_COLUMN_USAGE as kcu",o=>o.onRef("kcu.TABLE_SCHEMA","=","c.TABLE_SCHEMA").onRef("kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("kcu.POSITION_IN_UNIQUE_CONSTRAINT","is not",null)).whereRef("c.TABLE_SCHEMA","=","t.TABLE_SCHEMA").whereRef("c.TABLE_NAME","=","t.TABLE_NAME").select(["c.COLUMN_NAME as name","c.COLUMN_TYPE as datatype","c.ORDINAL_POSITION as position","kcu.REFERENCED_TABLE_NAME as fk_table","kcu.REFERENCED_COLUMN_NAME as fk_column"]).select(o=>[o("c.EXTRA","=","auto_increment").as("autoincrement"),o("c.EXTRA","in",["on update CURRENT_TIMESTAMP","STORED GENERATED","VIRTUAL GENERATED"]).as("computed"),o("c.COLUMN_KEY","=","PRI").as("pk"),o("c.IS_NULLABLE","=","YES").as("nullable")])).as("columns")).orderBy("t.TABLE_SCHEMA").orderBy("t.TABLE_NAME").orderBy("t.TABLE_TYPE"))}function D(){return[{columns:[{autoincrement:1,computed:0,datatype:"int",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"binary(16)",fk_column:null,fk_table:null,name:"uuid",nullable:1,pk:0,position:2},{autoincrement:0,computed:0,datatype:"varchar(255)",fk_column:null,fk_table:null,name:"name",nullable:1,pk:0,position:3},{autoincrement:0,computed:1,datatype:"text",fk_column:null,fk_table:null,name:"id_name",nullable:1,pk:0,position:4}],name:"animals",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:1,computed:0,datatype:"int",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"timestamp",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:0,position:2},{autoincrement:0,computed:0,datatype:"enum('admin','maintainer','member')",fk_column:null,fk_table:null,name:"role",nullable:0,pk:0,position:3},{autoincrement:0,computed:0,datatype:"int",fk_column:"id",fk_table:"animals",name:"animal_id",nullable:1,pk:0,position:4}],name:"users",schema:"studio",type:"BASE TABLE"}]}function x(e){let r=g(e),o=m`@@session.time_zone`;return A(r.selectNoFrom(r.case().when(o,"=","SYSTEM").then(m`@@system_time_zone`).else(o).end().as("timezone")).$narrowType())}function U(){return[{timezone:"UTC"}]}function Ae(e){let{executor:r,...o}=e;return{async delete(i,n){try{let t=C(i,o),[s]=await r.execute(t,n);return s?y({error:s,query:t}):[null,{...i,query:t}]}catch(t){return y({error:t})}},insert(i,n){throw new Error("Method not implemented.")},async introspect(i){try{let n=w(e),t=x(e),[[s,l],[c,u]]=await Promise.all([r.execute(n,i),r.execute(t,i)]);if(s)return y({error:s,query:n});if(c)return y({error:c,query:t});let _=u[0]?.timezone;return _?[null,q({query:n,tables:l,timezone:_})]:y({error:new Error("Timezone not found"),query:t})}catch(n){return y({error:n})}},async query(i,n){try{let t=h(i,o),[s,l]=await r.execute(t,n);return s?y({error:s,query:t}):[null,{filteredRowCount:l[0]?.__ps_count__||"0",rows:l,query:t}]}catch(t){return y({error:t})}},update(i,n){throw new Error("Method not implemented.")}}}function q(e){let{query:r,tables:o,timezone:i}=e;return o.reduce((n,t)=>{let{schemas:s}=n,{columns:l,name:c,schema:u}=t,_=l.sort((E,p)=>E.position-p.position).reduce((E,p)=>{let{datatype:d,name:R}=p,N=d.indexOf("("),T=(N>-1?d.substring(0,N):d).trim().toLowerCase();return{...E,[R]:{datatype:{...k[T]||{group:"raw"},isArray:!1,isNative:!0,name:T,options:T==="enum"?d.slice(6,-2).split("','"):[],schema:u},fkColumn:p.fk_column,fkSchema:u,fkTable:p.fk_table,isComputed:!!p.computed,isInPrimaryKey:!!p.pk,name:R,nullable:!!p.nullable,schema:u,table:c}}},{});return s[u]===void 0&&(s[u]={name:u,tables:{}}),s[u].tables[c]={columns:_,name:c,schema:u},n},{filterOperators:P,query:r,schemas:{},timezone:i})}var P=["=","!=",">",">=","<","<=","is","is not","like","not like"];function ge(){let e=D(),[{timezone:r}]=U();return q({tables:e,timezone:r,query:{parameters:[],sql:"<mocked>"}})}export{Ae as createMySQLAdapter,F as getCancelQuery,C as getDeleteQuery,X as getInsertQuery,h as getSelectQuery,w as getTablesQuery,x as getTimezoneQuery,Z as getUpdateQuery,ge as mockIntrospect,J as mockSelectQuery,D as mockTablesQuery,U as mockTimezoneQuery};
10
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/mysql-core/index.ts", "../../../data/mysql-core/adapter.ts", "../../../data/mysql-core/datatype.ts", "../../../data/mysql-core/dml.ts", "../../../data/mysql-core/builder.ts", "../../../data/mysql-core/introspection.ts", "../../../../../node_modules/.pnpm/kysely@0.28.8/node_modules/kysely/dist/esm/helpers/mysql.js"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\nexport * from \"./utility\";\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterRequirements,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { MYSQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport { getDeleteQuery, getSelectQuery } from \"./dml\";\nimport { getTablesQuery, getTimezoneQuery, mockTablesQuery, mockTimezoneQuery } from \"./introspection\";\n\nexport type MySQLAdapterRequirements = AdapterRequirements;\n\nexport function createMySQLAdapter(requirements: MySQLAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    insert(_details, _options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      throw new Error(\"Method not implemented.\");\n    },\n\n    async introspect(options): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      try {\n        const tablesQuery = getTablesQuery(requirements);\n        const timezoneQuery = getTimezoneQuery(requirements);\n\n        const [[tablesError, tables], [timezoneError, timezones]] = await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        if (timezoneError) {\n          return createAdapterError({ error: timezoneError, query: timezoneQuery });\n        }\n\n        const timezone = timezones[0]?.timezone;\n\n        if (!timezone) {\n          return createAdapterError({ error: new Error(\"Timezone not found\"), query: timezoneQuery });\n        }\n\n        return [null, createIntrospection({ query: tablesQuery, tables, timezone })];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.__ps_count__ || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    update(_details, _options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      throw new Error(\"Method not implemented.\");\n    },\n  };\n}\n\nfunction createIntrospection(args: {\n  query: Query;\n  tables: QueryResult<typeof getTablesQuery>;\n  timezone: string;\n}): AdapterIntrospectResult {\n  const { query, tables, timezone } = args;\n\n  return tables.reduce(\n    (result, table) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = table;\n\n      const columnsRecord = columns\n        .sort((a, b) => a.position - b.position)\n        .reduce(\n          (columns, column) => {\n            const { datatype, name: columnName } = column;\n\n            const indexOfParenthesis = datatype.indexOf(\"(\");\n            const strippedDataType = (indexOfParenthesis > -1 ? datatype.substring(0, indexOfParenthesis) : datatype)\n              .trim()\n              .toLowerCase();\n\n            return {\n              ...columns,\n              [columnName]: {\n                datatype: {\n                  ...(MYSQL_DATA_TYPES_TO_METADATA[strippedDataType] || { group: \"raw\" }),\n                  isArray: false,\n                  isNative: true,\n                  name: strippedDataType,\n                  options:\n                    strippedDataType === \"enum\" ? datatype.slice(`enum('`.length, -`')`.length).split(`','`) : [],\n                  schema,\n                },\n                fkColumn: column.fk_column,\n                fkSchema: schema,\n                fkTable: column.fk_table,\n                isComputed: Boolean(column.computed),\n                isInPrimaryKey: Boolean(column.pk),\n                name: columnName,\n                nullable: Boolean(column.nullable),\n                schema,\n                table: tableName,\n              } as const satisfies Column,\n            };\n          },\n          {} as Table[\"columns\"],\n        );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = { name: schema, tables: {} };\n      }\n\n      schemas[schema].tables[tableName] = { columns: columnsRecord, name: tableName, schema };\n\n      return result;\n    },\n    { filterOperators, query, schemas: {}, timezone } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n", "import type { DataType } from \"../adapter\";\n\nexport const MYSQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"group\">> = {\n  bigint: {\n    group: \"numeric\",\n  },\n  binary: {\n    group: \"string\",\n  },\n  bit: {\n    group: \"raw\",\n  },\n  blob: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  \"char binary\": {\n    group: \"string\",\n  },\n  date: {\n    group: \"datetime\",\n  },\n  datetime: {\n    group: \"datetime\",\n  },\n  dec: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  double: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  enum: {\n    group: \"enum\",\n  },\n  fixed: {\n    group: \"numeric\",\n  },\n  float: {\n    group: \"numeric\",\n  },\n  geometry: {\n    group: \"raw\",\n  },\n  geometrycollection: {\n    group: \"raw\",\n  },\n  int: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  linestring: {\n    group: \"raw\",\n  },\n  long: {\n    group: \"string\",\n  },\n  \"long varchar\": {\n    group: \"string\",\n  },\n  longblob: {\n    group: \"string\",\n  },\n  longtext: {\n    group: \"string\",\n  },\n  longvarbinary: {\n    group: \"string\",\n  },\n  longvarchar: {\n    group: \"string\",\n  },\n  mediumblob: {\n    group: \"string\",\n  },\n  mediumint: {\n    group: \"numeric\",\n  },\n  mediumtext: {\n    group: \"string\",\n  },\n  multilinestring: {\n    group: \"raw\",\n  },\n  multipoint: {\n    group: \"raw\",\n  },\n  multipolygon: {\n    group: \"raw\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  point: {\n    group: \"raw\",\n  },\n  polygon: {\n    group: \"raw\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  /**\n   * https://dev.mysql.com/doc/refman/9.5/en/set.html\n   */\n  set: {\n    group: \"raw\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  text: {\n    group: \"string\",\n  },\n  time: {\n    group: \"time\",\n  },\n  timestamp: {\n    group: \"datetime\",\n  },\n  tinyblob: {\n    group: \"string\",\n  },\n  tinyint: {\n    group: \"numeric\",\n  },\n  tinytext: {\n    group: \"string\",\n  },\n  varbinary: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  \"varchar binary\": {\n    group: \"string\",\n  },\n  /**\n   * https://dev.mysql.com/doc/refman/9.5/en/vector.html\n   */\n  vector: {\n    group: \"raw\",\n  },\n  year: {\n    group: \"numeric\",\n  },\n};\n", "import { type InferResult, type ReferenceExpression, sql } from \"kysely\";\n\nimport type { AdapterDeleteDetails, AdapterInsertDetails, AdapterQueryDetails, AdapterUpdateDetails } from \"../adapter\";\nimport {\n  applyInferredRowFilters,\n  applyTransformations,\n  type BuilderRequirements,\n  compile,\n  getSelectFilterExpression,\n} from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getMySQLBuilder } from \"./builder\";\nimport { mockTablesQuery } from \"./introspection\";\n\nexport function getDeleteQuery(\n  details: AdapterDeleteDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(builder.deleteFrom(tableName).$call(applyInferredRowFilters(rows, columns)));\n}\n\nexport function getInsertQuery(\n  _details: AdapterInsertDetails,\n  _requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  throw new Error(\"Not implemented\");\n}\n\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    filter = { after: \"and\", filters: [], kind: \"FilterGroup\" },\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  const filterExpression = getSelectFilterExpression(filter.filters, columns);\n\n  const countQuery = builder\n    .selectFrom(tableName)\n    .where(filterExpression)\n    .select((eb) => eb.cast<BigIntString>(eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)), \"text\").as(\"value\"));\n\n  return compile(\n    builder\n      .with(\"count\", () => countQuery)\n      .selectFrom([tableName, \"count\"])\n      // TODO: cursor pagination?\n      .where(filterExpression)\n      .select(Object.keys(columns))\n      .select(\n        sql\n          .ref<BigIntString>(\n            \"count.value\" satisfies ReferenceExpression<{ count: InferResult<typeof countQuery>[number] }, \"count\">,\n          )\n          .as(\"__ps_count__\"),\n      )\n      .$call((qb) => sortOrder.reduce((qb, item) => qb.orderBy(item.column, item.direction), qb))\n      .limit(pageSize)\n      // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n      .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockSelectQuery() {\n  // TODO: ...\n  return [] as const satisfies {\n    // best effort no need to go overboard\n    [K in ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"] | \"__ps_count__\"]: unknown;\n  }[];\n}\n\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(applyTransformations(\"update\", changes, columns))\n      .$call(applyInferredRowFilters([row], columns)),\n    //   .returning(Object.keys(columns))\n    //   .returning(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n", "import { type Kysely, MysqlAdapter, MysqlQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getMySQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({ ...requirements, Adapter: MysqlAdapter, QueryCompiler: MysqlQueryCompiler });\n}\n", "import { sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/mysql\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getMySQLBuilder } from \"./builder\";\n\ninterface Database {\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-columns-table.html */\n  \"information_schema.columns\": {\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    COLUMN_NAME: string;\n    /** The position of the column within the table. ORDINAL_POSITION is necessary because you might want to say ORDER BY ORDINAL_POSITION. Unlike SHOW COLUMNS, SELECT from the COLUMNS table does not have automatic ordering. */\n    ORDINAL_POSITION: number;\n    /** The default value for the column. This is NULL if the column has an explicit default of NULL, or if the column definition includes no DEFAULT clause. */\n    COLUMN_DEFAULT: unknown;\n    IS_NULLABLE: \"YES\" | \"NO\";\n    /** Contains the type name and possibly other information such as the precision or length. */\n    COLUMN_TYPE: string;\n    /** empty - not indexed or is secondary column in a multi-column nonunique index. PRI - part of a primary key. UNI - first column of a unique index. MUL - first column of a nonunique index */\n    COLUMN_KEY: \"\" | \"PRI\" | \"UNI\" | \"MUL\";\n    /** Extra information about the column. Possible values are */\n    EXTRA:\n      | \"\"\n      | \"auto_increment\"\n      | \"on update CURRENT_TIMESTAMP\"\n      | \"STORED GENERATED\"\n      | \"VIRTUAL GENERATED\"\n      | \"DEFAULT GENERATED\";\n    /** For generated columns, displays the expression used to compute column values. Empty for nongenerated columns. For information about generated columns, see Section 15.1.20.8, \u201CCREATE TABLE and Generated Columns\u201D. */\n    GENERATION_EXPRESSION: string;\n  };\n\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-tables-table.html */\n  \"information_schema.tables\": {\n    /** The name of the schema (database) to which the table belongs. */\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    /** BASE TABLE for a table, VIEW for a view, or SYSTEM VIEW for an INFORMATION_SCHEMA table. */\n    TABLE_TYPE: \"BASE TABLE\" | \"VIEW\" | \"SYSTEM VIEW\";\n  };\n\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-key-column-usage-table.html */\n  \"information_schema.KEY_COLUMN_USAGE\": {\n    CONSTRAINT_SCHEMA: string;\n    CONSTRAINT_NAME: string;\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    COLUMN_NAME: string;\n    /** null - when unique or primary key constraint. 1-n - when foreign key constraint */\n    POSITION_IN_UNIQUE_CONSTRAINT: number | null;\n    REFERENCED_TABLE_SCHEMA: string;\n    REFERENCED_TABLE_NAME: string;\n    REFERENCED_COLUMN_NAME: string;\n  };\n\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-table-constraints-table.html */\n  \"information_schema.TABLE_CONSTRAINTS\": {\n    CONSTRAINT_SCHEMA: string;\n    CONSTRAINT_NAME: string;\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    CONSTRAINT_TYPE: \"PRIMARY KEY\" | \"FOREIGN KEY\" | \"UNIQUE\" | \"CHECK\";\n  };\n}\n\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getMySQLBuilder<Database>(requirements)\n      .selectFrom(\"information_schema.tables as t\")\n      .where(\"t.TABLE_SCHEMA\", \"=\", sql<string>`database()`)\n      .where(\"t.TABLE_TYPE\", \"in\", [\"BASE TABLE\", \"VIEW\"])\n      .select([\"t.TABLE_SCHEMA as schema\", \"t.TABLE_NAME as name\", \"t.TABLE_TYPE as type\"])\n      .$narrowType<{ type: \"BASE TABLE\" | \"VIEW\" }>()\n      .select((eb) =>\n        // `json_arrayagg` ignores `order by` inside the subquery, so we need to order after aggregation.\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"information_schema.columns as c\")\n            .leftJoin(\"information_schema.KEY_COLUMN_USAGE as kcu\", (jb) =>\n              jb\n                .onRef(\"kcu.TABLE_SCHEMA\", \"=\", \"c.TABLE_SCHEMA\")\n                .onRef(\"kcu.TABLE_NAME\", \"=\", \"c.TABLE_NAME\")\n                .onRef(\"kcu.COLUMN_NAME\", \"=\", \"c.COLUMN_NAME\")\n                // only get foreign key constraints\n                .on(\"kcu.POSITION_IN_UNIQUE_CONSTRAINT\", \"is not\", null),\n            )\n            .whereRef(\"c.TABLE_SCHEMA\", \"=\", \"t.TABLE_SCHEMA\")\n            .whereRef(\"c.TABLE_NAME\", \"=\", \"t.TABLE_NAME\")\n            .select([\n              \"c.COLUMN_NAME as name\",\n              \"c.COLUMN_TYPE as datatype\",\n              \"c.ORDINAL_POSITION as position\",\n              \"kcu.REFERENCED_TABLE_NAME as fk_table\",\n              \"kcu.REFERENCED_COLUMN_NAME as fk_column\",\n            ])\n            .select((eb) => [\n              eb(\"c.EXTRA\", \"=\", \"auto_increment\").as(\"autoincrement\"),\n              eb(\"c.EXTRA\", \"in\", [\"on update CURRENT_TIMESTAMP\", \"STORED GENERATED\", \"VIRTUAL GENERATED\"]).as(\n                \"computed\",\n              ),\n              eb(\"c.COLUMN_KEY\", \"=\", \"PRI\").as(\"pk\"),\n              eb(\"c.IS_NULLABLE\", \"=\", \"YES\").as(\"nullable\"),\n            ]),\n        ).as(\"columns\"),\n      )\n      .orderBy(\"t.TABLE_SCHEMA\")\n      .orderBy(\"t.TABLE_NAME\")\n      .orderBy(\"t.TABLE_TYPE\"),\n  );\n}\n\nexport function mockTablesQuery() {\n  return [\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"binary(16)\",\n          fk_column: null,\n          fk_table: null,\n          name: \"uuid\",\n          nullable: 1,\n          pk: 0,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"varchar(255)\",\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 1,\n          pk: 0,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 1,\n          datatype: \"text\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id_name\",\n          nullable: 1,\n          pk: 0,\n          position: 4,\n        },\n      ],\n      name: \"animals\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: 0,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"enum('admin','maintainer','member')\",\n          fk_column: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: 0,\n          pk: 0,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"int\",\n          fk_column: \"id\",\n          fk_table: \"animals\",\n          name: \"animal_id\",\n          nullable: 1,\n          pk: 0,\n          position: 4,\n        },\n      ],\n      name: \"users\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\nexport function getTimezoneQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  const builder = getMySQLBuilder(requirements);\n\n  const sessionTz = sql<\"SYSTEM\" | (string & {})>`@@session.time_zone`;\n\n  return compile(\n    builder\n      .selectNoFrom(\n        builder\n          .case()\n          .when(sessionTz, \"=\", \"SYSTEM\")\n          .then(sql<string>`@@system_time_zone`)\n          .else(sessionTz)\n          .end()\n          .as(\"timezone\"),\n      )\n      .$narrowType<{ timezone: string }>(),\n  );\n}\n\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<typeof getTimezoneQuery>;\n}\n", "/// <reference types=\"./mysql.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A MySQL helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into arrays. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/mysql'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.pets[0]?.pet_id\n * result[0]?.pets[0]?.name\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select `id`, (\n *   select cast(coalesce(json_arrayagg(json_object(\n *     'pet_id', `agg`.`pet_id`,\n *     'name', `agg`.`name`\n *   )), '[]') as json) from (\n *     select `pet`.`id` as `pet_id`, `pet`.`name`\n *     from `pet`\n *     where `pet`.`owner_id` = `person`.`id`\n *     order by `pet`.`name`\n *   ) as `agg`\n * ) as `pets`\n * from `person`\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select cast(coalesce(json_arrayagg(json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') as json) from ${expr} as agg)`;\n}\n/**\n * A MySQL helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/mysql'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.favorite_pet?.pet_id\n * result[0]?.favorite_pet?.name\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select `id`, (\n *   select json_object(\n *     'pet_id', `obj`.`pet_id`,\n *     'name', `obj`.`name`\n *   ) from (\n *     select `pet`.`id` as `pet_id`, `pet`.`name`\n *     from `pet`\n *     where `pet`.`owner_id` = `person`.`id`\n *     and `pet`.`is_favorite` = ?\n *   ) as obj\n * ) as `favorite_pet`\n * from `person`\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The MySQL `json_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: eb.fn('concat', ['first_name', eb.val(' '), 'last_name'])\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select \"id\", json_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', concat(`first_name`, ?, `last_name`)\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\nfunction getMysqlJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('MySQL jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.');\n    }\n}\n"],
  "mappings": ";;;;;;;;6QAAAA,ICAAC,ICAAC,IAEO,IAAMC,EAAwE,CACnF,OAAQ,CACN,MAAO,SACT,EACA,OAAQ,CACN,MAAO,QACT,EACA,IAAK,CACH,MAAO,KACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,cAAe,CACb,MAAO,QACT,EACA,KAAM,CACJ,MAAO,UACT,EACA,SAAU,CACR,MAAO,UACT,EACA,IAAK,CACH,MAAO,SACT,EACA,QAAS,CACP,MAAO,SACT,EACA,OAAQ,CACN,MAAO,SACT,EACA,mBAAoB,CAClB,MAAO,SACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,MAAO,CACL,MAAO,SACT,EACA,MAAO,CACL,MAAO,SACT,EACA,SAAU,CACR,MAAO,KACT,EACA,mBAAoB,CAClB,MAAO,KACT,EACA,IAAK,CACH,MAAO,SACT,EACA,QAAS,CACP,MAAO,SACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,WAAY,CACV,MAAO,KACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,eAAgB,CACd,MAAO,QACT,EACA,SAAU,CACR,MAAO,QACT,EACA,SAAU,CACR,MAAO,QACT,EACA,cAAe,CACb,MAAO,QACT,EACA,YAAa,CACX,MAAO,QACT,EACA,WAAY,CACV,MAAO,QACT,EACA,UAAW,CACT,MAAO,SACT,EACA,WAAY,CACV,MAAO,QACT,EACA,gBAAiB,CACf,MAAO,KACT,EACA,WAAY,CACV,MAAO,KACT,EACA,aAAc,CACZ,MAAO,KACT,EACA,QAAS,CACP,MAAO,SACT,EACA,MAAO,CACL,MAAO,KACT,EACA,QAAS,CACP,MAAO,KACT,EACA,KAAM,CACJ,MAAO,SACT,EAIA,IAAK,CACH,MAAO,KACT,EACA,SAAU,CACR,MAAO,SACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,UAAW,CACT,MAAO,UACT,EACA,SAAU,CACR,MAAO,QACT,EACA,QAAS,CACP,MAAO,SACT,EACA,SAAU,CACR,MAAO,QACT,EACA,UAAW,CACT,MAAO,Q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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "MYSQL_DATA_TYPES_TO_METADATA", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getMySQLBuilder", "requirements", "getBuilder", "MysqlAdapter", "MysqlQueryCompiler", "getDeleteQuery", "details", "requirements", "rows", "columns", "tableName", "builder", "getMySQLBuilder", "compile", "applyInferredRowFilters", "getInsertQuery", "_details", "_requirements", "getSelectQuery", "filter", "pageIndex", "pageSize", "sortOrder", "filterExpression", "getSelectFilterExpression", "countQuery", "eb", "sql", "qb", "item", "mockSelectQuery", "getUpdateQuery", "changes", "row", "schema", "applyTransformations", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonArrayFrom", "expr", "sql", "getMysqlJsonObjectArgs", "getMysqlJsonObjectArgs", "node", "table", "getJsonObjectArgs", "getTablesQuery", "requirements", "compile", "getMySQLBuilder", "sql", "eb", "jsonArrayFrom", "jb", "mockTablesQuery", "getTimezoneQuery", "builder", "sessionTz", "mockTimezoneQuery", "createMySQLAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "_details", "_options", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "timezone", "createIntrospection", "getSelectQuery", "results", "args", "result", "table", "schemas", "columns", "tableName", "schema", "columnsRecord", "a", "b", "column", "datatype", "columnName", "indexOfParenthesis", "strippedDataType", "MYSQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery"]
}

9
+ import{a as k}from"../../chunk-32BUC7NR.js";import{a as H}from"../../chunk-ZUEQ555M.js";import{a as c}from"../../chunk-24UZSKGU.js";import{i as p,n as M,o as S,p as L,r as A,s as T,u as B,v as O}from"../../chunk-A6CVKSUD.js";import{e as l}from"../../chunk-GDQBQ7MK.js";l();l();l();var h={bigint:{group:"numeric"},binary:{group:"string"},bit:{group:"raw"},blob:{group:"string"},char:{group:"string"},"char binary":{group:"string"},date:{group:"datetime"},datetime:{group:"datetime"},dec:{group:"numeric"},decimal:{group:"numeric"},double:{group:"numeric"},"double precision":{group:"numeric"},enum:{group:"enum"},fixed:{group:"numeric"},float:{group:"numeric"},geometry:{group:"raw"},geometrycollection:{group:"raw"},int:{group:"numeric"},integer:{group:"numeric"},json:{group:"json"},linestring:{group:"raw"},long:{group:"string"},"long varchar":{group:"string"},longblob:{group:"string"},longtext:{group:"string"},longvarbinary:{group:"string"},longvarchar:{group:"string"},mediumblob:{group:"string"},mediumint:{group:"numeric"},mediumtext:{group:"string"},multilinestring:{group:"raw"},multipoint:{group:"raw"},multipolygon:{group:"raw"},numeric:{group:"numeric"},point:{group:"raw"},polygon:{group:"raw"},real:{group:"numeric"},set:{group:"raw"},smallint:{group:"numeric"},text:{group:"string"},time:{group:"time"},timestamp:{group:"datetime"},tinyblob:{group:"string"},tinyint:{group:"numeric"},tinytext:{group:"string"},varbinary:{group:"string"},varchar:{group:"string"},"varchar binary":{group:"string"},vector:{group:"raw"},year:{group:"numeric"}};l();l();function g(t){return L({...t,Adapter:S,QueryCompiler:M})}function Q(t,n){let{rows:o,table:{columns:i,name:r}}=t,e=g(n);return A(e.deleteFrom(r).$call(T(o,i)))}function ee(t,n){throw new Error("Not implemented")}function C(t,n){let{changes:o,row:i,table:{columns:r,name:e}}=t,s=g(n);return A(s.selectFrom(e).$call(T([{...i,changes:o}],r)).select(Object.keys(r)).select(F().as("__ps_updated_at__")))}function I(t,n){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},pageIndex:i,pageSize:r,sortOrder:e,table:{columns:s,name:u}}=t,E=g(n),a=O(o.filters,s),d=E.selectFrom(u).where(a).select(m=>m.cast(m.fn.coalesce(m.fn.countAll(),p.lit(0)),"text").as("value"));return A(E.with("count",()=>d).selectFrom([u,"count"]).where(a).select(Object.keys(s)).select(p.ref("count.value").as("__ps_count__")).$call(m=>e.reduce((y,f)=>y.orderBy(f.column,f.direction),m)).limit(r).offset(p.lit(BigInt(i)*BigInt(r))))}function te(){return[]}function w(t,n){let{changes:o,row:i,table:{columns:r,name:e,schema:s}}=t,u=g(n);return A(u.withSchema(s).updateTable(e).set(B("update",o,r)).$call(T([i],r)))}function F(){return p`cast(unix_timestamp(now(3)) * 1000 as unsigned)`}l();l();function x(t){return p`(select cast(coalesce(json_arrayagg(json_object(${p.join(z(t.toOperationNode(),"agg"))})), '[]') as json) from ${t} as agg)`}function z(t,n){try{return k(t,n)}catch{throw new Error("MySQL jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}function q(t){return A(g(t).selectFrom("information_schema.tables as t").where("t.TABLE_SCHEMA","=",p`database()`).where("t.TABLE_TYPE","in",["BASE TABLE","VIEW"]).select(["t.TABLE_SCHEMA as schema","t.TABLE_NAME as name","t.TABLE_TYPE as type"]).$narrowType().select(n=>x(n.selectFrom("information_schema.columns as c").leftJoin("information_schema.KEY_COLUMN_USAGE as kcu",o=>o.onRef("kcu.TABLE_SCHEMA","=","c.TABLE_SCHEMA").onRef("kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("kcu.POSITION_IN_UNIQUE_CONSTRAINT","is not",null)).whereRef("c.TABLE_SCHEMA","=","t.TABLE_SCHEMA").whereRef("c.TABLE_NAME","=","t.TABLE_NAME").select(["c.COLUMN_NAME as name","c.COLUMN_TYPE as datatype","c.ORDINAL_POSITION as position","kcu.REFERENCED_TABLE_NAME as fk_table","kcu.REFERENCED_COLUMN_NAME as fk_column"]).select(o=>[o("c.EXTRA","=","auto_increment").as("autoincrement"),o("c.EXTRA","in",["on update CURRENT_TIMESTAMP","STORED GENERATED","VIRTUAL GENERATED"]).as("computed"),o("c.COLUMN_KEY","=","PRI").as("pk"),o("c.IS_NULLABLE","=","YES").as("nullable")])).as("columns")).orderBy("t.TABLE_SCHEMA").orderBy("t.TABLE_NAME").orderBy("t.TABLE_TYPE"))}function U(){return[{columns:[{autoincrement:1,computed:0,datatype:"int",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"binary(16)",fk_column:null,fk_table:null,name:"uuid",nullable:1,pk:0,position:2},{autoincrement:0,computed:0,datatype:"varchar(255)",fk_column:null,fk_table:null,name:"name",nullable:1,pk:0,position:3},{autoincrement:0,computed:1,datatype:"text",fk_column:null,fk_table:null,name:"id_name",nullable:1,pk:0,position:4}],name:"animals",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:1,computed:0,datatype:"int",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"timestamp",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:0,position:2},{autoincrement:0,computed:0,datatype:"enum('admin','maintainer','member')",fk_column:null,fk_table:null,name:"role",nullable:0,pk:0,position:3},{autoincrement:0,computed:0,datatype:"int",fk_column:"id",fk_table:"animals",name:"animal_id",nullable:1,pk:0,position:4}],name:"users",schema:"studio",type:"BASE TABLE"}]}function D(t){let n=g(t),o=p`@@session.time_zone`;return A(n.selectNoFrom(n.case().when(o,"=","SYSTEM").then(p`@@system_time_zone`).else(o).end().as("timezone")).$narrowType())}function j(){return[{timezone:"UTC"}]}function fe(t){let{executor:n,...o}=t;return{async delete(i,r){try{let e=Q(i,o),[s]=await n.execute(e,r);return s?c({error:s,query:e}):[null,{...i,query:e}]}catch(e){return c({error:e})}},insert(i,r){throw new Error("Method not implemented.")},async introspect(i){try{let r=q(t),e=D(t),[[s,u],[E,a]]=await Promise.all([n.execute(r,i),n.execute(e,i)]);if(s)return c({error:s,query:r});if(E)return c({error:E,query:e});let d=a[0]?.timezone;return d?[null,P({query:r,tables:u,timezone:d})]:c({error:new Error("Timezone not found"),query:e})}catch(r){return c({error:r})}},async query(i,r){try{let e=I(i,o),[s,u]=await n.execute(e,r);return s?c({error:s,query:e}):[null,{filteredRowCount:u[0]?.__ps_count__||"0",rows:u,query:e}]}catch(e){return c({error:e})}},async update(i,r){try{let e=w(i,o),s=C(i,o),[[u],E]=await n.executeSequence([e,s],r);if(u)return c({error:u,query:e});let[a,d]=E;if(a)return c({error:a,query:e});let[m]=d;return m?[null,{row:m,query:e}]:c({error:new Error("Updated row not found"),query:e})}catch(e){return c({error:e})}}}}function P(t){let{query:n,tables:o,timezone:i}=t;return o.reduce((r,e)=>{let{schemas:s}=r,{columns:u,name:E,schema:a}=e,d=u.sort((m,y)=>m.position-y.position).reduce((m,y)=>{let{datatype:f,name:R}=y,N=f.indexOf("("),b=(N>-1?f.substring(0,N):f).trim().toLowerCase();return{...m,[R]:{datatype:{...h[b]||{group:"raw"},isArray:!1,isNative:!0,name:b,options:b==="enum"?f.slice(6,-2).split("','"):[],schema:a},fkColumn:y.fk_column,fkSchema:a,fkTable:y.fk_table,isComputed:!!y.computed,isInPrimaryKey:!!y.pk,name:R,nullable:!!y.nullable,schema:a,table:E}}},{});return s[a]===void 0&&(s[a]={name:a,tables:{}}),s[a].tables[E]={columns:d,name:E,schema:a},r},{filterOperators:Y,query:n,schemas:{},timezone:i})}var Y=["=","!=",">",">=","<","<=","is","is not","like","not like"];function _e(){let t=U(),[{timezone:n}]=j();return P({tables:t,timezone:n,query:{parameters:[],sql:"<mocked>"}})}export{fe as createMySQLAdapter,H as getCancelQuery,Q as getDeleteQuery,ee as getInsertQuery,I as getSelectQuery,q as getTablesQuery,D as getTimezoneQuery,w as getUpdateQuery,C as getUpdateRefetchQuery,_e as mockIntrospect,te as mockSelectQuery,U as mockTablesQuery,j as mockTimezoneQuery};
10
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/mysql-core/index.ts", "../../../data/mysql-core/adapter.ts", "../../../data/mysql-core/datatype.ts", "../../../data/mysql-core/dml.ts", "../../../data/mysql-core/builder.ts", "../../../data/mysql-core/introspection.ts", "../../../../../node_modules/.pnpm/kysely@0.28.8/node_modules/kysely/dist/esm/helpers/mysql.js"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\nexport * from \"./utility\";\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterRequirements,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { SequenceExecutor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { MYSQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport { getDeleteQuery, getSelectQuery, getUpdateQuery, getUpdateRefetchQuery } from \"./dml\";\nimport { getTablesQuery, getTimezoneQuery, mockTablesQuery, mockTimezoneQuery } from \"./introspection\";\n\nexport type MySQLAdapterRequirements = Omit<AdapterRequirements, \"executor\"> & {\n  executor: SequenceExecutor;\n};\n\nexport function createMySQLAdapter(requirements: MySQLAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    insert(_details, _options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      throw new Error(\"Method not implemented.\");\n    },\n\n    async introspect(options): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      try {\n        const tablesQuery = getTablesQuery(requirements);\n        const timezoneQuery = getTimezoneQuery(requirements);\n\n        const [[tablesError, tables], [timezoneError, timezones]] = await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        if (timezoneError) {\n          return createAdapterError({ error: timezoneError, query: timezoneQuery });\n        }\n\n        const timezone = timezones[0]?.timezone;\n\n        if (!timezone) {\n          return createAdapterError({ error: new Error(\"Timezone not found\"), query: timezoneQuery });\n        }\n\n        return [null, createIntrospection({ query: tablesQuery, tables, timezone })];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.__ps_count__ || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(details, options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const updateQuery = getUpdateQuery(details, otherRequirements);\n        const refetchQuery = getUpdateRefetchQuery(details, otherRequirements);\n\n        const [[updateError], refetchResult] = await executor.executeSequence([updateQuery, refetchQuery], options);\n\n        if (updateError) {\n          return createAdapterError({ error: updateError, query: updateQuery });\n        }\n\n        const [refetchError, results] = refetchResult!;\n\n        if (refetchError) {\n          return createAdapterError({ error: refetchError, query: updateQuery });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          return createAdapterError({ error: new Error(\"Updated row not found\"), query: updateQuery });\n        }\n\n        return [null, { row, query: updateQuery }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction createIntrospection(args: {\n  query: Query;\n  tables: QueryResult<typeof getTablesQuery>;\n  timezone: string;\n}): AdapterIntrospectResult {\n  const { query, tables, timezone } = args;\n\n  return tables.reduce(\n    (result, table) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = table;\n\n      const columnsRecord = columns\n        .sort((a, b) => a.position - b.position)\n        .reduce(\n          (columns, column) => {\n            const { datatype, name: columnName } = column;\n\n            const indexOfParenthesis = datatype.indexOf(\"(\");\n            const strippedDataType = (indexOfParenthesis > -1 ? datatype.substring(0, indexOfParenthesis) : datatype)\n              .trim()\n              .toLowerCase();\n\n            return {\n              ...columns,\n              [columnName]: {\n                datatype: {\n                  ...(MYSQL_DATA_TYPES_TO_METADATA[strippedDataType] || { group: \"raw\" }),\n                  isArray: false,\n                  isNative: true,\n                  name: strippedDataType,\n                  options:\n                    strippedDataType === \"enum\" ? datatype.slice(`enum('`.length, -`')`.length).split(`','`) : [],\n                  schema,\n                },\n                fkColumn: column.fk_column,\n                fkSchema: schema,\n                fkTable: column.fk_table,\n                isComputed: Boolean(column.computed),\n                isInPrimaryKey: Boolean(column.pk),\n                name: columnName,\n                nullable: Boolean(column.nullable),\n                schema,\n                table: tableName,\n              } as const satisfies Column,\n            };\n          },\n          {} as Table[\"columns\"],\n        );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = { name: schema, tables: {} };\n      }\n\n      schemas[schema].tables[tableName] = { columns: columnsRecord, name: tableName, schema };\n\n      return result;\n    },\n    { filterOperators, query, schemas: {}, timezone } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n", "import type { DataType } from \"../adapter\";\n\nexport const MYSQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"group\">> = {\n  bigint: {\n    group: \"numeric\",\n  },\n  binary: {\n    group: \"string\",\n  },\n  bit: {\n    group: \"raw\",\n  },\n  blob: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  \"char binary\": {\n    group: \"string\",\n  },\n  date: {\n    group: \"datetime\",\n  },\n  datetime: {\n    group: \"datetime\",\n  },\n  dec: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  double: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  enum: {\n    group: \"enum\",\n  },\n  fixed: {\n    group: \"numeric\",\n  },\n  float: {\n    group: \"numeric\",\n  },\n  geometry: {\n    group: \"raw\",\n  },\n  geometrycollection: {\n    group: \"raw\",\n  },\n  int: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  linestring: {\n    group: \"raw\",\n  },\n  long: {\n    group: \"string\",\n  },\n  \"long varchar\": {\n    group: \"string\",\n  },\n  longblob: {\n    group: \"string\",\n  },\n  longtext: {\n    group: \"string\",\n  },\n  longvarbinary: {\n    group: \"string\",\n  },\n  longvarchar: {\n    group: \"string\",\n  },\n  mediumblob: {\n    group: \"string\",\n  },\n  mediumint: {\n    group: \"numeric\",\n  },\n  mediumtext: {\n    group: \"string\",\n  },\n  multilinestring: {\n    group: \"raw\",\n  },\n  multipoint: {\n    group: \"raw\",\n  },\n  multipolygon: {\n    group: \"raw\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  point: {\n    group: \"raw\",\n  },\n  polygon: {\n    group: \"raw\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  /**\n   * https://dev.mysql.com/doc/refman/9.5/en/set.html\n   */\n  set: {\n    group: \"raw\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  text: {\n    group: \"string\",\n  },\n  time: {\n    group: \"time\",\n  },\n  timestamp: {\n    group: \"datetime\",\n  },\n  tinyblob: {\n    group: \"string\",\n  },\n  tinyint: {\n    group: \"numeric\",\n  },\n  tinytext: {\n    group: \"string\",\n  },\n  varbinary: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  \"varchar binary\": {\n    group: \"string\",\n  },\n  /**\n   * https://dev.mysql.com/doc/refman/9.5/en/vector.html\n   */\n  vector: {\n    group: \"raw\",\n  },\n  year: {\n    group: \"numeric\",\n  },\n};\n", "import { type InferResult, type ReferenceExpression, sql } from \"kysely\";\n\nimport type { AdapterDeleteDetails, AdapterInsertDetails, AdapterQueryDetails, AdapterUpdateDetails } from \"../adapter\";\nimport {\n  applyInferredRowFilters,\n  applyTransformations,\n  type BuilderRequirements,\n  compile,\n  getSelectFilterExpression,\n} from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getMySQLBuilder } from \"./builder\";\nimport { mockTablesQuery } from \"./introspection\";\n\nexport function getDeleteQuery(\n  details: AdapterDeleteDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(builder.deleteFrom(tableName).$call(applyInferredRowFilters(rows, columns)));\n}\n\nexport function getInsertQuery(\n  _details: AdapterInsertDetails,\n  _requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  throw new Error(\"Not implemented\");\n}\n\nexport function getUpdateRefetchQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .selectFrom(tableName)\n      .$call(applyInferredRowFilters([{ ...row, changes }], columns))\n      .select(Object.keys(columns))\n      .select(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    filter = { after: \"and\", filters: [], kind: \"FilterGroup\" },\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { columns, name: tableName },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  const filterExpression = getSelectFilterExpression(filter.filters, columns);\n\n  const countQuery = builder\n    .selectFrom(tableName)\n    .where(filterExpression)\n    .select((eb) => eb.cast<BigIntString>(eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)), \"text\").as(\"value\"));\n\n  return compile(\n    builder\n      .with(\"count\", () => countQuery)\n      .selectFrom([tableName, \"count\"])\n      // TODO: cursor pagination?\n      .where(filterExpression)\n      .select(Object.keys(columns))\n      .select(\n        sql\n          .ref<BigIntString>(\n            \"count.value\" satisfies ReferenceExpression<{ count: InferResult<typeof countQuery>[number] }, \"count\">,\n          )\n          .as(\"__ps_count__\"),\n      )\n      .$call((qb) => sortOrder.reduce((qb, item) => qb.orderBy(item.column, item.direction), qb))\n      .limit(pageSize)\n      // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n      .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockSelectQuery() {\n  // TODO: ...\n  return [] as const satisfies {\n    // best effort no need to go overboard\n    [K in ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"] | \"__ps_count__\"]: unknown;\n  }[];\n}\n\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getMySQLBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(applyTransformations(\"update\", changes, columns))\n      .$call(applyInferredRowFilters([row], columns)),\n    //   .returning(Object.keys(columns))\n    //   .returning(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\nfunction getCurrentTimestampMillis() {\n  return sql<number | string>`cast(unix_timestamp(now(3)) * 1000 as unsigned)`;\n}\n", "import { type Kysely, MysqlAdapter, MysqlQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getMySQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({ ...requirements, Adapter: MysqlAdapter, QueryCompiler: MysqlQueryCompiler });\n}\n", "import { sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/mysql\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getMySQLBuilder } from \"./builder\";\n\ninterface Database {\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-columns-table.html */\n  \"information_schema.columns\": {\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    COLUMN_NAME: string;\n    /** The position of the column within the table. ORDINAL_POSITION is necessary because you might want to say ORDER BY ORDINAL_POSITION. Unlike SHOW COLUMNS, SELECT from the COLUMNS table does not have automatic ordering. */\n    ORDINAL_POSITION: number;\n    /** The default value for the column. This is NULL if the column has an explicit default of NULL, or if the column definition includes no DEFAULT clause. */\n    COLUMN_DEFAULT: unknown;\n    IS_NULLABLE: \"YES\" | \"NO\";\n    /** Contains the type name and possibly other information such as the precision or length. */\n    COLUMN_TYPE: string;\n    /** empty - not indexed or is secondary column in a multi-column nonunique index. PRI - part of a primary key. UNI - first column of a unique index. MUL - first column of a nonunique index */\n    COLUMN_KEY: \"\" | \"PRI\" | \"UNI\" | \"MUL\";\n    /** Extra information about the column. Possible values are */\n    EXTRA:\n      | \"\"\n      | \"auto_increment\"\n      | \"on update CURRENT_TIMESTAMP\"\n      | \"STORED GENERATED\"\n      | \"VIRTUAL GENERATED\"\n      | \"DEFAULT GENERATED\";\n    /** For generated columns, displays the expression used to compute column values. Empty for nongenerated columns. For information about generated columns, see Section 15.1.20.8, \u201CCREATE TABLE and Generated Columns\u201D. */\n    GENERATION_EXPRESSION: string;\n  };\n\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-tables-table.html */\n  \"information_schema.tables\": {\n    /** The name of the schema (database) to which the table belongs. */\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    /** BASE TABLE for a table, VIEW for a view, or SYSTEM VIEW for an INFORMATION_SCHEMA table. */\n    TABLE_TYPE: \"BASE TABLE\" | \"VIEW\" | \"SYSTEM VIEW\";\n  };\n\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-key-column-usage-table.html */\n  \"information_schema.KEY_COLUMN_USAGE\": {\n    CONSTRAINT_SCHEMA: string;\n    CONSTRAINT_NAME: string;\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    COLUMN_NAME: string;\n    /** null - when unique or primary key constraint. 1-n - when foreign key constraint */\n    POSITION_IN_UNIQUE_CONSTRAINT: number | null;\n    REFERENCED_TABLE_SCHEMA: string;\n    REFERENCED_TABLE_NAME: string;\n    REFERENCED_COLUMN_NAME: string;\n  };\n\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-table-constraints-table.html */\n  \"information_schema.TABLE_CONSTRAINTS\": {\n    CONSTRAINT_SCHEMA: string;\n    CONSTRAINT_NAME: string;\n    TABLE_SCHEMA: string;\n    TABLE_NAME: string;\n    CONSTRAINT_TYPE: \"PRIMARY KEY\" | \"FOREIGN KEY\" | \"UNIQUE\" | \"CHECK\";\n  };\n}\n\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getMySQLBuilder<Database>(requirements)\n      .selectFrom(\"information_schema.tables as t\")\n      .where(\"t.TABLE_SCHEMA\", \"=\", sql<string>`database()`)\n      .where(\"t.TABLE_TYPE\", \"in\", [\"BASE TABLE\", \"VIEW\"])\n      .select([\"t.TABLE_SCHEMA as schema\", \"t.TABLE_NAME as name\", \"t.TABLE_TYPE as type\"])\n      .$narrowType<{ type: \"BASE TABLE\" | \"VIEW\" }>()\n      .select((eb) =>\n        // `json_arrayagg` ignores `order by` inside the subquery, so we need to order after aggregation.\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"information_schema.columns as c\")\n            .leftJoin(\"information_schema.KEY_COLUMN_USAGE as kcu\", (jb) =>\n              jb\n                .onRef(\"kcu.TABLE_SCHEMA\", \"=\", \"c.TABLE_SCHEMA\")\n                .onRef(\"kcu.TABLE_NAME\", \"=\", \"c.TABLE_NAME\")\n                .onRef(\"kcu.COLUMN_NAME\", \"=\", \"c.COLUMN_NAME\")\n                // only get foreign key constraints\n                .on(\"kcu.POSITION_IN_UNIQUE_CONSTRAINT\", \"is not\", null),\n            )\n            .whereRef(\"c.TABLE_SCHEMA\", \"=\", \"t.TABLE_SCHEMA\")\n            .whereRef(\"c.TABLE_NAME\", \"=\", \"t.TABLE_NAME\")\n            .select([\n              \"c.COLUMN_NAME as name\",\n              \"c.COLUMN_TYPE as datatype\",\n              \"c.ORDINAL_POSITION as position\",\n              \"kcu.REFERENCED_TABLE_NAME as fk_table\",\n              \"kcu.REFERENCED_COLUMN_NAME as fk_column\",\n            ])\n            .select((eb) => [\n              eb(\"c.EXTRA\", \"=\", \"auto_increment\").as(\"autoincrement\"),\n              eb(\"c.EXTRA\", \"in\", [\"on update CURRENT_TIMESTAMP\", \"STORED GENERATED\", \"VIRTUAL GENERATED\"]).as(\n                \"computed\",\n              ),\n              eb(\"c.COLUMN_KEY\", \"=\", \"PRI\").as(\"pk\"),\n              eb(\"c.IS_NULLABLE\", \"=\", \"YES\").as(\"nullable\"),\n            ]),\n        ).as(\"columns\"),\n      )\n      .orderBy(\"t.TABLE_SCHEMA\")\n      .orderBy(\"t.TABLE_NAME\")\n      .orderBy(\"t.TABLE_TYPE\"),\n  );\n}\n\nexport function mockTablesQuery() {\n  return [\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"binary(16)\",\n          fk_column: null,\n          fk_table: null,\n          name: \"uuid\",\n          nullable: 1,\n          pk: 0,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"varchar(255)\",\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 1,\n          pk: 0,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 1,\n          datatype: \"text\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id_name\",\n          nullable: 1,\n          pk: 0,\n          position: 4,\n        },\n      ],\n      name: \"animals\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          fk_column: null,\n          fk_table: null,\n          name: \"id\",\n          nullable: 0,\n          pk: 1,\n          position: 1,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: 0,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"enum('admin','maintainer','member')\",\n          fk_column: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: 0,\n          pk: 0,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"int\",\n          fk_column: \"id\",\n          fk_table: \"animals\",\n          name: \"animal_id\",\n          nullable: 1,\n          pk: 0,\n          position: 4,\n        },\n      ],\n      name: \"users\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\nexport function getTimezoneQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  const builder = getMySQLBuilder(requirements);\n\n  const sessionTz = sql<\"SYSTEM\" | (string & {})>`@@session.time_zone`;\n\n  return compile(\n    builder\n      .selectNoFrom(\n        builder\n          .case()\n          .when(sessionTz, \"=\", \"SYSTEM\")\n          .then(sql<string>`@@system_time_zone`)\n          .else(sessionTz)\n          .end()\n          .as(\"timezone\"),\n      )\n      .$narrowType<{ timezone: string }>(),\n  );\n}\n\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<typeof getTimezoneQuery>;\n}\n", "/// <reference types=\"./mysql.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A MySQL helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into arrays. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/mysql'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.pets[0]?.pet_id\n * result[0]?.pets[0]?.name\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select `id`, (\n *   select cast(coalesce(json_arrayagg(json_object(\n *     'pet_id', `agg`.`pet_id`,\n *     'name', `agg`.`name`\n *   )), '[]') as json) from (\n *     select `pet`.`id` as `pet_id`, `pet`.`name`\n *     from `pet`\n *     where `pet`.`owner_id` = `person`.`id`\n *     order by `pet`.`name`\n *   ) as `agg`\n * ) as `pets`\n * from `person`\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select cast(coalesce(json_arrayagg(json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') as json) from ${expr} as agg)`;\n}\n/**\n * A MySQL helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/mysql'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.favorite_pet?.pet_id\n * result[0]?.favorite_pet?.name\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select `id`, (\n *   select json_object(\n *     'pet_id', `obj`.`pet_id`,\n *     'name', `obj`.`name`\n *   ) from (\n *     select `pet`.`id` as `pet_id`, `pet`.`name`\n *     from `pet`\n *     where `pet`.`owner_id` = `person`.`id`\n *     and `pet`.`is_favorite` = ?\n *   ) as obj\n * ) as `favorite_pet`\n * from `person`\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The MySQL `json_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.\n * While the produced SQL is compatible with all MySQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: eb.fn('concat', ['first_name', eb.val(' '), 'last_name'])\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (MySQL):\n *\n * ```sql\n * select \"id\", json_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', concat(`first_name`, ?, `last_name`)\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\nfunction getMysqlJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('MySQL jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.');\n    }\n}\n"],
  "mappings": ";;;;;;;;6QAAAA,ICAAC,ICAAC,IAEO,IAAMC,EAAwE,CACnF,OAAQ,CACN,MAAO,SACT,EACA,OAAQ,CACN,MAAO,QACT,EACA,IAAK,CACH,MAAO,KACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,cAAe,CACb,MAAO,QACT,EACA,KAAM,CACJ,MAAO,UACT,EACA,SAAU,CACR,MAAO,UACT,EACA,IAAK,CACH,MAAO,SACT,EACA,QAAS,CACP,MAAO,SACT,EACA,OAAQ,CACN,MAAO,SACT,EACA,mBAAoB,CAClB,MAAO,SACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,MAAO,CACL,MAAO,SACT,EACA,MAAO,CACL,MAAO,SACT,EACA,SAAU,CACR,MAAO,KACT,EACA,mBAAoB,CAClB,MAAO,KACT,EACA,IAAK,CACH,MAAO,SACT,EACA,QAAS,CACP,MAAO,SACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,WAAY,CACV,MAAO,KACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,eAAgB,CACd,MAAO,QACT,EACA,SAAU,CACR,MAAO,QACT,EACA,SAAU,CACR,MAAO,QACT,EACA,cAAe,CACb,MAAO,QACT,EACA,YAAa,CACX,MAAO,QACT,EACA,WAAY,CACV,MAAO,QACT,EACA,UAAW,CACT,MAAO,SACT,EACA,WAAY,CACV,MAAO,QACT,EACA,gBAAiB,CACf,MAAO,KACT,EACA,WAAY,CACV,MAAO,KACT,EACA,aAAc,CACZ,MAAO,KACT,EACA,QAAS,CACP,MAAO,SACT,EACA,MAAO,CACL,MAAO,KACT,EACA,QAAS,CACP,MAAO,KACT,EACA,KAAM,CACJ,MAAO,SACT,EAIA,IAAK,CACH,MAAO,KACT,EACA,SAAU,CACR,MAAO,SACT,EACA,KAAM,CACJ,MAAO,QACT,EACA,KAAM,CACJ,MAAO,MACT,EACA,UAAW,CACT,MAAO,UACT,EACA,SAAU,CACR,MAAO,QACT,EACA,QAAS,CACP,MAAO,SACT,EACA,SAAU,CACR,MAAO,QACT,EACA,UAAW,CACT,MAAO,Q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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "MYSQL_DATA_TYPES_TO_METADATA", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getMySQLBuilder", "requirements", "getBuilder", "MysqlAdapter", "MysqlQueryCompiler", "getDeleteQuery", "details", "requirements", "rows", "columns", "tableName", "builder", "getMySQLBuilder", "compile", "applyInferredRowFilters", "getInsertQuery", "_details", "_requirements", "getUpdateRefetchQuery", "changes", "row", "getCurrentTimestampMillis", "getSelectQuery", "filter", "pageIndex", "pageSize", "sortOrder", "filterExpression", "getSelectFilterExpression", "countQuery", "eb", "sql", "qb", "item", "mockSelectQuery", "getUpdateQuery", "schema", "applyTransformations", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonArrayFrom", "expr", "sql", "getMysqlJsonObjectArgs", "getMysqlJsonObjectArgs", "node", "table", "getJsonObjectArgs", "getTablesQuery", "requirements", "compile", "getMySQLBuilder", "sql", "eb", "jsonArrayFrom", "jb", "mockTablesQuery", "getTimezoneQuery", "builder", "sessionTz", "mockTimezoneQuery", "createMySQLAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "_details", "_options", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "timezone", "createIntrospection", "getSelectQuery", "results", "updateQuery", "getUpdateQuery", "refetchQuery", "getUpdateRefetchQuery", "updateError", "refetchResult", "refetchError", "row", "args", "result", "table", "schemas", "columns", "tableName", "schema", "columnsRecord", "a", "b", "column", "datatype", "columnName", "indexOfParenthesis", "strippedDataType", "MYSQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery"]
}

@@ -1,2 +1,2 @@
1
- "use strict";var c=Object.defineProperty;var P=Object.getOwnPropertyDescriptor;var w=Object.getOwnPropertyNames;var q=Object.prototype.hasOwnProperty;var v=(e,r)=>{for(var o in r)c(e,o,{get:r[o],enumerable:!0})},Q=(e,r,o,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of w(r))!q.call(e,n)&&n!==o&&c(e,n,{get:()=>r[n],enumerable:!(t=P(r,n))||t.enumerable});return e};var g=e=>Q(c({},"__esModule",{value:!0}),e);var R={};v(R,{createMySQL2Executor:()=>h});module.exports=g(R);var l=class extends Error{constructor(){super("This operation was aborted"),this.name="AbortError"}};function a(){return[new l]}function x(e){return{parameters:[e],sql:"kill ?"}}function h(e){return{execute:async(r,o)=>{let{abortSignal:t}=o||{};if(!t)try{let[i]=await e.query(r.sql,r.parameters);return[null,i]}catch(i){return[i]}if(t.aborted)return a();let n,s;try{let i,y=new Promise(b=>i=b);t.addEventListener("abort",n=()=>i());let m=e.getConnection(),p=await Promise.race([m,y]);if(!p)return m.catch(()=>{}),a();if(s=p,t.aborted)return s.release(),a();let f=(s||e).query(r.sql,r.parameters),u=await Promise.race([f,y]);if(!u)return Promise.allSettled([k(e,u),f]).finally(()=>s?.release()),a();s.release();let[E]=u;return[null,E]}catch(i){return s?.release(),[i]}finally{n&&t?.removeEventListener("abort",n)}}}}async function k(e,r){let o=x(r);try{await e.query(o.sql,o.parameters)}catch(t){console.error("Failed to cancel query:",t)}}
2
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9teXNxbDIvaW5kZXgudHMiLCAiLi4vLi4vLi4vZGF0YS9leGVjdXRvci50cyIsICIuLi8uLi8uLi9kYXRhL215c3FsLWNvcmUvdXRpbGl0eS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHR5cGUgeyBQb29sLCBQb29sQ29ubmVjdGlvbiB9IGZyb20gXCJteXNxbDIvcHJvbWlzZVwiO1xuXG5pbXBvcnQgeyB0eXBlIEV4ZWN1dG9yLCBnZXRBYm9ydFJlc3VsdCB9IGZyb20gXCIuLi9leGVjdXRvclwiO1xuaW1wb3J0IHsgZ2V0Q2FuY2VsUXVlcnkgfSBmcm9tIFwiLi4vbXlzcWwtY29yZS91dGlsaXR5XCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVNeVNRTDJFeGVjdXRvcihwb29sOiBQb29sKTogRXhlY3V0b3Ige1xuICByZXR1cm4ge1xuICAgIGV4ZWN1dGU6IGFzeW5jIChxdWVyeSwgb3B0aW9ucykgPT4ge1xuICAgICAgY29uc3QgeyBhYm9ydFNpZ25hbCB9ID0gb3B0aW9ucyB8fCB7fTtcblxuICAgICAgaWYgKCFhYm9ydFNpZ25hbCkge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGNvbnN0IFtyZXN1bHRdID0gYXdhaXQgcG9vbC5xdWVyeShxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMpO1xuXG4gICAgICAgICAgcmV0dXJuIFtudWxsLCByZXN1bHQgYXMgbmV2ZXJdO1xuICAgICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICAgIHJldHVybiBbZXJyb3IgYXMgRXJyb3JdO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGlmIChhYm9ydFNpZ25hbC5hYm9ydGVkKSB7XG4gICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgfVxuXG4gICAgICBsZXQgYWJvcnRMaXN0ZW5lcjogKCgpID0+IHZvaWQpIHwgdW5kZWZpbmVkO1xuICAgICAgbGV0IGNvbm5lY3Rpb246IFBvb2xDb25uZWN0aW9uIHwgdW5kZWZpbmVkO1xuXG4gICAgICB0cnkge1xuICAgICAgICBsZXQgYWJvcnRlZDogKCkgPT4gdm9pZDtcbiAgICAgICAgY29uc3QgYWJvcnRpb25Qcm9taXNlID0gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUpID0+IChhYm9ydGVkID0gcmVzb2x2ZSkpO1xuXG4gICAgICAgIGFib3J0U2lnbmFsLmFkZEV2ZW50TGlzdGVuZXIoXCJhYm9ydFwiLCAoYWJvcnRMaXN0ZW5lciA9ICgpID0+IGFib3J0ZWQoKSkpO1xuXG4gICAgICAgIGNvbnN0IGNvbm5lY3Rpb25Qcm9taXNlID0gcG9vbC5nZXRDb25uZWN0aW9uKCk7XG5cbiAgICAgICAgY29uc3QgY29ubmVjdGlvblJlc3VsdCA9IGF3YWl0IFByb21pc2UucmFjZShbY29ubmVjdGlvblByb21pc2UsIGFib3J0aW9uUHJvbWlzZV0pO1xuXG4gICAgICAgIGlmICghY29ubmVjdGlvblJlc3VsdCkge1xuICAgICAgICAgIHZvaWQgY29ubmVjdGlvblByb21pc2UuY2F0Y2goKCkgPT4ge30pO1xuXG4gICAgICAgICAgcmV0dXJuIGdldEFib3J0UmVzdWx0KCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25uZWN0aW9uID0gY29ubmVjdGlvblJlc3VsdDtcblxuICAgICAgICBpZiAoYWJvcnRTaWduYWwuYWJvcnRlZCkge1xuICAgICAgICAgIGNvbm5lY3Rpb24ucmVsZWFzZSgpO1xuXG4gICAgICAgICAgcmV0dXJuIGdldEFib3J0UmVzdWx0KCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBxdWVyeVByb21pc2UgPSAoY29ubmVjdGlvbiB8fCBwb29sKS5xdWVyeShxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMpO1xuXG4gICAgICAgIGNvbnN0IHF1ZXJ5UmVzdWx0ID0gYXdhaXQgUHJvbWlzZS5yYWNlKFtxdWVyeVByb21pc2UsIGFib3J0aW9uUHJvbWlzZV0pO1xuXG4gICAgICAgIGlmICghcXVlcnlSZXN1bHQpIHtcbiAgICAgICAgICAvLyBub3QgaW1wb3J0YW50IGVub3VnaCB0byBhd2FpdC5cbiAgICAgICAgICB2b2lkIFByb21pc2UuYWxsU2V0dGxlZChbY2FuY2VsUXVlcnkocG9vbCwgcXVlcnlSZXN1bHQpLCBxdWVyeVByb21pc2VdKS5maW5hbGx5KCgpID0+IGNvbm5lY3Rpb24/LnJlbGVhc2UoKSk7XG5cbiAgICAgICAgICByZXR1cm4gZ2V0QWJvcnRSZXN1bHQoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbm5lY3Rpb24ucmVsZWFzZSgpO1xuXG4gICAgICAgIGNvbnN0IFtyZXN1bHRdID0gcXVlcnlSZXN1bHQ7XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCByZXN1bHQgYXMgbmV2ZXJdO1xuICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgY29ubmVjdGlvbj8ucmVsZWFzZSgpO1xuXG4gICAgICAgIHJldHVybiBbZXJyb3IgYXMgRXJyb3JdO1xuICAgICAgfSBmaW5hbGx5IHtcbiAgICAgICAgaWYgKGFib3J0TGlzdGVuZXIpIHtcbiAgICAgICAgICBhYm9ydFNpZ25hbD8ucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImFib3J0XCIsIGFib3J0TGlzdGVuZXIpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gY2FuY2VsUXVlcnkocG9vbDogUG9vbCwgdGhyZWFkSWQ6IHVua25vd24pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgcXVlcnkgPSBnZXRDYW5jZWxRdWVyeSh0aHJlYWRJZCk7XG5cbiAgdHJ5IHtcbiAgICBhd2FpdCBwb29sLnF1ZXJ5KHF1ZXJ5LnNxbCwgcXVlcnkucGFyYW1ldGVycyk7XG4gIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgY29uc29sZS5lcnJvcihcIkZhaWxlZCB0byBjYW5jZWwgcXVlcnk6XCIsIGVycm9yKTtcbiAgfVxufVxuIiwgImltcG9ydCB0eXBlIHsgUXVlcnksIFF1ZXJ5UmVzdWx0IH0gZnJvbSBcIi4vcXVlcnlcIjtcbmltcG9ydCB0eXBlIHsgRWl0aGVyIH0gZnJvbSBcIi4vdHlwZS11dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV4ZWN1dG9yIHtcbiAgZXhlY3V0ZTxUPihxdWVyeTogUXVlcnk8VD4sIG9wdGlvbnM/OiBFeGVjdXRlT3B0aW9ucyk6IFByb21pc2U8RWl0aGVyPEVycm9yLCBRdWVyeVJlc3VsdDxRdWVyeTxUPj4+Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFeGVjdXRlT3B0aW9ucyB7XG4gIGFib3J0U2lnbmFsPzogQWJvcnRTaWduYWw7XG59XG5cbmV4cG9ydCBjbGFzcyBBYm9ydEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcihcIlRoaXMgb3BlcmF0aW9uIHdhcyBhYm9ydGVkXCIpO1xuICAgIHRoaXMubmFtZSA9IFwiQWJvcnRFcnJvclwiO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRBYm9ydFJlc3VsdCgpOiBbQWJvcnRFcnJvcl0ge1xuICByZXR1cm4gW25ldyBBYm9ydEVycm9yKCldO1xufVxuIiwgImltcG9ydCB0eXBlIHsgUXVlcnkgfSBmcm9tIFwiLi4vcXVlcnlcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldENhbmNlbFF1ZXJ5KHRocmVhZElkOiB1bmtub3duKTogUXVlcnk8dW5rbm93bj4ge1xuICByZXR1cm4ge1xuICAgIHBhcmFtZXRlcnM6IFt0aHJlYWRJZF0sXG4gICAgc3FsOiBcImtpbGwgP1wiLFxuICB9O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogInlhQUFBLElBQUFBLEVBQUEsR0FBQUMsRUFBQUQsRUFBQSwwQkFBQUUsSUFBQSxlQUFBQyxFQUFBSCxHQ1dPLElBQU1JLEVBQU4sY0FBeUIsS0FBTSxDQUNwQyxhQUFjLENBQ1osTUFBTSw0QkFBNEIsRUFDbEMsS0FBSyxLQUFPLFlBQ2QsQ0FDRixFQUVPLFNBQVNDLEdBQStCLENBQzdDLE1BQU8sQ0FBQyxJQUFJRCxDQUFZLENBQzFCLENDbEJPLFNBQVNFLEVBQWVDLEVBQW1DLENBQ2hFLE1BQU8sQ0FDTCxXQUFZLENBQUNBLENBQVEsRUFDckIsSUFBSyxRQUNQLENBQ0YsQ0ZGTyxTQUFTQyxFQUFxQkMsRUFBc0IsQ0FDekQsTUFBTyxDQUNMLFFBQVMsTUFBT0MsRUFBT0MsSUFBWSxDQUNqQyxHQUFNLENBQUUsWUFBQUMsQ0FBWSxFQUFJRCxHQUFXLENBQUMsRUFFcEMsR0FBSSxDQUFDQyxFQUNILEdBQUksQ0FDRixHQUFNLENBQUNDLENBQU0sRUFBSSxNQUFNSixFQUFLLE1BQU1DLEVBQU0sSUFBS0EsRUFBTSxVQUFVLEVBRTdELE1BQU8sQ0FBQyxLQUFNRyxDQUFlLENBQy9CLE9BQVNDLEVBQWdCLENBQ3ZCLE1BQU8sQ0FBQ0EsQ0FBYyxDQUN4QixDQUdGLEdBQUlGLEVBQVksUUFDZCxPQUFPRyxFQUFlLEVBR3hCLElBQUlDLEVBQ0FDLEVBRUosR0FBSSxDQUNGLElBQUlDLEVBQ0VDLEVBQWtCLElBQUksUUFBZUMsR0FBYUYsRUFBVUUsQ0FBUSxFQUUxRVIsRUFBWSxpQkFBaUIsUUFBVUksRUFBZ0IsSUFBTUUsRUFBUSxDQUFFLEVBRXZFLElBQU1HLEVBQW9CWixFQUFLLGNBQWMsRUFFdkNhLEVBQW1CLE1BQU0sUUFBUSxLQUFLLENBQUNELEVBQW1CRixDQUFlLENBQUMsRUFFaEYsR0FBSSxDQUFDRyxFQUNILE9BQUtELEVBQWtCLE1BQU0sSUFBTSxDQUFDLENBQUMsRUFFOUJOLEVBQWUsRUFLeEIsR0FGQUUsRUFBYUssRUFFVFYsRUFBWSxRQUNkLE9BQUFLLEVBQVcsUUFBUSxFQUVaRixFQUFlLEVBR3hCLElBQU1RLEdBQWdCTixHQUFjUixHQUFNLE1BQU1DLEVBQU0sSUFBS0EsRUFBTSxVQUFVLEVBRXJFYyxFQUFjLE1BQU0sUUFBUSxLQUFLLENBQUNELEVBQWNKLENBQWUsQ0FBQyxFQUV0RSxHQUFJLENBQUNLLEVBRUgsT0FBSyxRQUFRLFdBQVcsQ0FBQ0MsRUFBWWhCLEVBQU1lLENBQVcsRUFBR0QsQ0FBWSxDQUFDLEVBQUUsUUFBUSxJQUFNTixHQUFZLFFBQVEsQ0FBQyxFQUVwR0YsRUFBZSxFQUd4QkUsRUFBVyxRQUFRLEVBRW5CLEdBQU0sQ0FBQ0osQ0FBTSxFQUFJVyxFQUVqQixNQUFPLENBQUMsS0FBTVgsQ0FBZSxDQUMvQixPQUFTQyxFQUFnQixDQUN2QixPQUFBRyxHQUFZLFFBQVEsRUFFYixDQUFDSCxDQUFjLENBQ3hCLFFBQUUsQ0FDSUUsR0FDRkosR0FBYSxvQkFBb0IsUUFBU0ksQ0FBYSxDQUUzRCxDQUNGLENBQ0YsQ0FDRixDQUVBLGVBQWVTLEVBQVloQixFQUFZaUIsRUFBa0MsQ0FDdkUsSUFBTWhCLEVBQVFpQixFQUFlRCxDQUFRLEVBRXJDLEdBQUksQ0FDRixNQUFNakIsRUFBSyxNQUFNQyxFQUFNLElBQUtBLEVBQU0sVUFBVSxDQUM5QyxPQUFTSSxFQUFnQixDQUN2QixRQUFRLE1BQU0sMEJBQTJCQSxDQUFLLENBQ2hELENBQ0YiLAogICJuYW1lcyI6IFsibXlzcWwyX2V4cG9ydHMiLCAiX19leHBvcnQiLCAiY3JlYXRlTXlTUUwyRXhlY3V0b3IiLCAiX190b0NvbW1vbkpTIiwgIkFib3J0RXJyb3IiLCAiZ2V0QWJvcnRSZXN1bHQiLCAiZ2V0Q2FuY2VsUXVlcnkiLCAidGhyZWFkSWQiLCAiY3JlYXRlTXlTUUwyRXhlY3V0b3IiLCAicG9vbCIsICJxdWVyeSIsICJvcHRpb25zIiwgImFib3J0U2lnbmFsIiwgInJlc3VsdCIsICJlcnJvciIsICJnZXRBYm9ydFJlc3VsdCIsICJhYm9ydExpc3RlbmVyIiwgImNvbm5lY3Rpb24iLCAiYWJvcnRlZCIsICJhYm9ydGlvblByb21pc2UiLCAicmVzb2x2ZSIsICJjb25uZWN0aW9uUHJvbWlzZSIsICJjb25uZWN0aW9uUmVzdWx0IiwgInF1ZXJ5UHJvbWlzZSIsICJxdWVyeVJlc3VsdCIsICJjYW5jZWxRdWVyeSIsICJ0aHJlYWRJZCIsICJnZXRDYW5jZWxRdWVyeSJdCn0K
1
+ "use strict";var c=Object.defineProperty;var q=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var b=Object.prototype.hasOwnProperty;var w=(e,r)=>{for(var o in r)c(e,o,{get:r[o],enumerable:!0})},v=(e,r,o,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of P(r))!b.call(e,n)&&n!==o&&c(e,n,{get:()=>r[n],enumerable:!(t=q(r,n))||t.enumerable});return e};var S=e=>v(c({},"__esModule",{value:!0}),e);var R={};w(R,{createMySQL2Executor:()=>h});module.exports=S(R);var l=class extends Error{constructor(){super("This operation was aborted"),this.name="AbortError"}};function s(){return[new l]}function E(e){return{parameters:[e],sql:"kill ?"}}function h(e){return{execute:async(r,o)=>{let{abortSignal:t}=o||{};if(!t)try{let[u]=await e.query(r.sql,r.parameters);return[null,u]}catch(u){return[u]}if(t.aborted)return s();let n,i;try{let u,y=new Promise(Q=>u=Q);t.addEventListener("abort",n=()=>u());let m=e.getConnection(),p=await Promise.race([m,y]);if(!p)return m.catch(()=>{}),s();if(i=p,t.aborted)return i.release(),s();let f=(i||e).query(r.sql,r.parameters),a=await Promise.race([f,y]);if(!a)return Promise.allSettled([g(e,a),f]).finally(()=>i?.release()),s();i.release();let[d]=a;return[null,d]}catch(u){return i?.release(),[u]}finally{n&&t?.removeEventListener("abort",n)}}}}async function g(e,r){let o=E(r);try{await e.query(o.sql,o.parameters)}catch(t){console.error("Failed to cancel query:",t)}}
2
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9teXNxbDIvaW5kZXgudHMiLCAiLi4vLi4vLi4vZGF0YS9leGVjdXRvci50cyIsICIuLi8uLi8uLi9kYXRhL215c3FsLWNvcmUvdXRpbGl0eS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHR5cGUgeyBQb29sLCBQb29sQ29ubmVjdGlvbiB9IGZyb20gXCJteXNxbDIvcHJvbWlzZVwiO1xuXG5pbXBvcnQgeyB0eXBlIEV4ZWN1dG9yLCBnZXRBYm9ydFJlc3VsdCB9IGZyb20gXCIuLi9leGVjdXRvclwiO1xuaW1wb3J0IHsgZ2V0Q2FuY2VsUXVlcnkgfSBmcm9tIFwiLi4vbXlzcWwtY29yZS91dGlsaXR5XCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVNeVNRTDJFeGVjdXRvcihwb29sOiBQb29sKTogRXhlY3V0b3Ige1xuICByZXR1cm4ge1xuICAgIGV4ZWN1dGU6IGFzeW5jIChxdWVyeSwgb3B0aW9ucykgPT4ge1xuICAgICAgY29uc3QgeyBhYm9ydFNpZ25hbCB9ID0gb3B0aW9ucyB8fCB7fTtcblxuICAgICAgaWYgKCFhYm9ydFNpZ25hbCkge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGNvbnN0IFtyZXN1bHRdID0gYXdhaXQgcG9vbC5xdWVyeShxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMpO1xuXG4gICAgICAgICAgcmV0dXJuIFtudWxsLCByZXN1bHQgYXMgbmV2ZXJdO1xuICAgICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICAgIHJldHVybiBbZXJyb3IgYXMgRXJyb3JdO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGlmIChhYm9ydFNpZ25hbC5hYm9ydGVkKSB7XG4gICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgfVxuXG4gICAgICBsZXQgYWJvcnRMaXN0ZW5lcjogKCgpID0+IHZvaWQpIHwgdW5kZWZpbmVkO1xuICAgICAgbGV0IGNvbm5lY3Rpb246IFBvb2xDb25uZWN0aW9uIHwgdW5kZWZpbmVkO1xuXG4gICAgICB0cnkge1xuICAgICAgICBsZXQgYWJvcnRlZDogKCkgPT4gdm9pZDtcbiAgICAgICAgY29uc3QgYWJvcnRpb25Qcm9taXNlID0gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUpID0+IChhYm9ydGVkID0gcmVzb2x2ZSkpO1xuXG4gICAgICAgIGFib3J0U2lnbmFsLmFkZEV2ZW50TGlzdGVuZXIoXCJhYm9ydFwiLCAoYWJvcnRMaXN0ZW5lciA9ICgpID0+IGFib3J0ZWQoKSkpO1xuXG4gICAgICAgIGNvbnN0IGNvbm5lY3Rpb25Qcm9taXNlID0gcG9vbC5nZXRDb25uZWN0aW9uKCk7XG5cbiAgICAgICAgY29uc3QgY29ubmVjdGlvblJlc3VsdCA9IGF3YWl0IFByb21pc2UucmFjZShbY29ubmVjdGlvblByb21pc2UsIGFib3J0aW9uUHJvbWlzZV0pO1xuXG4gICAgICAgIGlmICghY29ubmVjdGlvblJlc3VsdCkge1xuICAgICAgICAgIHZvaWQgY29ubmVjdGlvblByb21pc2UuY2F0Y2goKCkgPT4ge30pO1xuXG4gICAgICAgICAgcmV0dXJuIGdldEFib3J0UmVzdWx0KCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25uZWN0aW9uID0gY29ubmVjdGlvblJlc3VsdDtcblxuICAgICAgICBpZiAoYWJvcnRTaWduYWwuYWJvcnRlZCkge1xuICAgICAgICAgIGNvbm5lY3Rpb24ucmVsZWFzZSgpO1xuXG4gICAgICAgICAgcmV0dXJuIGdldEFib3J0UmVzdWx0KCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBxdWVyeVByb21pc2UgPSAoY29ubmVjdGlvbiB8fCBwb29sKS5xdWVyeShxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMpO1xuXG4gICAgICAgIGNvbnN0IHF1ZXJ5UmVzdWx0ID0gYXdhaXQgUHJvbWlzZS5yYWNlKFtxdWVyeVByb21pc2UsIGFib3J0aW9uUHJvbWlzZV0pO1xuXG4gICAgICAgIGlmICghcXVlcnlSZXN1bHQpIHtcbiAgICAgICAgICAvLyBub3QgaW1wb3J0YW50IGVub3VnaCB0byBhd2FpdC5cbiAgICAgICAgICB2b2lkIFByb21pc2UuYWxsU2V0dGxlZChbY2FuY2VsUXVlcnkocG9vbCwgcXVlcnlSZXN1bHQpLCBxdWVyeVByb21pc2VdKS5maW5hbGx5KCgpID0+IGNvbm5lY3Rpb24/LnJlbGVhc2UoKSk7XG5cbiAgICAgICAgICByZXR1cm4gZ2V0QWJvcnRSZXN1bHQoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbm5lY3Rpb24ucmVsZWFzZSgpO1xuXG4gICAgICAgIGNvbnN0IFtyZXN1bHRdID0gcXVlcnlSZXN1bHQ7XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCByZXN1bHQgYXMgbmV2ZXJdO1xuICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgY29ubmVjdGlvbj8ucmVsZWFzZSgpO1xuXG4gICAgICAgIHJldHVybiBbZXJyb3IgYXMgRXJyb3JdO1xuICAgICAgfSBmaW5hbGx5IHtcbiAgICAgICAgaWYgKGFib3J0TGlzdGVuZXIpIHtcbiAgICAgICAgICBhYm9ydFNpZ25hbD8ucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImFib3J0XCIsIGFib3J0TGlzdGVuZXIpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gY2FuY2VsUXVlcnkocG9vbDogUG9vbCwgdGhyZWFkSWQ6IHVua25vd24pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgcXVlcnkgPSBnZXRDYW5jZWxRdWVyeSh0aHJlYWRJZCk7XG5cbiAgdHJ5IHtcbiAgICBhd2FpdCBwb29sLnF1ZXJ5KHF1ZXJ5LnNxbCwgcXVlcnkucGFyYW1ldGVycyk7XG4gIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgY29uc29sZS5lcnJvcihcIkZhaWxlZCB0byBjYW5jZWwgcXVlcnk6XCIsIGVycm9yKTtcbiAgfVxufVxuIiwgImltcG9ydCB0eXBlIHsgUXVlcnksIFF1ZXJ5UmVzdWx0IH0gZnJvbSBcIi4vcXVlcnlcIjtcbmltcG9ydCB0eXBlIHsgRWl0aGVyIH0gZnJvbSBcIi4vdHlwZS11dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV4ZWN1dG9yIHtcbiAgZXhlY3V0ZTxUPihxdWVyeTogUXVlcnk8VD4sIG9wdGlvbnM/OiBFeGVjdXRlT3B0aW9ucyk6IFByb21pc2U8RWl0aGVyPEVycm9yLCBRdWVyeVJlc3VsdDxRdWVyeTxUPj4+Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZXF1ZW5jZUV4ZWN1dG9yIGV4dGVuZHMgRXhlY3V0b3Ige1xuICBleGVjdXRlU2VxdWVuY2U8VCwgUz4oXG4gICAgcXVlcnk6IFtRdWVyeTxUPiwgUXVlcnk8Uz5dLFxuICAgIG9wdGlvbnM/OiBFeGVjdXRlT3B0aW9ucyxcbiAgKTogUHJvbWlzZTxbW0Vycm9yXV0gfCBbW251bGwsIFF1ZXJ5UmVzdWx0PFF1ZXJ5PFQ+Pl0sIEVpdGhlcjxFcnJvciwgUXVlcnlSZXN1bHQ8UXVlcnk8Uz4+Pl0+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV4ZWN1dGVPcHRpb25zIHtcbiAgYWJvcnRTaWduYWw/OiBBYm9ydFNpZ25hbDtcbn1cblxuZXhwb3J0IGNsYXNzIEFib3J0RXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKFwiVGhpcyBvcGVyYXRpb24gd2FzIGFib3J0ZWRcIik7XG4gICAgdGhpcy5uYW1lID0gXCJBYm9ydEVycm9yXCI7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEFib3J0UmVzdWx0KCk6IFtBYm9ydEVycm9yXSB7XG4gIHJldHVybiBbbmV3IEFib3J0RXJyb3IoKV07XG59XG4iLCAiaW1wb3J0IHR5cGUgeyBRdWVyeSB9IGZyb20gXCIuLi9xdWVyeVwiO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q2FuY2VsUXVlcnkodGhyZWFkSWQ6IHVua25vd24pOiBRdWVyeTx1bmtub3duPiB7XG4gIHJldHVybiB7XG4gICAgcGFyYW1ldGVyczogW3RocmVhZElkXSxcbiAgICBzcWw6IFwia2lsbCA/XCIsXG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAieWFBQUEsSUFBQUEsRUFBQSxHQUFBQyxFQUFBRCxFQUFBLDBCQUFBRSxJQUFBLGVBQUFDLEVBQUFILEdDa0JPLElBQU1JLEVBQU4sY0FBeUIsS0FBTSxDQUNwQyxhQUFjLENBQ1osTUFBTSw0QkFBNEIsRUFDbEMsS0FBSyxLQUFPLFlBQ2QsQ0FDRixFQUVPLFNBQVNDLEdBQStCLENBQzdDLE1BQU8sQ0FBQyxJQUFJRCxDQUFZLENBQzFCLENDekJPLFNBQVNFLEVBQWVDLEVBQW1DLENBQ2hFLE1BQU8sQ0FDTCxXQUFZLENBQUNBLENBQVEsRUFDckIsSUFBSyxRQUNQLENBQ0YsQ0ZGTyxTQUFTQyxFQUFxQkMsRUFBc0IsQ0FDekQsTUFBTyxDQUNMLFFBQVMsTUFBT0MsRUFBT0MsSUFBWSxDQUNqQyxHQUFNLENBQUUsWUFBQUMsQ0FBWSxFQUFJRCxHQUFXLENBQUMsRUFFcEMsR0FBSSxDQUFDQyxFQUNILEdBQUksQ0FDRixHQUFNLENBQUNDLENBQU0sRUFBSSxNQUFNSixFQUFLLE1BQU1DLEVBQU0sSUFBS0EsRUFBTSxVQUFVLEVBRTdELE1BQU8sQ0FBQyxLQUFNRyxDQUFlLENBQy9CLE9BQVNDLEVBQWdCLENBQ3ZCLE1BQU8sQ0FBQ0EsQ0FBYyxDQUN4QixDQUdGLEdBQUlGLEVBQVksUUFDZCxPQUFPRyxFQUFlLEVBR3hCLElBQUlDLEVBQ0FDLEVBRUosR0FBSSxDQUNGLElBQUlDLEVBQ0VDLEVBQWtCLElBQUksUUFBZUMsR0FBYUYsRUFBVUUsQ0FBUSxFQUUxRVIsRUFBWSxpQkFBaUIsUUFBVUksRUFBZ0IsSUFBTUUsRUFBUSxDQUFFLEVBRXZFLElBQU1HLEVBQW9CWixFQUFLLGNBQWMsRUFFdkNhLEVBQW1CLE1BQU0sUUFBUSxLQUFLLENBQUNELEVBQW1CRixDQUFlLENBQUMsRUFFaEYsR0FBSSxDQUFDRyxFQUNILE9BQUtELEVBQWtCLE1BQU0sSUFBTSxDQUFDLENBQUMsRUFFOUJOLEVBQWUsRUFLeEIsR0FGQUUsRUFBYUssRUFFVFYsRUFBWSxRQUNkLE9BQUFLLEVBQVcsUUFBUSxFQUVaRixFQUFlLEVBR3hCLElBQU1RLEdBQWdCTixHQUFjUixHQUFNLE1BQU1DLEVBQU0sSUFBS0EsRUFBTSxVQUFVLEVBRXJFYyxFQUFjLE1BQU0sUUFBUSxLQUFLLENBQUNELEVBQWNKLENBQWUsQ0FBQyxFQUV0RSxHQUFJLENBQUNLLEVBRUgsT0FBSyxRQUFRLFdBQVcsQ0FBQ0MsRUFBWWhCLEVBQU1lLENBQVcsRUFBR0QsQ0FBWSxDQUFDLEVBQUUsUUFBUSxJQUFNTixHQUFZLFFBQVEsQ0FBQyxFQUVwR0YsRUFBZSxFQUd4QkUsRUFBVyxRQUFRLEVBRW5CLEdBQU0sQ0FBQ0osQ0FBTSxFQUFJVyxFQUVqQixNQUFPLENBQUMsS0FBTVgsQ0FBZSxDQUMvQixPQUFTQyxFQUFnQixDQUN2QixPQUFBRyxHQUFZLFFBQVEsRUFFYixDQUFDSCxDQUFjLENBQ3hCLFFBQUUsQ0FDSUUsR0FDRkosR0FBYSxvQkFBb0IsUUFBU0ksQ0FBYSxDQUUzRCxDQUNGLENBQ0YsQ0FDRixDQUVBLGVBQWVTLEVBQVloQixFQUFZaUIsRUFBa0MsQ0FDdkUsSUFBTWhCLEVBQVFpQixFQUFlRCxDQUFRLEVBRXJDLEdBQUksQ0FDRixNQUFNakIsRUFBSyxNQUFNQyxFQUFNLElBQUtBLEVBQU0sVUFBVSxDQUM5QyxPQUFTSSxFQUFnQixDQUN2QixRQUFRLE1BQU0sMEJBQTJCQSxDQUFLLENBQ2hELENBQ0YiLAogICJuYW1lcyI6IFsibXlzcWwyX2V4cG9ydHMiLCAiX19leHBvcnQiLCAiY3JlYXRlTXlTUUwyRXhlY3V0b3IiLCAiX190b0NvbW1vbkpTIiwgIkFib3J0RXJyb3IiLCAiZ2V0QWJvcnRSZXN1bHQiLCAiZ2V0Q2FuY2VsUXVlcnkiLCAidGhyZWFkSWQiLCAiY3JlYXRlTXlTUUwyRXhlY3V0b3IiLCAicG9vbCIsICJxdWVyeSIsICJvcHRpb25zIiwgImFib3J0U2lnbmFsIiwgInJlc3VsdCIsICJlcnJvciIsICJnZXRBYm9ydFJlc3VsdCIsICJhYm9ydExpc3RlbmVyIiwgImNvbm5lY3Rpb24iLCAiYWJvcnRlZCIsICJhYm9ydGlvblByb21pc2UiLCAicmVzb2x2ZSIsICJjb25uZWN0aW9uUHJvbWlzZSIsICJjb25uZWN0aW9uUmVzdWx0IiwgInF1ZXJ5UHJvbWlzZSIsICJxdWVyeVJlc3VsdCIsICJjYW5jZWxRdWVyeSIsICJ0aHJlYWRJZCIsICJnZXRDYW5jZWxRdWVyeSJdCn0K
@@ -1,5 +1,5 @@
1
1
  import { Pool } from 'mysql2/promise';
2
- import { E as Executor } from '../../index-2horhMcs.cjs';
2
+ import { E as Executor } from '../../index-CV9DQF9a.cjs';
3
3
  import 'kysely';
4
4
 
5
5
  declare function createMySQL2Executor(pool: Pool): Executor;
@@ -1,5 +1,5 @@
1
1
  import { Pool } from 'mysql2/promise';
2
- import { E as Executor } from '../../index-2horhMcs.js';
2
+ import { E as Executor } from '../../index-CV9DQF9a.js';
3
3
  import 'kysely';
4
4
 
5
5
  declare function createMySQL2Executor(pool: Pool): 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{a as f}from"../../chunk-ZUEQ555M.js";import{b as a}from"../../chunk-AHIV4VYN.js";import{e as y}from"../../chunk-GDQBQ7MK.js";y();function E(t){return{execute:async(n,i)=>{let{abortSignal:r}=i||{};if(!r)try{let[e]=await t.query(n.sql,n.parameters);return[null,e]}catch(e){return[e]}if(r.aborted)return a();let s,o;try{let e,l=new Promise(v=>e=v);r.addEventListener("abort",s=()=>e());let u=t.getConnection(),m=await Promise.race([u,l]);if(!m)return u.catch(()=>{}),a();if(o=m,r.aborted)return o.release(),a();let d=(o||t).query(n.sql,n.parameters),c=await Promise.race([d,l]);if(!c)return Promise.allSettled([b(t,c),d]).finally(()=>o?.release()),a();o.release();let[P]=c;return[null,P]}catch(e){return o?.release(),[e]}finally{s&&r?.removeEventListener("abort",s)}}}}async function b(t,n){let i=f(n);try{await t.query(i.sql,i.parameters)}catch(r){console.error("Failed to cancel query:",r)}}export{E as createMySQL2Executor};
9
+ import{a as f}from"../../chunk-ZUEQ555M.js";import{b as a}from"../../chunk-NQGSK3IM.js";import{e as y}from"../../chunk-GDQBQ7MK.js";y();function E(t){return{execute:async(n,i)=>{let{abortSignal:r}=i||{};if(!r)try{let[e]=await t.query(n.sql,n.parameters);return[null,e]}catch(e){return[e]}if(r.aborted)return a();let s,o;try{let e,l=new Promise(v=>e=v);r.addEventListener("abort",s=()=>e());let u=t.getConnection(),m=await Promise.race([u,l]);if(!m)return u.catch(()=>{}),a();if(o=m,r.aborted)return o.release(),a();let d=(o||t).query(n.sql,n.parameters),c=await Promise.race([d,l]);if(!c)return Promise.allSettled([b(t,c),d]).finally(()=>o?.release()),a();o.release();let[P]=c;return[null,P]}catch(e){return o?.release(),[e]}finally{s&&r?.removeEventListener("abort",s)}}}}async function b(t,n){let i=f(n);try{await t.query(i.sql,i.parameters)}catch(r){console.error("Failed to cancel query:",r)}}export{E as createMySQL2Executor};
10
10
  //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9teXNxbDIvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB0eXBlIHsgUG9vbCwgUG9vbENvbm5lY3Rpb24gfSBmcm9tIFwibXlzcWwyL3Byb21pc2VcIjtcblxuaW1wb3J0IHsgdHlwZSBFeGVjdXRvciwgZ2V0QWJvcnRSZXN1bHQgfSBmcm9tIFwiLi4vZXhlY3V0b3JcIjtcbmltcG9ydCB7IGdldENhbmNlbFF1ZXJ5IH0gZnJvbSBcIi4uL215c3FsLWNvcmUvdXRpbGl0eVwiO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlTXlTUUwyRXhlY3V0b3IocG9vbDogUG9vbCk6IEV4ZWN1dG9yIHtcbiAgcmV0dXJuIHtcbiAgICBleGVjdXRlOiBhc3luYyAocXVlcnksIG9wdGlvbnMpID0+IHtcbiAgICAgIGNvbnN0IHsgYWJvcnRTaWduYWwgfSA9IG9wdGlvbnMgfHwge307XG5cbiAgICAgIGlmICghYWJvcnRTaWduYWwpIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCBbcmVzdWx0XSA9IGF3YWl0IHBvb2wucXVlcnkocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzKTtcblxuICAgICAgICAgIHJldHVybiBbbnVsbCwgcmVzdWx0IGFzIG5ldmVyXTtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoYWJvcnRTaWduYWwuYWJvcnRlZCkge1xuICAgICAgICByZXR1cm4gZ2V0QWJvcnRSZXN1bHQoKTtcbiAgICAgIH1cblxuICAgICAgbGV0IGFib3J0TGlzdGVuZXI6ICgoKSA9PiB2b2lkKSB8IHVuZGVmaW5lZDtcbiAgICAgIGxldCBjb25uZWN0aW9uOiBQb29sQ29ubmVjdGlvbiB8IHVuZGVmaW5lZDtcblxuICAgICAgdHJ5IHtcbiAgICAgICAgbGV0IGFib3J0ZWQ6ICgpID0+IHZvaWQ7XG4gICAgICAgIGNvbnN0IGFib3J0aW9uUHJvbWlzZSA9IG5ldyBQcm9taXNlPHZvaWQ+KChyZXNvbHZlKSA9PiAoYWJvcnRlZCA9IHJlc29sdmUpKTtcblxuICAgICAgICBhYm9ydFNpZ25hbC5hZGRFdmVudExpc3RlbmVyKFwiYWJvcnRcIiwgKGFib3J0TGlzdGVuZXIgPSAoKSA9PiBhYm9ydGVkKCkpKTtcblxuICAgICAgICBjb25zdCBjb25uZWN0aW9uUHJvbWlzZSA9IHBvb2wuZ2V0Q29ubmVjdGlvbigpO1xuXG4gICAgICAgIGNvbnN0IGNvbm5lY3Rpb25SZXN1bHQgPSBhd2FpdCBQcm9taXNlLnJhY2UoW2Nvbm5lY3Rpb25Qcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAoIWNvbm5lY3Rpb25SZXN1bHQpIHtcbiAgICAgICAgICB2b2lkIGNvbm5lY3Rpb25Qcm9taXNlLmNhdGNoKCgpID0+IHt9KTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29ubmVjdGlvbiA9IGNvbm5lY3Rpb25SZXN1bHQ7XG5cbiAgICAgICAgaWYgKGFib3J0U2lnbmFsLmFib3J0ZWQpIHtcbiAgICAgICAgICBjb25uZWN0aW9uLnJlbGVhc2UoKTtcblxuICAgICAgICAgIHJldHVybiBnZXRBYm9ydFJlc3VsdCgpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcXVlcnlQcm9taXNlID0gKGNvbm5lY3Rpb24gfHwgcG9vbCkucXVlcnkocXVlcnkuc3FsLCBxdWVyeS5wYXJhbWV0ZXJzKTtcblxuICAgICAgICBjb25zdCBxdWVyeVJlc3VsdCA9IGF3YWl0IFByb21pc2UucmFjZShbcXVlcnlQcm9taXNlLCBhYm9ydGlvblByb21pc2VdKTtcblxuICAgICAgICBpZiAoIXF1ZXJ5UmVzdWx0KSB7XG4gICAgICAgICAgLy8gbm90IGltcG9ydGFudCBlbm91Z2ggdG8gYXdhaXQuXG4gICAgICAgICAgdm9pZCBQcm9taXNlLmFsbFNldHRsZWQoW2NhbmNlbFF1ZXJ5KHBvb2wsIHF1ZXJ5UmVzdWx0KSwgcXVlcnlQcm9taXNlXSkuZmluYWxseSgoKSA9PiBjb25uZWN0aW9uPy5yZWxlYXNlKCkpO1xuXG4gICAgICAgICAgcmV0dXJuIGdldEFib3J0UmVzdWx0KCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25uZWN0aW9uLnJlbGVhc2UoKTtcblxuICAgICAgICBjb25zdCBbcmVzdWx0XSA9IHF1ZXJ5UmVzdWx0O1xuXG4gICAgICAgIHJldHVybiBbbnVsbCwgcmVzdWx0IGFzIG5ldmVyXTtcbiAgICAgIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgICAgIGNvbm5lY3Rpb24/LnJlbGVhc2UoKTtcblxuICAgICAgICByZXR1cm4gW2Vycm9yIGFzIEVycm9yXTtcbiAgICAgIH0gZmluYWxseSB7XG4gICAgICAgIGlmIChhYm9ydExpc3RlbmVyKSB7XG4gICAgICAgICAgYWJvcnRTaWduYWw/LnJlbW92ZUV2ZW50TGlzdGVuZXIoXCJhYm9ydFwiLCBhYm9ydExpc3RlbmVyKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG4gIH07XG59XG5cbmFzeW5jIGZ1bmN0aW9uIGNhbmNlbFF1ZXJ5KHBvb2w6IFBvb2wsIHRocmVhZElkOiB1bmtub3duKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHF1ZXJ5ID0gZ2V0Q2FuY2VsUXVlcnkodGhyZWFkSWQpO1xuXG4gIHRyeSB7XG4gICAgYXdhaXQgcG9vbC5xdWVyeShxdWVyeS5zcWwsIHF1ZXJ5LnBhcmFtZXRlcnMpO1xuICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgIGNvbnNvbGUuZXJyb3IoXCJGYWlsZWQgdG8gY2FuY2VsIHF1ZXJ5OlwiLCBlcnJvcik7XG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7O29JQUFBQSxJQUtPLFNBQVNDLEVBQXFCQyxFQUFzQixDQUN6RCxNQUFPLENBQ0wsUUFBUyxNQUFPQyxFQUFPQyxJQUFZLENBQ2pDLEdBQU0sQ0FBRSxZQUFBQyxDQUFZLEVBQUlELEdBQVcsQ0FBQyxFQUVwQyxHQUFJLENBQUNDLEVBQ0gsR0FBSSxDQUNGLEdBQU0sQ0FBQ0MsQ0FBTSxFQUFJLE1BQU1KLEVBQUssTUFBTUMsRUFBTSxJQUFLQSxFQUFNLFVBQVUsRUFFN0QsTUFBTyxDQUFDLEtBQU1HLENBQWUsQ0FDL0IsT0FBU0MsRUFBZ0IsQ0FDdkIsTUFBTyxDQUFDQSxDQUFjLENBQ3hCLENBR0YsR0FBSUYsRUFBWSxRQUNkLE9BQU9HLEVBQWUsRUFHeEIsSUFBSUMsRUFDQUMsRUFFSixHQUFJLENBQ0YsSUFBSUMsRUFDRUMsRUFBa0IsSUFBSSxRQUFlQyxHQUFhRixFQUFVRSxDQUFRLEVBRTFFUixFQUFZLGlCQUFpQixRQUFVSSxFQUFnQixJQUFNRSxFQUFRLENBQUUsRUFFdkUsSUFBTUcsRUFBb0JaLEVBQUssY0FBYyxFQUV2Q2EsRUFBbUIsTUFBTSxRQUFRLEtBQUssQ0FBQ0QsRUFBbUJGLENBQWUsQ0FBQyxFQUVoRixHQUFJLENBQUNHLEVBQ0gsT0FBS0QsRUFBa0IsTUFBTSxJQUFNLENBQUMsQ0FBQyxFQUU5Qk4sRUFBZSxFQUt4QixHQUZBRSxFQUFhSyxFQUVUVixFQUFZLFFBQ2QsT0FBQUssRUFBVyxRQUFRLEVBRVpGLEVBQWUsRUFHeEIsSUFBTVEsR0FBZ0JOLEdBQWNSLEdBQU0sTUFBTUMsRUFBTSxJQUFLQSxFQUFNLFVBQVUsRUFFckVjLEVBQWMsTUFBTSxRQUFRLEtBQUssQ0FBQ0QsRUFBY0osQ0FBZSxDQUFDLEVBRXRFLEdBQUksQ0FBQ0ssRUFFSCxPQUFLLFFBQVEsV0FBVyxDQUFDQyxFQUFZaEIsRUFBTWUsQ0FBVyxFQUFHRCxDQUFZLENBQUMsRUFBRSxRQUFRLElBQU1OLEdBQVksUUFBUSxDQUFDLEVBRXBHRixFQUFlLEVBR3hCRSxFQUFXLFFBQVEsRUFFbkIsR0FBTSxDQUFDSixDQUFNLEVBQUlXLEVBRWpCLE1BQU8sQ0FBQyxLQUFNWCxDQUFlLENBQy9CLE9BQVNDLEVBQWdCLENBQ3ZCLE9BQUFHLEdBQVksUUFBUSxFQUViLENBQUNILENBQWMsQ0FDeEIsUUFBRSxDQUNJRSxHQUNGSixHQUFhLG9CQUFvQixRQUFTSSxDQUFhLENBRTNELENBQ0YsQ0FDRixDQUNGLENBRUEsZUFBZVMsRUFBWWhCLEVBQVlpQixFQUFrQyxDQUN2RSxJQUFNaEIsRUFBUWlCLEVBQWVELENBQVEsRUFFckMsR0FBSSxDQUNGLE1BQU1qQixFQUFLLE1BQU1DLEVBQU0sSUFBS0EsRUFBTSxVQUFVLENBQzlDLE9BQVNJLEVBQWdCLENBQ3ZCLFFBQVEsTUFBTSwwQkFBMkJBLENBQUssQ0FDaEQsQ0FDRiIsCiAgIm5hbWVzIjogWyJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiIsICJjcmVhdGVNeVNRTDJFeGVjdXRvciIsICJwb29sIiwgInF1ZXJ5IiwgIm9wdGlvbnMiLCAiYWJvcnRTaWduYWwiLCAicmVzdWx0IiwgImVycm9yIiwgImdldEFib3J0UmVzdWx0IiwgImFib3J0TGlzdGVuZXIiLCAiY29ubmVjdGlvbiIsICJhYm9ydGVkIiwgImFib3J0aW9uUHJvbWlzZSIsICJyZXNvbHZlIiwgImNvbm5lY3Rpb25Qcm9taXNlIiwgImNvbm5lY3Rpb25SZXN1bHQiLCAicXVlcnlQcm9taXNlIiwgInF1ZXJ5UmVzdWx0IiwgImNhbmNlbFF1ZXJ5IiwgInRocmVhZElkIiwgImdldENhbmNlbFF1ZXJ5Il0KfQo=
@@ -1,5 +1,5 @@
1
1
  import { DatabaseSync } from 'node:sqlite';
2
- import { E as Executor } from '../../index-2horhMcs.cjs';
2
+ import { E as Executor } from '../../index-CV9DQF9a.cjs';
3
3
  import 'kysely';
4
4
 
5
5
  declare function createNodeSQLiteExecutor(database: DatabaseSync): Executor;
@@ -1,5 +1,5 @@
1
1
  import { DatabaseSync } from 'node:sqlite';
2
- import { E as Executor } from '../../index-2horhMcs.js';
2
+ import { E as Executor } from '../../index-CV9DQF9a.js';
3
3
  import 'kysely';
4
4
 
5
5
  declare function createNodeSQLiteExecutor(database: DatabaseSync): Executor;