@prisma/studio-core 0.0.0-dev.202601182335 → 0.0.0-dev.202601190122

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.
@@ -48,7 +48,23 @@ declare function getSelectQuery(details: AdapterQueryDetails, requirements?: Omi
48
48
  /**
49
49
  * For testing purposes.
50
50
  */
51
- declare function mockSelectQuery(): [];
51
+ declare function mockSelectQuery(): [{
52
+ readonly id: 1;
53
+ readonly created_at: Date;
54
+ readonly deleted_at: null;
55
+ readonly role: "admin";
56
+ readonly name: "Alice";
57
+ readonly name_role: "Alice_admin";
58
+ readonly __ps_count__: "2";
59
+ }, {
60
+ readonly id: 2;
61
+ readonly created_at: Date;
62
+ readonly deleted_at: null;
63
+ readonly role: "member";
64
+ readonly name: "Bob";
65
+ readonly name_role: "Bob_member";
66
+ readonly __ps_count__: "2";
67
+ }];
52
68
  declare function getUpdateQuery(details: AdapterUpdateDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
53
69
  affectedRows?: number | undefined;
54
70
  insertId?: number | undefined;
@@ -178,7 +194,7 @@ declare function mockTablesQuery(): [{
178
194
  readonly autoincrement: 0;
179
195
  readonly computed: 0;
180
196
  readonly datatype: "timestamp";
181
- readonly default: null;
197
+ readonly default: "current_timestamp";
182
198
  readonly fk_column: null;
183
199
  readonly fk_table: null;
184
200
  readonly name: "created_at";
@@ -188,25 +204,47 @@ declare function mockTablesQuery(): [{
188
204
  }, {
189
205
  readonly autoincrement: 0;
190
206
  readonly computed: 0;
191
- readonly datatype: "enum('admin','maintainer','member')";
207
+ readonly datatype: "timestamp";
192
208
  readonly default: null;
193
209
  readonly fk_column: null;
194
210
  readonly fk_table: null;
195
- readonly name: "role";
196
- readonly nullable: 0;
211
+ readonly name: "deleted_at";
212
+ readonly nullable: 1;
197
213
  readonly pk: null;
198
214
  readonly position: 3;
199
215
  }, {
200
216
  readonly autoincrement: 0;
201
217
  readonly computed: 0;
202
- readonly datatype: "int";
218
+ readonly datatype: "text";
203
219
  readonly default: null;
204
- readonly fk_column: "id";
205
- readonly fk_table: "animals";
206
- readonly name: "animal_id";
220
+ readonly fk_column: null;
221
+ readonly fk_table: null;
222
+ readonly name: "role";
207
223
  readonly nullable: 1;
208
224
  readonly pk: null;
209
225
  readonly position: 4;
226
+ }, {
227
+ readonly autoincrement: 0;
228
+ readonly computed: 0;
229
+ readonly datatype: "text";
230
+ readonly default: null;
231
+ readonly fk_column: null;
232
+ readonly fk_table: null;
233
+ readonly name: "name";
234
+ readonly nullable: 1;
235
+ readonly pk: null;
236
+ readonly position: 5;
237
+ }, {
238
+ readonly autoincrement: 0;
239
+ readonly computed: 1;
240
+ readonly datatype: "text";
241
+ readonly default: null;
242
+ readonly fk_column: null;
243
+ readonly fk_table: null;
244
+ readonly name: "name_role";
245
+ readonly nullable: 1;
246
+ readonly pk: null;
247
+ readonly position: 6;
210
248
  }];
211
249
  readonly name: "users";
212
250
  readonly schema: "studio";
@@ -48,7 +48,23 @@ declare function getSelectQuery(details: AdapterQueryDetails, requirements?: Omi
48
48
  /**
49
49
  * For testing purposes.
50
50
  */
51
- declare function mockSelectQuery(): [];
51
+ declare function mockSelectQuery(): [{
52
+ readonly id: 1;
53
+ readonly created_at: Date;
54
+ readonly deleted_at: null;
55
+ readonly role: "admin";
56
+ readonly name: "Alice";
57
+ readonly name_role: "Alice_admin";
58
+ readonly __ps_count__: "2";
59
+ }, {
60
+ readonly id: 2;
61
+ readonly created_at: Date;
62
+ readonly deleted_at: null;
63
+ readonly role: "member";
64
+ readonly name: "Bob";
65
+ readonly name_role: "Bob_member";
66
+ readonly __ps_count__: "2";
67
+ }];
52
68
  declare function getUpdateQuery(details: AdapterUpdateDetails, requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
53
69
  affectedRows?: number | undefined;
54
70
  insertId?: number | undefined;
@@ -178,7 +194,7 @@ declare function mockTablesQuery(): [{
178
194
  readonly autoincrement: 0;
179
195
  readonly computed: 0;
180
196
  readonly datatype: "timestamp";
181
- readonly default: null;
197
+ readonly default: "current_timestamp";
182
198
  readonly fk_column: null;
183
199
  readonly fk_table: null;
184
200
  readonly name: "created_at";
@@ -188,25 +204,47 @@ declare function mockTablesQuery(): [{
188
204
  }, {
189
205
  readonly autoincrement: 0;
190
206
  readonly computed: 0;
191
- readonly datatype: "enum('admin','maintainer','member')";
207
+ readonly datatype: "timestamp";
192
208
  readonly default: null;
193
209
  readonly fk_column: null;
194
210
  readonly fk_table: null;
195
- readonly name: "role";
196
- readonly nullable: 0;
211
+ readonly name: "deleted_at";
212
+ readonly nullable: 1;
197
213
  readonly pk: null;
198
214
  readonly position: 3;
199
215
  }, {
200
216
  readonly autoincrement: 0;
201
217
  readonly computed: 0;
202
- readonly datatype: "int";
218
+ readonly datatype: "text";
203
219
  readonly default: null;
204
- readonly fk_column: "id";
205
- readonly fk_table: "animals";
206
- readonly name: "animal_id";
220
+ readonly fk_column: null;
221
+ readonly fk_table: null;
222
+ readonly name: "role";
207
223
  readonly nullable: 1;
208
224
  readonly pk: null;
209
225
  readonly position: 4;
226
+ }, {
227
+ readonly autoincrement: 0;
228
+ readonly computed: 0;
229
+ readonly datatype: "text";
230
+ readonly default: null;
231
+ readonly fk_column: null;
232
+ readonly fk_table: null;
233
+ readonly name: "name";
234
+ readonly nullable: 1;
235
+ readonly pk: null;
236
+ readonly position: 5;
237
+ }, {
238
+ readonly autoincrement: 0;
239
+ readonly computed: 1;
240
+ readonly datatype: "text";
241
+ readonly default: null;
242
+ readonly fk_column: null;
243
+ readonly fk_table: null;
244
+ readonly name: "name_role";
245
+ readonly nullable: 1;
246
+ readonly pk: null;
247
+ readonly position: 6;
210
248
  }];
211
249
  readonly name: "users";
212
250
  readonly schema: "studio";
@@ -6,6 +6,6 @@ function require(mod) {
6
6
  if (mod === 'react-dom') return ___react_dom___;
7
7
  throw new Error(`Unknown module ${mod}`);
8
8
  }
9
- import"../../chunk-WEUE32ZL.js";import{a as oe}from"../../chunk-6MJRFEB4.js";import{a as i}from"../../chunk-V6YDTHJJ.js";import{A as S,B as F,C as q,D as z,q as _,v as j,w as P,x as Y,z as R}from"../../chunk-UHDZB3FI.js";import{e as E}from"../../chunk-GGFIWHFO.js";E();E();E();var $={bigint:{group:"numeric"},binary:{group:"string"},bit:{group:"raw"},blob:{group:"string"},char:{group:"string"},"char binary":{group:"string"},date:{format:"YYYY-MM-DD",group:"datetime"},datetime:{format:"YYYY-MM-DD HH:mm:ss.SSS",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:{format:"HH:mm:ss.SSS",group:"time"},timestamp:{format:"YYYY-MM-DD HH:mm:ss.SSS",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:{format:"YYYY",group:"numeric"}};E();E();function b(n){return Y({...n,Adapter:P,QueryCompiler:j})}function v(n,t){let{rows:o,table:{columns:u,name:e}}=n,r=b(t);return R(r.deleteFrom(e).$call(S(o,u)).$castTo())}function Q(n,t){let{rows:o,table:{columns:u,name:e}}=n,r=b(t);return R(r.insertInto(e).values(q({columns:u,context:"insert",supportsDefaultKeyword:!0,values:o})).$castTo())}function I(n,t){let{criteria:o,table:{columns:u,name:e}}=n,r=b(t);return R(r.selectFrom(e).$call(S(o,u)).select(Object.keys(u)).select(V().as("__ps_inserted_at__")))}function G(n,t){let{changes:o,row:u,table:{columns:e,name:r}}=n,s=b(t);return R(s.selectFrom(r).$call(S([{...u,...o}],e)).select(Object.keys(e)).select(V().as("__ps_updated_at__")))}function H(n,t){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},pageIndex:u,pageSize:e,sortOrder:r,table:{columns:s,name:m}}=n,f=b(t),c=z(o.filters,s),g="__ps_agg__",A="__ps_count__",y=f.selectFrom(m).where(c).select(l=>l.cast(l.fn.coalesce(l.fn.countAll(),_.lit(0)),"char").as(A));return R(f.with(g,()=>y).selectFrom(m).innerJoin(g,l=>l.onTrue()).where(c).select(`${g}.${A}`).select(Object.keys(s)).$call(l=>r.reduce((T,a)=>T.orderBy(a.column,a.direction),l)).limit(e).offset(_.lit(BigInt(u)*BigInt(e))))}function fe(){return[]}function K(n,t){let{changes:o,row:u,table:{columns:e,name:r,schema:s}}=n,m=b(t);return R(m.withSchema(s).updateTable(r).set(q({columns:e,context:"update",supportsDefaultKeyword:!0,values:o})).$call(S([u],e)).$castTo())}function V(){return _`cast(unix_timestamp(now(3)) * 1000 as unsigned)`}E();E();function J(n){return _`json_object(${_.join(Object.keys(n).flatMap(t=>[_.lit(t),n[t]]))})`}function W(n){let t=_`database()`,u=b(n).selectFrom("information_schema.columns as c").leftJoin("information_schema.KEY_COLUMN_USAGE as kcu",e=>e.on("kcu.TABLE_SCHEMA","=",t).onRef("kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("kcu.POSITION_IN_UNIQUE_CONSTRAINT","is not",null)).leftJoin("information_schema.KEY_COLUMN_USAGE as pk_kcu",e=>e.on("pk_kcu.TABLE_SCHEMA","=",t).onRef("pk_kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("pk_kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("pk_kcu.CONSTRAINT_NAME","=","PRIMARY")).where("c.TABLE_SCHEMA","=",t).select(["c.COLUMN_DEFAULT as default","c.COLUMN_NAME as name","c.COLUMN_TYPE as datatype","c.ORDINAL_POSITION as position","c.TABLE_NAME","kcu.REFERENCED_TABLE_NAME as fk_table","kcu.REFERENCED_COLUMN_NAME as fk_column","pk_kcu.ORDINAL_POSITION as pk"]).select(e=>[e("c.EXTRA","=","auto_increment").as("autoincrement"),e("c.EXTRA","in",["on update CURRENT_TIMESTAMP","STORED GENERATED","VIRTUAL GENERATED"]).as("computed"),e("c.IS_NULLABLE","=","YES").as("nullable")]);return R(b(n).with("cols",()=>u).selectFrom("information_schema.tables as t").innerJoin("cols as c",e=>e.onRef("c.TABLE_NAME","=","t.TABLE_NAME")).where("t.TABLE_SCHEMA","=",t).where("t.TABLE_TYPE","in",["BASE TABLE","VIEW"]).groupBy([t,"t.TABLE_NAME","t.TABLE_TYPE"]).select([t.as("schema"),"t.TABLE_NAME as name","t.TABLE_TYPE as type"]).$narrowType().select(e=>e.fn("json_arrayagg",[J({autoincrement:e.ref("c.autoincrement"),computed:e.ref("c.computed"),datatype:e.ref("c.datatype"),default:e.ref("c.default"),fk_column:e.ref("c.fk_column"),fk_table:e.ref("c.fk_table"),name:e.ref("c.name"),position:e.ref("c.position"),pk:e.ref("c.pk"),nullable:e.ref("c.nullable")})]).as("columns")).orderBy("t.TABLE_SCHEMA").orderBy("t.TABLE_NAME").orderBy("t.TABLE_TYPE"))}function X(){return[{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"binary(16)",default:"uuid_to_bin(uuid())",fk_column:null,fk_table:null,name:"uuid",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"varchar(255)",default:null,fk_column:null,fk_table:null,name:"name",nullable:1,pk:null,position:3},{autoincrement:0,computed:1,datatype:"text",default:null,fk_column:null,fk_table:null,name:"id_name",nullable:1,pk:null,position:4}],name:"animals",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:0,computed:0,datatype:"char(36)",default:"uuid()",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"text",default:null,fk_column:null,fk_table:null,name:"name",nullable:0,pk:2,position:2},{autoincrement:0,computed:0,datatype:"timestamp",default:"CURRENT_TIMESTAMP",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:3}],name:"composite_pk",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"timestamp",default:null,fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"enum('admin','maintainer','member')",default:null,fk_column:null,fk_table:null,name:"role",nullable:0,pk:null,position:3},{autoincrement:0,computed:0,datatype:"int",default:null,fk_column:"id",fk_table:"animals",name:"animal_id",nullable:1,pk:null,position:4}],name:"users",schema:"studio",type:"BASE TABLE"}]}function Z(n){let t=b(n),o=_`@@session.time_zone`;return R(t.selectNoFrom(t.case().when(o,"=","SYSTEM").then(_`@@system_time_zone`).else(o).end().as("timezone")).$narrowType())}function ee(){return[{timezone:"UTC"}]}function Le(n){let{executor:t,...o}=n;return{async delete(u,e){try{let r=v(u,o),[s]=await t.execute(r,e);return s?i({error:s,query:r}):[null,{...u,query:r}]}catch(r){return i({error:r})}},async insert(u,e){try{let{rows:r,table:s}=u,{columns:m}=s,f=Object.values(m).find(a=>a.isAutoincrement),c=r.map(a=>F(a,m)),g=c.some(a=>{let p=Object.values(a);return p.length===0||p.some(d=>d==null)});if(!f&&g)return i({error:new Error("Cannot proceed with the insertion, some rows cannot be refetched after insertion."),query:Q(u,o)});if(!g){let a=Q(u,o),p=I({criteria:c,table:s},o),d=[a,p],[[h],N]=await t.executeSequence(d,e),k=L(d);if(h)return i({error:h,query:k});let[M,O]=N;return M?i({error:new Error("Failed to refetch inserted rows - please refresh.",{cause:M}),query:k}):[null,{rows:O,query:k}]}let A=await Promise.all(r.map(async a=>{let p=Q({rows:[a],table:s},o),[d,h]=await t.execute(p,e);if(d)return i({error:d,query:p});let{name:N}=f,k=a[N]||h[0]?.insertId;if(!k)return i({error:new Error("Could not determine value for autoincrement column to refetch inserted row."),query:p});let M=I({criteria:[{[N]:k}],table:{...s,columns:Object.values(m).reduce((x,D)=>{let{name:U}=D;return x[U]={...D,pkPosition:U===N?1:null},x},{})}},o),[O,te]=await t.execute(M,e),B=L([p,M]);if(O)return console.error("Error refetching inserted row:",O),i({error:new Error("Failed to refetch inserted row - please refresh.",{cause:O}),query:B});let[C]=te;return C?[null,{row:C,query:B}]:i({error:new Error("Refetch query returned no results for inserted row."),query:B})})),y=[],l=null,T=[];for(let a=0;a<A.length;a++){let[p,d]=A[a];p?(T.push([a,p]),p.query&&(l=l?L([l,p.query]):p.query)):(y.push(d.row),d.query&&(l=l?L([l,d.query]):d.query))}return T.length>0?i({error:new AggregateError(T.map(([,a])=>a),`Row${T.length>1?"s":""} ${T.map(([a])=>a).join(", ")} could not be inserted or refetched.`),query:l}):[null,{rows:y,query:l}]}catch(r){return i({error:r})}},async introspect(u){try{let e=W(n),r=Z(n),[[s,m],[f,c]]=await Promise.all([t.execute(e,u),t.execute(r,u)]);if(s)return i({error:s,query:e});if(f)return i({error:f,query:r});let g=c[0]?.timezone;return g?[null,re({query:e,tables:m,timezone:g})]:i({error:new Error("Timezone not found"),query:r})}catch(e){return i({error:e})}},async query(u,e){try{let r=H(u,o),[s,m]=await t.execute(r,e);return s?i({error:s,query:r}):[null,{filteredRowCount:m[0]?.__ps_count__||"0",rows:m,query:r}]}catch(r){return i({error:r})}},async update(u,e){try{let r=K(u,o),s=G(u,o),[[m],f]=await t.executeSequence([r,s],e);if(m)return i({error:m,query:r});let[c,g]=f;if(c)return i({error:c,query:r});let[A]=g;return A?[null,{row:A,query:r}]:i({error:new Error("Updated row not found"),query:r})}catch(r){return i({error:r})}}}}function re(n){let{query:t,tables:o,timezone:u}=n;return o.reduce((e,r)=>{let{schemas:s}=e,{columns:m,name:f,schema:c}=r,g=m.sort((A,y)=>A.position-y.position).reduce((A,y)=>{let{datatype:l,default:T,name:a}=y,p=l.indexOf("("),d=(p>-1?l.substring(0,p):l).trim().toLowerCase(),h=!!y.autoincrement,N=!!y.computed,k=!!y.nullable;return{...A,[a]:{datatype:{...$[d]||{group:"raw"},isArray:!1,isNative:!0,name:d,options:d==="enum"?l.slice(6,-2).split("','"):[],schema:c},defaultValue:T,fkColumn:y.fk_column,fkSchema:c,fkTable:y.fk_table,isAutoincrement:h,isComputed:N,isRequired:!k&&!h&&!N&&T==null,name:a,nullable:k,pkPosition:y.pk,schema:c,table:f}}},{});return s[c]===void 0&&(s[c]={name:c,tables:{}}),s[c].tables[f]={columns:g,name:f,schema:c},e},{filterOperators:ne,query:t,schemas:{},timezone:u})}var ne=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Be(){let n=X(),[{timezone:t}]=ee();return re({tables:n,timezone:t,query:{parameters:[],sql:"<mocked>"}})}function L(n){let[t,o]=n;return{parameters:t.parameters.concat(o.parameters),sql:`${t.sql};
9
+ import"../../chunk-WEUE32ZL.js";import{a as oe}from"../../chunk-6MJRFEB4.js";import{a as l}from"../../chunk-V6YDTHJJ.js";import{A as S,B as F,C as q,D as z,q as A,v as j,w as P,x as Y,z as k}from"../../chunk-UHDZB3FI.js";import{e as _}from"../../chunk-GGFIWHFO.js";_();_();_();var $={bigint:{group:"numeric"},binary:{group:"string"},bit:{group:"raw"},blob:{group:"string"},char:{group:"string"},"char binary":{group:"string"},date:{format:"YYYY-MM-DD",group:"datetime"},datetime:{format:"YYYY-MM-DD HH:mm:ss.SSS",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:{format:"HH:mm:ss.SSS",group:"time"},timestamp:{format:"YYYY-MM-DD HH:mm:ss.SSS",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:{format:"YYYY",group:"numeric"}};_();_();function b(n){return Y({...n,Adapter:P,QueryCompiler:j})}function v(n,r){let{rows:o,table:{columns:u,name:e}}=n,t=b(r);return k(t.deleteFrom(e).$call(S(o,u)).$castTo())}function Q(n,r){let{rows:o,table:{columns:u,name:e}}=n,t=b(r);return k(t.insertInto(e).values(q({columns:u,context:"insert",supportsDefaultKeyword:!0,values:o})).$castTo())}function I(n,r){let{criteria:o,table:{columns:u,name:e}}=n,t=b(r);return k(t.selectFrom(e).$call(S(o,u)).select(Object.keys(u)).select(V().as("__ps_inserted_at__")))}function G(n,r){let{changes:o,row:u,table:{columns:e,name:t}}=n,a=b(r);return k(a.selectFrom(t).$call(S([{...u,...o}],e)).select(Object.keys(e)).select(V().as("__ps_updated_at__")))}function H(n,r){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},pageIndex:u,pageSize:e,sortOrder:t,table:{columns:a,name:m}}=n,f=b(r),c=z(o.filters,a),E="__ps_agg__",g="__ps_count__",y=f.selectFrom(m).where(c).select(i=>i.cast(i.fn.coalesce(i.fn.countAll(),A.lit(0)),"char").as(g));return k(f.with(E,()=>y).selectFrom(m).innerJoin(E,i=>i.onTrue()).where(c).select(`${E}.${g}`).select(Object.keys(a)).$call(i=>t.reduce((T,s)=>T.orderBy(s.column,s.direction),i)).limit(e).offset(A.lit(BigInt(u)*BigInt(e))))}function fe(){return[{id:1,created_at:new Date("2025-01-27T00:00:00.000Z"),deleted_at:null,role:"admin",name:"Alice",name_role:"Alice_admin",__ps_count__:"2"},{id:2,created_at:new Date("2025-01-26T23:00:00.000Z"),deleted_at:null,role:"member",name:"Bob",name_role:"Bob_member",__ps_count__:"2"}]}function K(n,r){let{changes:o,row:u,table:{columns:e,name:t,schema:a}}=n,m=b(r);return k(m.withSchema(a).updateTable(t).set(q({columns:e,context:"update",supportsDefaultKeyword:!0,values:o})).$call(S([u],e)).$castTo())}function V(){return A`cast(unix_timestamp(now(3)) * 1000 as unsigned)`}_();_();function J(n){return A`json_object(${A.join(Object.keys(n).flatMap(r=>[A.lit(r),n[r]]))})`}function W(n){let r=A`database()`,u=b(n).selectFrom("information_schema.columns as c").leftJoin("information_schema.KEY_COLUMN_USAGE as kcu",e=>e.on("kcu.TABLE_SCHEMA","=",r).onRef("kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("kcu.POSITION_IN_UNIQUE_CONSTRAINT","is not",null)).leftJoin("information_schema.KEY_COLUMN_USAGE as pk_kcu",e=>e.on("pk_kcu.TABLE_SCHEMA","=",r).onRef("pk_kcu.TABLE_NAME","=","c.TABLE_NAME").onRef("pk_kcu.COLUMN_NAME","=","c.COLUMN_NAME").on("pk_kcu.CONSTRAINT_NAME","=","PRIMARY")).where("c.TABLE_SCHEMA","=",r).select(["c.COLUMN_DEFAULT as default","c.COLUMN_NAME as name","c.COLUMN_TYPE as datatype","c.ORDINAL_POSITION as position","c.TABLE_NAME","kcu.REFERENCED_TABLE_NAME as fk_table","kcu.REFERENCED_COLUMN_NAME as fk_column","pk_kcu.ORDINAL_POSITION as pk"]).select(e=>[e("c.EXTRA","=","auto_increment").as("autoincrement"),e("c.EXTRA","in",["on update CURRENT_TIMESTAMP","STORED GENERATED","VIRTUAL GENERATED"]).as("computed"),e("c.IS_NULLABLE","=","YES").as("nullable")]);return k(b(n).with("cols",()=>u).selectFrom("information_schema.tables as t").innerJoin("cols as c",e=>e.onRef("c.TABLE_NAME","=","t.TABLE_NAME")).where("t.TABLE_SCHEMA","=",r).where("t.TABLE_TYPE","in",["BASE TABLE","VIEW"]).groupBy([r,"t.TABLE_NAME","t.TABLE_TYPE"]).select([r.as("schema"),"t.TABLE_NAME as name","t.TABLE_TYPE as type"]).$narrowType().select(e=>e.fn("json_arrayagg",[J({autoincrement:e.ref("c.autoincrement"),computed:e.ref("c.computed"),datatype:e.ref("c.datatype"),default:e.ref("c.default"),fk_column:e.ref("c.fk_column"),fk_table:e.ref("c.fk_table"),name:e.ref("c.name"),position:e.ref("c.position"),pk:e.ref("c.pk"),nullable:e.ref("c.nullable")})]).as("columns")).orderBy("t.TABLE_SCHEMA").orderBy("t.TABLE_NAME").orderBy("t.TABLE_TYPE"))}function X(){return[{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"binary(16)",default:"uuid_to_bin(uuid())",fk_column:null,fk_table:null,name:"uuid",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"varchar(255)",default:null,fk_column:null,fk_table:null,name:"name",nullable:1,pk:null,position:3},{autoincrement:0,computed:1,datatype:"text",default:null,fk_column:null,fk_table:null,name:"id_name",nullable:1,pk:null,position:4}],name:"animals",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:0,computed:0,datatype:"char(36)",default:"uuid()",fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"text",default:null,fk_column:null,fk_table:null,name:"name",nullable:0,pk:2,position:2},{autoincrement:0,computed:0,datatype:"timestamp",default:"CURRENT_TIMESTAMP",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:3}],name:"composite_pk",schema:"studio",type:"BASE TABLE"},{columns:[{autoincrement:1,computed:0,datatype:"int",default:null,fk_column:null,fk_table:null,name:"id",nullable:0,pk:1,position:1},{autoincrement:0,computed:0,datatype:"timestamp",default:"current_timestamp",fk_column:null,fk_table:null,name:"created_at",nullable:1,pk:null,position:2},{autoincrement:0,computed:0,datatype:"timestamp",default:null,fk_column:null,fk_table:null,name:"deleted_at",nullable:1,pk:null,position:3},{autoincrement:0,computed:0,datatype:"text",default:null,fk_column:null,fk_table:null,name:"role",nullable:1,pk:null,position:4},{autoincrement:0,computed:0,datatype:"text",default:null,fk_column:null,fk_table:null,name:"name",nullable:1,pk:null,position:5},{autoincrement:0,computed:1,datatype:"text",default:null,fk_column:null,fk_table:null,name:"name_role",nullable:1,pk:null,position:6}],name:"users",schema:"studio",type:"BASE TABLE"}]}function Z(n){let r=b(n),o=A`@@session.time_zone`;return k(r.selectNoFrom(r.case().when(o,"=","SYSTEM").then(A`@@system_time_zone`).else(o).end().as("timezone")).$narrowType())}function ee(){return[{timezone:"UTC"}]}function Le(n){let{executor:r,...o}=n;return{async delete(u,e){try{let t=v(u,o),[a]=await r.execute(t,e);return a?l({error:a,query:t}):[null,{...u,query:t}]}catch(t){return l({error:t})}},async insert(u,e){try{let{rows:t,table:a}=u,{columns:m}=a,f=Object.values(m).find(s=>s.isAutoincrement),c=t.map(s=>F(s,m)),E=c.some(s=>{let p=Object.values(s);return p.length===0||p.some(d=>d==null)});if(!f&&E)return l({error:new Error("Cannot proceed with the insertion, some rows cannot be refetched after insertion."),query:Q(u,o)});if(!E){let s=Q(u,o),p=I({criteria:c,table:a},o),d=[s,p],[[h],N]=await r.executeSequence(d,e),R=L(d);if(h)return l({error:h,query:R});let[M,O]=N;return M?l({error:new Error("Failed to refetch inserted rows - please refresh.",{cause:M}),query:R}):[null,{rows:O,query:R}]}let g=await Promise.all(t.map(async s=>{let p=Q({rows:[s],table:a},o),[d,h]=await r.execute(p,e);if(d)return l({error:d,query:p});let{name:N}=f,R=s[N]||h[0]?.insertId;if(!R)return l({error:new Error("Could not determine value for autoincrement column to refetch inserted row."),query:p});let M=I({criteria:[{[N]:R}],table:{...a,columns:Object.values(m).reduce((x,D)=>{let{name:U}=D;return x[U]={...D,pkPosition:U===N?1:null},x},{})}},o),[O,re]=await r.execute(M,e),B=L([p,M]);if(O)return console.error("Error refetching inserted row:",O),l({error:new Error("Failed to refetch inserted row - please refresh.",{cause:O}),query:B});let[C]=re;return C?[null,{row:C,query:B}]:l({error:new Error("Refetch query returned no results for inserted row."),query:B})})),y=[],i=null,T=[];for(let s=0;s<g.length;s++){let[p,d]=g[s];p?(T.push([s,p]),p.query&&(i=i?L([i,p.query]):p.query)):(y.push(d.row),d.query&&(i=i?L([i,d.query]):d.query))}return T.length>0?l({error:new AggregateError(T.map(([,s])=>s),`Row${T.length>1?"s":""} ${T.map(([s])=>s).join(", ")} could not be inserted or refetched.`),query:i}):[null,{rows:y,query:i}]}catch(t){return l({error:t})}},async introspect(u){try{let e=W(n),t=Z(n),[[a,m],[f,c]]=await Promise.all([r.execute(e,u),r.execute(t,u)]);if(a)return l({error:a,query:e});if(f)return l({error:f,query:t});let E=c[0]?.timezone;return E?[null,te({query:e,tables:m,timezone:E})]:l({error:new Error("Timezone not found"),query:t})}catch(e){return l({error:e})}},async query(u,e){try{let t=H(u,o),[a,m]=await r.execute(t,e);return a?l({error:a,query:t}):[null,{filteredRowCount:m[0]?.__ps_count__||"0",rows:m,query:t}]}catch(t){return l({error:t})}},async update(u,e){try{let t=K(u,o),a=G(u,o),[[m],f]=await r.executeSequence([t,a],e);if(m)return l({error:m,query:t});let[c,E]=f;if(c)return l({error:c,query:t});let[g]=E;return g?[null,{row:g,query:t}]:l({error:new Error("Updated row not found"),query:t})}catch(t){return l({error:t})}}}}function te(n){let{query:r,tables:o,timezone:u}=n;return o.reduce((e,t)=>{let{schemas:a}=e,{columns:m,name:f,schema:c}=t,E=m.sort((g,y)=>g.position-y.position).reduce((g,y)=>{let{datatype:i,default:T,name:s}=y,p=i.indexOf("("),d=(p>-1?i.substring(0,p):i).trim().toLowerCase(),h=!!y.autoincrement,N=!!y.computed,R=!!y.nullable;return{...g,[s]:{datatype:{...$[d]||{group:"raw"},isArray:!1,isNative:!0,name:d,options:d==="enum"?i.slice(6,-2).split("','"):[],schema:c},defaultValue:T,fkColumn:y.fk_column,fkSchema:c,fkTable:y.fk_table,isAutoincrement:h,isComputed:N,isRequired:!R&&!h&&!N&&T==null,name:s,nullable:R,pkPosition:y.pk,schema:c,table:f}}},{});return a[c]===void 0&&(a[c]={name:c,tables:{}}),a[c].tables[f]={columns:E,name:f,schema:c},e},{filterOperators:ne,query:r,schemas:{},timezone:u})}var ne=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Be(){let n=X(),[{timezone:r}]=ee();return te({tables:n,timezone:r,query:{parameters:[],sql:"<mocked>"}})}function L(n){let[r,o]=n;return{parameters:r.parameters.concat(o.parameters),sql:`${r.sql};
10
10
  ${o.sql}`}}export{Le as createMySQLAdapter,oe as getCancelQuery,v as getDeleteQuery,Q as getInsertQuery,I as getInsertRefetchQuery,H as getSelectQuery,W as getTablesQuery,Z as getTimezoneQuery,K as getUpdateQuery,G as getUpdateRefetchQuery,Be as mockIntrospect,fe as mockSelectQuery,X as mockTablesQuery,ee as mockTimezoneQuery};
11
- //# 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 { inferFilterObject, type Query, type QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { MYSQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport {\n  getDeleteQuery,\n  getInsertQuery,\n  getInsertRefetchQuery,\n  getSelectQuery,\n  getUpdateQuery,\n  getUpdateRefetchQuery,\n} 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    async insert(details, options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const { rows, table } = details;\n        const { columns } = table;\n\n        const autoincrementColumn: Column | undefined = Object.values(columns).find((column) => column.isAutoincrement);\n\n        const filterObjects = rows.map((row) => inferFilterObject(row, columns));\n\n        const hasPartialFilterObjects = filterObjects.some((filterObject) => {\n          const filterValues = Object.values(filterObject);\n\n          return filterValues.length === 0 || filterValues.some((value) => value == null);\n        });\n\n        // TODO: handle classic partial filter object cases (e.g. uuid) here or before requesting from adapter.\n        if (!autoincrementColumn && hasPartialFilterObjects) {\n          return createAdapterError({\n            error: new Error(\"Cannot proceed with the insertion, some rows cannot be refetched after insertion.\"),\n            query: getInsertQuery(details, otherRequirements),\n          });\n        }\n\n        if (!hasPartialFilterObjects) {\n          const insertQuery = getInsertQuery(details, otherRequirements);\n          const refetchQuery = getInsertRefetchQuery({ criteria: filterObjects, table }, otherRequirements);\n          const sequence = [insertQuery, refetchQuery] as const;\n\n          const [[insertError], maybeRefetchResult] = await executor.executeSequence(sequence, options);\n\n          const query = joinSequence(sequence);\n\n          if (insertError) {\n            return createAdapterError({ error: insertError, query });\n          }\n\n          const [refetchError, refetchResults] = maybeRefetchResult!;\n\n          if (refetchError) {\n            return createAdapterError({\n              error: new Error(\"Failed to refetch inserted rows - please refresh.\", { cause: refetchError }),\n              query,\n            });\n          }\n\n          return [null, { rows: refetchResults, query }];\n        }\n\n        // has autoincrement column - insert rows one by one and refetch, taking advantage of `insertId` if inserted row has no value for this column.\n        const results = await Promise.all(\n          rows.map(async (row) => {\n            const insertQuery = getInsertQuery({ rows: [row], table }, otherRequirements);\n\n            const [error, result] = await executor.execute(insertQuery, options);\n\n            if (error) {\n              return createAdapterError({ error, query: insertQuery });\n            }\n\n            const { name: autoincrementColumnName } = autoincrementColumn!;\n\n            const value = row[autoincrementColumnName] || result[0]?.insertId;\n\n            if (!value) {\n              return createAdapterError({\n                error: new Error(\"Could not determine value for autoincrement column to refetch inserted row.\"),\n                query: insertQuery,\n              });\n            }\n\n            const refetchQuery = getInsertRefetchQuery(\n              {\n                criteria: [{ [autoincrementColumnName]: value }],\n                table: {\n                  ...table,\n                  // FIXME: dirty hack to mark autoincrement column as THE primary key for refetching.\n                  columns: Object.values(columns).reduce(\n                    (acc, column) => {\n                      const { name: columnName } = column;\n\n                      acc[columnName] = {\n                        ...column,\n                        pkPosition: columnName === autoincrementColumnName ? 1 : null,\n                      };\n\n                      return acc;\n                    },\n                    {} as Table[\"columns\"],\n                  ),\n                },\n              },\n              otherRequirements,\n            );\n\n            const [refetchError, refetchResults] = await executor.execute(refetchQuery, options);\n\n            const query = joinSequence([insertQuery, refetchQuery]);\n\n            if (refetchError) {\n              console.error(\"Error refetching inserted row:\", refetchError);\n\n              return createAdapterError({\n                error: new Error(\"Failed to refetch inserted row - please refresh.\", { cause: refetchError }),\n                query,\n              });\n            }\n\n            const [refetchedRow] = refetchResults;\n\n            if (!refetchedRow) {\n              return createAdapterError({\n                error: new Error(\"Refetch query returned no results for inserted row.\"),\n                query,\n              });\n            }\n\n            return [null, { row: refetchedRow, query }] as const;\n          }),\n        );\n\n        const insertedRows: Record<string, unknown>[] = [];\n        let query: Query<unknown> | null = null;\n        const errors: [number, AdapterError][] = [];\n\n        for (let i = 0; i < results.length; i++) {\n          const [error, result] = results[i]!;\n\n          if (error) {\n            errors.push([i, error]);\n\n            if (error.query) {\n              query = !query ? error.query : joinSequence([query, error.query]);\n            }\n          } else {\n            insertedRows.push(result.row);\n\n            if (result.query) {\n              query = !query ? result.query : joinSequence([query, result.query]);\n            }\n          }\n        }\n\n        if (errors.length > 0) {\n          return createAdapterError({\n            error: new AggregateError(\n              errors.map(([, error]) => error),\n              `Row${errors.length > 1 ? \"s\" : \"\"} ${errors.map(([index]) => index).join(\", \")} could not be inserted or refetched.`,\n            ),\n            query: query!,\n          });\n        }\n\n        return [null, { rows: insertedRows, query: query! }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\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        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, default: defaultValue, 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            const isAutoincrement = Boolean(column.autoincrement);\n            const isComputed = Boolean(column.computed);\n            const nullable = Boolean(column.nullable);\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                defaultValue,\n                fkColumn: column.fk_column,\n                fkSchema: schema,\n                fkTable: column.fk_table,\n                isAutoincrement,\n                isComputed,\n                isRequired: !nullable && !isAutoincrement && !isComputed && defaultValue == null,\n                name: columnName,\n                nullable,\n                pkPosition: column.pk,\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\nfunction joinSequence(sequence: readonly [Query<unknown>, Query<unknown>]): Query<unknown> {\n  const [query0, query1] = sequence;\n\n  return {\n    parameters: query0.parameters.concat(query1.parameters),\n    sql: `${query0.sql};\\n${query1.sql}`,\n  };\n}\n", "import type { DataType } from \"../adapter\";\n\nexport const MYSQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"format\" | \"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    format: \"YYYY-MM-DD\",\n    group: \"datetime\",\n  },\n  datetime: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\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    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  timestamp: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\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    format: \"YYYY\",\n    group: \"numeric\",\n  },\n};\n", "import { type InferResult, type SimpleReferenceExpression, sql } from \"kysely\";\nimport type { OkPacketParams } from \"mysql2\";\n\nimport type { AdapterDeleteDetails, AdapterQueryDetails, AdapterUpdateDetails, Table } 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)).$castTo<OkPacketParams>());\n}\n\nexport function getInsertQuery(\n  details: { rows: Record<string, unknown>[]; table: Table },\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(\n    builder\n      .insertInto(tableName)\n      .values(applyTransformations({ columns, context: \"insert\", supportsDefaultKeyword: true, values: rows }))\n      .$castTo<OkPacketParams>(),\n  );\n}\n\nexport function getInsertRefetchQuery(\n  details: { criteria: Record<string, unknown>[]; table: Table },\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    criteria,\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(criteria, columns))\n      .select(Object.keys(columns))\n      .select(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\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 AGG_NAME = \"__ps_agg__\";\n  const COUNT_REF = \"__ps_count__\";\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)), \"char\").as(COUNT_REF));\n\n  return compile(\n    builder\n      .with(AGG_NAME, () => countQuery)\n      .selectFrom(tableName)\n      .innerJoin(AGG_NAME, (jb) => jb.onTrue())\n      // TODO: cursor pagination?\n      .where(filterExpression)\n      .select(\n        `${AGG_NAME}.${COUNT_REF}` satisfies SimpleReferenceExpression<\n          { [AGG_NAME]: InferResult<typeof countQuery>[number] },\n          typeof AGG_NAME\n        >,\n      )\n      .select(Object.keys(columns))\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({ columns, context: \"update\", supportsDefaultKeyword: true, values: changes }))\n      .$call(applyInferredRowFilters([row], columns))\n      .$castTo<OkPacketParams>(),\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 { type InferResult, sql } from \"kysely\";\nimport { jsonBuildObject } 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-key-column-usage-table.html */\n  \"information_schema.KEY_COLUMN_USAGE\": {\n    COLUMN_NAME: string;\n    CONSTRAINT_NAME: string;\n    ORDINAL_POSITION: number;\n    /** null - when unique or primary key constraint. 1-n - when foreign key constraint */\n    POSITION_IN_UNIQUE_CONSTRAINT: number | null;\n    REFERENCED_COLUMN_NAME: string;\n    REFERENCED_TABLE_NAME: string;\n    TABLE_NAME: string;\n    TABLE_SCHEMA: string;\n  };\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-columns-table.html */\n  \"information_schema.columns\": {\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: string | null;\n    COLUMN_NAME: string;\n    /** Contains the type name and possibly other information such as the precision or length. */\n    COLUMN_TYPE: string;\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    IS_NULLABLE: \"YES\" | \"NO\";\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    TABLE_NAME: string;\n    TABLE_SCHEMA: string;\n  };\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-tables-table.html */\n  \"information_schema.tables\": {\n    TABLE_NAME: string;\n    /** The name of the schema (database) to which the table belongs. */\n    TABLE_SCHEMA: 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\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  const database = sql<string>`database()`;\n\n  const builder = getMySQLBuilder<Database>(requirements);\n\n  const columnsQuery = builder\n    .selectFrom(\"information_schema.columns as c\")\n    .leftJoin(\"information_schema.KEY_COLUMN_USAGE as kcu\", (jb) =>\n      jb\n        .on(\"kcu.TABLE_SCHEMA\", \"=\", database)\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    .leftJoin(\"information_schema.KEY_COLUMN_USAGE as pk_kcu\", (jb) =>\n      jb\n        .on(\"pk_kcu.TABLE_SCHEMA\", \"=\", database)\n        .onRef(\"pk_kcu.TABLE_NAME\", \"=\", \"c.TABLE_NAME\")\n        .onRef(\"pk_kcu.COLUMN_NAME\", \"=\", \"c.COLUMN_NAME\")\n        // only get primary key constraint - guaranteed to be \"PRIMARY\" even if a name was given during creation\n        .on(\"pk_kcu.CONSTRAINT_NAME\", \"=\", \"PRIMARY\"),\n    )\n    .where(\"c.TABLE_SCHEMA\", \"=\", database)\n    .select([\n      \"c.COLUMN_DEFAULT as default\",\n      \"c.COLUMN_NAME as name\",\n      \"c.COLUMN_TYPE as datatype\",\n      \"c.ORDINAL_POSITION as position\",\n      \"c.TABLE_NAME\",\n      \"kcu.REFERENCED_TABLE_NAME as fk_table\",\n      \"kcu.REFERENCED_COLUMN_NAME as fk_column\",\n      \"pk_kcu.ORDINAL_POSITION as pk\",\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(\"computed\"),\n      eb(\"c.IS_NULLABLE\", \"=\", \"YES\").as(\"nullable\"),\n    ]);\n\n  return compile(\n    getMySQLBuilder<Database>(requirements)\n      .with(\"cols\", () => columnsQuery)\n      .selectFrom(\"information_schema.tables as t\")\n      .innerJoin(\"cols as c\", (jb) => jb.onRef(\"c.TABLE_NAME\", \"=\", \"t.TABLE_NAME\"))\n      .where(\"t.TABLE_SCHEMA\", \"=\", database)\n      .where(\"t.TABLE_TYPE\", \"in\", [\"BASE TABLE\", \"VIEW\"])\n      .groupBy([database, \"t.TABLE_NAME\", \"t.TABLE_TYPE\"])\n      .select([database.as(\"schema\"), \"t.TABLE_NAME as name\", \"t.TABLE_TYPE as type\"])\n      .$narrowType<{ type: \"BASE TABLE\" | \"VIEW\" }>()\n      .select((eb) =>\n        eb\n          .fn<Omit<InferResult<typeof columnsQuery>[number], \"TABLE_NAME\">[]>(\"json_arrayagg\", [\n            jsonBuildObject({\n              autoincrement: eb.ref(\"c.autoincrement\"),\n              computed: eb.ref(\"c.computed\"),\n              datatype: eb.ref(\"c.datatype\"),\n              default: eb.ref(\"c.default\"),\n              fk_column: eb.ref(\"c.fk_column\"),\n              fk_table: eb.ref(\"c.fk_table\"),\n              name: eb.ref(\"c.name\"),\n              position: eb.ref(\"c.position\"),\n              pk: eb.ref(\"c.pk\"),\n              nullable: eb.ref(\"c.nullable\"),\n            }),\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          default: null,\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          default: \"uuid_to_bin(uuid())\",\n          fk_column: null,\n          fk_table: null,\n          name: \"uuid\",\n          nullable: 1,\n          pk: null,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"varchar(255)\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 1,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"id_name\",\n          nullable: 1,\n          pk: null,\n          position: 4,\n        },\n      ],\n      name: \"animals\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"char(36)\",\n          default: \"uuid()\",\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: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 0,\n          pk: 2,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          default: \"CURRENT_TIMESTAMP\",\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n      ],\n      name: \"composite_pk\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          default: null,\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          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: null,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"enum('admin','maintainer','member')\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: 0,\n          pk: null,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"int\",\n          default: null,\n          fk_column: \"id\",\n          fk_table: \"animals\",\n          name: \"animal_id\",\n          nullable: 1,\n          pk: null,\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": ";;;;;;;;yQAAAA,ICAAC,ICAAC,IAEO,IAAMC,EAAmF,CAC9F,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,OAAQ,aACR,MAAO,UACT,EACA,SAAU,CACR,OAAQ,0BACR,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,OAAQ,eACR,MAAO,MACT,EACA,UAAW,CACT,OAAQ,0BACR,MAAO,UACT,EACA,SAAU,CACR,MAAO,QACT,EACA,QAAS,CACP,MAAO,SACT,EACA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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", "applyTransformations", "getInsertRefetchQuery", "criteria", "getCurrentTimestampMillis", "getUpdateRefetchQuery", "changes", "row", "getSelectQuery", "filter", "pageIndex", "pageSize", "sortOrder", "filterExpression", "getSelectFilterExpression", "AGG_NAME", "COUNT_REF", "countQuery", "eb", "sql", "jb", "qb", "item", "mockSelectQuery", "getUpdateQuery", "schema", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonBuildObject", "obj", "sql", "k", "getTablesQuery", "requirements", "database", "sql", "columnsQuery", "getMySQLBuilder", "jb", "eb", "compile", "jsonBuildObject", "mockTablesQuery", "getTimezoneQuery", "builder", "sessionTz", "mockTimezoneQuery", "createMySQLAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "rows", "table", "columns", "autoincrementColumn", "column", "filterObjects", "row", "inferFilterObject", "hasPartialFilterObjects", "filterObject", "filterValues", "value", "getInsertQuery", "insertQuery", "refetchQuery", "getInsertRefetchQuery", "sequence", "insertError", "maybeRefetchResult", "joinSequence", "refetchError", "refetchResults", "results", "result", "autoincrementColumnName", "acc", "columnName", "refetchedRow", "insertedRows", "errors", "i", "index", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "timezone", "createIntrospection", "getSelectQuery", "updateQuery", "getUpdateQuery", "getUpdateRefetchQuery", "updateError", "refetchResult", "args", "schemas", "tableName", "schema", "columnsRecord", "a", "b", "datatype", "defaultValue", "indexOfParenthesis", "strippedDataType", "isAutoincrement", "isComputed", "nullable", "MYSQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery", "query0", "query1"]
}

11
+ //# 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 { inferFilterObject, type Query, type QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { MYSQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport {\n  getDeleteQuery,\n  getInsertQuery,\n  getInsertRefetchQuery,\n  getSelectQuery,\n  getUpdateQuery,\n  getUpdateRefetchQuery,\n} 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    async insert(details, options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const { rows, table } = details;\n        const { columns } = table;\n\n        const autoincrementColumn: Column | undefined = Object.values(columns).find((column) => column.isAutoincrement);\n\n        const filterObjects = rows.map((row) => inferFilterObject(row, columns));\n\n        const hasPartialFilterObjects = filterObjects.some((filterObject) => {\n          const filterValues = Object.values(filterObject);\n\n          return filterValues.length === 0 || filterValues.some((value) => value == null);\n        });\n\n        // TODO: handle classic partial filter object cases (e.g. uuid) here or before requesting from adapter.\n        if (!autoincrementColumn && hasPartialFilterObjects) {\n          return createAdapterError({\n            error: new Error(\"Cannot proceed with the insertion, some rows cannot be refetched after insertion.\"),\n            query: getInsertQuery(details, otherRequirements),\n          });\n        }\n\n        if (!hasPartialFilterObjects) {\n          const insertQuery = getInsertQuery(details, otherRequirements);\n          const refetchQuery = getInsertRefetchQuery({ criteria: filterObjects, table }, otherRequirements);\n          const sequence = [insertQuery, refetchQuery] as const;\n\n          const [[insertError], maybeRefetchResult] = await executor.executeSequence(sequence, options);\n\n          const query = joinSequence(sequence);\n\n          if (insertError) {\n            return createAdapterError({ error: insertError, query });\n          }\n\n          const [refetchError, refetchResults] = maybeRefetchResult!;\n\n          if (refetchError) {\n            return createAdapterError({\n              error: new Error(\"Failed to refetch inserted rows - please refresh.\", { cause: refetchError }),\n              query,\n            });\n          }\n\n          return [null, { rows: refetchResults, query }];\n        }\n\n        // has autoincrement column - insert rows one by one and refetch, taking advantage of `insertId` if inserted row has no value for this column.\n        const results = await Promise.all(\n          rows.map(async (row) => {\n            const insertQuery = getInsertQuery({ rows: [row], table }, otherRequirements);\n\n            const [error, result] = await executor.execute(insertQuery, options);\n\n            if (error) {\n              return createAdapterError({ error, query: insertQuery });\n            }\n\n            const { name: autoincrementColumnName } = autoincrementColumn!;\n\n            const value = row[autoincrementColumnName] || result[0]?.insertId;\n\n            if (!value) {\n              return createAdapterError({\n                error: new Error(\"Could not determine value for autoincrement column to refetch inserted row.\"),\n                query: insertQuery,\n              });\n            }\n\n            const refetchQuery = getInsertRefetchQuery(\n              {\n                criteria: [{ [autoincrementColumnName]: value }],\n                table: {\n                  ...table,\n                  // FIXME: dirty hack to mark autoincrement column as THE primary key for refetching.\n                  columns: Object.values(columns).reduce(\n                    (acc, column) => {\n                      const { name: columnName } = column;\n\n                      acc[columnName] = {\n                        ...column,\n                        pkPosition: columnName === autoincrementColumnName ? 1 : null,\n                      };\n\n                      return acc;\n                    },\n                    {} as Table[\"columns\"],\n                  ),\n                },\n              },\n              otherRequirements,\n            );\n\n            const [refetchError, refetchResults] = await executor.execute(refetchQuery, options);\n\n            const query = joinSequence([insertQuery, refetchQuery]);\n\n            if (refetchError) {\n              console.error(\"Error refetching inserted row:\", refetchError);\n\n              return createAdapterError({\n                error: new Error(\"Failed to refetch inserted row - please refresh.\", { cause: refetchError }),\n                query,\n              });\n            }\n\n            const [refetchedRow] = refetchResults;\n\n            if (!refetchedRow) {\n              return createAdapterError({\n                error: new Error(\"Refetch query returned no results for inserted row.\"),\n                query,\n              });\n            }\n\n            return [null, { row: refetchedRow, query }] as const;\n          }),\n        );\n\n        const insertedRows: Record<string, unknown>[] = [];\n        let query: Query<unknown> | null = null;\n        const errors: [number, AdapterError][] = [];\n\n        for (let i = 0; i < results.length; i++) {\n          const [error, result] = results[i]!;\n\n          if (error) {\n            errors.push([i, error]);\n\n            if (error.query) {\n              query = !query ? error.query : joinSequence([query, error.query]);\n            }\n          } else {\n            insertedRows.push(result.row);\n\n            if (result.query) {\n              query = !query ? result.query : joinSequence([query, result.query]);\n            }\n          }\n        }\n\n        if (errors.length > 0) {\n          return createAdapterError({\n            error: new AggregateError(\n              errors.map(([, error]) => error),\n              `Row${errors.length > 1 ? \"s\" : \"\"} ${errors.map(([index]) => index).join(\", \")} could not be inserted or refetched.`,\n            ),\n            query: query!,\n          });\n        }\n\n        return [null, { rows: insertedRows, query: query! }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\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        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, default: defaultValue, 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            const isAutoincrement = Boolean(column.autoincrement);\n            const isComputed = Boolean(column.computed);\n            const nullable = Boolean(column.nullable);\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                defaultValue,\n                fkColumn: column.fk_column,\n                fkSchema: schema,\n                fkTable: column.fk_table,\n                isAutoincrement,\n                isComputed,\n                isRequired: !nullable && !isAutoincrement && !isComputed && defaultValue == null,\n                name: columnName,\n                nullable,\n                pkPosition: column.pk,\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\nfunction joinSequence(sequence: readonly [Query<unknown>, Query<unknown>]): Query<unknown> {\n  const [query0, query1] = sequence;\n\n  return {\n    parameters: query0.parameters.concat(query1.parameters),\n    sql: `${query0.sql};\\n${query1.sql}`,\n  };\n}\n", "import type { DataType } from \"../adapter\";\n\nexport const MYSQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"format\" | \"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    format: \"YYYY-MM-DD\",\n    group: \"datetime\",\n  },\n  datetime: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\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    format: \"HH:mm:ss.SSS\",\n    group: \"time\",\n  },\n  timestamp: {\n    format: \"YYYY-MM-DD HH:mm:ss.SSS\",\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    format: \"YYYY\",\n    group: \"numeric\",\n  },\n};\n", "import { type InferResult, type SimpleReferenceExpression, sql } from \"kysely\";\nimport type { OkPacketParams } from \"mysql2\";\n\nimport type { AdapterDeleteDetails, AdapterQueryDetails, AdapterUpdateDetails, Table } 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)).$castTo<OkPacketParams>());\n}\n\nexport function getInsertQuery(\n  details: { rows: Record<string, unknown>[]; table: Table },\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(\n    builder\n      .insertInto(tableName)\n      .values(applyTransformations({ columns, context: \"insert\", supportsDefaultKeyword: true, values: rows }))\n      .$castTo<OkPacketParams>(),\n  );\n}\n\nexport function getInsertRefetchQuery(\n  details: { criteria: Record<string, unknown>[]; table: Table },\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    criteria,\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(criteria, columns))\n      .select(Object.keys(columns))\n      .select(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\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 AGG_NAME = \"__ps_agg__\";\n  const COUNT_REF = \"__ps_count__\";\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)), \"char\").as(COUNT_REF));\n\n  return compile(\n    builder\n      .with(AGG_NAME, () => countQuery)\n      .selectFrom(tableName)\n      .innerJoin(AGG_NAME, (jb) => jb.onTrue())\n      // TODO: cursor pagination?\n      .where(filterExpression)\n      .select(\n        `${AGG_NAME}.${COUNT_REF}` satisfies SimpleReferenceExpression<\n          { [AGG_NAME]: InferResult<typeof countQuery>[number] },\n          typeof AGG_NAME\n        >,\n      )\n      .select(Object.keys(columns))\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  return [\n    {\n      id: 1,\n      created_at: new Date(\"2025-01-27T00:00:00.000Z\"),\n      deleted_at: null,\n      role: \"admin\",\n      name: \"Alice\",\n      name_role: \"Alice_admin\",\n      __ps_count__: \"2\",\n    },\n    {\n      id: 2,\n      created_at: new Date(\"2025-01-26T23:00:00.000Z\"),\n      deleted_at: null,\n      role: \"member\",\n      name: \"Bob\",\n      name_role: \"Bob_member\",\n      __ps_count__: \"2\",\n    },\n  ] as const satisfies {\n    // best effort no need to go overboard\n    [K in ReturnType<typeof mockTablesQuery>[2][\"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({ columns, context: \"update\", supportsDefaultKeyword: true, values: changes }))\n      .$call(applyInferredRowFilters([row], columns))\n      .$castTo<OkPacketParams>(),\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 { type InferResult, sql } from \"kysely\";\nimport { jsonBuildObject } 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-key-column-usage-table.html */\n  \"information_schema.KEY_COLUMN_USAGE\": {\n    COLUMN_NAME: string;\n    CONSTRAINT_NAME: string;\n    ORDINAL_POSITION: number;\n    /** null - when unique or primary key constraint. 1-n - when foreign key constraint */\n    POSITION_IN_UNIQUE_CONSTRAINT: number | null;\n    REFERENCED_COLUMN_NAME: string;\n    REFERENCED_TABLE_NAME: string;\n    TABLE_NAME: string;\n    TABLE_SCHEMA: string;\n  };\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-columns-table.html */\n  \"information_schema.columns\": {\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: string | null;\n    COLUMN_NAME: string;\n    /** Contains the type name and possibly other information such as the precision or length. */\n    COLUMN_TYPE: string;\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    IS_NULLABLE: \"YES\" | \"NO\";\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    TABLE_NAME: string;\n    TABLE_SCHEMA: string;\n  };\n  /** https://dev.mysql.com/doc/refman/8.4/en/information-schema-tables-table.html */\n  \"information_schema.tables\": {\n    TABLE_NAME: string;\n    /** The name of the schema (database) to which the table belongs. */\n    TABLE_SCHEMA: 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\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  const database = sql<string>`database()`;\n\n  const builder = getMySQLBuilder<Database>(requirements);\n\n  const columnsQuery = builder\n    .selectFrom(\"information_schema.columns as c\")\n    .leftJoin(\"information_schema.KEY_COLUMN_USAGE as kcu\", (jb) =>\n      jb\n        .on(\"kcu.TABLE_SCHEMA\", \"=\", database)\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    .leftJoin(\"information_schema.KEY_COLUMN_USAGE as pk_kcu\", (jb) =>\n      jb\n        .on(\"pk_kcu.TABLE_SCHEMA\", \"=\", database)\n        .onRef(\"pk_kcu.TABLE_NAME\", \"=\", \"c.TABLE_NAME\")\n        .onRef(\"pk_kcu.COLUMN_NAME\", \"=\", \"c.COLUMN_NAME\")\n        // only get primary key constraint - guaranteed to be \"PRIMARY\" even if a name was given during creation\n        .on(\"pk_kcu.CONSTRAINT_NAME\", \"=\", \"PRIMARY\"),\n    )\n    .where(\"c.TABLE_SCHEMA\", \"=\", database)\n    .select([\n      \"c.COLUMN_DEFAULT as default\",\n      \"c.COLUMN_NAME as name\",\n      \"c.COLUMN_TYPE as datatype\",\n      \"c.ORDINAL_POSITION as position\",\n      \"c.TABLE_NAME\",\n      \"kcu.REFERENCED_TABLE_NAME as fk_table\",\n      \"kcu.REFERENCED_COLUMN_NAME as fk_column\",\n      \"pk_kcu.ORDINAL_POSITION as pk\",\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(\"computed\"),\n      eb(\"c.IS_NULLABLE\", \"=\", \"YES\").as(\"nullable\"),\n    ]);\n\n  return compile(\n    getMySQLBuilder<Database>(requirements)\n      .with(\"cols\", () => columnsQuery)\n      .selectFrom(\"information_schema.tables as t\")\n      .innerJoin(\"cols as c\", (jb) => jb.onRef(\"c.TABLE_NAME\", \"=\", \"t.TABLE_NAME\"))\n      .where(\"t.TABLE_SCHEMA\", \"=\", database)\n      .where(\"t.TABLE_TYPE\", \"in\", [\"BASE TABLE\", \"VIEW\"])\n      .groupBy([database, \"t.TABLE_NAME\", \"t.TABLE_TYPE\"])\n      .select([database.as(\"schema\"), \"t.TABLE_NAME as name\", \"t.TABLE_TYPE as type\"])\n      .$narrowType<{ type: \"BASE TABLE\" | \"VIEW\" }>()\n      .select((eb) =>\n        eb\n          .fn<Omit<InferResult<typeof columnsQuery>[number], \"TABLE_NAME\">[]>(\"json_arrayagg\", [\n            jsonBuildObject({\n              autoincrement: eb.ref(\"c.autoincrement\"),\n              computed: eb.ref(\"c.computed\"),\n              datatype: eb.ref(\"c.datatype\"),\n              default: eb.ref(\"c.default\"),\n              fk_column: eb.ref(\"c.fk_column\"),\n              fk_table: eb.ref(\"c.fk_table\"),\n              name: eb.ref(\"c.name\"),\n              position: eb.ref(\"c.position\"),\n              pk: eb.ref(\"c.pk\"),\n              nullable: eb.ref(\"c.nullable\"),\n            }),\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          default: null,\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          default: \"uuid_to_bin(uuid())\",\n          fk_column: null,\n          fk_table: null,\n          name: \"uuid\",\n          nullable: 1,\n          pk: null,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"varchar(255)\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 1,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"id_name\",\n          nullable: 1,\n          pk: null,\n          position: 4,\n        },\n      ],\n      name: \"animals\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"char(36)\",\n          default: \"uuid()\",\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: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 0,\n          pk: 2,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          default: \"CURRENT_TIMESTAMP\",\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n      ],\n      name: \"composite_pk\",\n      schema: \"studio\",\n      type: \"BASE TABLE\",\n    },\n    {\n      columns: [\n        {\n          autoincrement: 1,\n          computed: 0,\n          datatype: \"int\",\n          default: null,\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          default: \"current_timestamp\",\n          fk_column: null,\n          fk_table: null,\n          name: \"created_at\",\n          nullable: 1,\n          pk: null,\n          position: 2,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"timestamp\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"deleted_at\",\n          nullable: 1,\n          pk: null,\n          position: 3,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"role\",\n          nullable: 1,\n          pk: null,\n          position: 4,\n        },\n        {\n          autoincrement: 0,\n          computed: 0,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name\",\n          nullable: 1,\n          pk: null,\n          position: 5,\n        },\n        {\n          autoincrement: 0,\n          computed: 1,\n          datatype: \"text\",\n          default: null,\n          fk_column: null,\n          fk_table: null,\n          name: \"name_role\",\n          nullable: 1,\n          pk: null,\n          position: 6,\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": ";;;;;;;;yQAAAA,ICAAC,ICAAC,IAEO,IAAMC,EAAmF,CAC9F,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,OAAQ,aACR,MAAO,UACT,EACA,SAAU,CACR,OAAQ,0BACR,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,OAAQ,eACR,MAAO,MACT,EACA,UAAW,CACT,OAAQ,0BACR,MAAO,UACT,EACA,SAAU,CACR,MAAO,QACT,EACA,QAAS,CACP,MAAO,SACT,EACA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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", "applyTransformations", "getInsertRefetchQuery", "criteria", "getCurrentTimestampMillis", "getUpdateRefetchQuery", "changes", "row", "getSelectQuery", "filter", "pageIndex", "pageSize", "sortOrder", "filterExpression", "getSelectFilterExpression", "AGG_NAME", "COUNT_REF", "countQuery", "eb", "sql", "jb", "qb", "item", "mockSelectQuery", "getUpdateQuery", "schema", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonBuildObject", "obj", "sql", "k", "getTablesQuery", "requirements", "database", "sql", "columnsQuery", "getMySQLBuilder", "jb", "eb", "compile", "jsonBuildObject", "mockTablesQuery", "getTimezoneQuery", "builder", "sessionTz", "mockTimezoneQuery", "createMySQLAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "rows", "table", "columns", "autoincrementColumn", "column", "filterObjects", "row", "inferFilterObject", "hasPartialFilterObjects", "filterObject", "filterValues", "value", "getInsertQuery", "insertQuery", "refetchQuery", "getInsertRefetchQuery", "sequence", "insertError", "maybeRefetchResult", "joinSequence", "refetchError", "refetchResults", "results", "result", "autoincrementColumnName", "acc", "columnName", "refetchedRow", "insertedRows", "errors", "i", "index", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "timezone", "createIntrospection", "getSelectQuery", "updateQuery", "getUpdateQuery", "getUpdateRefetchQuery", "updateError", "refetchResult", "args", "schemas", "tableName", "schema", "columnsRecord", "a", "b", "datatype", "defaultValue", "indexOfParenthesis", "strippedDataType", "isAutoincrement", "isComputed", "nullable", "MYSQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery", "query0", "query1"]
}
