@prisma/studio-core 0.11.0 → 0.11.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/dist/chunk-I4OGOLAT.js +10 -0
  2. package/dist/chunk-J6YP3MM4.js +10 -0
  3. package/dist/data/accelerate/index.d.cts +1 -1
  4. package/dist/data/accelerate/index.d.ts +1 -1
  5. package/dist/data/bff/index.d.cts +1 -1
  6. package/dist/data/bff/index.d.ts +1 -1
  7. package/dist/data/index.d.cts +1 -1
  8. package/dist/data/index.d.ts +1 -1
  9. package/dist/data/mysql-core/index.cjs +2 -2
  10. package/dist/data/mysql-core/index.d.cts +49 -2
  11. package/dist/data/mysql-core/index.d.ts +49 -2
  12. package/dist/data/mysql-core/index.js +3 -3
  13. package/dist/data/mysql2/index.d.cts +1 -1
  14. package/dist/data/mysql2/index.d.ts +1 -1
  15. package/dist/data/node-sqlite/index.d.cts +1 -1
  16. package/dist/data/node-sqlite/index.d.ts +1 -1
  17. package/dist/data/pglite/index.cjs +1 -1
  18. package/dist/data/pglite/index.d.cts +1 -1
  19. package/dist/data/pglite/index.d.ts +1 -1
  20. package/dist/data/pglite/index.js +1 -1
  21. package/dist/data/postgres-core/index.cjs +1 -1
  22. package/dist/data/postgres-core/index.d.cts +1 -1
  23. package/dist/data/postgres-core/index.d.ts +1 -1
  24. package/dist/data/postgres-core/index.js +1 -1
  25. package/dist/data/postgresjs/index.d.cts +1 -1
  26. package/dist/data/postgresjs/index.d.ts +1 -1
  27. package/dist/data/ppg/index.d.cts +1 -1
  28. package/dist/data/ppg/index.d.ts +1 -1
  29. package/dist/data/sqlite-core/index.cjs +2 -2
  30. package/dist/data/sqlite-core/index.d.cts +14 -2
  31. package/dist/data/sqlite-core/index.d.ts +14 -2
  32. package/dist/data/sqlite-core/index.js +2 -2
  33. package/dist/{executor-B5UdD1ZH.d.cts → executor-CFej-Wsy.d.cts} +1 -1
  34. package/dist/{executor-B5UdD1ZH.d.ts → executor-CFej-Wsy.d.ts} +1 -1
  35. package/dist/metafile-cjs.json +1 -1
  36. package/dist/metafile-esm.json +1 -1
  37. package/dist/ui/index.cjs +1 -1
  38. package/dist/ui/index.d.cts +1 -1
  39. package/dist/ui/index.d.ts +1 -1
  40. package/dist/ui/index.js +1 -1
  41. package/package.json +1 -1
  42. package/dist/chunk-DUKJZEWA.js +0 -10
  43. package/dist/chunk-PYMTS4U4.js +0 -10
@@ -1,4 +1,4 @@
1
- import { A as AdapterRequirements, d as Adapter, T as Table, F as FilterOperator, Q as Query, n as AdapterQueryDetails, K as BuilderRequirements, y as AdapterDeleteDetails, u as AdapterInsertDetails, w as AdapterUpdateDetails } from '../../executor-B5UdD1ZH.cjs';
1
+ import { A as AdapterRequirements, d as Adapter, T as Table, F as FilterOperator, Q as Query, n as AdapterQueryDetails, K as BuilderRequirements, y as AdapterDeleteDetails, u as AdapterInsertDetails, w as AdapterUpdateDetails } from '../../executor-CFej-Wsy.cjs';
2
2
  import * as kysely from 'kysely';
3
3
 
4
4
  type SQLIteAdapterRequirements = AdapterRequirements;
@@ -70,10 +70,11 @@ declare function getUpdateQuery(details: AdapterUpdateDetails, requirements?: Om
70
70
 
71
71
  declare function getTablesQuery(requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
72
72
  name: string;
73
- sql: string | null;
73
+ sql: string;
74
74
  columns: {
75
75
  name: string;
76
76
  pk: number;
77
+ default: string | null;
77
78
  datatype: string;
78
79
  fk_table: string | null;
79
80
  fk_column: string | null;
@@ -90,6 +91,7 @@ declare function mockTablesQuery(): [{
90
91
  readonly columns: [{
91
92
  readonly name: "id";
92
93
  readonly datatype: "INTEGER";
94
+ readonly default: null;
93
95
  readonly pk: 1;
94
96
  readonly computed: 0;
95
97
  readonly nullable: 0;
@@ -98,6 +100,7 @@ declare function mockTablesQuery(): [{
98
100
  }, {
99
101
  readonly name: "name";
100
102
  readonly datatype: "TEXT";
103
+ readonly default: null;
101
104
  readonly pk: 0;
102
105
  readonly computed: 0;
103
106
  readonly nullable: 1;
@@ -110,6 +113,7 @@ declare function mockTablesQuery(): [{
110
113
  readonly columns: [{
111
114
  readonly name: "id";
112
115
  readonly datatype: "UUID";
116
+ readonly default: null;
113
117
  readonly pk: 1;
114
118
  readonly computed: 0;
115
119
  readonly nullable: 0;
@@ -118,6 +122,7 @@ declare function mockTablesQuery(): [{
118
122
  }, {
119
123
  readonly name: "created_at";
120
124
  readonly datatype: "TIMESTAMP";
125
+ readonly default: null;
121
126
  readonly pk: 0;
122
127
  readonly computed: 0;
123
128
  readonly nullable: 1;
@@ -126,6 +131,7 @@ declare function mockTablesQuery(): [{
126
131
  }, {
127
132
  readonly name: "deleted_at";
128
133
  readonly datatype: "TIMESTAMP";
134
+ readonly default: null;
129
135
  readonly pk: 0;
130
136
  readonly computed: 0;
131
137
  readonly nullable: 1;
@@ -134,6 +140,7 @@ declare function mockTablesQuery(): [{
134
140
  }, {
135
141
  readonly name: "role";
136
142
  readonly datatype: "varchar";
143
+ readonly default: null;
137
144
  readonly pk: 0;
138
145
  readonly computed: 0;
139
146
  readonly nullable: 1;
@@ -142,6 +149,7 @@ declare function mockTablesQuery(): [{
142
149
  }, {
143
150
  readonly name: "name";
144
151
  readonly datatype: "varchar";
152
+ readonly default: null;
145
153
  readonly pk: 0;
146
154
  readonly computed: 0;
147
155
  readonly nullable: 1;
@@ -150,6 +158,7 @@ declare function mockTablesQuery(): [{
150
158
  }, {
151
159
  readonly name: "name_role";
152
160
  readonly datatype: "text";
161
+ readonly default: null;
153
162
  readonly pk: 0;
154
163
  readonly computed: 0;
155
164
  readonly nullable: 1;
@@ -162,6 +171,7 @@ declare function mockTablesQuery(): [{
162
171
  readonly columns: [{
163
172
  readonly name: "id";
164
173
  readonly datatype: "UUID";
174
+ readonly default: null;
165
175
  readonly pk: 1;
166
176
  readonly computed: 0;
167
177
  readonly nullable: 0;
@@ -170,6 +180,7 @@ declare function mockTablesQuery(): [{
170
180
  }, {
171
181
  readonly name: "name";
172
182
  readonly datatype: "TEXT";
183
+ readonly default: null;
173
184
  readonly pk: 2;
174
185
  readonly computed: 0;
175
186
  readonly nullable: 1;
@@ -178,6 +189,7 @@ declare function mockTablesQuery(): [{
178
189
  }, {
179
190
  readonly name: "created_at";
180
191
  readonly datatype: "timestamp";
192
+ readonly default: null;
181
193
  readonly pk: 0;
182
194
  readonly computed: 0;
183
195
  readonly nullable: 1;
@@ -1,4 +1,4 @@
1
- import { A as AdapterRequirements, d as Adapter, T as Table, F as FilterOperator, Q as Query, n as AdapterQueryDetails, K as BuilderRequirements, y as AdapterDeleteDetails, u as AdapterInsertDetails, w as AdapterUpdateDetails } from '../../executor-B5UdD1ZH.js';
1
+ import { A as AdapterRequirements, d as Adapter, T as Table, F as FilterOperator, Q as Query, n as AdapterQueryDetails, K as BuilderRequirements, y as AdapterDeleteDetails, u as AdapterInsertDetails, w as AdapterUpdateDetails } from '../../executor-CFej-Wsy.js';
2
2
  import * as kysely from 'kysely';
3
3
 
4
4
  type SQLIteAdapterRequirements = AdapterRequirements;
@@ -70,10 +70,11 @@ declare function getUpdateQuery(details: AdapterUpdateDetails, requirements?: Om
70
70
 
71
71
  declare function getTablesQuery(requirements?: Omit<BuilderRequirements, "Adapter" | "QueryCompiler">): Query<{
72
72
  name: string;
73
- sql: string | null;
73
+ sql: string;
74
74
  columns: {
75
75
  name: string;
76
76
  pk: number;
77
+ default: string | null;
77
78
  datatype: string;
78
79
  fk_table: string | null;
79
80
  fk_column: string | null;
@@ -90,6 +91,7 @@ declare function mockTablesQuery(): [{
90
91
  readonly columns: [{
91
92
  readonly name: "id";
92
93
  readonly datatype: "INTEGER";
94
+ readonly default: null;
93
95
  readonly pk: 1;
94
96
  readonly computed: 0;
95
97
  readonly nullable: 0;
@@ -98,6 +100,7 @@ declare function mockTablesQuery(): [{
98
100
  }, {
99
101
  readonly name: "name";
100
102
  readonly datatype: "TEXT";
103
+ readonly default: null;
101
104
  readonly pk: 0;
102
105
  readonly computed: 0;
103
106
  readonly nullable: 1;
@@ -110,6 +113,7 @@ declare function mockTablesQuery(): [{
110
113
  readonly columns: [{
111
114
  readonly name: "id";
112
115
  readonly datatype: "UUID";
116
+ readonly default: null;
113
117
  readonly pk: 1;
114
118
  readonly computed: 0;
115
119
  readonly nullable: 0;
@@ -118,6 +122,7 @@ declare function mockTablesQuery(): [{
118
122
  }, {
119
123
  readonly name: "created_at";
120
124
  readonly datatype: "TIMESTAMP";
125
+ readonly default: null;
121
126
  readonly pk: 0;
122
127
  readonly computed: 0;
123
128
  readonly nullable: 1;
@@ -126,6 +131,7 @@ declare function mockTablesQuery(): [{
126
131
  }, {
127
132
  readonly name: "deleted_at";
128
133
  readonly datatype: "TIMESTAMP";
134
+ readonly default: null;
129
135
  readonly pk: 0;
130
136
  readonly computed: 0;
131
137
  readonly nullable: 1;
@@ -134,6 +140,7 @@ declare function mockTablesQuery(): [{
134
140
  }, {
135
141
  readonly name: "role";
136
142
  readonly datatype: "varchar";
143
+ readonly default: null;
137
144
  readonly pk: 0;
138
145
  readonly computed: 0;
139
146
  readonly nullable: 1;
@@ -142,6 +149,7 @@ declare function mockTablesQuery(): [{
142
149
  }, {
143
150
  readonly name: "name";
144
151
  readonly datatype: "varchar";
152
+ readonly default: null;
145
153
  readonly pk: 0;
146
154
  readonly computed: 0;
147
155
  readonly nullable: 1;
@@ -150,6 +158,7 @@ declare function mockTablesQuery(): [{
150
158
  }, {
151
159
  readonly name: "name_role";
152
160
  readonly datatype: "text";
161
+ readonly default: null;
153
162
  readonly pk: 0;
154
163
  readonly computed: 0;
155
164
  readonly nullable: 1;
@@ -162,6 +171,7 @@ declare function mockTablesQuery(): [{
162
171
  readonly columns: [{
163
172
  readonly name: "id";
164
173
  readonly datatype: "UUID";
174
+ readonly default: null;
165
175
  readonly pk: 1;
166
176
  readonly computed: 0;
167
177
  readonly nullable: 0;
@@ -170,6 +180,7 @@ declare function mockTablesQuery(): [{
170
180
  }, {
171
181
  readonly name: "name";
172
182
  readonly datatype: "TEXT";
183
+ readonly default: null;
173
184
  readonly pk: 2;
174
185
  readonly computed: 0;
175
186
  readonly nullable: 1;
@@ -178,6 +189,7 @@ declare function mockTablesQuery(): [{
178
189
  }, {
179
190
  readonly name: "created_at";
180
191
  readonly datatype: "timestamp";
192
+ readonly default: null;
181
193
  readonly pk: 0;
182
194
  readonly computed: 0;
183
195
  readonly nullable: 1;
@@ -6,5 +6,5 @@ function require(mod) {
6
6
  if (mod === 'react-dom') return ___react_dom___;
7
7
  throw new Error(`Unknown module ${mod}`);
8
8
  }
9
- import{a as L}from"../../chunk-R55ES2HZ.js";import{a as i}from"../../chunk-PYMTS4U4.js";import{A as I,D as O,p as E,q as d,r as q,s as w,x as B,z as f}from"../../chunk-R7UWW2TY.js";import{e as s}from"../../chunk-GDQBQ7MK.js";s();s();s();var j={BLOB:{group:"raw"},INTEGER:{group:"numeric"},NULL:{group:"raw"},NUMERIC:{group:"numeric"},REAL:{group:"numeric"},TEXT:{group:"string"}};function D(r){if(!r)return"BLOB";let t=r.toUpperCase();return t.includes("INT")?"INTEGER":t.includes("TEXT")||t.includes("CHAR")||t.includes("CLOB")?"TEXT":t.includes("BLOB")?"BLOB":t.includes("REAL")||t.includes("FLOA")||t.includes("DOUB")?"REAL":"NUMERIC"}s();s();function y(r){return B({...r,Adapter:w,QueryCompiler:q})}function S(r,t){let{filter:l={after:"and",filters:[],kind:"FilterGroup"},pageIndex:o,pageSize:n,sortOrder:e,table:{columns:a,name:u}}=r,c=y(t),b=O(l.filters,a),p="__ps_agg__",A="__ps_count__",k=c.selectFrom(u).where(b).select(m=>m.cast(m.fn.coalesce(m.fn.countAll(),d.lit(0)),"text").as(A));return f(c.with(p,()=>k).selectFrom(u).innerJoin(p,m=>m.onTrue()).where(b).select(`${p}.${A}`).select(Object.keys(a)).$call(m=>e.reduce((R,g)=>R.orderBy(g.column,g.direction),m)).limit(n).offset(d.lit(BigInt(o)*BigInt(n))))}function ee(){return[{created_at:new Date("2025-01-26T21:56:12.345Z"),deleted_at:null,id:1,name:"John Doe",__ps_count__:"2",role:"admin",name_role:"Jonn Doe - admin"},{created_at:new Date("2025-01-26T20:56:12.345Z"),deleted_at:null,id:2,name:"Jane Doe",__ps_count__:"2",role:"poweruser",name_role:"Jane Doe - poweruser"}]}function N(r,t){let{rows:l,table:{columns:o,name:n}}=r,e=y(t);return f(e.deleteFrom(n).$call(I(l,o)).returning(Object.keys(o)).returning(Q().as("__ps_deleted_at__")))}function C(r,t){let{table:{columns:l,name:o},rows:n}=r,e=y(t);return f(e.insertInto(o).values(n.map(a=>Object.keys(a).length===0?{[Object.keys(l)[0]]:null}:a)).returning(Object.keys(l)).returning(Q().as("__ps_inserted_at__")))}function F(r,t){let{changes:l,row:o,table:{columns:n,name:e}}=r,a=y(t);return f(a.updateTable(e).set(l).$call(I([o],n)).returning(Object.keys(n)).returning(Q().as("__ps_updated_at__")))}function Q(){let r=E();return r.cast(r.cast(d`(julianday('now') - 2440587.5) * 86400000.0`,"integer"),"text")}s();s();function U(r){return d`(select coalesce(json_group_array(json_object(${d.join(v(r.toOperationNode(),"agg"))})), '[]') from ${r} as agg)`}function v(r,t){try{return L(r,t)}catch{throw new Error("SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}function M(r){return f(y(r).selectFrom(E().fn("pragma_table_list",[]).as("tl")).leftJoin("sqlite_schema as ss",t=>t.onRef("ss.type","=","tl.type").onRef("ss.name","=","tl.name")).where("tl.type","in",["table","view"]).where("tl.schema","=","main").where("tl.name","not like","sqlite_%").select(["tl.name","ss.sql"]).select(t=>[U(t.selectFrom(t.fn("pragma_table_xinfo",["tl.name"]).as("txi")).leftJoin(t.fn("pragma_foreign_key_list",["tl.name"]).as("fkl"),"fkl.from","txi.name").where("txi.hidden","!=",1).select(["txi.name","txi.pk","txi.type as datatype","fkl.table as fk_table","fkl.to as fk_column"]).select(l=>[l("txi.hidden","in",[2,3]).as("computed"),l("txi.notnull","!=",0).as("nullable")])).as("columns")]),{transformations:{columns:"json-parse"}})}function P(){return[{name:"animals",sql:"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);",columns:[{name:"id",datatype:"INTEGER",pk:1,computed:0,nullable:0,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]},{name:"users",sql:"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);",columns:[{name:"id",datatype:"UUID",pk:1,computed:0,nullable:0,fk_table:null,fk_column:null},{name:"created_at",datatype:"TIMESTAMP",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"deleted_at",datatype:"TIMESTAMP",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"role",datatype:"varchar",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"varchar",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name_role",datatype:"text",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]},{name:"composite_pk",sql:"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));",columns:[{name:"id",datatype:"UUID",pk:1,computed:0,nullable:0,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",pk:2,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"created_at",datatype:"timestamp",pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]}]}var T="main",X=["=","!=",">",">=","<","<=","is","is not","like","not like"];function be(r){let{executor:t,...l}=r;return{defaultSchema:T,async delete(o,n){try{let e=N(o,l),[a]=await t.execute(e,n);return a?i({error:a,query:e}):[null,{...o,query:e}]}catch(e){return i({error:e})}},async insert(o,n){try{let e=C(o,l),[a,u]=await t.execute(e,n);return a?i({error:a,query:e}):[null,{rows:u,query:e}]}catch(e){return i({error:e})}},async introspect(o){try{let n=M(r),[e,a]=await t.execute(n,o);return e?i({error:e,query:n}):[null,G({query:n,tables:a})]}catch(n){return i({error:n})}},async query(o,n){try{let e=S(o,l),[a,u]=await t.execute(e,n);return a?i({error:a,query:e}):[null,{filteredRowCount:u[0]?.__ps_count__||"0",rows:u,query:e}]}catch(e){return i({error:e})}},async update(o,n){try{let e=F(o,l),[a,u]=await t.execute(e,n);if(a)return i({error:a,query:e});let[c]=u;return c?[null,{row:c,query:e}]:i({error:new Error("Update failed"),query:e})}catch(e){return i({error:e})}}}}function G(r){let{tables:t,query:l}=r;return{filterOperators:X,query:l,schemas:t.reduce((o,n)=>{let{columns:e,name:a,sql:u}=n,c=e.reduce((b,p)=>{let{datatype:A,fk_column:k,name:m,pk:R}=p,g=D(A),h=!!p.computed,x=!!p.nullable;return b[m]={datatype:{...j[g],affinity:g,isArray:!1,isNative:!0,name:A,options:[],schema:T},defaultValue:null,fkColumn:k,fkSchema:k?T:null,fkTable:p.fk_table,isAutoincrement:!1,isComputed:h,isRequired:!x&&!h,name:m,nullable:x,pkPosition:R>0?R:null,schema:T,table:a},b},{});return o.main.tables[a]={columns:c,name:a,schema:"main"},o},{main:{tables:{},name:"main"}}),timezone:"UTC"}}function Ae(){let r={parameters:[],sql:"<mocked>"},t=P();return G({query:r,tables:t})}export{be as createSQLiteAdapter,N as getDeleteQuery,C as getInsertQuery,S as getSelectQuery,M as getTablesQuery,F as getUpdateQuery,Ae as mockIntrospect,ee as mockSelectQuery,P as mockTablesQuery};
10
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/sqlite-core/index.ts", "../../../data/sqlite-core/adapter.ts", "../../../data/sqlite-core/datatype.ts", "../../../data/sqlite-core/dml.ts", "../../../data/sqlite-core/builder.ts", "../../../data/sqlite-core/introspection.ts", "../../../../../node_modules/.pnpm/kysely@0.28.8/node_modules/kysely/dist/esm/helpers/sqlite.js"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\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  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { determineColumnAffinity, SQLITE_AFFINITY_TO_METADATA } from \"./datatype\";\nimport { getDeleteQuery, getInsertQuery, getSelectQuery, getUpdateQuery } from \"./dml\";\nimport { getTablesQuery, mockTablesQuery } from \"./introspection\";\n\nexport type SQLIteAdapterRequirements = AdapterRequirements;\n\nconst schema = \"main\";\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n] satisfies FilterOperator[];\n\nexport function createSQLiteAdapter(requirements: SQLIteAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    defaultSchema: schema,\n\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        // TODO: use results too.\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 query = getInsertQuery(details, otherRequirements);\n\n        const [error, rows] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { rows, 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\n        const [tablesError, tables] = await executor.execute(tablesQuery, options);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        return [null, createIntrospection({ query: tablesQuery, tables })];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.__ps_count__ || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(details, options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const query = getUpdateQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          // TODO: custom error?\n          return createAdapterError({ error: new Error(\"Update failed\"), query });\n        }\n\n        return [null, { row, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction createIntrospection(args: {\n  tables: QueryResult<typeof getTablesQuery>;\n  query: Query;\n}): AdapterIntrospectResult {\n  const { tables, query: tablesQuery } = args;\n\n  return {\n    filterOperators,\n    query: tablesQuery,\n    schemas: tables.reduce(\n      (schemas, table) => {\n        const { columns, name: tableName, sql: _sql } = table;\n\n        const columnsRecord = columns.reduce(\n          (columns, column) => {\n            const { datatype, fk_column, name: columnName, pk } = column;\n\n            const affinity = determineColumnAffinity(datatype);\n\n            const isComputed = Boolean(column.computed);\n            const nullable = Boolean(column.nullable);\n\n            columns[columnName] = {\n              datatype: {\n                // TODO: worth exploring still vibing with the declared data type for stuff like dates in the future.\n                ...SQLITE_AFFINITY_TO_METADATA[affinity],\n                affinity,\n                isArray: false,\n                isNative: true,\n                name: datatype,\n                // TODO: use `table.sql` to determine enum options from `check` constraints.\n                options: [],\n                schema,\n              },\n              // TODO: introspect sqlite default values.\n              defaultValue: null,\n              fkColumn: fk_column,\n              fkSchema: fk_column ? schema : null,\n              fkTable: column.fk_table,\n              // TODO: use `table.sql` to determine autoincrement\n              isAutoincrement: false,\n              isComputed,\n              // TODO: also handle !autoinc && default == null\n              isRequired: !nullable && !isComputed,\n              name: columnName,\n              nullable,\n              pkPosition: pk > 0 ? pk : null,\n              schema,\n              table: tableName,\n            };\n\n            return columns;\n          },\n          {} as Table[\"columns\"],\n        );\n\n        schemas.main!.tables[tableName] = {\n          columns: columnsRecord,\n          name: tableName,\n          schema: \"main\",\n        };\n\n        return schemas;\n      },\n      {\n        main: { tables: {}, name: \"main\" },\n      } satisfies AdapterIntrospectResult[\"schemas\"] as AdapterIntrospectResult[\"schemas\"],\n    ),\n    timezone: \"UTC\",\n  };\n}\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n  const tables = mockTablesQuery();\n\n  return createIntrospection({ query, tables }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      main: {\n        name: \"main\";\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: string;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n", "import type { DataType } from \"../adapter\";\n\nexport type SQLiteAffinity = \"BLOB\" | \"INTEGER\" | \"NULL\" | \"NUMERIC\" | \"REAL\" | \"TEXT\";\n\nexport const SQLITE_AFFINITY_TO_METADATA: Record<SQLiteAffinity, Pick<DataType, \"format\" | \"group\">> = {\n  BLOB: {\n    group: \"raw\",\n  },\n  INTEGER: {\n    group: \"numeric\",\n  },\n  NULL: {\n    group: \"raw\",\n  },\n  NUMERIC: {\n    group: \"numeric\",\n  },\n  REAL: {\n    group: \"numeric\",\n  },\n  TEXT: {\n    group: \"string\",\n  },\n};\n\n/**\n * https://sqlite.org/datatype3.html#determination_of_column_affinity\n *\n * DO NOT CHANGE THE ORDER OF THE CHECKS IN THIS FUNCTION!\n */\nexport function determineColumnAffinity(declaredDataType: string | null): SQLiteAffinity {\n  if (!declaredDataType) {\n    return \"BLOB\";\n  }\n\n  const upperType = declaredDataType.toUpperCase();\n\n  if (upperType.includes(\"INT\")) {\n    return \"INTEGER\";\n  }\n\n  if (upperType.includes(\"TEXT\") || upperType.includes(\"CHAR\") || upperType.includes(\"CLOB\")) {\n    return \"TEXT\";\n  }\n\n  if (upperType.includes(\"BLOB\")) {\n    return \"BLOB\";\n  }\n\n  if (upperType.includes(\"REAL\") || upperType.includes(\"FLOA\") || upperType.includes(\"DOUB\")) {\n    return \"REAL\";\n  }\n\n  return \"NUMERIC\";\n}\n", "import { expressionBuilder, type InferResult, sql } from \"kysely\";\nimport { SimpleReferenceExpression } from \"kysely\";\n\nimport type { AdapterDeleteDetails, AdapterInsertDetails, AdapterQueryDetails, AdapterUpdateDetails } from \"../adapter\";\nimport { applyInferredRowFilters, type BuilderRequirements, compile, getSelectFilterExpression } from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getSQLiteBuilder } from \"./builder\";\nimport { mockTablesQuery } from \"./introspection\";\n\n/**\n * Returns a query that selects all columns from a table with an unbound row count as `__ps_count__`.\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 = getSQLiteBuilder<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)), \"text\").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      created_at: new Date(\"2025-01-26T21:56:12.345Z\"),\n      deleted_at: null,\n      id: 1,\n      name: \"John Doe\",\n      __ps_count__: \"2\",\n      role: \"admin\",\n      name_role: \"Jonn Doe - admin\",\n    },\n    {\n      created_at: new Date(\"2025-01-26T20:56:12.345Z\"),\n      deleted_at: null,\n      id: 2,\n      name: \"Jane Doe\",\n      __ps_count__: \"2\",\n      role: \"poweruser\",\n      name_role: \"Jane Doe - poweruser\",\n    },\n  ] 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\n/**\n * Returns a query that deletes a given set of rows.\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 = getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .deleteFrom(tableName)\n      .$call(applyInferredRowFilters(rows, columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_deleted_at__\")),\n  );\n}\n\n/**\n * Inserts one or more rows into a table and returns the inserted rows along with their `ctid`.\n */\nexport function getInsertQuery(\n  details: AdapterInsertDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    table: { columns, name: tableName },\n    rows,\n  } = details;\n\n  const builder = getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .insertInto(tableName)\n      .values(rows.map((row) => (Object.keys(row).length === 0 ? { [Object.keys(columns)[0]!]: null } : row)))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\n}\n\n/**\n * Returns a query that updates a given row in a table with given changes.\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 },\n  } = details;\n\n  const builder = getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .updateTable(tableName)\n      .set(changes)\n      .$call(applyInferredRowFilters([row], columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\nfunction getCurrentTimestampMillis() {\n  const eb = expressionBuilder();\n\n  return eb.cast<BigIntString>(eb.cast(sql`(julianday('now') - 2440587.5) * 86400000.0`, \"integer\"), \"text\");\n}\n", "import { type Kysely, SqliteAdapter, SqliteQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getSQLiteBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder<Database>({\n    ...requirements,\n    Adapter: SqliteAdapter,\n    QueryCompiler: SqliteQueryCompiler,\n  });\n}\n", "/**\n * SQLite introspection queries to be used by the SQLite adapter's introspect method.\n * @module sqlite-core/introspection\n *\n * References:\n * https://sqlite.org/pragma.html\n * https://sqlite.org/schematab.html\n */\n\nimport { expressionBuilder } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/sqlite\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getSQLiteBuilder } from \"./builder\";\n\ninterface Database {\n  /** the main system table */\n  sqlite_schema: {\n    /** object name */\n    name: string;\n    /** page number in root index when object is a table. */\n    rootpage: number;\n    /** sql statement that can recreate the object. null when internal index object. */\n    sql: string | null;\n    /** related table/view name when object is an index/trigger. */\n    tbl_name: string;\n    /** object type */\n    type: \"index\" | \"table\" | \"trigger\" | \"view\";\n  };\n}\n\n/**\n * The shape of each row returned by `pragma_table_list(tableName?)`.\n */\ninterface PragmaTableList {\n  /** object name */\n  name: string;\n  /** schema name */\n  schema: \"main\" | \"temp\";\n  /** object type */\n  type: \"shadow\" | \"table\" | \"view\" | \"virtual\";\n}\n\n/**\n * The shape of each row returned by `pragma_table_xinfo(tableName)`.\n */\ninterface PragmaTableXInfo {\n  /** \"rank within current result set\" */\n  cid: number;\n  /** default value */\n  dflt_value: unknown;\n  /** 0 - normal, 1 - hidden, 2-3 - dynamic/stored generated */\n  hidden: 0 | 1 | 2 | 3;\n  /** column name */\n  name: string;\n  /** whether the column can be null */\n  notnull: 0 | 1;\n  /** 0 if not part of the primary key, otherwise the 1-based ordinal number of the column in the primary key */\n  pk: number;\n  /** data type */\n  type: string;\n}\n\n/**\n * The shape of each row returned by `pragma_foreign_key_list(tableName)`.\n */\ninterface PragmaForeignKeyList {\n  /** column name */\n  from: string;\n  /** ordinal number of column within the foreign key */\n  seq: number;\n  /** foreign table name */\n  table: string;\n  /** column name in the foreign table */\n  to: string;\n}\n\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getSQLiteBuilder<Database>(requirements)\n      .selectFrom(expressionBuilder().fn<PragmaTableList>(\"pragma_table_list\", []).as(\"tl\"))\n      .leftJoin(\"sqlite_schema as ss\", (jb) => jb.onRef(\"ss.type\", \"=\", \"tl.type\").onRef(\"ss.name\", \"=\", \"tl.name\"))\n      .where(\"tl.type\", \"in\", [\"table\", \"view\"])\n      // exclude temporary tables/views\n      .where(\"tl.schema\", \"=\", \"main\")\n      // exclude system tables/views\n      .where(\"tl.name\", \"not like\", \"sqlite_%\")\n      .select([\"tl.name\", \"ss.sql\"])\n      .select((eb) => [\n        jsonArrayFrom(\n          eb\n            .selectFrom(eb.fn<PragmaTableXInfo>(\"pragma_table_xinfo\", [\"tl.name\"]).as(\"txi\"))\n            .leftJoin(\n              eb.fn<PragmaForeignKeyList>(\"pragma_foreign_key_list\", [\"tl.name\"]).as(\"fkl\"),\n              \"fkl.from\",\n              \"txi.name\",\n            )\n            // exclude hidden columns\n            .where(\"txi.hidden\", \"!=\", 1)\n            .select([\"txi.name\", \"txi.pk\", \"txi.type as datatype\", \"fkl.table as fk_table\", \"fkl.to as fk_column\"])\n            .select((eb) => [eb(\"txi.hidden\", \"in\", [2, 3]).as(\"computed\"), eb(\"txi.notnull\", \"!=\", 0).as(\"nullable\")]),\n        ).as(\"columns\"),\n      ]),\n    { transformations: { columns: \"json-parse\" } },\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      name: \"animals\",\n      sql: \"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"INTEGER\",\n          pk: 1,\n          computed: 0,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"TEXT\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n    {\n      name: \"users\",\n      sql: \"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"UUID\",\n          pk: 1,\n          computed: 0,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"TIMESTAMP\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"deleted_at\",\n          datatype: \"TIMESTAMP\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"role\",\n          datatype: \"varchar\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"varchar\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name_role\",\n          datatype: \"text\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n    {\n      name: \"composite_pk\",\n      sql: \"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"UUID\",\n          pk: 1,\n          computed: 0,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"TEXT\",\n          pk: 2,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"timestamp\",\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n", "/// <reference types=\"./sqlite.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A SQLite helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/sqlite'\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 (SQLite):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_group_array(json_object(\n *     'pet_id', \"agg\".\"pet_id\",\n *     'name', \"agg\".\"name\"\n *   )), '[]') 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 coalesce(json_group_array(json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') from ${expr} as agg)`;\n}\n/**\n * A SQLite helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/sqlite'\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 (SQLite):\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(getSqliteJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The SQLite `json_object` function.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/sqlite'\n *\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: sql<string>`first_name ||\u00A0' ' || 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 (SQLite):\n *\n * ```sql\n * select \"id\", json_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', \"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 getSqliteJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('SQLite 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": "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Ae,KAAM,CAAC,EAAE,GAAG,UAAU,CAAC,CAAC,CAC9G,EAAE,GAAG,SAAS,CAChB,CAAC,EACH,CAAE,gBAAiB,CAAE,QAAS,YAAa,CAAE,CAC/C,CACF,CAKO,SAASE,GAAkB,CAChC,MAAO,CACL,CACE,KAAM,UACN,IAAK,4DACL,QAAS,CACP,CACE,KAAM,KACN,SAAU,UACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,OACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,CACF,CACF,EACA,CACE,KAAM,QACN,IAAK,oIACL,QAAS,CACP,CACE,KAAM,KACN,SAAU,OACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,aACN,SAAU,YACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,aACN,SAAU,YACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,UACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,UACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,YACN,SAAU,OACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,CACF,CACF,EACA,CACE,KAAM,eACN,IAAK,gGACL,QAAS,CACP,CACE,KAAM,KACN,SAAU,OACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,OACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,aACN,SAAU,YACV,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,CACF,CACF,CACF,CACF,CJjNA,IAAMC,EAAS,OAETC,EAA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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "SQLITE_AFFINITY_TO_METADATA", "determineColumnAffinity", "declaredDataType", "upperType", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getSQLiteBuilder", "requirements", "getBuilder", "SqliteAdapter", "SqliteQueryCompiler", "getSelectQuery", "details", "requirements", "filter", "pageIndex", "pageSize", "sortOrder", "columns", "tableName", "builder", "getSQLiteBuilder", "filterExpression", "getSelectFilterExpression", "AGG_NAME", "COUNT_REF", "countQuery", "eb", "sql", "compile", "jb", "qb", "item", "mockSelectQuery", "getDeleteQuery", "rows", "applyInferredRowFilters", "getCurrentTimestampMillis", "getInsertQuery", "row", "getUpdateQuery", "changes", "expressionBuilder", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonArrayFrom", "expr", "sql", "getSqliteJsonObjectArgs", "getSqliteJsonObjectArgs", "node", "table", "getJsonObjectArgs", "getTablesQuery", "requirements", "compile", "getSQLiteBuilder", "expressionBuilder", "jb", "eb", "jsonArrayFrom", "mockTablesQuery", "schema", "filterOperators", "createSQLiteAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "getInsertQuery", "rows", "tablesQuery", "getTablesQuery", "tablesError", "tables", "createIntrospection", "getSelectQuery", "results", "getUpdateQuery", "row", "args", "schemas", "table", "columns", "tableName", "_sql", "columnsRecord", "column", "datatype", "fk_column", "columnName", "pk", "affinity", "determineColumnAffinity", "isComputed", "nullable", "SQLITE_AFFINITY_TO_METADATA", "mockIntrospect", "mockTablesQuery"]
}

9
+ import{a as j}from"../../chunk-R55ES2HZ.js";import{a as u}from"../../chunk-I4OGOLAT.js";import{A as I,D as L,p as T,q as d,r as O,s as B,x as D,z as f}from"../../chunk-R7UWW2TY.js";import{e as s}from"../../chunk-GDQBQ7MK.js";s();s();s();var N={BLOB:{group:"raw"},INTEGER:{group:"numeric"},NULL:{group:"raw"},NUMERIC:{group:"numeric"},REAL:{group:"numeric"},TEXT:{group:"string"}};function S(r){if(!r)return"BLOB";let t=r.toUpperCase();return t.includes("INT")?"INTEGER":t.includes("TEXT")||t.includes("CHAR")||t.includes("CLOB")?"TEXT":t.includes("BLOB")?"BLOB":t.includes("REAL")||t.includes("FLOA")||t.includes("DOUB")?"REAL":"NUMERIC"}s();s();function y(r){return D({...r,Adapter:B,QueryCompiler:O})}function U(r,t){let{filter:o={after:"and",filters:[],kind:"FilterGroup"},pageIndex:l,pageSize:n,sortOrder:e,table:{columns:a,name:i}}=r,c=y(t),g=L(o.filters,a),p="__ps_agg__",_="__ps_count__",k=c.selectFrom(i).where(g).select(m=>m.cast(m.fn.coalesce(m.fn.countAll(),d.lit(0)),"text").as(_));return f(c.with(p,()=>k).selectFrom(i).innerJoin(p,m=>m.onTrue()).where(g).select(`${p}.${_}`).select(Object.keys(a)).$call(m=>e.reduce((R,b)=>R.orderBy(b.column,b.direction),m)).limit(n).offset(d.lit(BigInt(l)*BigInt(n))))}function le(){return[{created_at:new Date("2025-01-26T21:56:12.345Z"),deleted_at:null,id:1,name:"John Doe",__ps_count__:"2",role:"admin",name_role:"Jonn Doe - admin"},{created_at:new Date("2025-01-26T20:56:12.345Z"),deleted_at:null,id:2,name:"Jane Doe",__ps_count__:"2",role:"poweruser",name_role:"Jane Doe - poweruser"}]}function C(r,t){let{rows:o,table:{columns:l,name:n}}=r,e=y(t);return f(e.deleteFrom(n).$call(I(o,l)).returning(Object.keys(l)).returning(Q().as("__ps_deleted_at__")))}function F(r,t){let{table:{columns:o,name:l},rows:n}=r,e=y(t);return f(e.insertInto(l).values(n.map(a=>Object.keys(a).length===0?{[Object.keys(o)[0]]:null}:a)).returning(Object.keys(o)).returning(Q().as("__ps_inserted_at__")))}function M(r,t){let{changes:o,row:l,table:{columns:n,name:e}}=r,a=y(t);return f(a.updateTable(e).set(o).$call(I([l],n)).returning(Object.keys(n)).returning(Q().as("__ps_updated_at__")))}function Q(){let r=T();return r.cast(r.cast(d`(julianday('now') - 2440587.5) * 86400000.0`,"integer"),"text")}s();s();function P(r){return d`(select coalesce(json_group_array(json_object(${d.join(J(r.toOperationNode(),"agg"))})), '[]') from ${r} as agg)`}function J(r,t){try{return j(r,t)}catch{throw new Error("SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}function G(r){return f(y(r).selectFrom(T().fn("pragma_table_list",[]).as("tl")).leftJoin("sqlite_schema as ss",t=>t.onRef("ss.type","=","tl.type").onRef("ss.name","=","tl.name")).where("tl.type","in",["table","view"]).where("tl.schema","=","main").where("tl.name","not like","sqlite_%").select(["tl.name","ss.sql"]).$narrowType().select(t=>[P(t.selectFrom(t.fn("pragma_table_xinfo",["tl.name"]).as("txi")).leftJoin(t.fn("pragma_foreign_key_list",["tl.name"]).as("fkl"),"fkl.from","txi.name").where("txi.hidden","!=",1).select(["txi.dflt_value as default","txi.name","txi.pk","txi.type as datatype","fkl.table as fk_table","fkl.to as fk_column"]).select(o=>[o("txi.hidden","in",[2,3]).as("computed"),o("txi.notnull","!=",0).as("nullable")])).as("columns")]),{transformations:{columns:"json-parse"}})}function v(){return[{name:"animals",sql:"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);",columns:[{name:"id",datatype:"INTEGER",default:null,pk:1,computed:0,nullable:0,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]},{name:"users",sql:"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);",columns:[{name:"id",datatype:"UUID",default:null,pk:1,computed:0,nullable:0,fk_table:null,fk_column:null},{name:"created_at",datatype:"TIMESTAMP",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"deleted_at",datatype:"TIMESTAMP",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"role",datatype:"varchar",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name",datatype:"varchar",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"name_role",datatype:"text",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]},{name:"composite_pk",sql:"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));",columns:[{name:"id",datatype:"UUID",default:null,pk:1,computed:0,nullable:0,fk_table:null,fk_column:null},{name:"name",datatype:"TEXT",default:null,pk:2,computed:0,nullable:1,fk_table:null,fk_column:null},{name:"created_at",datatype:"timestamp",default:null,pk:0,computed:0,nullable:1,fk_table:null,fk_column:null}]}]}var E="main",K=["=","!=",">",">=","<","<=","is","is not","like","not like"];function Te(r){let{executor:t,...o}=r;return{defaultSchema:E,async delete(l,n){try{let e=C(l,o),[a]=await t.execute(e,n);return a?u({error:a,query:e}):[null,{...l,query:e}]}catch(e){return u({error:e})}},async insert(l,n){try{let e=F(l,o),[a,i]=await t.execute(e,n);return a?u({error:a,query:e}):[null,{rows:i,query:e}]}catch(e){return u({error:e})}},async introspect(l){try{let n=G(r),[e,a]=await t.execute(n,l);return e?u({error:e,query:n}):[null,X({query:n,tables:a})]}catch(n){return u({error:n})}},async query(l,n){try{let e=U(l,o),[a,i]=await t.execute(e,n);return a?u({error:a,query:e}):[null,{filteredRowCount:i[0]?.__ps_count__||"0",rows:i,query:e}]}catch(e){return u({error:e})}},async update(l,n){try{let e=M(l,o),[a,i]=await t.execute(e,n);if(a)return u({error:a,query:e});let[c]=i;return c?[null,{row:c,query:e}]:u({error:new Error("Update failed"),query:e})}catch(e){return u({error:e})}}}}var Y=/WITHOUT\s+ROWID/i;function X(r){let{tables:t,query:o}=r;return{filterOperators:K,query:o,schemas:t.reduce((l,n)=>{let{columns:e,name:a,sql:i}=n,c=e.reduce((g,p)=>{let{datatype:_,default:k,fk_column:m,name:R,pk:b}=p,x=S(_),h=!!p.computed,w=!!p.nullable,q=_.toUpperCase()==="INTEGER"&&b===1&&!e.some(function($){return $.pk>1})&&!Y.test(i);return g[R]={datatype:{...N[x],affinity:x,isArray:!1,isNative:!0,name:_,options:[],schema:E},defaultValue:k,fkColumn:m,fkSchema:m?E:null,fkTable:p.fk_table,isAutoincrement:q,isComputed:h,isRequired:!w&&!q&&!h&&k==null,name:R,nullable:w,pkPosition:b>0?b:null,schema:E,table:a},g},{});return l.main.tables[a]={columns:c,name:a,schema:"main"},l},{main:{tables:{},name:"main"}}),timezone:"UTC"}}function Ee(){let r={parameters:[],sql:"<mocked>"},t=v();return X({query:r,tables:t})}export{Te as createSQLiteAdapter,C as getDeleteQuery,F as getInsertQuery,U as getSelectQuery,G as getTablesQuery,M as getUpdateQuery,Ee as mockIntrospect,le as mockSelectQuery,v as mockTablesQuery};
10
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/sqlite-core/index.ts", "../../../data/sqlite-core/adapter.ts", "../../../data/sqlite-core/datatype.ts", "../../../data/sqlite-core/dml.ts", "../../../data/sqlite-core/builder.ts", "../../../data/sqlite-core/introspection.ts", "../../../../../node_modules/.pnpm/kysely@0.28.8/node_modules/kysely/dist/esm/helpers/sqlite.js"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\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  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { determineColumnAffinity, SQLITE_AFFINITY_TO_METADATA } from \"./datatype\";\nimport { getDeleteQuery, getInsertQuery, getSelectQuery, getUpdateQuery } from \"./dml\";\nimport { getTablesQuery, mockTablesQuery } from \"./introspection\";\n\nexport type SQLIteAdapterRequirements = AdapterRequirements;\n\nconst schema = \"main\";\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n] satisfies FilterOperator[];\n\nexport function createSQLiteAdapter(requirements: SQLIteAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    defaultSchema: schema,\n\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n\n        // TODO: use results too.\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 query = getInsertQuery(details, otherRequirements);\n\n        const [error, rows] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { rows, 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\n        const [tablesError, tables] = await executor.execute(tablesQuery, options);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        return [null, createIntrospection({ query: tablesQuery, tables })];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.__ps_count__ || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(details, options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const query = getUpdateQuery(details, otherRequirements);\n\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          // TODO: custom error?\n          return createAdapterError({ error: new Error(\"Update failed\"), query });\n        }\n\n        return [null, { row, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nconst WITHOUT_ROWID_REGEX = /WITHOUT\\s+ROWID/i;\n\nfunction createIntrospection(args: {\n  tables: QueryResult<typeof getTablesQuery>;\n  query: Query;\n}): AdapterIntrospectResult {\n  const { tables, query: tablesQuery } = args;\n\n  return {\n    filterOperators,\n    query: tablesQuery,\n    schemas: tables.reduce(\n      (schemas, table) => {\n        const { columns, name: tableName, sql } = table;\n\n        const columnsRecord = columns.reduce(\n          (columnsRecord, column) => {\n            const { datatype, default: defaultValue, fk_column, name: columnName, pk } = column;\n\n            const affinity = determineColumnAffinity(datatype);\n\n            const isComputed = Boolean(column.computed);\n            const nullable = Boolean(column.nullable);\n\n            /**\n             * `INTEGER PRIMARY KEY` columns act as `rowid` alias. `rowid` columns\n             * are auto-generated unique numbers that exist in every SQLite table\n             * unless a table is created using `WITHOUT ROWID` option.\n             */\n            const isRowId =\n              datatype.toUpperCase() === \"INTEGER\" &&\n              pk === 1 &&\n              !columns.some(function isAlsoInPrimaryKey(column) {\n                return column.pk > 1;\n              }) &&\n              !WITHOUT_ROWID_REGEX.test(sql);\n\n            columnsRecord[columnName] = {\n              datatype: {\n                ...SQLITE_AFFINITY_TO_METADATA[affinity],\n                affinity,\n                isArray: false,\n                isNative: true,\n                name: datatype,\n                // TODO: use `table.sql` to determine enum options from `check` constraints.\n                options: [],\n                schema,\n              },\n              defaultValue,\n              fkColumn: fk_column,\n              fkSchema: fk_column ? schema : null,\n              fkTable: column.fk_table,\n              // since `rowid` is auto generated unique number, and `AUTO INCREMENT`\n              // can only be applied to such columns, we consider them autoincrement\n              // and we don't need to check for the existence of the modifier in\n              // the `CREATE TABLE` statement.\n              isAutoincrement: isRowId,\n              isComputed,\n              isRequired: !nullable && !isRowId && !isComputed && defaultValue == null,\n              name: columnName,\n              nullable,\n              pkPosition: pk > 0 ? pk : null,\n              schema,\n              table: tableName,\n            };\n\n            return columnsRecord;\n          },\n          {} as Table[\"columns\"],\n        );\n\n        schemas.main!.tables[tableName] = {\n          columns: columnsRecord,\n          name: tableName,\n          schema: \"main\",\n        };\n\n        return schemas;\n      },\n      {\n        main: { tables: {}, name: \"main\" },\n      } satisfies AdapterIntrospectResult[\"schemas\"] as AdapterIntrospectResult[\"schemas\"],\n    ),\n    timezone: \"UTC\",\n  };\n}\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n  const tables = mockTablesQuery();\n\n  return createIntrospection({ query, tables }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      main: {\n        name: \"main\";\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: string;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n", "import type { DataType } from \"../adapter\";\n\nexport type SQLiteAffinity = \"BLOB\" | \"INTEGER\" | \"NULL\" | \"NUMERIC\" | \"REAL\" | \"TEXT\";\n\nexport const SQLITE_AFFINITY_TO_METADATA: Record<SQLiteAffinity, Pick<DataType, \"format\" | \"group\">> = {\n  BLOB: {\n    group: \"raw\",\n  },\n  INTEGER: {\n    group: \"numeric\",\n  },\n  NULL: {\n    group: \"raw\",\n  },\n  NUMERIC: {\n    group: \"numeric\",\n  },\n  REAL: {\n    group: \"numeric\",\n  },\n  TEXT: {\n    group: \"string\",\n  },\n};\n\n/**\n * https://sqlite.org/datatype3.html#determination_of_column_affinity\n *\n * DO NOT CHANGE THE ORDER OF THE CHECKS IN THIS FUNCTION!\n */\nexport function determineColumnAffinity(declaredDataType: string | null): SQLiteAffinity {\n  if (!declaredDataType) {\n    return \"BLOB\";\n  }\n\n  const upperType = declaredDataType.toUpperCase();\n\n  if (upperType.includes(\"INT\")) {\n    return \"INTEGER\";\n  }\n\n  if (upperType.includes(\"TEXT\") || upperType.includes(\"CHAR\") || upperType.includes(\"CLOB\")) {\n    return \"TEXT\";\n  }\n\n  if (upperType.includes(\"BLOB\")) {\n    return \"BLOB\";\n  }\n\n  if (upperType.includes(\"REAL\") || upperType.includes(\"FLOA\") || upperType.includes(\"DOUB\")) {\n    return \"REAL\";\n  }\n\n  return \"NUMERIC\";\n}\n", "import { expressionBuilder, type InferResult, sql } from \"kysely\";\nimport { SimpleReferenceExpression } from \"kysely\";\n\nimport type { AdapterDeleteDetails, AdapterInsertDetails, AdapterQueryDetails, AdapterUpdateDetails } from \"../adapter\";\nimport { applyInferredRowFilters, type BuilderRequirements, compile, getSelectFilterExpression } from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getSQLiteBuilder } from \"./builder\";\nimport { mockTablesQuery } from \"./introspection\";\n\n/**\n * Returns a query that selects all columns from a table with an unbound row count as `__ps_count__`.\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 = getSQLiteBuilder<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)), \"text\").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      created_at: new Date(\"2025-01-26T21:56:12.345Z\"),\n      deleted_at: null,\n      id: 1,\n      name: \"John Doe\",\n      __ps_count__: \"2\",\n      role: \"admin\",\n      name_role: \"Jonn Doe - admin\",\n    },\n    {\n      created_at: new Date(\"2025-01-26T20:56:12.345Z\"),\n      deleted_at: null,\n      id: 2,\n      name: \"Jane Doe\",\n      __ps_count__: \"2\",\n      role: \"poweruser\",\n      name_role: \"Jane Doe - poweruser\",\n    },\n  ] 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\n/**\n * Returns a query that deletes a given set of rows.\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 = getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .deleteFrom(tableName)\n      .$call(applyInferredRowFilters(rows, columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_deleted_at__\")),\n  );\n}\n\n/**\n * Inserts one or more rows into a table and returns the inserted rows along with their `ctid`.\n */\nexport function getInsertQuery(\n  details: AdapterInsertDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    table: { columns, name: tableName },\n    rows,\n  } = details;\n\n  const builder = getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .insertInto(tableName)\n      .values(rows.map((row) => (Object.keys(row).length === 0 ? { [Object.keys(columns)[0]!]: null } : row)))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_inserted_at__\")),\n  );\n}\n\n/**\n * Returns a query that updates a given row in a table with given changes.\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 },\n  } = details;\n\n  const builder = getSQLiteBuilder<Record<string, Record<string, unknown>>>(requirements);\n\n  return compile(\n    builder\n      .updateTable(tableName)\n      .set(changes)\n      .$call(applyInferredRowFilters([row], columns))\n      .returning(Object.keys(columns))\n      .returning(getCurrentTimestampMillis().as(\"__ps_updated_at__\")),\n  );\n}\n\nfunction getCurrentTimestampMillis() {\n  const eb = expressionBuilder();\n\n  return eb.cast<BigIntString>(eb.cast(sql`(julianday('now') - 2440587.5) * 86400000.0`, \"integer\"), \"text\");\n}\n", "import { type Kysely, SqliteAdapter, SqliteQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getSQLiteBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder<Database>({\n    ...requirements,\n    Adapter: SqliteAdapter,\n    QueryCompiler: SqliteQueryCompiler,\n  });\n}\n", "/**\n * SQLite introspection queries to be used by the SQLite adapter's introspect method.\n * @module sqlite-core/introspection\n *\n * References:\n * https://sqlite.org/pragma.html\n * https://sqlite.org/schematab.html\n */\n\nimport { expressionBuilder, type NotNull } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/sqlite\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getSQLiteBuilder } from \"./builder\";\n\ninterface Database {\n  /** the main system table */\n  sqlite_schema: {\n    /** object name */\n    name: string;\n    /** page number in root index when object is a table. */\n    rootpage: number;\n    /** sql statement that can recreate the object. null when internal index object. */\n    sql: string | null;\n    /** related table/view name when object is an index/trigger. */\n    tbl_name: string;\n    /** object type */\n    type: \"index\" | \"table\" | \"trigger\" | \"view\";\n  };\n}\n\n/**\n * The shape of each row returned by `pragma_table_list(tableName?)`.\n */\ninterface PragmaTableList {\n  /** object name */\n  name: string;\n  /** schema name */\n  schema: \"main\" | \"temp\";\n  /** object type */\n  type: \"shadow\" | \"table\" | \"view\" | \"virtual\";\n}\n\n/**\n * The shape of each row returned by `pragma_table_xinfo(tableName)`.\n */\ninterface PragmaTableXInfo {\n  /** \"rank within current result set\" */\n  cid: number;\n  /** default value */\n  dflt_value: string | null;\n  /** 0 - normal, 1 - hidden, 2-3 - dynamic/stored generated */\n  hidden: 0 | 1 | 2 | 3;\n  /** column name */\n  name: string;\n  /** whether the column can be null */\n  notnull: 0 | 1;\n  /** 0 if not part of the primary key, otherwise the 1-based ordinal number of the column in the primary key */\n  pk: number;\n  /** data type */\n  type: string;\n}\n\n/**\n * The shape of each row returned by `pragma_foreign_key_list(tableName)`.\n */\ninterface PragmaForeignKeyList {\n  /** column name */\n  from: string;\n  /** ordinal number of column within the foreign key */\n  seq: number;\n  /** foreign table name */\n  table: string;\n  /** column name in the foreign table */\n  to: string;\n}\n\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getSQLiteBuilder<Database>(requirements)\n      .selectFrom(expressionBuilder().fn<PragmaTableList>(\"pragma_table_list\", []).as(\"tl\"))\n      .leftJoin(\"sqlite_schema as ss\", (jb) => jb.onRef(\"ss.type\", \"=\", \"tl.type\").onRef(\"ss.name\", \"=\", \"tl.name\"))\n      .where(\"tl.type\", \"in\", [\"table\", \"view\"])\n      // exclude temporary tables/views\n      .where(\"tl.schema\", \"=\", \"main\")\n      // exclude system tables/views\n      .where(\"tl.name\", \"not like\", \"sqlite_%\")\n      .select([\"tl.name\", \"ss.sql\"])\n      // since we're excluding system tables, `ss.sql` should never be null here.\n      .$narrowType<{ sql: NotNull }>()\n      .select((eb) => [\n        jsonArrayFrom(\n          eb\n            .selectFrom(eb.fn<PragmaTableXInfo>(\"pragma_table_xinfo\", [\"tl.name\"]).as(\"txi\"))\n            .leftJoin(\n              eb.fn<PragmaForeignKeyList>(\"pragma_foreign_key_list\", [\"tl.name\"]).as(\"fkl\"),\n              \"fkl.from\",\n              \"txi.name\",\n            )\n            // exclude hidden columns\n            .where(\"txi.hidden\", \"!=\", 1)\n            .select([\n              \"txi.dflt_value as default\",\n              \"txi.name\",\n              \"txi.pk\",\n              \"txi.type as datatype\",\n              \"fkl.table as fk_table\",\n              \"fkl.to as fk_column\",\n            ])\n            .select((eb) => [eb(\"txi.hidden\", \"in\", [2, 3]).as(\"computed\"), eb(\"txi.notnull\", \"!=\", 0).as(\"nullable\")]),\n        ).as(\"columns\"),\n      ]),\n    { transformations: { columns: \"json-parse\" } },\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      name: \"animals\",\n      sql: \"CREATE TABLE animals (id INTEGER PRIMARY KEY, name TEXT);\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"INTEGER\",\n          default: null,\n          pk: 1,\n          computed: 0,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"TEXT\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n    {\n      name: \"users\",\n      sql: \"CREATE TABLE users (id UUID PRIMARY KEY, created_at TIMESTAMP, deleted_at TIMESTAMP, role varchar, name varchar, name_role text);\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"UUID\",\n          default: null,\n          pk: 1,\n          computed: 0,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"TIMESTAMP\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"deleted_at\",\n          datatype: \"TIMESTAMP\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"role\",\n          datatype: \"varchar\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"varchar\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name_role\",\n          datatype: \"text\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n    {\n      name: \"composite_pk\",\n      sql: \"CREATE TABLE composite_pk (id UUID, name TEXT, created_at timestamp, PRIMARY KEY (id, name));\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"UUID\",\n          default: null,\n          pk: 1,\n          computed: 0,\n          nullable: 0,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"TEXT\",\n          default: null,\n          pk: 2,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"timestamp\",\n          default: null,\n          pk: 0,\n          computed: 0,\n          nullable: 1,\n          fk_table: null,\n          fk_column: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n", "/// <reference types=\"./sqlite.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A SQLite helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/sqlite'\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 (SQLite):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_group_array(json_object(\n *     'pet_id', \"agg\".\"pet_id\",\n *     'name', \"agg\".\"name\"\n *   )), '[]') 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 coalesce(json_group_array(json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') from ${expr} as agg)`;\n}\n/**\n * A SQLite helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/sqlite'\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 (SQLite):\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(getSqliteJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The SQLite `json_object` function.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/sqlite'\n *\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: sql<string>`first_name ||\u00A0' ' || 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 (SQLite):\n *\n * ```sql\n * select \"id\", json_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', \"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 getSqliteJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('SQLite 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": ";;;;;;;;iOAAAA,ICAAC,ICAAC,IAIO,IAAMC,EAA0F,CACrG,KAAM,CACJ,MAAO,KACT,EACA,QAAS,CACP,MAAO,SACT,EACA,KAAM,CACJ,MAAO,KACT,EACA,QAAS,CACP,MAAO,SACT,EACA,KAAM,CACJ,MAAO,SACT,EACA,KAAM,CACJ,MAAO,QACT,CACF,EAOO,SAASC,EAAwBC,EAAiD,CACvF,GAAI,CAACA,EACH,MAAO,OAGT,IAAMC,EAAYD,EAAiB,YAAY,EAE/C,OAAIC,EAAU,SAAS,KAAK,EACnB,UAGLA,EAAU,SAAS,MAAM,GAAKA,EAAU,SAAS,MAAM,GAAKA,EAAU,SAAS,MAAM,EAChF,OAGLA,EAAU,SAAS,MAAM,EACpB,OAGLA,EAAU,SAAS,MAAM,GAAKA,EAAU,SAAS,MAAM,GAAKA,EAAU,SAAS,MAAM,EAChF,OAGF,SACT,CCtDAC,ICAAC,IAKO,SAASC,EACdC,EACkB,CAClB,OAAOC,EAAqB,CAC1B,GAAGD,EACH,QAASE,EACT,cAAeC,CACjB,CAAC,CACH,CDDO,SAASC,EACdC,EACAC,EACA,CACA,GAAM,CACJ,OAAAC,EAAS,CAAE,MAAO,MAAO,QAAS,CAAC,EAAG,KAAM,aAAc,EAC1D,UAAAC,EACA,SAAAC,EACA,UAAAC,EACA,MAAO,CAAE,QAAAC,EAAS,KAAMC,CAAU,CACpC,EAAIP,EAEEQ,EAAUC,EAA0DR,CAAY,EAEhFS,EAAmBC,EAA0BT,EAAO,QAASI,CAAO,EAEpEM,EAAW,aACXC,EAAY,eAEZC,EAAaN,EAChB,WAAWD,CAAS,EACpB,MAAMG,CAAgB,EACtB,OAAQK,GAAOA,EAAG,KAAmBA,EAAG,GAAG,SAASA,EAAG,GAAG,SAAS,EAAGC,EAAI,IAAI,CAAC,CAAC,EAAG,MAAM,EAAE,GAAGH,CAAS,CAAC,EAE3G,OAAOI,EACLT,EACG,KAAKI,EAAU,IAAME,CAAU,EAC/B,WAAWP,CAAS,EACpB,UAAUK,EAAWM,GAAOA,EAAG,OAAO,CAAC,EAEvC,MAAMR,CAAgB,EACtB,OACC,GAAGE,CAAQ,IAAIC,CAAS,EAI1B,EACC,OAAO,OAAO,KAAKP,CAAO,CAAC,EAC3B,MAAOa,GAAOd,EAAU,OAAO,CAACc,EAAIC,IAASD,EAAG,QAAQC,EAAK,OAAQA,EAAK,SAAS,EAAGD,CAAE,CAAC,EACzF,MAAMf,CAAQ,EAEd,OAAOY,EAAI,IAAI,OAAOb,CAAS,EAAI,OAAOC,CAAQ,CAAC,CAAC,CACzD,CACF,CAKO,SAASiB,IAAkB,CAChC,MAAO,CACL,CACE,WAAY,IAAI,KAAK,0BAA0B,EAC/C,WAAY,KACZ,GAAI,EACJ,KAAM,WACN,aAAc,IACd,KAAM,QACN,UAAW,kBACb,EACA,CACE,WAAY,IAAI,KAAK,0BAA0B,EAC/C,WAAY,KACZ,GAAI,EACJ,KAAM,WACN,aAAc,IACd,KAAM,YACN,UAAW,sBACb,CACF,CAIF,CAKO,SAASC,EACdtB,EACAC,EACA,CACA,GAAM,CACJ,KAAAsB,EACA,MAAO,CAAE,QAAAjB,EAAS,KAAMC,CAAU,CACpC,EAAIP,EAEEQ,EAAUC,EAA0DR,CAAY,EAEtF,OAAOgB,EACLT,EACG,WAAWD,CAAS,EACpB,MAAMiB,EAAwBD,EAAMjB,CAAO,CAAC,EAC5C,UAAU,OAAO,KAAKA,CAAO,CAAC,EAC9B,UAAUmB,EAA0B,EAAE,GAAG,mBAAmB,CAAC,CAClE,CACF,CAKO,SAASC,EACd1B,EACAC,EACA,CACA,GAAM,CACJ,MAAO,CAAE,QAAAK,EAAS,KAAMC,CAAU,EAClC,KAAAgB,CACF,EAAIvB,EAEEQ,EAAUC,EAA0DR,CAAY,EAEtF,OAAOgB,EACLT,EACG,WAAWD,CAAS,EACpB,OAAOgB,EAAK,IAAKI,GAAS,OAAO,KAAKA,CAAG,EAAE,SAAW,EAAI,CAAE,CAAC,OAAO,KAAKrB,CAAO,EAAE,CAAC,CAAE,EAAG,IAAK,EAAIqB,CAAI,CAAC,EACtG,UAAU,OAAO,KAAKrB,CAAO,CAAC,EAC9B,UAAUmB,EAA0B,EAAE,GAAG,oBAAoB,CAAC,CACnE,CACF,CAKO,SAASG,EACd5B,EACAC,EACA,CACA,GAAM,CACJ,QAAA4B,EACA,IAAAF,EACA,MAAO,CAAE,QAAArB,EAAS,KAAMC,CAAU,CACpC,EAAIP,EAEEQ,EAAUC,EAA0DR,CAAY,EAEtF,OAAOgB,EACLT,EACG,YAAYD,CAAS,EACrB,IAAIsB,CAAO,EACX,MAAML,EAAwB,CAACG,CAAG,EAAGrB,CAAO,CAAC,EAC7C,UAAU,OAAO,KAAKA,CAAO,CAAC,EAC9B,UAAUmB,EAA0B,EAAE,GAAG,mBAAmB,CAAC,CAClE,CACF,CAEA,SAASA,GAA4B,CACnC,IAAMV,EAAKe,EAAkB,EAE7B,OAAOf,EAAG,KAAmBA,EAAG,KAAKC,+CAAkD,SAAS,EAAG,MAAM,CAC3G,CEjKAe,ICAAC,IAgEO,SAASC,EAAcC,EAAM,CAChC,OAAOC,kDAAqDA,EAAI,KAAKC,EAAwBF,EAAK,gBAAgB,EAAG,KAAK,CAAC,CAAC,kBAAkBA,CAAI,UACtJ,CA8HA,SAASG,EAAwBC,EAAMC,EAAO,CAC1C,GAAI,CACA,OAAOC,EAAkBF,EAAMC,CAAK,CACxC,MACM,CACF,MAAM,IAAI,MAAM,mLAAmL,CACvM,CACJ,CD1HO,SAASE,EAAeC,EAAuE,CACpG,OAAOC,EACLC,EAA2BF,CAAY,EACpC,WAAWG,EAAkB,EAAE,GAAoB,oBAAqB,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,EACpF,SAAS,sBAAwBC,GAAOA,EAAG,MAAM,UAAW,IAAK,SAAS,EAAE,MAAM,UAAW,IAAK,SAAS,CAAC,EAC5G,MAAM,UAAW,KAAM,CAAC,QAAS,MAAM,CAAC,EAExC,MAAM,YAAa,IAAK,MAAM,EAE9B,MAAM,UAAW,WAAY,UAAU,EACvC,OAAO,CAAC,UAAW,QAAQ,CAAC,EAE5B,YAA8B,EAC9B,OAAQC,GAAO,CACdC,EACED,EACG,WAAWA,EAAG,GAAqB,qBAAsB,CAAC,SAAS,CAAC,EAAE,GAAG,KAAK,CAAC,EAC/E,SACCA,EAAG,GAAyB,0BAA2B,CAAC,SAAS,CAAC,EAAE,GAAG,KAAK,EAC5E,WACA,UACF,EAEC,MAAM,aAAc,KAAM,CAAC,EAC3B,OAAO,CACN,4BACA,WACA,SACA,uBACA,wBACA,qBACF,CAAC,EACA,OAAQA,GAAO,CAACA,EAAG,aAAc,KAAM,CAAC,EAAG,CAAC,CAAC,EAAE,GAAG,UAAU,EAAGA,EAAG,cAAe,KAAM,CAAC,EAAE,GAAG,UAAU,CAAC,CAAC,CAC9G,EAAE,GAAG,SAAS,CAChB,CAAC,EACH,CAAE,gBAAiB,CAAE,QAAS,YAAa,CAAE,CAC/C,CACF,CAKO,SAASE,GAAkB,CAChC,MAAO,CACL,CACE,KAAM,UACN,IAAK,4DACL,QAAS,CACP,CACE,KAAM,KACN,SAAU,UACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,OACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,CACF,CACF,EACA,CACE,KAAM,QACN,IAAK,oIACL,QAAS,CACP,CACE,KAAM,KACN,SAAU,OACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,aACN,SAAU,YACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,aACN,SAAU,YACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,UACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,UACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,YACN,SAAU,OACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,CACF,CACF,EACA,CACE,KAAM,eACN,IAAK,gGACL,QAAS,CACP,CACE,KAAM,KACN,SAAU,OACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KAAM,OACN,SAAU,OACV,QAAS,KACT,GAAI,EACJ,SAAU,EACV,SAAU,EACV,SAAU,KACV,UAAW,IACb,EACA,CACE,KA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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "SQLITE_AFFINITY_TO_METADATA", "determineColumnAffinity", "declaredDataType", "upperType", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getSQLiteBuilder", "requirements", "getBuilder", "SqliteAdapter", "SqliteQueryCompiler", "getSelectQuery", "details", "requirements", "filter", "pageIndex", "pageSize", "sortOrder", "columns", "tableName", "builder", "getSQLiteBuilder", "filterExpression", "getSelectFilterExpression", "AGG_NAME", "COUNT_REF", "countQuery", "eb", "sql", "compile", "jb", "qb", "item", "mockSelectQuery", "getDeleteQuery", "rows", "applyInferredRowFilters", "getCurrentTimestampMillis", "getInsertQuery", "row", "getUpdateQuery", "changes", "expressionBuilder", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonArrayFrom", "expr", "sql", "getSqliteJsonObjectArgs", "getSqliteJsonObjectArgs", "node", "table", "getJsonObjectArgs", "getTablesQuery", "requirements", "compile", "getSQLiteBuilder", "expressionBuilder", "jb", "eb", "jsonArrayFrom", "mockTablesQuery", "schema", "filterOperators", "createSQLiteAdapter", "requirements", "executor", "otherRequirements", "details", "options", "query", "getDeleteQuery", "error", "createAdapterError", "getInsertQuery", "rows", "tablesQuery", "getTablesQuery", "tablesError", "tables", "createIntrospection", "getSelectQuery", "results", "getUpdateQuery", "row", "WITHOUT_ROWID_REGEX", "args", "schemas", "table", "columns", "tableName", "sql", "columnsRecord", "column", "datatype", "defaultValue", "fk_column", "columnName", "pk", "affinity", "determineColumnAffinity", "isComputed", "nullable", "isRowId", "SQLITE_AFFINITY_TO_METADATA", "mockIntrospect", "mockTablesQuery"]
}

@@ -71,7 +71,7 @@ interface Table {
71
71
  }
72
72
  interface Column {
73
73
  datatype: DataType;
74
- defaultValue: "CURRENT_DATE" | "CURRENT_TIME" | "CURRENT_TIMESTAMP" | "gen_random_uuid()" | "(JSON_ARRAY())" | `nextval(${string})` | `now()` | "(UUID_TO_BIN(UUID()))" | (string & {}) | null;
74
+ defaultValue: "CURRENT_DATE" | "CURRENT_TIME" | "CURRENT_TIMESTAMP" | "datetime('now')" | "gen_random_uuid()" | "json_array()" | `nextval(${string})` | `now()` | "uuid_to_bin(uuid())" | "uuid()" | (string & {}) | null;
75
75
  fkColumn: ColumnName | null;
76
76
  fkSchema: SchemaName | null;
77
77
  fkTable: TableName | null;
@@ -71,7 +71,7 @@ interface Table {
71
71
  }
72
72
  interface Column {
73
73
  datatype: DataType;
74
- defaultValue: "CURRENT_DATE" | "CURRENT_TIME" | "CURRENT_TIMESTAMP" | "gen_random_uuid()" | "(JSON_ARRAY())" | `nextval(${string})` | `now()` | "(UUID_TO_BIN(UUID()))" | (string & {}) | null;
74
+ defaultValue: "CURRENT_DATE" | "CURRENT_TIME" | "CURRENT_TIMESTAMP" | "datetime('now')" | "gen_random_uuid()" | "json_array()" | `nextval(${string})` | `now()` | "uuid_to_bin(uuid())" | "uuid()" | (string & {}) | null;
75
75
  fkColumn: ColumnName | null;
76
76
  fkSchema: SchemaName | null;
77
77
  fkTable: TableName | null;