@prisma/studio-core 0.7.0 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-32BUC7NR.js +10 -0
- package/dist/chunk-3KCOUVOV.js +10 -0
- package/dist/chunk-A6CVKSUD.js +10 -0
- package/dist/chunk-M7E5UEO3.js +10 -0
- package/dist/chunk-O6ZAHVDF.js +10 -0
- package/dist/chunk-SXTJF4PD.js +10 -0
- package/dist/chunk-ZUEQ555M.js +10 -0
- package/dist/data/accelerate/index.d.cts +1 -1
- package/dist/data/accelerate/index.d.ts +1 -1
- package/dist/data/bff/index.cjs +2 -2
- package/dist/data/bff/index.d.cts +15 -3
- package/dist/data/bff/index.d.ts +15 -3
- package/dist/data/bff/index.js +2 -2
- package/dist/data/index.d.cts +1 -1
- package/dist/data/index.d.ts +1 -1
- package/dist/data/index.js +1 -1
- package/dist/data/mysql-core/index.cjs +3 -0
- package/dist/data/mysql-core/index.d.cts +176 -0
- package/dist/data/mysql-core/index.d.ts +176 -0
- package/dist/data/mysql-core/index.js +11 -0
- package/dist/data/mysql2/index.cjs +2 -0
- package/dist/data/mysql2/index.d.cts +7 -0
- package/dist/data/mysql2/index.d.ts +7 -0
- package/dist/data/mysql2/index.js +10 -0
- package/dist/data/node-sqlite/index.cjs +2 -2
- package/dist/data/node-sqlite/index.d.cts +2 -3
- package/dist/data/node-sqlite/index.d.ts +2 -3
- package/dist/data/node-sqlite/index.js +2 -2
- package/dist/data/pglite/index.cjs +2 -2
- package/dist/data/pglite/index.d.cts +1 -1
- package/dist/data/pglite/index.d.ts +1 -1
- package/dist/data/pglite/index.js +2 -2
- package/dist/data/postgres-core/index.cjs +2 -2
- package/dist/data/postgres-core/index.d.cts +37 -37
- package/dist/data/postgres-core/index.d.ts +37 -37
- package/dist/data/postgres-core/index.js +1 -1
- package/dist/data/postgresjs/index.cjs +2 -2
- package/dist/data/postgresjs/index.d.cts +3 -14
- package/dist/data/postgresjs/index.d.ts +3 -14
- package/dist/data/postgresjs/index.js +2 -2
- package/dist/data/ppg/index.d.cts +1 -1
- package/dist/data/ppg/index.d.ts +1 -1
- package/dist/data/sqlite-core/index.cjs +2 -2
- package/dist/data/sqlite-core/index.d.cts +25 -25
- package/dist/data/sqlite-core/index.d.ts +25 -25
- package/dist/data/sqlite-core/index.js +2 -2
- package/dist/{index-2horhMcs.d.cts → index-BhPjNuvP.d.cts} +10 -6
- package/dist/{index-2horhMcs.d.ts → index-BhPjNuvP.d.ts} +10 -6
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/dist/ui/index.cjs +1 -1
- package/dist/ui/index.d.cts +1 -1
- package/dist/ui/index.d.ts +1 -1
- package/dist/ui/index.js +2 -2
- package/package.json +22 -1
- package/dist/chunk-AHIV4VYN.js +0 -10
- package/dist/chunk-CTJRZ7VA.js +0 -10
- package/dist/chunk-NDYVVFWW.js +0 -10
- package/dist/chunk-OTK4ZF2W.js +0 -10
- package/dist/chunk-WHLVNWIR.js +0 -10
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-
|
|
1
|
+
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-BhPjNuvP.cjs';
|
|
2
2
|
import * as kysely from 'kysely';
|
|
3
3
|
|
|
4
4
|
type SQLIteAdapterRequirements = AdapterRequirements;
|
|
@@ -74,8 +74,8 @@ declare function getTablesQuery(requirements?: Omit<BuilderRequirements, "Adapte
|
|
|
74
74
|
columns: {
|
|
75
75
|
name: string;
|
|
76
76
|
datatype: string;
|
|
77
|
-
|
|
78
|
-
|
|
77
|
+
fk_table: string | null;
|
|
78
|
+
fk_column: string | null;
|
|
79
79
|
computed: kysely.SqlBool;
|
|
80
80
|
nullable: kysely.SqlBool;
|
|
81
81
|
pk: kysely.SqlBool;
|
|
@@ -93,16 +93,16 @@ declare function mockTablesQuery(): [{
|
|
|
93
93
|
readonly pk: 1;
|
|
94
94
|
readonly computed: 0;
|
|
95
95
|
readonly nullable: 0;
|
|
96
|
-
readonly
|
|
97
|
-
readonly
|
|
96
|
+
readonly fk_table: null;
|
|
97
|
+
readonly fk_column: null;
|
|
98
98
|
}, {
|
|
99
99
|
readonly name: "name";
|
|
100
100
|
readonly datatype: "TEXT";
|
|
101
101
|
readonly pk: 0;
|
|
102
102
|
readonly computed: 0;
|
|
103
103
|
readonly nullable: 1;
|
|
104
|
-
readonly
|
|
105
|
-
readonly
|
|
104
|
+
readonly fk_table: null;
|
|
105
|
+
readonly fk_column: null;
|
|
106
106
|
}];
|
|
107
107
|
}, {
|
|
108
108
|
readonly name: "users";
|
|
@@ -113,48 +113,48 @@ declare function mockTablesQuery(): [{
|
|
|
113
113
|
readonly pk: 1;
|
|
114
114
|
readonly computed: 0;
|
|
115
115
|
readonly nullable: 0;
|
|
116
|
-
readonly
|
|
117
|
-
readonly
|
|
116
|
+
readonly fk_table: null;
|
|
117
|
+
readonly fk_column: null;
|
|
118
118
|
}, {
|
|
119
119
|
readonly name: "created_at";
|
|
120
120
|
readonly datatype: "TIMESTAMP";
|
|
121
121
|
readonly pk: 0;
|
|
122
122
|
readonly computed: 0;
|
|
123
123
|
readonly nullable: 1;
|
|
124
|
-
readonly
|
|
125
|
-
readonly
|
|
124
|
+
readonly fk_table: null;
|
|
125
|
+
readonly fk_column: null;
|
|
126
126
|
}, {
|
|
127
127
|
readonly name: "deleted_at";
|
|
128
128
|
readonly datatype: "TIMESTAMP";
|
|
129
129
|
readonly pk: 0;
|
|
130
130
|
readonly computed: 0;
|
|
131
131
|
readonly nullable: 1;
|
|
132
|
-
readonly
|
|
133
|
-
readonly
|
|
132
|
+
readonly fk_table: null;
|
|
133
|
+
readonly fk_column: null;
|
|
134
134
|
}, {
|
|
135
135
|
readonly name: "role";
|
|
136
136
|
readonly datatype: "varchar";
|
|
137
137
|
readonly pk: 0;
|
|
138
138
|
readonly computed: 0;
|
|
139
139
|
readonly nullable: 1;
|
|
140
|
-
readonly
|
|
141
|
-
readonly
|
|
140
|
+
readonly fk_table: null;
|
|
141
|
+
readonly fk_column: null;
|
|
142
142
|
}, {
|
|
143
143
|
readonly name: "name";
|
|
144
144
|
readonly datatype: "varchar";
|
|
145
145
|
readonly pk: 0;
|
|
146
146
|
readonly computed: 0;
|
|
147
147
|
readonly nullable: 1;
|
|
148
|
-
readonly
|
|
149
|
-
readonly
|
|
148
|
+
readonly fk_table: null;
|
|
149
|
+
readonly fk_column: null;
|
|
150
150
|
}, {
|
|
151
151
|
readonly name: "name_role";
|
|
152
152
|
readonly datatype: "text";
|
|
153
153
|
readonly pk: 0;
|
|
154
154
|
readonly computed: 0;
|
|
155
155
|
readonly nullable: 1;
|
|
156
|
-
readonly
|
|
157
|
-
readonly
|
|
156
|
+
readonly fk_table: null;
|
|
157
|
+
readonly fk_column: null;
|
|
158
158
|
}];
|
|
159
159
|
}, {
|
|
160
160
|
readonly name: "composite_pk";
|
|
@@ -165,24 +165,24 @@ declare function mockTablesQuery(): [{
|
|
|
165
165
|
readonly pk: 1;
|
|
166
166
|
readonly computed: 0;
|
|
167
167
|
readonly nullable: 0;
|
|
168
|
-
readonly
|
|
169
|
-
readonly
|
|
168
|
+
readonly fk_table: null;
|
|
169
|
+
readonly fk_column: null;
|
|
170
170
|
}, {
|
|
171
171
|
readonly name: "name";
|
|
172
172
|
readonly datatype: "TEXT";
|
|
173
173
|
readonly pk: 1;
|
|
174
174
|
readonly computed: 0;
|
|
175
175
|
readonly nullable: 1;
|
|
176
|
-
readonly
|
|
177
|
-
readonly
|
|
176
|
+
readonly fk_table: null;
|
|
177
|
+
readonly fk_column: null;
|
|
178
178
|
}, {
|
|
179
179
|
readonly name: "created_at";
|
|
180
180
|
readonly datatype: "timestamp";
|
|
181
181
|
readonly pk: 0;
|
|
182
182
|
readonly computed: 0;
|
|
183
183
|
readonly nullable: 1;
|
|
184
|
-
readonly
|
|
185
|
-
readonly
|
|
184
|
+
readonly fk_table: null;
|
|
185
|
+
readonly fk_column: null;
|
|
186
186
|
}];
|
|
187
187
|
}];
|
|
188
188
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-
|
|
1
|
+
import { d as AdapterRequirements, A as Adapter, T as Table, F as FilterOperator, Q as Query, e as AdapterQueryDetails, B as BuilderRequirements, f as AdapterDeleteDetails, g as AdapterInsertDetails, h as AdapterUpdateDetails } from '../../index-BhPjNuvP.js';
|
|
2
2
|
import * as kysely from 'kysely';
|
|
3
3
|
|
|
4
4
|
type SQLIteAdapterRequirements = AdapterRequirements;
|
|
@@ -74,8 +74,8 @@ declare function getTablesQuery(requirements?: Omit<BuilderRequirements, "Adapte
|
|
|
74
74
|
columns: {
|
|
75
75
|
name: string;
|
|
76
76
|
datatype: string;
|
|
77
|
-
|
|
78
|
-
|
|
77
|
+
fk_table: string | null;
|
|
78
|
+
fk_column: string | null;
|
|
79
79
|
computed: kysely.SqlBool;
|
|
80
80
|
nullable: kysely.SqlBool;
|
|
81
81
|
pk: kysely.SqlBool;
|
|
@@ -93,16 +93,16 @@ declare function mockTablesQuery(): [{
|
|
|
93
93
|
readonly pk: 1;
|
|
94
94
|
readonly computed: 0;
|
|
95
95
|
readonly nullable: 0;
|
|
96
|
-
readonly
|
|
97
|
-
readonly
|
|
96
|
+
readonly fk_table: null;
|
|
97
|
+
readonly fk_column: null;
|
|
98
98
|
}, {
|
|
99
99
|
readonly name: "name";
|
|
100
100
|
readonly datatype: "TEXT";
|
|
101
101
|
readonly pk: 0;
|
|
102
102
|
readonly computed: 0;
|
|
103
103
|
readonly nullable: 1;
|
|
104
|
-
readonly
|
|
105
|
-
readonly
|
|
104
|
+
readonly fk_table: null;
|
|
105
|
+
readonly fk_column: null;
|
|
106
106
|
}];
|
|
107
107
|
}, {
|
|
108
108
|
readonly name: "users";
|
|
@@ -113,48 +113,48 @@ declare function mockTablesQuery(): [{
|
|
|
113
113
|
readonly pk: 1;
|
|
114
114
|
readonly computed: 0;
|
|
115
115
|
readonly nullable: 0;
|
|
116
|
-
readonly
|
|
117
|
-
readonly
|
|
116
|
+
readonly fk_table: null;
|
|
117
|
+
readonly fk_column: null;
|
|
118
118
|
}, {
|
|
119
119
|
readonly name: "created_at";
|
|
120
120
|
readonly datatype: "TIMESTAMP";
|
|
121
121
|
readonly pk: 0;
|
|
122
122
|
readonly computed: 0;
|
|
123
123
|
readonly nullable: 1;
|
|
124
|
-
readonly
|
|
125
|
-
readonly
|
|
124
|
+
readonly fk_table: null;
|
|
125
|
+
readonly fk_column: null;
|
|
126
126
|
}, {
|
|
127
127
|
readonly name: "deleted_at";
|
|
128
128
|
readonly datatype: "TIMESTAMP";
|
|
129
129
|
readonly pk: 0;
|
|
130
130
|
readonly computed: 0;
|
|
131
131
|
readonly nullable: 1;
|
|
132
|
-
readonly
|
|
133
|
-
readonly
|
|
132
|
+
readonly fk_table: null;
|
|
133
|
+
readonly fk_column: null;
|
|
134
134
|
}, {
|
|
135
135
|
readonly name: "role";
|
|
136
136
|
readonly datatype: "varchar";
|
|
137
137
|
readonly pk: 0;
|
|
138
138
|
readonly computed: 0;
|
|
139
139
|
readonly nullable: 1;
|
|
140
|
-
readonly
|
|
141
|
-
readonly
|
|
140
|
+
readonly fk_table: null;
|
|
141
|
+
readonly fk_column: null;
|
|
142
142
|
}, {
|
|
143
143
|
readonly name: "name";
|
|
144
144
|
readonly datatype: "varchar";
|
|
145
145
|
readonly pk: 0;
|
|
146
146
|
readonly computed: 0;
|
|
147
147
|
readonly nullable: 1;
|
|
148
|
-
readonly
|
|
149
|
-
readonly
|
|
148
|
+
readonly fk_table: null;
|
|
149
|
+
readonly fk_column: null;
|
|
150
150
|
}, {
|
|
151
151
|
readonly name: "name_role";
|
|
152
152
|
readonly datatype: "text";
|
|
153
153
|
readonly pk: 0;
|
|
154
154
|
readonly computed: 0;
|
|
155
155
|
readonly nullable: 1;
|
|
156
|
-
readonly
|
|
157
|
-
readonly
|
|
156
|
+
readonly fk_table: null;
|
|
157
|
+
readonly fk_column: null;
|
|
158
158
|
}];
|
|
159
159
|
}, {
|
|
160
160
|
readonly name: "composite_pk";
|
|
@@ -165,24 +165,24 @@ declare function mockTablesQuery(): [{
|
|
|
165
165
|
readonly pk: 1;
|
|
166
166
|
readonly computed: 0;
|
|
167
167
|
readonly nullable: 0;
|
|
168
|
-
readonly
|
|
169
|
-
readonly
|
|
168
|
+
readonly fk_table: null;
|
|
169
|
+
readonly fk_column: null;
|
|
170
170
|
}, {
|
|
171
171
|
readonly name: "name";
|
|
172
172
|
readonly datatype: "TEXT";
|
|
173
173
|
readonly pk: 1;
|
|
174
174
|
readonly computed: 0;
|
|
175
175
|
readonly nullable: 1;
|
|
176
|
-
readonly
|
|
177
|
-
readonly
|
|
176
|
+
readonly fk_table: null;
|
|
177
|
+
readonly fk_column: null;
|
|
178
178
|
}, {
|
|
179
179
|
readonly name: "created_at";
|
|
180
180
|
readonly datatype: "timestamp";
|
|
181
181
|
readonly pk: 0;
|
|
182
182
|
readonly computed: 0;
|
|
183
183
|
readonly nullable: 1;
|
|
184
|
-
readonly
|
|
185
|
-
readonly
|
|
184
|
+
readonly fk_table: null;
|
|
185
|
+
readonly fk_column: null;
|
|
186
186
|
}];
|
|
187
187
|
}];
|
|
188
188
|
|
|
@@ -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
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
|
|
9
|
+
import{a as q}from"../../chunk-32BUC7NR.js";import{a as u}from"../../chunk-O6ZAHVDF.js";import{h as k,i as p,j as Q,k as h,p as x,r as f,s as T,v as w}from"../../chunk-A6CVKSUD.js";import{e as s}from"../../chunk-GDQBQ7MK.js";s();s();s();var B={BLOB:{group:"raw"},INTEGER:{group:"numeric"},NULL:{group:"raw"},NUMERIC:{group:"numeric"},REAL:{group:"numeric"},TEXT:{group:"string"}};function O(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 x({...r,Adapter:h,QueryCompiler:Q})}function L(r,t){let{filter:l={after:"and",filters:[],kind:"FilterGroup"},pageIndex:o,pageSize:n,sortOrder:e,table:{columns:a,name:i}}=r,c=y(t),b=w(l.filters,a),d=c.selectFrom(i).where(b).select(m=>m.cast(m.fn.coalesce(m.fn.countAll(),p.lit(0)),"text").as("value"));return f(c.with("count",()=>d).selectFrom([i,"count"]).where(b).select(p.ref("count.value").as("__ps_count__")).select(Object.keys(a)).$call(m=>e.reduce((A,g)=>A.orderBy(g.column,g.direction),m)).limit(n).offset(p.lit(BigInt(o)*BigInt(n))))}function H(){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 j(r,t){let{rows:l,table:{columns:o,name:n}}=r,e=y(t);return f(e.deleteFrom(n).$call(T(l,o)).returning(Object.keys(o)).returning(E().as("__ps_deleted_at__")))}function D(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(E().as("__ps_inserted_at__")))}function S(r,t){let{changes:l,row:o,table:{columns:n,name:e}}=r,a=y(t);return f(a.updateTable(e).set(l).$call(T([o],n)).returning(Object.keys(n)).returning(E().as("__ps_updated_at__")))}function E(){let r=k();return r.cast(r.cast(p`(julianday('now') - 2440587.5) * 86400000.0`,"integer"),"text")}s();s();function C(r){return p`(select coalesce(json_group_array(json_object(${p.join(P(r.toOperationNode(),"agg"))})), '[]') from ${r} as agg)`}function P(r,t){try{return q(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 F(r){return f(y(r).selectFrom(k().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=>[C(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.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"),l("txi.pk","!=",0).as("pk")])).as("columns")]),{transformations:{columns:"json-parse"}})}function U(){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:1,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 R="main",M=["=","!=",">",">=","<","<=","is","is not","like","not like"];function fe(r){let{executor:t,...l}=r;return{defaultSchema:R,async delete(o,n){try{let e=j(o,l),[a]=await t.execute(e,n);return a?u({error:a,query:e}):[null,{...o,query:e}]}catch(e){return u({error:e})}},async insert(o,n){try{let e=D(o,l),[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(o){try{let n=F(r),[e,a]=await t.execute(n,o);return e?u({error:e,query:n}):[null,N({query:n,tables:a})]}catch(n){return u({error:n})}},async query(o,n){try{let e=L(o,l),[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(o,n){try{let e=S(o,l),[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})}}}}function N(r){let{tables:t,query:l}=r;return{filterOperators:M,query:l,schemas:t.reduce((o,n)=>{let{columns:e,name:a,sql:i}=n,c=e.reduce((b,d)=>{let{datatype:m,fk_column:A,name:g}=d,I=O(m);return b[g]={datatype:{...B[I],affinity:I,isArray:!1,isNative:!0,name:m,options:[],schema:R},fkColumn:A,fkSchema:A?R:null,fkTable:d.fk_table,isAutoincrement:!1,isComputed:!!d.computed,isInPrimaryKey:!!d.pk,name:g,nullable:!!d.nullable,schema:R,table:a},b},{});return o.main.tables[a]={columns:c,name:a,schema:"main"},o},{main:{tables:{},name:"main"}}),timezone:"UTC"}}function ye(){let r={parameters:[],sql:"<mocked>"},t=U();return N({query:r,tables:t})}export{fe as createSQLiteAdapter,j as getDeleteQuery,D as getInsertQuery,L as getSelectQuery,F as getTablesQuery,S as getUpdateQuery,ye as mockIntrospect,H as mockSelectQuery,U 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 } = column;\n\n            const affinity = determineColumnAffinity(datatype);\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              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: Boolean(column.computed),\n              isInPrimaryKey: Boolean(column.pk),\n              name: columnName,\n              nullable: Boolean(column.nullable),\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, \"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, type ReferenceExpression, sql } 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 countQuery = builder\n    .selectFrom(tableName)\n    .where(filterExpression)\n    .select((eb) => eb.cast<BigIntString>(eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)), \"text\").as(\"value\"));\n\n  return compile(\n    builder\n      .with(\"count\", () => countQuery)\n      .selectFrom([tableName, \"count\"])\n      // TODO: cursor pagination?\n      .where(filterExpression)\n      .select(\n        sql\n          .ref<BigIntString>(\n            \"count.value\" satisfies ReferenceExpression<{ count: InferResult<typeof countQuery>[number] }, \"count\">,\n          )\n          .as(\"__ps_count__\"),\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.type as datatype\", \"fkl.table as fk_table\", \"fkl.to as fk_column\"])\n            .select((eb) => [\n              eb(\"txi.hidden\", \"in\", [2, 3]).as(\"computed\"),\n              eb(\"txi.notnull\", \"!=\", 0).as(\"nullable\"),\n              eb(\"txi.pk\", \"!=\", 0).as(\"pk\"),\n            ]),\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: 1,\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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AC,EAAE,GAAG,IAAI,CAC/B,CAAC,CACL,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,CJrNA,IAAMC,EAAS,OAETC,EAAkB,CACtB,I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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", "countQuery", "eb", "sql", "compile", "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", "affinity", "determineColumnAffinity", "SQLITE_AFFINITY_TO_METADATA", "mockIntrospect", "mockTablesQuery"]
}

|
|
@@ -71,15 +71,16 @@ interface Table {
|
|
|
71
71
|
}
|
|
72
72
|
interface Column {
|
|
73
73
|
datatype: DataType;
|
|
74
|
+
fkColumn: ColumnName | null;
|
|
75
|
+
fkSchema: SchemaName | null;
|
|
76
|
+
fkTable: TableName | null;
|
|
77
|
+
isAutoincrement: boolean;
|
|
74
78
|
isComputed: boolean;
|
|
75
79
|
isInPrimaryKey: boolean;
|
|
76
80
|
name: ColumnName;
|
|
77
81
|
nullable: boolean;
|
|
78
82
|
schema: SchemaName;
|
|
79
83
|
table: TableName;
|
|
80
|
-
fkSchema: SchemaName | null;
|
|
81
|
-
fkColumn: ColumnName | null;
|
|
82
|
-
fkTable: TableName | null;
|
|
83
84
|
}
|
|
84
85
|
interface DataType {
|
|
85
86
|
/**
|
|
@@ -207,7 +208,7 @@ interface AdapterInsertResult {
|
|
|
207
208
|
/**
|
|
208
209
|
* The executed query string.
|
|
209
210
|
*/
|
|
210
|
-
query: Query
|
|
211
|
+
query: Query<unknown>;
|
|
211
212
|
}
|
|
212
213
|
interface AdapterUpdateDetails {
|
|
213
214
|
/**
|
|
@@ -236,7 +237,7 @@ interface AdapterUpdateResult {
|
|
|
236
237
|
/**
|
|
237
238
|
* The executed query string.
|
|
238
239
|
*/
|
|
239
|
-
query: Query
|
|
240
|
+
query: Query<unknown>;
|
|
240
241
|
}
|
|
241
242
|
interface AdapterDeleteDetails {
|
|
242
243
|
/**
|
|
@@ -287,6 +288,9 @@ declare function applyInferredRowFilters(rows: Record<string, unknown>[], column
|
|
|
287
288
|
interface Executor {
|
|
288
289
|
execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;
|
|
289
290
|
}
|
|
291
|
+
interface SequenceExecutor extends Executor {
|
|
292
|
+
executeSequence<T, S>(sequence: readonly [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
|
|
293
|
+
}
|
|
290
294
|
interface ExecuteOptions {
|
|
291
295
|
abortSignal?: AbortSignal;
|
|
292
296
|
}
|
|
@@ -295,4 +299,4 @@ declare class AbortError extends Error {
|
|
|
295
299
|
}
|
|
296
300
|
declare function getAbortResult(): [AbortError];
|
|
297
301
|
|
|
298
|
-
export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type
|
|
302
|
+
export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type ExecuteOptions as E, type FilterOperator as F, type AdapterDeleteResult as G, createAdapterError as H, AbortError as I, getAbortResult as J, type BigIntString as K, type NumericString as N, type Query as Q, type SequenceExecutor as S, type Table as T, type Either as a, type QueryResult as b, type Executor as c, type AdapterRequirements as d, type AdapterQueryDetails as e, type AdapterDeleteDetails as f, type AdapterInsertDetails as g, type AdapterUpdateDetails as h, AdapterError as i, applyInferredRowFilters as j, type AdapterBaseOptions as k, type AdapterIntrospectOptions as l, type AdapterQueryOptions as m, type AdapterInsertOptions as n, type AdapterUpdateOptions as o, type AdapterDeleteOptions as p, type AdapterIntrospectResult as q, type Schema as r, type DataTypeGroup as s, type ColumnFilter as t, type FilterGroup as u, type SortOrderItem as v, type SortDirection as w, type AdapterQueryResult as x, type AdapterInsertResult as y, type AdapterUpdateResult as z };
|
|
@@ -71,15 +71,16 @@ interface Table {
|
|
|
71
71
|
}
|
|
72
72
|
interface Column {
|
|
73
73
|
datatype: DataType;
|
|
74
|
+
fkColumn: ColumnName | null;
|
|
75
|
+
fkSchema: SchemaName | null;
|
|
76
|
+
fkTable: TableName | null;
|
|
77
|
+
isAutoincrement: boolean;
|
|
74
78
|
isComputed: boolean;
|
|
75
79
|
isInPrimaryKey: boolean;
|
|
76
80
|
name: ColumnName;
|
|
77
81
|
nullable: boolean;
|
|
78
82
|
schema: SchemaName;
|
|
79
83
|
table: TableName;
|
|
80
|
-
fkSchema: SchemaName | null;
|
|
81
|
-
fkColumn: ColumnName | null;
|
|
82
|
-
fkTable: TableName | null;
|
|
83
84
|
}
|
|
84
85
|
interface DataType {
|
|
85
86
|
/**
|
|
@@ -207,7 +208,7 @@ interface AdapterInsertResult {
|
|
|
207
208
|
/**
|
|
208
209
|
* The executed query string.
|
|
209
210
|
*/
|
|
210
|
-
query: Query
|
|
211
|
+
query: Query<unknown>;
|
|
211
212
|
}
|
|
212
213
|
interface AdapterUpdateDetails {
|
|
213
214
|
/**
|
|
@@ -236,7 +237,7 @@ interface AdapterUpdateResult {
|
|
|
236
237
|
/**
|
|
237
238
|
* The executed query string.
|
|
238
239
|
*/
|
|
239
|
-
query: Query
|
|
240
|
+
query: Query<unknown>;
|
|
240
241
|
}
|
|
241
242
|
interface AdapterDeleteDetails {
|
|
242
243
|
/**
|
|
@@ -287,6 +288,9 @@ declare function applyInferredRowFilters(rows: Record<string, unknown>[], column
|
|
|
287
288
|
interface Executor {
|
|
288
289
|
execute<T>(query: Query<T>, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Query<T>>>>;
|
|
289
290
|
}
|
|
291
|
+
interface SequenceExecutor extends Executor {
|
|
292
|
+
executeSequence<T, S>(sequence: readonly [Query<T>, Query<S>], options?: ExecuteOptions): Promise<[[Error]] | [[null, QueryResult<Query<T>>], Either<Error, QueryResult<Query<S>>>]>;
|
|
293
|
+
}
|
|
290
294
|
interface ExecuteOptions {
|
|
291
295
|
abortSignal?: AbortSignal;
|
|
292
296
|
}
|
|
@@ -295,4 +299,4 @@ declare class AbortError extends Error {
|
|
|
295
299
|
}
|
|
296
300
|
declare function getAbortResult(): [AbortError];
|
|
297
301
|
|
|
298
|
-
export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type
|
|
302
|
+
export { type Adapter as A, type BuilderRequirements as B, type Column as C, type DataType as D, type ExecuteOptions as E, type FilterOperator as F, type AdapterDeleteResult as G, createAdapterError as H, AbortError as I, getAbortResult as J, type BigIntString as K, type NumericString as N, type Query as Q, type SequenceExecutor as S, type Table as T, type Either as a, type QueryResult as b, type Executor as c, type AdapterRequirements as d, type AdapterQueryDetails as e, type AdapterDeleteDetails as f, type AdapterInsertDetails as g, type AdapterUpdateDetails as h, AdapterError as i, applyInferredRowFilters as j, type AdapterBaseOptions as k, type AdapterIntrospectOptions as l, type AdapterQueryOptions as m, type AdapterInsertOptions as n, type AdapterUpdateOptions as o, type AdapterDeleteOptions as p, type AdapterIntrospectResult as q, type Schema as r, type DataTypeGroup as s, type ColumnFilter as t, type FilterGroup as u, type SortOrderItem as v, type SortDirection as w, type AdapterQueryResult as x, type AdapterInsertResult as y, type AdapterUpdateResult as z };
|