drizzle-graphql-plus 0.8.7 → 0.8.9
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/.github/workflows/release.yaml +74 -0
- package/LICENSE +201 -0
- package/dprint.json +31 -0
- package/drizzle.test-config.ts +29 -0
- package/package.json +17 -18
- package/scripts/build.ts +28 -0
- package/src/index.ts +74 -0
- package/src/types.ts +535 -0
- package/src/util/builders/common.ts +842 -0
- package/src/util/builders/index.ts +5 -0
- package/src/util/builders/mysql.ts +567 -0
- package/src/util/builders/pg.ts +616 -0
- package/src/util/builders/sqlite.ts +622 -0
- package/src/util/builders/types.ts +317 -0
- package/src/util/case-ops/index.ts +9 -0
- package/src/util/data-mappers/index.ts +162 -0
- package/src/util/type-converter/index.ts +148 -0
- package/src/util/type-converter/types.ts +54 -0
- package/tests/mysql-custom.test.ts +2009 -0
- package/tests/mysql.test.ts +4600 -0
- package/tests/pg-custom.test.ts +2054 -0
- package/tests/pg.test.ts +4285 -0
- package/tests/schema/mysql.ts +72 -0
- package/tests/schema/pg.ts +83 -0
- package/tests/schema/sqlite.ts +64 -0
- package/tests/sqlite-custom.test.ts +1956 -0
- package/tests/sqlite.test.ts +3749 -0
- package/tests/tsconfig.json +11 -0
- package/tests/util/query/index.ts +30 -0
- package/tsconfig.build.json +4 -0
- package/tsconfig.dts.json +13 -0
- package/tsconfig.json +48 -0
- package/vitest.config.ts +17 -0
- package/index.cjs +0 -1974
- package/index.cjs.map +0 -1
- package/index.d.cts +0 -247
- package/index.d.ts +0 -247
- package/index.js +0 -2012
- package/index.js.map +0 -1
package/index.cjs
DELETED
|
@@ -1,1974 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc2) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc2 = __getOwnPropDesc(from, key)) || desc2.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
buildSchema: () => buildSchema
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
var import_drizzle_orm7 = require("drizzle-orm");
|
|
27
|
-
var import_mysql_core3 = require("drizzle-orm/mysql-core");
|
|
28
|
-
var import_pg_core3 = require("drizzle-orm/pg-core");
|
|
29
|
-
var import_sqlite_core3 = require("drizzle-orm/sqlite-core");
|
|
30
|
-
var import_graphql7 = require("graphql");
|
|
31
|
-
|
|
32
|
-
// src/util/builders/mysql.ts
|
|
33
|
-
var import_drizzle_orm4 = require("drizzle-orm");
|
|
34
|
-
var import_mysql_core2 = require("drizzle-orm/mysql-core");
|
|
35
|
-
var import_graphql4 = require("graphql");
|
|
36
|
-
|
|
37
|
-
// src/util/builders/common.ts
|
|
38
|
-
var import_drizzle_orm3 = require("drizzle-orm");
|
|
39
|
-
var import_graphql3 = require("graphql");
|
|
40
|
-
|
|
41
|
-
// src/util/case-ops/index.ts
|
|
42
|
-
var uncapitalize = (input) => input.length ? `${input[0].toLocaleLowerCase()}${input.length > 1 ? input.slice(1, input.length) : ""}` : input;
|
|
43
|
-
var capitalize = (input) => input.length ? `${input[0].toLocaleUpperCase()}${input.length > 1 ? input.slice(1, input.length) : ""}` : input;
|
|
44
|
-
|
|
45
|
-
// src/util/data-mappers/index.ts
|
|
46
|
-
var import_drizzle_orm = require("drizzle-orm");
|
|
47
|
-
var import_graphql = require("graphql");
|
|
48
|
-
var remapToGraphQLCore = (key, value, tableName, column, relationMap) => {
|
|
49
|
-
if (value instanceof Date)
|
|
50
|
-
return value.toISOString();
|
|
51
|
-
if (value instanceof Buffer)
|
|
52
|
-
return Array.from(value);
|
|
53
|
-
if (typeof value === "bigint")
|
|
54
|
-
return value.toString();
|
|
55
|
-
if (Array.isArray(value)) {
|
|
56
|
-
const relations = relationMap?.[tableName];
|
|
57
|
-
if (relations?.[key]) {
|
|
58
|
-
return remapToGraphQLArrayOutput(
|
|
59
|
-
value,
|
|
60
|
-
relations[key].targetTableName,
|
|
61
|
-
relations[key].relation.referencedTable,
|
|
62
|
-
relationMap
|
|
63
|
-
);
|
|
64
|
-
}
|
|
65
|
-
if (column.columnType === "PgGeometry" || column.columnType === "PgVector")
|
|
66
|
-
return value;
|
|
67
|
-
return value.map((arrVal) => remapToGraphQLCore(key, arrVal, tableName, column, relationMap));
|
|
68
|
-
}
|
|
69
|
-
if (typeof value === "object") {
|
|
70
|
-
const relations = relationMap?.[tableName];
|
|
71
|
-
if (relations?.[key]) {
|
|
72
|
-
return remapToGraphQLSingleOutput(
|
|
73
|
-
value,
|
|
74
|
-
relations[key].targetTableName,
|
|
75
|
-
relations[key].relation.referencedTable,
|
|
76
|
-
relationMap
|
|
77
|
-
);
|
|
78
|
-
}
|
|
79
|
-
if (column.columnType === "PgGeometryObject")
|
|
80
|
-
return value;
|
|
81
|
-
return JSON.stringify(value);
|
|
82
|
-
}
|
|
83
|
-
return value;
|
|
84
|
-
};
|
|
85
|
-
var remapToGraphQLSingleOutput = (queryOutput, tableName, table, relationMap) => {
|
|
86
|
-
for (const [key, value] of Object.entries(queryOutput)) {
|
|
87
|
-
if (value === void 0 || value === null) {
|
|
88
|
-
delete queryOutput[key];
|
|
89
|
-
} else {
|
|
90
|
-
queryOutput[key] = remapToGraphQLCore(key, value, tableName, table[key], relationMap);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
return queryOutput;
|
|
94
|
-
};
|
|
95
|
-
var remapToGraphQLArrayOutput = (queryOutput, tableName, table, relationMap) => {
|
|
96
|
-
for (const entry of queryOutput) {
|
|
97
|
-
remapToGraphQLSingleOutput(entry, tableName, table, relationMap);
|
|
98
|
-
}
|
|
99
|
-
return queryOutput;
|
|
100
|
-
};
|
|
101
|
-
var remapFromGraphQLCore = (value, column, columnName) => {
|
|
102
|
-
switch (column.dataType) {
|
|
103
|
-
case "date": {
|
|
104
|
-
const formatted = new Date(value);
|
|
105
|
-
if (Number.isNaN(formatted.getTime()))
|
|
106
|
-
throw new import_graphql.GraphQLError(`Field '${columnName}' is not a valid date!`);
|
|
107
|
-
return formatted;
|
|
108
|
-
}
|
|
109
|
-
case "buffer": {
|
|
110
|
-
if (!Array.isArray(value)) {
|
|
111
|
-
throw new import_graphql.GraphQLError(`Field '${columnName}' is not an array!`);
|
|
112
|
-
}
|
|
113
|
-
return Buffer.from(value);
|
|
114
|
-
}
|
|
115
|
-
case "json": {
|
|
116
|
-
if (column.columnType === "PgGeometryObject")
|
|
117
|
-
return value;
|
|
118
|
-
try {
|
|
119
|
-
return JSON.parse(value);
|
|
120
|
-
} catch (e) {
|
|
121
|
-
throw new import_graphql.GraphQLError(
|
|
122
|
-
`Invalid JSON in field '${columnName}':
|
|
123
|
-
${e instanceof Error ? e.message : "Unknown error"}`
|
|
124
|
-
);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
case "array": {
|
|
128
|
-
if (!Array.isArray(value)) {
|
|
129
|
-
throw new import_graphql.GraphQLError(`Field '${columnName}' is not an array!`);
|
|
130
|
-
}
|
|
131
|
-
if (column.columnType === "PgGeometry" && value.length !== 2) {
|
|
132
|
-
throw new import_graphql.GraphQLError(
|
|
133
|
-
`Invalid float tuple in field '${columnName}': expected array with length of 2, received ${value.length}`
|
|
134
|
-
);
|
|
135
|
-
}
|
|
136
|
-
return value;
|
|
137
|
-
}
|
|
138
|
-
case "bigint": {
|
|
139
|
-
try {
|
|
140
|
-
return BigInt(value);
|
|
141
|
-
} catch (error) {
|
|
142
|
-
throw new import_graphql.GraphQLError(`Field '${columnName}' is not a BigInt!`);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
default: {
|
|
146
|
-
return value;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
};
|
|
150
|
-
var remapFromGraphQLSingleInput = (queryInput, table) => {
|
|
151
|
-
for (const [key, value] of Object.entries(queryInput)) {
|
|
152
|
-
if (value === void 0) {
|
|
153
|
-
delete queryInput[key];
|
|
154
|
-
} else {
|
|
155
|
-
const column = (0, import_drizzle_orm.getTableColumns)(table)[key];
|
|
156
|
-
if (!column)
|
|
157
|
-
throw new import_graphql.GraphQLError(`Unknown column: ${key}`);
|
|
158
|
-
if (value === null && column.notNull) {
|
|
159
|
-
delete queryInput[key];
|
|
160
|
-
continue;
|
|
161
|
-
}
|
|
162
|
-
queryInput[key] = remapFromGraphQLCore(value, column, key);
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
return queryInput;
|
|
166
|
-
};
|
|
167
|
-
var remapFromGraphQLArrayInput = (queryInput, table) => {
|
|
168
|
-
for (const entry of queryInput)
|
|
169
|
-
remapFromGraphQLSingleInput(entry, table);
|
|
170
|
-
return queryInput;
|
|
171
|
-
};
|
|
172
|
-
|
|
173
|
-
// src/util/type-converter/index.ts
|
|
174
|
-
var import_drizzle_orm2 = require("drizzle-orm");
|
|
175
|
-
var import_mysql_core = require("drizzle-orm/mysql-core");
|
|
176
|
-
var import_pg_core = require("drizzle-orm/pg-core");
|
|
177
|
-
var import_sqlite_core = require("drizzle-orm/sqlite-core");
|
|
178
|
-
var import_graphql2 = require("graphql");
|
|
179
|
-
var allowedNameChars = /^[a-zA-Z0-9_]+$/;
|
|
180
|
-
var enumMap = /* @__PURE__ */ new WeakMap();
|
|
181
|
-
var generateEnumCached = (column, columnName, tableName) => {
|
|
182
|
-
if (enumMap.has(column))
|
|
183
|
-
return enumMap.get(column);
|
|
184
|
-
const gqlEnum = new import_graphql2.GraphQLEnumType({
|
|
185
|
-
name: `${capitalize(tableName)}${capitalize(columnName)}Enum`,
|
|
186
|
-
values: Object.fromEntries(column.enumValues.map((e, index) => [allowedNameChars.test(e) ? e : `Option${index}`, {
|
|
187
|
-
value: e,
|
|
188
|
-
description: `Value: ${e}`
|
|
189
|
-
}]))
|
|
190
|
-
});
|
|
191
|
-
enumMap.set(column, gqlEnum);
|
|
192
|
-
return gqlEnum;
|
|
193
|
-
};
|
|
194
|
-
var geoXyType = new import_graphql2.GraphQLObjectType({
|
|
195
|
-
name: "PgGeometryObject",
|
|
196
|
-
fields: {
|
|
197
|
-
x: { type: import_graphql2.GraphQLFloat },
|
|
198
|
-
y: { type: import_graphql2.GraphQLFloat }
|
|
199
|
-
}
|
|
200
|
-
});
|
|
201
|
-
var geoXyInputType = new import_graphql2.GraphQLInputObjectType({
|
|
202
|
-
name: "PgGeometryObjectInput",
|
|
203
|
-
fields: {
|
|
204
|
-
x: { type: import_graphql2.GraphQLFloat },
|
|
205
|
-
y: { type: import_graphql2.GraphQLFloat }
|
|
206
|
-
}
|
|
207
|
-
});
|
|
208
|
-
var columnToGraphQLCore = (column, columnName, tableName, isInput) => {
|
|
209
|
-
switch (column.dataType) {
|
|
210
|
-
case "boolean":
|
|
211
|
-
return { type: import_graphql2.GraphQLBoolean, description: "Boolean" };
|
|
212
|
-
case "json":
|
|
213
|
-
return column.columnType === "PgGeometryObject" ? {
|
|
214
|
-
type: isInput ? geoXyInputType : geoXyType,
|
|
215
|
-
description: "Geometry points XY"
|
|
216
|
-
} : { type: import_graphql2.GraphQLString, description: "JSON" };
|
|
217
|
-
case "date":
|
|
218
|
-
return { type: import_graphql2.GraphQLString, description: "Date" };
|
|
219
|
-
case "string":
|
|
220
|
-
if (column.enumValues?.length)
|
|
221
|
-
return { type: generateEnumCached(column, columnName, tableName) };
|
|
222
|
-
return { type: import_graphql2.GraphQLString, description: "String" };
|
|
223
|
-
case "bigint":
|
|
224
|
-
return { type: import_graphql2.GraphQLString, description: "BigInt" };
|
|
225
|
-
case "number":
|
|
226
|
-
return (0, import_drizzle_orm2.is)(column, import_pg_core.PgInteger) || (0, import_drizzle_orm2.is)(column, import_pg_core.PgSerial) || (0, import_drizzle_orm2.is)(column, import_mysql_core.MySqlInt) || (0, import_drizzle_orm2.is)(column, import_mysql_core.MySqlSerial) || (0, import_drizzle_orm2.is)(column, import_sqlite_core.SQLiteInteger) ? { type: import_graphql2.GraphQLInt, description: "Integer" } : { type: import_graphql2.GraphQLFloat, description: "Float" };
|
|
227
|
-
case "buffer":
|
|
228
|
-
return { type: new import_graphql2.GraphQLList(new import_graphql2.GraphQLNonNull(import_graphql2.GraphQLInt)), description: "Buffer" };
|
|
229
|
-
case "array": {
|
|
230
|
-
if (column.columnType === "PgVector") {
|
|
231
|
-
return {
|
|
232
|
-
type: new import_graphql2.GraphQLList(new import_graphql2.GraphQLNonNull(import_graphql2.GraphQLFloat)),
|
|
233
|
-
description: "Array<Float>"
|
|
234
|
-
};
|
|
235
|
-
}
|
|
236
|
-
if (column.columnType === "PgGeometry") {
|
|
237
|
-
return {
|
|
238
|
-
type: new import_graphql2.GraphQLList(new import_graphql2.GraphQLNonNull(import_graphql2.GraphQLFloat)),
|
|
239
|
-
description: "Tuple<[Float, Float]>"
|
|
240
|
-
};
|
|
241
|
-
}
|
|
242
|
-
const innerType = columnToGraphQLCore(
|
|
243
|
-
column.baseColumn,
|
|
244
|
-
columnName,
|
|
245
|
-
tableName,
|
|
246
|
-
isInput
|
|
247
|
-
);
|
|
248
|
-
return {
|
|
249
|
-
type: new import_graphql2.GraphQLList(new import_graphql2.GraphQLNonNull(innerType.type)),
|
|
250
|
-
description: `Array<${innerType.description}>`
|
|
251
|
-
};
|
|
252
|
-
}
|
|
253
|
-
case "custom":
|
|
254
|
-
default:
|
|
255
|
-
throw new Error(`Drizzle-GraphQL Error: Type ${column.dataType} is not implemented!`);
|
|
256
|
-
}
|
|
257
|
-
};
|
|
258
|
-
var drizzleColumnToGraphQLType = (column, columnName, tableName, forceNullable = false, defaultIsNullable = false, isInput = false) => {
|
|
259
|
-
const typeDesc = columnToGraphQLCore(column, columnName, tableName, isInput);
|
|
260
|
-
const noDesc = ["string", "boolean", "number"];
|
|
261
|
-
if (noDesc.find((e) => e === column.dataType))
|
|
262
|
-
delete typeDesc.description;
|
|
263
|
-
if (forceNullable)
|
|
264
|
-
return typeDesc;
|
|
265
|
-
if (column.notNull && !(defaultIsNullable && (column.hasDefault || column.defaultFn))) {
|
|
266
|
-
return {
|
|
267
|
-
type: new import_graphql2.GraphQLNonNull(typeDesc.type),
|
|
268
|
-
description: typeDesc.description
|
|
269
|
-
};
|
|
270
|
-
}
|
|
271
|
-
return typeDesc;
|
|
272
|
-
};
|
|
273
|
-
|
|
274
|
-
// src/util/builders/common.ts
|
|
275
|
-
var rqbCrashTypes = ["SQLiteBigInt", "SQLiteBlobJson", "SQLiteBlobBuffer"];
|
|
276
|
-
var extractSelectedColumnsFromTree = (tree, table) => {
|
|
277
|
-
const tableColumns = (0, import_drizzle_orm3.getTableColumns)(table);
|
|
278
|
-
const treeEntries = Object.entries(tree);
|
|
279
|
-
const selectedColumns = [];
|
|
280
|
-
for (const [fieldName, fieldData] of treeEntries) {
|
|
281
|
-
if (!tableColumns[fieldData.name])
|
|
282
|
-
continue;
|
|
283
|
-
selectedColumns.push([fieldData.name, true]);
|
|
284
|
-
}
|
|
285
|
-
if (!selectedColumns.length) {
|
|
286
|
-
const columnKeys = Object.entries(tableColumns);
|
|
287
|
-
const columnName = columnKeys.find(
|
|
288
|
-
(e) => rqbCrashTypes.find((haram) => e[1].columnType !== haram)
|
|
289
|
-
)?.[0] ?? columnKeys[0][0];
|
|
290
|
-
selectedColumns.push([columnName, true]);
|
|
291
|
-
}
|
|
292
|
-
return Object.fromEntries(selectedColumns);
|
|
293
|
-
};
|
|
294
|
-
var extractSelectedColumnsFromTreeSQLFormat = (tree, table) => {
|
|
295
|
-
const tableColumns = (0, import_drizzle_orm3.getTableColumns)(table);
|
|
296
|
-
const treeEntries = Object.entries(tree);
|
|
297
|
-
const selectedColumns = [];
|
|
298
|
-
for (const [fieldName, fieldData] of treeEntries) {
|
|
299
|
-
if (!tableColumns[fieldData.name])
|
|
300
|
-
continue;
|
|
301
|
-
selectedColumns.push([fieldData.name, tableColumns[fieldData.name]]);
|
|
302
|
-
}
|
|
303
|
-
if (!selectedColumns.length) {
|
|
304
|
-
const columnKeys = Object.entries(tableColumns);
|
|
305
|
-
const columnName = columnKeys.find(
|
|
306
|
-
(e) => rqbCrashTypes.find((haram) => e[1].columnType !== haram)
|
|
307
|
-
)?.[0] ?? columnKeys[0][0];
|
|
308
|
-
selectedColumns.push([columnName, tableColumns[columnName]]);
|
|
309
|
-
}
|
|
310
|
-
return Object.fromEntries(selectedColumns);
|
|
311
|
-
};
|
|
312
|
-
var innerOrder = new import_graphql3.GraphQLInputObjectType({
|
|
313
|
-
name: "InnerOrder",
|
|
314
|
-
fields: {
|
|
315
|
-
direction: {
|
|
316
|
-
type: new import_graphql3.GraphQLNonNull(
|
|
317
|
-
new import_graphql3.GraphQLEnumType({
|
|
318
|
-
name: "OrderDirection",
|
|
319
|
-
description: "Order by direction",
|
|
320
|
-
values: {
|
|
321
|
-
asc: {
|
|
322
|
-
value: "asc",
|
|
323
|
-
description: "Ascending order"
|
|
324
|
-
},
|
|
325
|
-
desc: {
|
|
326
|
-
value: "desc",
|
|
327
|
-
description: "Descending order"
|
|
328
|
-
}
|
|
329
|
-
}
|
|
330
|
-
})
|
|
331
|
-
)
|
|
332
|
-
},
|
|
333
|
-
priority: {
|
|
334
|
-
type: new import_graphql3.GraphQLNonNull(import_graphql3.GraphQLInt),
|
|
335
|
-
description: "Priority of current field"
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
});
|
|
339
|
-
var generateColumnFilterValues = (column, tableName, columnName) => {
|
|
340
|
-
const columnGraphQLType = drizzleColumnToGraphQLType(
|
|
341
|
-
column,
|
|
342
|
-
columnName,
|
|
343
|
-
tableName,
|
|
344
|
-
true,
|
|
345
|
-
false,
|
|
346
|
-
true
|
|
347
|
-
);
|
|
348
|
-
const columnArr = new import_graphql3.GraphQLList(new import_graphql3.GraphQLNonNull(columnGraphQLType.type));
|
|
349
|
-
const baseFields = {
|
|
350
|
-
eq: {
|
|
351
|
-
type: columnGraphQLType.type,
|
|
352
|
-
description: columnGraphQLType.description
|
|
353
|
-
},
|
|
354
|
-
ne: {
|
|
355
|
-
type: columnGraphQLType.type,
|
|
356
|
-
description: columnGraphQLType.description
|
|
357
|
-
},
|
|
358
|
-
lt: {
|
|
359
|
-
type: columnGraphQLType.type,
|
|
360
|
-
description: columnGraphQLType.description
|
|
361
|
-
},
|
|
362
|
-
lte: {
|
|
363
|
-
type: columnGraphQLType.type,
|
|
364
|
-
description: columnGraphQLType.description
|
|
365
|
-
},
|
|
366
|
-
gt: {
|
|
367
|
-
type: columnGraphQLType.type,
|
|
368
|
-
description: columnGraphQLType.description
|
|
369
|
-
},
|
|
370
|
-
gte: {
|
|
371
|
-
type: columnGraphQLType.type,
|
|
372
|
-
description: columnGraphQLType.description
|
|
373
|
-
},
|
|
374
|
-
like: { type: import_graphql3.GraphQLString },
|
|
375
|
-
notLike: { type: import_graphql3.GraphQLString },
|
|
376
|
-
ilike: { type: import_graphql3.GraphQLString },
|
|
377
|
-
notIlike: { type: import_graphql3.GraphQLString },
|
|
378
|
-
inArray: {
|
|
379
|
-
type: columnArr,
|
|
380
|
-
description: `Array<${columnGraphQLType.description}>`
|
|
381
|
-
},
|
|
382
|
-
notInArray: {
|
|
383
|
-
type: columnArr,
|
|
384
|
-
description: `Array<${columnGraphQLType.description}>`
|
|
385
|
-
},
|
|
386
|
-
isNull: { type: import_graphql3.GraphQLBoolean },
|
|
387
|
-
isNotNull: { type: import_graphql3.GraphQLBoolean }
|
|
388
|
-
};
|
|
389
|
-
const type = new import_graphql3.GraphQLInputObjectType({
|
|
390
|
-
name: `${capitalize(tableName)}${capitalize(columnName)}Filters`,
|
|
391
|
-
fields: {
|
|
392
|
-
...baseFields,
|
|
393
|
-
OR: {
|
|
394
|
-
type: new import_graphql3.GraphQLList(
|
|
395
|
-
new import_graphql3.GraphQLNonNull(
|
|
396
|
-
new import_graphql3.GraphQLInputObjectType({
|
|
397
|
-
name: `${capitalize(tableName)}${capitalize(
|
|
398
|
-
columnName
|
|
399
|
-
)}filtersOr`,
|
|
400
|
-
fields: {
|
|
401
|
-
...baseFields
|
|
402
|
-
}
|
|
403
|
-
})
|
|
404
|
-
)
|
|
405
|
-
)
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
});
|
|
409
|
-
return type;
|
|
410
|
-
};
|
|
411
|
-
var orderMap = /* @__PURE__ */ new WeakMap();
|
|
412
|
-
var generateTableOrderCached = (table) => {
|
|
413
|
-
if (orderMap.has(table))
|
|
414
|
-
return orderMap.get(table);
|
|
415
|
-
const columns = (0, import_drizzle_orm3.getTableColumns)(table);
|
|
416
|
-
const columnEntries = Object.entries(columns);
|
|
417
|
-
const remapped = Object.fromEntries(
|
|
418
|
-
columnEntries.map(([columnName, columnDescription]) => [
|
|
419
|
-
columnName,
|
|
420
|
-
{ type: innerOrder }
|
|
421
|
-
])
|
|
422
|
-
);
|
|
423
|
-
orderMap.set(table, remapped);
|
|
424
|
-
return remapped;
|
|
425
|
-
};
|
|
426
|
-
var filterMap = /* @__PURE__ */ new WeakMap();
|
|
427
|
-
var generateTableFilterValuesCached = (table, tableName) => {
|
|
428
|
-
if (filterMap.has(table))
|
|
429
|
-
return filterMap.get(table);
|
|
430
|
-
const columns = (0, import_drizzle_orm3.getTableColumns)(table);
|
|
431
|
-
const columnEntries = Object.entries(columns);
|
|
432
|
-
const remapped = Object.fromEntries(
|
|
433
|
-
columnEntries.map(([columnName, columnDescription]) => [
|
|
434
|
-
columnName,
|
|
435
|
-
{
|
|
436
|
-
type: generateColumnFilterValues(
|
|
437
|
-
columnDescription,
|
|
438
|
-
tableName,
|
|
439
|
-
columnName
|
|
440
|
-
)
|
|
441
|
-
}
|
|
442
|
-
])
|
|
443
|
-
);
|
|
444
|
-
filterMap.set(table, remapped);
|
|
445
|
-
return remapped;
|
|
446
|
-
};
|
|
447
|
-
var fieldMap = /* @__PURE__ */ new WeakMap();
|
|
448
|
-
var generateTableSelectTypeFieldsCached = (table, tableName) => {
|
|
449
|
-
if (fieldMap.has(table))
|
|
450
|
-
return fieldMap.get(table);
|
|
451
|
-
const columns = (0, import_drizzle_orm3.getTableColumns)(table);
|
|
452
|
-
const columnEntries = Object.entries(columns);
|
|
453
|
-
const remapped = Object.fromEntries(
|
|
454
|
-
columnEntries.map(([columnName, columnDescription]) => [
|
|
455
|
-
columnName,
|
|
456
|
-
drizzleColumnToGraphQLType(columnDescription, columnName, tableName)
|
|
457
|
-
])
|
|
458
|
-
);
|
|
459
|
-
fieldMap.set(table, remapped);
|
|
460
|
-
return remapped;
|
|
461
|
-
};
|
|
462
|
-
var orderTypeMap = /* @__PURE__ */ new WeakMap();
|
|
463
|
-
var generateTableOrderTypeCached = (table, tableName) => {
|
|
464
|
-
if (orderTypeMap.has(table))
|
|
465
|
-
return orderTypeMap.get(table);
|
|
466
|
-
const orderColumns = generateTableOrderCached(table);
|
|
467
|
-
const order = new import_graphql3.GraphQLInputObjectType({
|
|
468
|
-
name: `${capitalize(tableName)}OrderBy`,
|
|
469
|
-
fields: orderColumns
|
|
470
|
-
});
|
|
471
|
-
orderTypeMap.set(table, order);
|
|
472
|
-
return order;
|
|
473
|
-
};
|
|
474
|
-
var filterTypeMap = /* @__PURE__ */ new WeakMap();
|
|
475
|
-
var generateTableFilterTypeCached = (table, tableName) => {
|
|
476
|
-
if (filterTypeMap.has(table))
|
|
477
|
-
return filterTypeMap.get(table);
|
|
478
|
-
const filterColumns = generateTableFilterValuesCached(table, tableName);
|
|
479
|
-
const filters = new import_graphql3.GraphQLInputObjectType({
|
|
480
|
-
name: `${capitalize(tableName)}Filters`,
|
|
481
|
-
fields: {
|
|
482
|
-
...filterColumns,
|
|
483
|
-
OR: {
|
|
484
|
-
type: new import_graphql3.GraphQLList(
|
|
485
|
-
new import_graphql3.GraphQLNonNull(
|
|
486
|
-
new import_graphql3.GraphQLInputObjectType({
|
|
487
|
-
name: `${capitalize(tableName)}FiltersOr`,
|
|
488
|
-
fields: filterColumns
|
|
489
|
-
})
|
|
490
|
-
)
|
|
491
|
-
)
|
|
492
|
-
}
|
|
493
|
-
}
|
|
494
|
-
});
|
|
495
|
-
filterTypeMap.set(table, filters);
|
|
496
|
-
return filters;
|
|
497
|
-
};
|
|
498
|
-
var generateSelectFields = (tables, tableName, relationMap, typeName, withOrder, relationsDepthLimit, currentDepth = 0, usedTables = /* @__PURE__ */ new Set()) => {
|
|
499
|
-
const relations = relationMap[tableName];
|
|
500
|
-
const relationEntries = relations ? Object.entries(relations) : [];
|
|
501
|
-
const table = tables[tableName];
|
|
502
|
-
const order = withOrder ? generateTableOrderTypeCached(table, tableName) : void 0;
|
|
503
|
-
const filters = generateTableFilterTypeCached(table, tableName);
|
|
504
|
-
const tableFields = generateTableSelectTypeFieldsCached(table, tableName);
|
|
505
|
-
if (usedTables.has(tableName) || typeof relationsDepthLimit === "number" && currentDepth >= relationsDepthLimit || !relationEntries.length) {
|
|
506
|
-
return {
|
|
507
|
-
order,
|
|
508
|
-
filters,
|
|
509
|
-
tableFields,
|
|
510
|
-
relationFields: {}
|
|
511
|
-
};
|
|
512
|
-
}
|
|
513
|
-
const rawRelationFields = [];
|
|
514
|
-
const updatedUsedTables = new Set(usedTables).add(tableName);
|
|
515
|
-
const newDepth = currentDepth + 1;
|
|
516
|
-
for (const [relationName, { targetTableName, relation }] of relationEntries) {
|
|
517
|
-
const relTypeName = `${typeName}${capitalize(relationName)}Relation`;
|
|
518
|
-
const isOne = (0, import_drizzle_orm3.is)(relation, import_drizzle_orm3.One);
|
|
519
|
-
const relData = generateSelectFields(
|
|
520
|
-
tables,
|
|
521
|
-
targetTableName,
|
|
522
|
-
relationMap,
|
|
523
|
-
relTypeName,
|
|
524
|
-
!isOne,
|
|
525
|
-
relationsDepthLimit,
|
|
526
|
-
newDepth,
|
|
527
|
-
updatedUsedTables
|
|
528
|
-
);
|
|
529
|
-
const relType = new import_graphql3.GraphQLObjectType({
|
|
530
|
-
name: relTypeName,
|
|
531
|
-
fields: { ...relData.tableFields, ...relData.relationFields }
|
|
532
|
-
});
|
|
533
|
-
if (isOne) {
|
|
534
|
-
rawRelationFields.push([
|
|
535
|
-
relationName,
|
|
536
|
-
{
|
|
537
|
-
type: relType,
|
|
538
|
-
args: {
|
|
539
|
-
where: { type: relData.filters }
|
|
540
|
-
}
|
|
541
|
-
}
|
|
542
|
-
]);
|
|
543
|
-
continue;
|
|
544
|
-
}
|
|
545
|
-
rawRelationFields.push([
|
|
546
|
-
relationName,
|
|
547
|
-
{
|
|
548
|
-
type: new import_graphql3.GraphQLNonNull(new import_graphql3.GraphQLList(new import_graphql3.GraphQLNonNull(relType))),
|
|
549
|
-
args: {
|
|
550
|
-
where: { type: relData.filters },
|
|
551
|
-
orderBy: { type: relData.order },
|
|
552
|
-
offset: { type: import_graphql3.GraphQLInt },
|
|
553
|
-
limit: { type: import_graphql3.GraphQLInt }
|
|
554
|
-
}
|
|
555
|
-
}
|
|
556
|
-
]);
|
|
557
|
-
}
|
|
558
|
-
const relationFields = Object.fromEntries(rawRelationFields);
|
|
559
|
-
return {
|
|
560
|
-
order,
|
|
561
|
-
filters,
|
|
562
|
-
tableFields,
|
|
563
|
-
relationFields
|
|
564
|
-
};
|
|
565
|
-
};
|
|
566
|
-
var generateTableTypes = (tableName, tables, relationMap, withReturning, relationsDepthLimit) => {
|
|
567
|
-
const stylizedName = capitalize(tableName);
|
|
568
|
-
const { tableFields, relationFields, filters, order } = generateSelectFields(
|
|
569
|
-
tables,
|
|
570
|
-
tableName,
|
|
571
|
-
relationMap,
|
|
572
|
-
stylizedName,
|
|
573
|
-
true,
|
|
574
|
-
relationsDepthLimit
|
|
575
|
-
);
|
|
576
|
-
const table = tables[tableName];
|
|
577
|
-
const columns = (0, import_drizzle_orm3.getTableColumns)(table);
|
|
578
|
-
const columnEntries = Object.entries(columns);
|
|
579
|
-
const insertFields = Object.fromEntries(
|
|
580
|
-
columnEntries.map(([columnName, columnDescription]) => [
|
|
581
|
-
columnName,
|
|
582
|
-
drizzleColumnToGraphQLType(
|
|
583
|
-
columnDescription,
|
|
584
|
-
columnName,
|
|
585
|
-
tableName,
|
|
586
|
-
false,
|
|
587
|
-
true,
|
|
588
|
-
true
|
|
589
|
-
)
|
|
590
|
-
])
|
|
591
|
-
);
|
|
592
|
-
const updateFields = Object.fromEntries(
|
|
593
|
-
columnEntries.map(([columnName, columnDescription]) => [
|
|
594
|
-
columnName,
|
|
595
|
-
drizzleColumnToGraphQLType(
|
|
596
|
-
columnDescription,
|
|
597
|
-
columnName,
|
|
598
|
-
tableName,
|
|
599
|
-
true,
|
|
600
|
-
false,
|
|
601
|
-
true
|
|
602
|
-
)
|
|
603
|
-
])
|
|
604
|
-
);
|
|
605
|
-
const insertInput = new import_graphql3.GraphQLInputObjectType({
|
|
606
|
-
name: `${stylizedName}InsertInput`,
|
|
607
|
-
fields: insertFields
|
|
608
|
-
});
|
|
609
|
-
const tableFieldsInterface = new import_graphql3.GraphQLInterfaceType({
|
|
610
|
-
name: `${stylizedName}Fields`,
|
|
611
|
-
fields: tableFields
|
|
612
|
-
});
|
|
613
|
-
const selectSingleOutput = new import_graphql3.GraphQLObjectType({
|
|
614
|
-
name: `${stylizedName}SelectItem`,
|
|
615
|
-
fields: { ...tableFields, ...relationFields },
|
|
616
|
-
interfaces: [tableFieldsInterface]
|
|
617
|
-
});
|
|
618
|
-
const selectArrOutput = new import_graphql3.GraphQLNonNull(
|
|
619
|
-
new import_graphql3.GraphQLList(new import_graphql3.GraphQLNonNull(selectSingleOutput))
|
|
620
|
-
);
|
|
621
|
-
const singleTableItemOutput = withReturning ? new import_graphql3.GraphQLObjectType({
|
|
622
|
-
name: `${stylizedName}Item`,
|
|
623
|
-
fields: tableFields,
|
|
624
|
-
interfaces: [tableFieldsInterface]
|
|
625
|
-
}) : void 0;
|
|
626
|
-
const arrTableItemOutput = withReturning ? new import_graphql3.GraphQLNonNull(
|
|
627
|
-
new import_graphql3.GraphQLList(new import_graphql3.GraphQLNonNull(singleTableItemOutput))
|
|
628
|
-
) : void 0;
|
|
629
|
-
const updateInput = new import_graphql3.GraphQLInputObjectType({
|
|
630
|
-
name: `${stylizedName}UpdateInput`,
|
|
631
|
-
fields: updateFields
|
|
632
|
-
});
|
|
633
|
-
const inputs = {
|
|
634
|
-
insertInput,
|
|
635
|
-
updateInput,
|
|
636
|
-
tableOrder: order,
|
|
637
|
-
tableFilters: filters
|
|
638
|
-
};
|
|
639
|
-
const outputs = withReturning ? {
|
|
640
|
-
selectSingleOutput,
|
|
641
|
-
selectArrOutput,
|
|
642
|
-
singleTableItemOutput,
|
|
643
|
-
arrTableItemOutput
|
|
644
|
-
} : {
|
|
645
|
-
selectSingleOutput,
|
|
646
|
-
selectArrOutput
|
|
647
|
-
};
|
|
648
|
-
return {
|
|
649
|
-
inputs,
|
|
650
|
-
outputs
|
|
651
|
-
};
|
|
652
|
-
};
|
|
653
|
-
var extractOrderBy = (table, orderArgs) => {
|
|
654
|
-
const res = [];
|
|
655
|
-
for (const [column, config] of Object.entries(orderArgs).sort(
|
|
656
|
-
(a, b) => (b[1]?.priority ?? 0) - (a[1]?.priority ?? 0)
|
|
657
|
-
)) {
|
|
658
|
-
if (!config)
|
|
659
|
-
continue;
|
|
660
|
-
const { direction } = config;
|
|
661
|
-
res.push(
|
|
662
|
-
direction === "asc" ? (0, import_drizzle_orm3.asc)((0, import_drizzle_orm3.getTableColumns)(table)[column]) : (0, import_drizzle_orm3.desc)((0, import_drizzle_orm3.getTableColumns)(table)[column])
|
|
663
|
-
);
|
|
664
|
-
}
|
|
665
|
-
return res;
|
|
666
|
-
};
|
|
667
|
-
var extractFiltersColumn = (column, columnName, operators) => {
|
|
668
|
-
if (!operators.OR?.length)
|
|
669
|
-
delete operators.OR;
|
|
670
|
-
const entries = Object.entries(
|
|
671
|
-
operators
|
|
672
|
-
);
|
|
673
|
-
if (operators.OR) {
|
|
674
|
-
if (entries.length > 1) {
|
|
675
|
-
throw new import_graphql3.GraphQLError(
|
|
676
|
-
`WHERE ${columnName}: Cannot specify both fields and 'OR' in column operators!`
|
|
677
|
-
);
|
|
678
|
-
}
|
|
679
|
-
const variants2 = [];
|
|
680
|
-
for (const variant of operators.OR) {
|
|
681
|
-
const extracted = extractFiltersColumn(column, columnName, variant);
|
|
682
|
-
if (extracted)
|
|
683
|
-
variants2.push(extracted);
|
|
684
|
-
}
|
|
685
|
-
return variants2.length ? variants2.length > 1 ? (0, import_drizzle_orm3.or)(...variants2) : variants2[0] : void 0;
|
|
686
|
-
}
|
|
687
|
-
const variants = [];
|
|
688
|
-
for (const [operatorName, operatorValue] of entries) {
|
|
689
|
-
if (operatorValue === null || operatorValue === false)
|
|
690
|
-
continue;
|
|
691
|
-
let operator;
|
|
692
|
-
switch (operatorName) {
|
|
693
|
-
case "eq":
|
|
694
|
-
operator = operator ?? import_drizzle_orm3.eq;
|
|
695
|
-
case "ne":
|
|
696
|
-
operator = operator ?? import_drizzle_orm3.ne;
|
|
697
|
-
case "gt":
|
|
698
|
-
operator = operator ?? import_drizzle_orm3.gt;
|
|
699
|
-
case "gte":
|
|
700
|
-
operator = operator ?? import_drizzle_orm3.gte;
|
|
701
|
-
case "lt":
|
|
702
|
-
operator = operator ?? import_drizzle_orm3.lt;
|
|
703
|
-
case "lte":
|
|
704
|
-
operator = operator ?? import_drizzle_orm3.lte;
|
|
705
|
-
const singleValue = remapFromGraphQLCore(
|
|
706
|
-
operatorValue,
|
|
707
|
-
column,
|
|
708
|
-
columnName
|
|
709
|
-
);
|
|
710
|
-
variants.push(operator(column, singleValue));
|
|
711
|
-
break;
|
|
712
|
-
case "like":
|
|
713
|
-
operator = operator ?? import_drizzle_orm3.like;
|
|
714
|
-
case "notLike":
|
|
715
|
-
operator = operator ?? import_drizzle_orm3.notLike;
|
|
716
|
-
case "ilike":
|
|
717
|
-
operator = operator ?? import_drizzle_orm3.ilike;
|
|
718
|
-
case "notIlike":
|
|
719
|
-
operator = operator ?? import_drizzle_orm3.notIlike;
|
|
720
|
-
variants.push(operator(column, operatorValue));
|
|
721
|
-
break;
|
|
722
|
-
case "inArray":
|
|
723
|
-
operator = operator ?? import_drizzle_orm3.inArray;
|
|
724
|
-
case "notInArray":
|
|
725
|
-
operator = operator ?? import_drizzle_orm3.notInArray;
|
|
726
|
-
if (!operatorValue.length) {
|
|
727
|
-
throw new import_graphql3.GraphQLError(
|
|
728
|
-
`WHERE ${columnName}: Unable to use operator ${operatorName} with an empty array!`
|
|
729
|
-
);
|
|
730
|
-
}
|
|
731
|
-
const arrayValue = operatorValue.map(
|
|
732
|
-
(val) => remapFromGraphQLCore(val, column, columnName)
|
|
733
|
-
);
|
|
734
|
-
variants.push(operator(column, arrayValue));
|
|
735
|
-
break;
|
|
736
|
-
case "isNull":
|
|
737
|
-
operator = operator ?? import_drizzle_orm3.isNull;
|
|
738
|
-
case "isNotNull":
|
|
739
|
-
operator = operator ?? import_drizzle_orm3.isNotNull;
|
|
740
|
-
variants.push(operator(column));
|
|
741
|
-
}
|
|
742
|
-
}
|
|
743
|
-
return variants.length ? variants.length > 1 ? (0, import_drizzle_orm3.and)(...variants) : variants[0] : void 0;
|
|
744
|
-
};
|
|
745
|
-
var extractFilters = (table, tableName, filters) => {
|
|
746
|
-
if (!filters.OR?.length)
|
|
747
|
-
delete filters.OR;
|
|
748
|
-
const entries = Object.entries(filters);
|
|
749
|
-
if (!entries.length)
|
|
750
|
-
return;
|
|
751
|
-
if (filters.OR) {
|
|
752
|
-
if (entries.length > 1) {
|
|
753
|
-
throw new import_graphql3.GraphQLError(
|
|
754
|
-
`WHERE ${tableName}: Cannot specify both fields and 'OR' in table filters!`
|
|
755
|
-
);
|
|
756
|
-
}
|
|
757
|
-
const variants2 = [];
|
|
758
|
-
for (const variant of filters.OR) {
|
|
759
|
-
const extracted = extractFilters(table, tableName, variant);
|
|
760
|
-
if (extracted)
|
|
761
|
-
variants2.push(extracted);
|
|
762
|
-
}
|
|
763
|
-
return variants2.length ? variants2.length > 1 ? (0, import_drizzle_orm3.or)(...variants2) : variants2[0] : void 0;
|
|
764
|
-
}
|
|
765
|
-
const variants = [];
|
|
766
|
-
for (const [columnName, operators] of entries) {
|
|
767
|
-
if (operators === null)
|
|
768
|
-
continue;
|
|
769
|
-
const column = (0, import_drizzle_orm3.getTableColumns)(table)[columnName];
|
|
770
|
-
variants.push(extractFiltersColumn(column, columnName, operators));
|
|
771
|
-
}
|
|
772
|
-
return variants.length ? variants.length > 1 ? (0, import_drizzle_orm3.and)(...variants) : variants[0] : void 0;
|
|
773
|
-
};
|
|
774
|
-
var extractRelationsParamsInner = (relationMap, tables, tableName, typeName, originField, isInitial = false) => {
|
|
775
|
-
const relations = relationMap[tableName];
|
|
776
|
-
if (!relations)
|
|
777
|
-
return void 0;
|
|
778
|
-
const baseField = Object.entries(originField.fieldsByTypeName).find(
|
|
779
|
-
([key, value]) => key === typeName
|
|
780
|
-
)?.[1];
|
|
781
|
-
if (!baseField)
|
|
782
|
-
return void 0;
|
|
783
|
-
const args = {};
|
|
784
|
-
for (const [relName, { targetTableName, relation }] of Object.entries(
|
|
785
|
-
relations
|
|
786
|
-
)) {
|
|
787
|
-
const relTypeName = `${isInitial ? capitalize(tableName) : typeName}${capitalize(relName)}Relation`;
|
|
788
|
-
const relFieldSelection = Object.values(baseField).find(
|
|
789
|
-
(field) => field.name === relName
|
|
790
|
-
)?.fieldsByTypeName[relTypeName];
|
|
791
|
-
if (!relFieldSelection)
|
|
792
|
-
continue;
|
|
793
|
-
const columns = extractSelectedColumnsFromTree(
|
|
794
|
-
relFieldSelection,
|
|
795
|
-
tables[targetTableName]
|
|
796
|
-
);
|
|
797
|
-
const thisRecord = {};
|
|
798
|
-
thisRecord.columns = columns;
|
|
799
|
-
const relationField = Object.values(baseField).find(
|
|
800
|
-
(e) => e.name === relName
|
|
801
|
-
);
|
|
802
|
-
const relationArgs = relationField?.args;
|
|
803
|
-
const orderBy = relationArgs?.orderBy ? extractOrderBy(tables[targetTableName], relationArgs.orderBy) : void 0;
|
|
804
|
-
const where = relationArgs?.where ? extractFilters(tables[targetTableName], relName, relationArgs?.where) : void 0;
|
|
805
|
-
const offset = relationArgs?.offset ?? void 0;
|
|
806
|
-
const limit = relationArgs?.limit ?? void 0;
|
|
807
|
-
thisRecord.orderBy = orderBy;
|
|
808
|
-
thisRecord.where = where;
|
|
809
|
-
thisRecord.offset = offset;
|
|
810
|
-
thisRecord.limit = limit;
|
|
811
|
-
const relWith = relationField ? extractRelationsParamsInner(
|
|
812
|
-
relationMap,
|
|
813
|
-
tables,
|
|
814
|
-
targetTableName,
|
|
815
|
-
relTypeName,
|
|
816
|
-
relationField
|
|
817
|
-
) : void 0;
|
|
818
|
-
thisRecord.with = relWith;
|
|
819
|
-
args[relName] = thisRecord;
|
|
820
|
-
}
|
|
821
|
-
return args;
|
|
822
|
-
};
|
|
823
|
-
var extractRelationsParams = (relationMap, tables, tableName, info, typeName) => {
|
|
824
|
-
if (!info)
|
|
825
|
-
return void 0;
|
|
826
|
-
return extractRelationsParamsInner(
|
|
827
|
-
relationMap,
|
|
828
|
-
tables,
|
|
829
|
-
tableName,
|
|
830
|
-
typeName,
|
|
831
|
-
info,
|
|
832
|
-
true
|
|
833
|
-
);
|
|
834
|
-
};
|
|
835
|
-
|
|
836
|
-
// src/util/builders/mysql.ts
|
|
837
|
-
var import_graphql_parse_resolve_info = require("graphql-parse-resolve-info");
|
|
838
|
-
var generateSelectArray = (db, tableName, tables, relationMap, orderArgs, filterArgs) => {
|
|
839
|
-
const queryName = `${uncapitalize(tableName)}`;
|
|
840
|
-
const queryBase = db.query[tableName];
|
|
841
|
-
if (!queryBase) {
|
|
842
|
-
throw new Error(
|
|
843
|
-
`Drizzle-GraphQL Error: Table ${tableName} not found in drizzle instance. Did you forget to pass schema to drizzle constructor?`
|
|
844
|
-
);
|
|
845
|
-
}
|
|
846
|
-
const queryArgs = {
|
|
847
|
-
offset: {
|
|
848
|
-
type: import_graphql4.GraphQLInt
|
|
849
|
-
},
|
|
850
|
-
limit: {
|
|
851
|
-
type: import_graphql4.GraphQLInt
|
|
852
|
-
},
|
|
853
|
-
orderBy: {
|
|
854
|
-
type: orderArgs
|
|
855
|
-
},
|
|
856
|
-
where: {
|
|
857
|
-
type: filterArgs
|
|
858
|
-
}
|
|
859
|
-
};
|
|
860
|
-
const typeName = `${capitalize(tableName)}SelectItem`;
|
|
861
|
-
const table = tables[tableName];
|
|
862
|
-
return {
|
|
863
|
-
name: queryName,
|
|
864
|
-
resolver: async (source, args, context, info) => {
|
|
865
|
-
try {
|
|
866
|
-
const { offset, limit, orderBy, where } = args;
|
|
867
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info.parseResolveInfo)(info, {
|
|
868
|
-
deep: true
|
|
869
|
-
});
|
|
870
|
-
const query = queryBase.findMany({
|
|
871
|
-
columns: extractSelectedColumnsFromTree(
|
|
872
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
873
|
-
table
|
|
874
|
-
),
|
|
875
|
-
offset,
|
|
876
|
-
limit,
|
|
877
|
-
orderBy: orderBy ? extractOrderBy(table, orderBy) : void 0,
|
|
878
|
-
where: where ? extractFilters(table, tableName, where) : void 0,
|
|
879
|
-
with: relationMap[tableName] ? extractRelationsParams(relationMap, tables, tableName, parsedInfo, typeName) : void 0
|
|
880
|
-
});
|
|
881
|
-
const result = await query;
|
|
882
|
-
return remapToGraphQLArrayOutput(result, tableName, table, relationMap);
|
|
883
|
-
} catch (e) {
|
|
884
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
885
|
-
throw new import_graphql4.GraphQLError(e.message);
|
|
886
|
-
}
|
|
887
|
-
throw e;
|
|
888
|
-
}
|
|
889
|
-
},
|
|
890
|
-
args: queryArgs
|
|
891
|
-
};
|
|
892
|
-
};
|
|
893
|
-
var generateSelectSingle = (db, tableName, tables, relationMap, orderArgs, filterArgs) => {
|
|
894
|
-
const queryName = `${uncapitalize(tableName)}Single`;
|
|
895
|
-
const queryBase = db.query[tableName];
|
|
896
|
-
if (!queryBase) {
|
|
897
|
-
throw new Error(
|
|
898
|
-
`Drizzle-GraphQL Error: Table ${tableName} not found in drizzle instance. Did you forget to pass schema to drizzle constructor?`
|
|
899
|
-
);
|
|
900
|
-
}
|
|
901
|
-
const queryArgs = {
|
|
902
|
-
offset: {
|
|
903
|
-
type: import_graphql4.GraphQLInt
|
|
904
|
-
},
|
|
905
|
-
orderBy: {
|
|
906
|
-
type: orderArgs
|
|
907
|
-
},
|
|
908
|
-
where: {
|
|
909
|
-
type: filterArgs
|
|
910
|
-
}
|
|
911
|
-
};
|
|
912
|
-
const typeName = `${capitalize(tableName)}SelectItem`;
|
|
913
|
-
const table = tables[tableName];
|
|
914
|
-
return {
|
|
915
|
-
name: queryName,
|
|
916
|
-
resolver: async (source, args, context, info) => {
|
|
917
|
-
try {
|
|
918
|
-
const { offset, orderBy, where } = args;
|
|
919
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info.parseResolveInfo)(info, {
|
|
920
|
-
deep: true
|
|
921
|
-
});
|
|
922
|
-
const query = queryBase.findFirst({
|
|
923
|
-
columns: extractSelectedColumnsFromTree(
|
|
924
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
925
|
-
table
|
|
926
|
-
),
|
|
927
|
-
offset,
|
|
928
|
-
orderBy: orderBy ? extractOrderBy(table, orderBy) : void 0,
|
|
929
|
-
where: where ? extractFilters(table, tableName, where) : void 0,
|
|
930
|
-
with: relationMap[tableName] ? extractRelationsParams(relationMap, tables, tableName, parsedInfo, typeName) : void 0
|
|
931
|
-
});
|
|
932
|
-
const result = await query;
|
|
933
|
-
if (!result)
|
|
934
|
-
return void 0;
|
|
935
|
-
return remapToGraphQLSingleOutput(result, tableName, table, relationMap);
|
|
936
|
-
} catch (e) {
|
|
937
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
938
|
-
throw new import_graphql4.GraphQLError(e.message);
|
|
939
|
-
}
|
|
940
|
-
throw e;
|
|
941
|
-
}
|
|
942
|
-
},
|
|
943
|
-
args: queryArgs
|
|
944
|
-
};
|
|
945
|
-
};
|
|
946
|
-
var generateInsertArray = (db, tableName, table, baseType) => {
|
|
947
|
-
const queryName = `insertInto${capitalize(tableName)}`;
|
|
948
|
-
const queryArgs = {
|
|
949
|
-
values: {
|
|
950
|
-
type: new import_graphql4.GraphQLNonNull(new import_graphql4.GraphQLList(new import_graphql4.GraphQLNonNull(baseType)))
|
|
951
|
-
}
|
|
952
|
-
};
|
|
953
|
-
return {
|
|
954
|
-
name: queryName,
|
|
955
|
-
resolver: async (source, args, context, info) => {
|
|
956
|
-
try {
|
|
957
|
-
const input = remapFromGraphQLArrayInput(args.values, table);
|
|
958
|
-
if (!input.length)
|
|
959
|
-
throw new import_graphql4.GraphQLError("No values were provided!");
|
|
960
|
-
await db.insert(table).values(input);
|
|
961
|
-
return { isSuccess: true };
|
|
962
|
-
} catch (e) {
|
|
963
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
964
|
-
throw new import_graphql4.GraphQLError(e.message);
|
|
965
|
-
}
|
|
966
|
-
throw e;
|
|
967
|
-
}
|
|
968
|
-
},
|
|
969
|
-
args: queryArgs
|
|
970
|
-
};
|
|
971
|
-
};
|
|
972
|
-
var generateInsertSingle = (db, tableName, table, baseType) => {
|
|
973
|
-
const queryName = `insertInto${capitalize(tableName)}Single`;
|
|
974
|
-
const queryArgs = {
|
|
975
|
-
values: {
|
|
976
|
-
type: new import_graphql4.GraphQLNonNull(baseType)
|
|
977
|
-
}
|
|
978
|
-
};
|
|
979
|
-
return {
|
|
980
|
-
name: queryName,
|
|
981
|
-
resolver: async (source, args, context, info) => {
|
|
982
|
-
try {
|
|
983
|
-
const input = remapFromGraphQLSingleInput(args.values, table);
|
|
984
|
-
await db.insert(table).values(input);
|
|
985
|
-
return { isSuccess: true };
|
|
986
|
-
} catch (e) {
|
|
987
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
988
|
-
throw new import_graphql4.GraphQLError(e.message);
|
|
989
|
-
}
|
|
990
|
-
throw e;
|
|
991
|
-
}
|
|
992
|
-
},
|
|
993
|
-
args: queryArgs
|
|
994
|
-
};
|
|
995
|
-
};
|
|
996
|
-
var generateUpdate = (db, tableName, table, setArgs, filterArgs) => {
|
|
997
|
-
const queryName = `update${capitalize(tableName)}`;
|
|
998
|
-
const queryArgs = {
|
|
999
|
-
set: {
|
|
1000
|
-
type: new import_graphql4.GraphQLNonNull(setArgs)
|
|
1001
|
-
},
|
|
1002
|
-
where: {
|
|
1003
|
-
type: filterArgs
|
|
1004
|
-
}
|
|
1005
|
-
};
|
|
1006
|
-
return {
|
|
1007
|
-
name: queryName,
|
|
1008
|
-
resolver: async (source, args, context, info) => {
|
|
1009
|
-
try {
|
|
1010
|
-
const { where, set } = args;
|
|
1011
|
-
const input = remapFromGraphQLSingleInput(set, table);
|
|
1012
|
-
if (!Object.keys(input).length)
|
|
1013
|
-
throw new import_graphql4.GraphQLError("Unable to update with no values specified!");
|
|
1014
|
-
let query = db.update(table).set(input);
|
|
1015
|
-
if (where) {
|
|
1016
|
-
const filters = extractFilters(table, tableName, where);
|
|
1017
|
-
query = query.where(filters);
|
|
1018
|
-
}
|
|
1019
|
-
await query;
|
|
1020
|
-
return { isSuccess: true };
|
|
1021
|
-
} catch (e) {
|
|
1022
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1023
|
-
throw new import_graphql4.GraphQLError(e.message);
|
|
1024
|
-
}
|
|
1025
|
-
throw e;
|
|
1026
|
-
}
|
|
1027
|
-
},
|
|
1028
|
-
args: queryArgs
|
|
1029
|
-
};
|
|
1030
|
-
};
|
|
1031
|
-
var generateDelete = (db, tableName, table, filterArgs) => {
|
|
1032
|
-
const queryName = `deleteFrom${tableName}`;
|
|
1033
|
-
const queryArgs = {
|
|
1034
|
-
where: {
|
|
1035
|
-
type: filterArgs
|
|
1036
|
-
}
|
|
1037
|
-
};
|
|
1038
|
-
return {
|
|
1039
|
-
name: queryName,
|
|
1040
|
-
resolver: async (source, args, context, info) => {
|
|
1041
|
-
try {
|
|
1042
|
-
const { where } = args;
|
|
1043
|
-
let query = db.delete(table);
|
|
1044
|
-
if (where) {
|
|
1045
|
-
const filters = extractFilters(table, tableName, where);
|
|
1046
|
-
query = query.where(filters);
|
|
1047
|
-
}
|
|
1048
|
-
await query;
|
|
1049
|
-
return { isSuccess: true };
|
|
1050
|
-
} catch (e) {
|
|
1051
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1052
|
-
throw new import_graphql4.GraphQLError(e.message);
|
|
1053
|
-
}
|
|
1054
|
-
throw e;
|
|
1055
|
-
}
|
|
1056
|
-
},
|
|
1057
|
-
args: queryArgs
|
|
1058
|
-
};
|
|
1059
|
-
};
|
|
1060
|
-
var generateSchemaData = (db, schema, relationsDepthLimit) => {
|
|
1061
|
-
const rawSchema = schema;
|
|
1062
|
-
const schemaEntries = Object.entries(rawSchema);
|
|
1063
|
-
const tableEntries = schemaEntries.filter(([key, value]) => (0, import_drizzle_orm4.is)(value, import_mysql_core2.MySqlTable));
|
|
1064
|
-
const tables = Object.fromEntries(tableEntries);
|
|
1065
|
-
if (!tableEntries.length) {
|
|
1066
|
-
throw new Error(
|
|
1067
|
-
"Drizzle-GraphQL Error: No tables detected in Drizzle-ORM's database instance. Did you forget to pass schema to drizzle constructor?"
|
|
1068
|
-
);
|
|
1069
|
-
}
|
|
1070
|
-
const rawRelations = schemaEntries.filter(([key, value]) => (0, import_drizzle_orm4.is)(value, import_drizzle_orm4.Relations)).map(([key, value]) => [
|
|
1071
|
-
tableEntries.find(
|
|
1072
|
-
([tableName, tableValue]) => tableValue === value.table
|
|
1073
|
-
)[0],
|
|
1074
|
-
value
|
|
1075
|
-
]).map(([tableName, relValue]) => [
|
|
1076
|
-
tableName,
|
|
1077
|
-
relValue.config((0, import_drizzle_orm4.createTableRelationsHelpers)(tables[tableName]))
|
|
1078
|
-
]);
|
|
1079
|
-
const namedRelations = Object.fromEntries(
|
|
1080
|
-
rawRelations.map(([relName, config]) => {
|
|
1081
|
-
const namedConfig = Object.fromEntries(
|
|
1082
|
-
Object.entries(config).map(([innerRelName, innerRelValue]) => [innerRelName, {
|
|
1083
|
-
relation: innerRelValue,
|
|
1084
|
-
targetTableName: tableEntries.find(
|
|
1085
|
-
([tableName, tableValue]) => tableValue === innerRelValue.referencedTable
|
|
1086
|
-
)[0]
|
|
1087
|
-
}])
|
|
1088
|
-
);
|
|
1089
|
-
return [
|
|
1090
|
-
relName,
|
|
1091
|
-
namedConfig
|
|
1092
|
-
];
|
|
1093
|
-
})
|
|
1094
|
-
);
|
|
1095
|
-
const queries = {};
|
|
1096
|
-
const mutations = {};
|
|
1097
|
-
const gqlSchemaTypes = Object.fromEntries(
|
|
1098
|
-
Object.entries(tables).map(([tableName, table]) => [
|
|
1099
|
-
tableName,
|
|
1100
|
-
generateTableTypes(tableName, tables, namedRelations, false, relationsDepthLimit)
|
|
1101
|
-
])
|
|
1102
|
-
);
|
|
1103
|
-
const mutationReturnType = new import_graphql4.GraphQLObjectType({
|
|
1104
|
-
name: `MutationReturn`,
|
|
1105
|
-
fields: {
|
|
1106
|
-
isSuccess: {
|
|
1107
|
-
type: new import_graphql4.GraphQLNonNull(import_graphql4.GraphQLBoolean)
|
|
1108
|
-
}
|
|
1109
|
-
}
|
|
1110
|
-
});
|
|
1111
|
-
const inputs = {};
|
|
1112
|
-
const outputs = {
|
|
1113
|
-
MutationReturn: mutationReturnType
|
|
1114
|
-
};
|
|
1115
|
-
for (const [tableName, tableTypes] of Object.entries(gqlSchemaTypes)) {
|
|
1116
|
-
const { insertInput, updateInput, tableFilters, tableOrder } = tableTypes.inputs;
|
|
1117
|
-
const { selectSingleOutput, selectArrOutput } = tableTypes.outputs;
|
|
1118
|
-
const selectArrGenerated = generateSelectArray(
|
|
1119
|
-
db,
|
|
1120
|
-
tableName,
|
|
1121
|
-
tables,
|
|
1122
|
-
namedRelations,
|
|
1123
|
-
tableOrder,
|
|
1124
|
-
tableFilters
|
|
1125
|
-
);
|
|
1126
|
-
const selectSingleGenerated = generateSelectSingle(
|
|
1127
|
-
db,
|
|
1128
|
-
tableName,
|
|
1129
|
-
tables,
|
|
1130
|
-
namedRelations,
|
|
1131
|
-
tableOrder,
|
|
1132
|
-
tableFilters
|
|
1133
|
-
);
|
|
1134
|
-
const insertArrGenerated = generateInsertArray(db, tableName, schema[tableName], insertInput);
|
|
1135
|
-
const insertSingleGenerated = generateInsertSingle(db, tableName, schema[tableName], insertInput);
|
|
1136
|
-
const updateGenerated = generateUpdate(
|
|
1137
|
-
db,
|
|
1138
|
-
tableName,
|
|
1139
|
-
schema[tableName],
|
|
1140
|
-
updateInput,
|
|
1141
|
-
tableFilters
|
|
1142
|
-
);
|
|
1143
|
-
const deleteGenerated = generateDelete(db, tableName, schema[tableName], tableFilters);
|
|
1144
|
-
queries[selectArrGenerated.name] = {
|
|
1145
|
-
type: selectArrOutput,
|
|
1146
|
-
args: selectArrGenerated.args,
|
|
1147
|
-
resolve: selectArrGenerated.resolver
|
|
1148
|
-
};
|
|
1149
|
-
queries[selectSingleGenerated.name] = {
|
|
1150
|
-
type: selectSingleOutput,
|
|
1151
|
-
args: selectSingleGenerated.args,
|
|
1152
|
-
resolve: selectSingleGenerated.resolver
|
|
1153
|
-
};
|
|
1154
|
-
mutations[insertArrGenerated.name] = {
|
|
1155
|
-
type: mutationReturnType,
|
|
1156
|
-
args: insertArrGenerated.args,
|
|
1157
|
-
resolve: insertArrGenerated.resolver
|
|
1158
|
-
};
|
|
1159
|
-
mutations[insertSingleGenerated.name] = {
|
|
1160
|
-
type: mutationReturnType,
|
|
1161
|
-
args: insertSingleGenerated.args,
|
|
1162
|
-
resolve: insertSingleGenerated.resolver
|
|
1163
|
-
};
|
|
1164
|
-
mutations[updateGenerated.name] = {
|
|
1165
|
-
type: mutationReturnType,
|
|
1166
|
-
args: updateGenerated.args,
|
|
1167
|
-
resolve: updateGenerated.resolver
|
|
1168
|
-
};
|
|
1169
|
-
mutations[deleteGenerated.name] = {
|
|
1170
|
-
type: mutationReturnType,
|
|
1171
|
-
args: deleteGenerated.args,
|
|
1172
|
-
resolve: deleteGenerated.resolver
|
|
1173
|
-
};
|
|
1174
|
-
[insertInput, updateInput, tableFilters, tableOrder].forEach((e) => inputs[e.name] = e);
|
|
1175
|
-
outputs[selectSingleOutput.name] = selectSingleOutput;
|
|
1176
|
-
}
|
|
1177
|
-
return { queries, mutations, inputs, types: outputs };
|
|
1178
|
-
};
|
|
1179
|
-
|
|
1180
|
-
// src/util/builders/pg.ts
|
|
1181
|
-
var import_drizzle_orm5 = require("drizzle-orm");
|
|
1182
|
-
var import_pg_core2 = require("drizzle-orm/pg-core");
|
|
1183
|
-
var import_graphql5 = require("graphql");
|
|
1184
|
-
var import_graphql_parse_resolve_info2 = require("graphql-parse-resolve-info");
|
|
1185
|
-
var generateSelectArray2 = (db, tableName, tables, relationMap, orderArgs, filterArgs) => {
|
|
1186
|
-
const queryName = `${uncapitalize(tableName)}`;
|
|
1187
|
-
const queryBase = db.query[tableName];
|
|
1188
|
-
if (!queryBase) {
|
|
1189
|
-
throw new Error(
|
|
1190
|
-
`Drizzle-GraphQL Error: Table ${tableName} not found in drizzle instance. Did you forget to pass schema to drizzle constructor?`
|
|
1191
|
-
);
|
|
1192
|
-
}
|
|
1193
|
-
const queryArgs = {
|
|
1194
|
-
offset: {
|
|
1195
|
-
type: import_graphql5.GraphQLInt
|
|
1196
|
-
},
|
|
1197
|
-
limit: {
|
|
1198
|
-
type: import_graphql5.GraphQLInt
|
|
1199
|
-
},
|
|
1200
|
-
orderBy: {
|
|
1201
|
-
type: orderArgs
|
|
1202
|
-
},
|
|
1203
|
-
where: {
|
|
1204
|
-
type: filterArgs
|
|
1205
|
-
}
|
|
1206
|
-
};
|
|
1207
|
-
const typeName = `${capitalize(tableName)}SelectItem`;
|
|
1208
|
-
const table = tables[tableName];
|
|
1209
|
-
return {
|
|
1210
|
-
name: queryName,
|
|
1211
|
-
resolver: async (source, args, context, info) => {
|
|
1212
|
-
try {
|
|
1213
|
-
const { offset, limit, orderBy, where } = args;
|
|
1214
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info2.parseResolveInfo)(info, {
|
|
1215
|
-
deep: true
|
|
1216
|
-
});
|
|
1217
|
-
const query = queryBase.findMany({
|
|
1218
|
-
columns: extractSelectedColumnsFromTree(
|
|
1219
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1220
|
-
table
|
|
1221
|
-
),
|
|
1222
|
-
/*extractSelectedColumnsFromNode(tableSelection, info.fragments, table) */
|
|
1223
|
-
offset,
|
|
1224
|
-
limit,
|
|
1225
|
-
orderBy: orderBy ? extractOrderBy(table, orderBy) : void 0,
|
|
1226
|
-
where: where ? extractFilters(table, tableName, where) : void 0,
|
|
1227
|
-
with: relationMap[tableName] ? extractRelationsParams(relationMap, tables, tableName, parsedInfo, typeName) : void 0
|
|
1228
|
-
});
|
|
1229
|
-
const result = await query;
|
|
1230
|
-
return remapToGraphQLArrayOutput(result, tableName, table, relationMap);
|
|
1231
|
-
} catch (e) {
|
|
1232
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1233
|
-
throw new import_graphql5.GraphQLError(e.message);
|
|
1234
|
-
}
|
|
1235
|
-
throw e;
|
|
1236
|
-
}
|
|
1237
|
-
},
|
|
1238
|
-
args: queryArgs
|
|
1239
|
-
};
|
|
1240
|
-
};
|
|
1241
|
-
var generateSelectSingle2 = (db, tableName, tables, relationMap, orderArgs, filterArgs) => {
|
|
1242
|
-
const queryName = `${uncapitalize(tableName)}Single`;
|
|
1243
|
-
const queryBase = db.query[tableName];
|
|
1244
|
-
if (!queryBase) {
|
|
1245
|
-
throw new Error(
|
|
1246
|
-
`Drizzle-GraphQL Error: Table ${tableName} not found in drizzle instance. Did you forget to pass schema to drizzle constructor?`
|
|
1247
|
-
);
|
|
1248
|
-
}
|
|
1249
|
-
const queryArgs = {
|
|
1250
|
-
offset: {
|
|
1251
|
-
type: import_graphql5.GraphQLInt
|
|
1252
|
-
},
|
|
1253
|
-
orderBy: {
|
|
1254
|
-
type: orderArgs
|
|
1255
|
-
},
|
|
1256
|
-
where: {
|
|
1257
|
-
type: filterArgs
|
|
1258
|
-
}
|
|
1259
|
-
};
|
|
1260
|
-
const typeName = `${capitalize(tableName)}SelectItem`;
|
|
1261
|
-
const table = tables[tableName];
|
|
1262
|
-
return {
|
|
1263
|
-
name: queryName,
|
|
1264
|
-
resolver: async (source, args, context, info) => {
|
|
1265
|
-
try {
|
|
1266
|
-
const { offset, orderBy, where } = args;
|
|
1267
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info2.parseResolveInfo)(info, {
|
|
1268
|
-
deep: true
|
|
1269
|
-
});
|
|
1270
|
-
const query = queryBase.findFirst({
|
|
1271
|
-
columns: extractSelectedColumnsFromTree(
|
|
1272
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1273
|
-
table
|
|
1274
|
-
),
|
|
1275
|
-
offset,
|
|
1276
|
-
orderBy: orderBy ? extractOrderBy(table, orderBy) : void 0,
|
|
1277
|
-
where: where ? extractFilters(table, tableName, where) : void 0,
|
|
1278
|
-
with: relationMap[tableName] ? extractRelationsParams(relationMap, tables, tableName, parsedInfo, typeName) : void 0
|
|
1279
|
-
});
|
|
1280
|
-
const result = await query;
|
|
1281
|
-
if (!result)
|
|
1282
|
-
return void 0;
|
|
1283
|
-
return remapToGraphQLSingleOutput(result, tableName, table, relationMap);
|
|
1284
|
-
} catch (e) {
|
|
1285
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1286
|
-
throw new import_graphql5.GraphQLError(e.message);
|
|
1287
|
-
}
|
|
1288
|
-
throw e;
|
|
1289
|
-
}
|
|
1290
|
-
},
|
|
1291
|
-
args: queryArgs
|
|
1292
|
-
};
|
|
1293
|
-
};
|
|
1294
|
-
var generateInsertArray2 = (db, tableName, table, baseType) => {
|
|
1295
|
-
const queryName = `insertInto${capitalize(tableName)}`;
|
|
1296
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1297
|
-
const queryArgs = {
|
|
1298
|
-
values: {
|
|
1299
|
-
type: new import_graphql5.GraphQLNonNull(new import_graphql5.GraphQLList(new import_graphql5.GraphQLNonNull(baseType)))
|
|
1300
|
-
}
|
|
1301
|
-
};
|
|
1302
|
-
return {
|
|
1303
|
-
name: queryName,
|
|
1304
|
-
resolver: async (source, args, context, info) => {
|
|
1305
|
-
try {
|
|
1306
|
-
const input = remapFromGraphQLArrayInput(args.values, table);
|
|
1307
|
-
if (!input.length)
|
|
1308
|
-
throw new import_graphql5.GraphQLError("No values were provided!");
|
|
1309
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info2.parseResolveInfo)(info, {
|
|
1310
|
-
deep: true
|
|
1311
|
-
});
|
|
1312
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1313
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1314
|
-
table
|
|
1315
|
-
);
|
|
1316
|
-
const result = await db.insert(table).values(input).returning(columns).onConflictDoNothing();
|
|
1317
|
-
return remapToGraphQLArrayOutput(result, tableName, table);
|
|
1318
|
-
} catch (e) {
|
|
1319
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1320
|
-
throw new import_graphql5.GraphQLError(e.message);
|
|
1321
|
-
}
|
|
1322
|
-
throw e;
|
|
1323
|
-
}
|
|
1324
|
-
},
|
|
1325
|
-
args: queryArgs
|
|
1326
|
-
};
|
|
1327
|
-
};
|
|
1328
|
-
var generateInsertSingle2 = (db, tableName, table, baseType) => {
|
|
1329
|
-
const queryName = `insertInto${capitalize(tableName)}Single`;
|
|
1330
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1331
|
-
const queryArgs = {
|
|
1332
|
-
values: {
|
|
1333
|
-
type: new import_graphql5.GraphQLNonNull(baseType)
|
|
1334
|
-
}
|
|
1335
|
-
};
|
|
1336
|
-
return {
|
|
1337
|
-
name: queryName,
|
|
1338
|
-
resolver: async (source, args, context, info) => {
|
|
1339
|
-
try {
|
|
1340
|
-
const input = remapFromGraphQLSingleInput(args.values, table);
|
|
1341
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info2.parseResolveInfo)(info, {
|
|
1342
|
-
deep: true
|
|
1343
|
-
});
|
|
1344
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1345
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1346
|
-
table
|
|
1347
|
-
);
|
|
1348
|
-
const result = await db.insert(table).values(input).returning(columns).onConflictDoNothing();
|
|
1349
|
-
if (!result[0])
|
|
1350
|
-
return void 0;
|
|
1351
|
-
return remapToGraphQLSingleOutput(result[0], tableName, table);
|
|
1352
|
-
} catch (e) {
|
|
1353
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1354
|
-
throw new import_graphql5.GraphQLError(e.message);
|
|
1355
|
-
}
|
|
1356
|
-
throw e;
|
|
1357
|
-
}
|
|
1358
|
-
},
|
|
1359
|
-
args: queryArgs
|
|
1360
|
-
};
|
|
1361
|
-
};
|
|
1362
|
-
var generateUpdate2 = (db, tableName, table, setArgs, filterArgs) => {
|
|
1363
|
-
const queryName = `update${capitalize(tableName)}`;
|
|
1364
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1365
|
-
const queryArgs = {
|
|
1366
|
-
set: {
|
|
1367
|
-
type: new import_graphql5.GraphQLNonNull(setArgs)
|
|
1368
|
-
},
|
|
1369
|
-
where: {
|
|
1370
|
-
type: filterArgs
|
|
1371
|
-
}
|
|
1372
|
-
};
|
|
1373
|
-
return {
|
|
1374
|
-
name: queryName,
|
|
1375
|
-
resolver: async (source, args, context, info) => {
|
|
1376
|
-
try {
|
|
1377
|
-
const { where, set } = args;
|
|
1378
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info2.parseResolveInfo)(info, {
|
|
1379
|
-
deep: true
|
|
1380
|
-
});
|
|
1381
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1382
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1383
|
-
table
|
|
1384
|
-
);
|
|
1385
|
-
const input = remapFromGraphQLSingleInput(set, table);
|
|
1386
|
-
if (!Object.keys(input).length)
|
|
1387
|
-
throw new import_graphql5.GraphQLError("Unable to update with no values specified!");
|
|
1388
|
-
let query = db.update(table).set(input);
|
|
1389
|
-
if (where) {
|
|
1390
|
-
const filters = extractFilters(table, tableName, where);
|
|
1391
|
-
query = query.where(filters);
|
|
1392
|
-
}
|
|
1393
|
-
query = query.returning(columns);
|
|
1394
|
-
const result = await query;
|
|
1395
|
-
return remapToGraphQLArrayOutput(result, tableName, table);
|
|
1396
|
-
} catch (e) {
|
|
1397
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1398
|
-
throw new import_graphql5.GraphQLError(e.message);
|
|
1399
|
-
}
|
|
1400
|
-
throw e;
|
|
1401
|
-
}
|
|
1402
|
-
},
|
|
1403
|
-
args: queryArgs
|
|
1404
|
-
};
|
|
1405
|
-
};
|
|
1406
|
-
var generateDelete2 = (db, tableName, table, filterArgs) => {
|
|
1407
|
-
const queryName = `deleteFrom${capitalize(tableName)}`;
|
|
1408
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1409
|
-
const queryArgs = {
|
|
1410
|
-
where: {
|
|
1411
|
-
type: filterArgs
|
|
1412
|
-
}
|
|
1413
|
-
};
|
|
1414
|
-
return {
|
|
1415
|
-
name: queryName,
|
|
1416
|
-
resolver: async (source, args, context, info) => {
|
|
1417
|
-
try {
|
|
1418
|
-
const { where } = args;
|
|
1419
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info2.parseResolveInfo)(info, {
|
|
1420
|
-
deep: true
|
|
1421
|
-
});
|
|
1422
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1423
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1424
|
-
table
|
|
1425
|
-
);
|
|
1426
|
-
let query = db.delete(table);
|
|
1427
|
-
if (where) {
|
|
1428
|
-
const filters = extractFilters(table, tableName, where);
|
|
1429
|
-
query = query.where(filters);
|
|
1430
|
-
}
|
|
1431
|
-
query = query.returning(columns);
|
|
1432
|
-
const result = await query;
|
|
1433
|
-
return remapToGraphQLArrayOutput(result, tableName, table);
|
|
1434
|
-
} catch (e) {
|
|
1435
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1436
|
-
throw new import_graphql5.GraphQLError(e.message);
|
|
1437
|
-
}
|
|
1438
|
-
throw e;
|
|
1439
|
-
}
|
|
1440
|
-
},
|
|
1441
|
-
args: queryArgs
|
|
1442
|
-
};
|
|
1443
|
-
};
|
|
1444
|
-
var generateSchemaData2 = (db, schema, relationsDepthLimit) => {
|
|
1445
|
-
const rawSchema = schema;
|
|
1446
|
-
const schemaEntries = Object.entries(rawSchema);
|
|
1447
|
-
const tableEntries = schemaEntries.filter(([key, value]) => (0, import_drizzle_orm5.is)(value, import_pg_core2.PgTable));
|
|
1448
|
-
const tables = Object.fromEntries(tableEntries);
|
|
1449
|
-
if (!tableEntries.length) {
|
|
1450
|
-
throw new Error(
|
|
1451
|
-
"Drizzle-GraphQL Error: No tables detected in Drizzle-ORM's database instance. Did you forget to pass schema to drizzle constructor?"
|
|
1452
|
-
);
|
|
1453
|
-
}
|
|
1454
|
-
const rawRelations = schemaEntries.filter(([key, value]) => (0, import_drizzle_orm5.is)(value, import_drizzle_orm5.Relations)).map(([key, value]) => [
|
|
1455
|
-
tableEntries.find(
|
|
1456
|
-
([tableName, tableValue]) => tableValue === value.table
|
|
1457
|
-
)[0],
|
|
1458
|
-
value
|
|
1459
|
-
]).map(([tableName, relValue]) => [
|
|
1460
|
-
tableName,
|
|
1461
|
-
relValue.config((0, import_drizzle_orm5.createTableRelationsHelpers)(tables[tableName]))
|
|
1462
|
-
]);
|
|
1463
|
-
const namedRelations = Object.fromEntries(
|
|
1464
|
-
rawRelations.map(([relName, config]) => {
|
|
1465
|
-
const namedConfig = Object.fromEntries(
|
|
1466
|
-
Object.entries(config).map(([innerRelName, innerRelValue]) => [innerRelName, {
|
|
1467
|
-
relation: innerRelValue,
|
|
1468
|
-
targetTableName: tableEntries.find(
|
|
1469
|
-
([tableName, tableValue]) => tableValue === innerRelValue.referencedTable
|
|
1470
|
-
)[0]
|
|
1471
|
-
}])
|
|
1472
|
-
);
|
|
1473
|
-
return [
|
|
1474
|
-
relName,
|
|
1475
|
-
namedConfig
|
|
1476
|
-
];
|
|
1477
|
-
})
|
|
1478
|
-
);
|
|
1479
|
-
const queries = {};
|
|
1480
|
-
const mutations = {};
|
|
1481
|
-
const gqlSchemaTypes = Object.fromEntries(
|
|
1482
|
-
Object.entries(tables).map(([tableName, table]) => [
|
|
1483
|
-
tableName,
|
|
1484
|
-
generateTableTypes(tableName, tables, namedRelations, true, relationsDepthLimit)
|
|
1485
|
-
])
|
|
1486
|
-
);
|
|
1487
|
-
const inputs = {};
|
|
1488
|
-
const outputs = {};
|
|
1489
|
-
for (const [tableName, tableTypes] of Object.entries(gqlSchemaTypes)) {
|
|
1490
|
-
const { insertInput, updateInput, tableFilters, tableOrder } = tableTypes.inputs;
|
|
1491
|
-
const { selectSingleOutput, selectArrOutput, singleTableItemOutput, arrTableItemOutput } = tableTypes.outputs;
|
|
1492
|
-
const selectArrGenerated = generateSelectArray2(
|
|
1493
|
-
db,
|
|
1494
|
-
tableName,
|
|
1495
|
-
tables,
|
|
1496
|
-
namedRelations,
|
|
1497
|
-
tableOrder,
|
|
1498
|
-
tableFilters
|
|
1499
|
-
);
|
|
1500
|
-
const selectSingleGenerated = generateSelectSingle2(
|
|
1501
|
-
db,
|
|
1502
|
-
tableName,
|
|
1503
|
-
tables,
|
|
1504
|
-
namedRelations,
|
|
1505
|
-
tableOrder,
|
|
1506
|
-
tableFilters
|
|
1507
|
-
);
|
|
1508
|
-
const insertArrGenerated = generateInsertArray2(db, tableName, schema[tableName], insertInput);
|
|
1509
|
-
const insertSingleGenerated = generateInsertSingle2(db, tableName, schema[tableName], insertInput);
|
|
1510
|
-
const updateGenerated = generateUpdate2(db, tableName, schema[tableName], updateInput, tableFilters);
|
|
1511
|
-
const deleteGenerated = generateDelete2(db, tableName, schema[tableName], tableFilters);
|
|
1512
|
-
queries[selectArrGenerated.name] = {
|
|
1513
|
-
type: selectArrOutput,
|
|
1514
|
-
args: selectArrGenerated.args,
|
|
1515
|
-
resolve: selectArrGenerated.resolver
|
|
1516
|
-
};
|
|
1517
|
-
queries[selectSingleGenerated.name] = {
|
|
1518
|
-
type: selectSingleOutput,
|
|
1519
|
-
args: selectSingleGenerated.args,
|
|
1520
|
-
resolve: selectSingleGenerated.resolver
|
|
1521
|
-
};
|
|
1522
|
-
mutations[insertArrGenerated.name] = {
|
|
1523
|
-
type: arrTableItemOutput,
|
|
1524
|
-
args: insertArrGenerated.args,
|
|
1525
|
-
resolve: insertArrGenerated.resolver
|
|
1526
|
-
};
|
|
1527
|
-
mutations[insertSingleGenerated.name] = {
|
|
1528
|
-
type: singleTableItemOutput,
|
|
1529
|
-
args: insertSingleGenerated.args,
|
|
1530
|
-
resolve: insertSingleGenerated.resolver
|
|
1531
|
-
};
|
|
1532
|
-
mutations[updateGenerated.name] = {
|
|
1533
|
-
type: arrTableItemOutput,
|
|
1534
|
-
args: updateGenerated.args,
|
|
1535
|
-
resolve: updateGenerated.resolver
|
|
1536
|
-
};
|
|
1537
|
-
mutations[deleteGenerated.name] = {
|
|
1538
|
-
type: arrTableItemOutput,
|
|
1539
|
-
args: deleteGenerated.args,
|
|
1540
|
-
resolve: deleteGenerated.resolver
|
|
1541
|
-
};
|
|
1542
|
-
[insertInput, updateInput, tableFilters, tableOrder].forEach((e) => inputs[e.name] = e);
|
|
1543
|
-
outputs[selectSingleOutput.name] = selectSingleOutput;
|
|
1544
|
-
outputs[singleTableItemOutput.name] = singleTableItemOutput;
|
|
1545
|
-
}
|
|
1546
|
-
return { queries, mutations, inputs, types: outputs };
|
|
1547
|
-
};
|
|
1548
|
-
|
|
1549
|
-
// src/util/builders/sqlite.ts
|
|
1550
|
-
var import_drizzle_orm6 = require("drizzle-orm");
|
|
1551
|
-
var import_sqlite_core2 = require("drizzle-orm/sqlite-core");
|
|
1552
|
-
var import_graphql6 = require("graphql");
|
|
1553
|
-
var import_graphql_parse_resolve_info3 = require("graphql-parse-resolve-info");
|
|
1554
|
-
var generateSelectArray3 = (db, tableName, tables, relationMap, orderArgs, filterArgs) => {
|
|
1555
|
-
const queryName = `${uncapitalize(tableName)}`;
|
|
1556
|
-
const queryBase = db.query[tableName];
|
|
1557
|
-
if (!queryBase) {
|
|
1558
|
-
throw new Error(
|
|
1559
|
-
`Drizzle-GraphQL Error: Table ${tableName} not found in drizzle instance. Did you forget to pass schema to drizzle constructor?`
|
|
1560
|
-
);
|
|
1561
|
-
}
|
|
1562
|
-
const queryArgs = {
|
|
1563
|
-
offset: {
|
|
1564
|
-
type: import_graphql6.GraphQLInt
|
|
1565
|
-
},
|
|
1566
|
-
limit: {
|
|
1567
|
-
type: import_graphql6.GraphQLInt
|
|
1568
|
-
},
|
|
1569
|
-
orderBy: {
|
|
1570
|
-
type: orderArgs
|
|
1571
|
-
},
|
|
1572
|
-
where: {
|
|
1573
|
-
type: filterArgs
|
|
1574
|
-
}
|
|
1575
|
-
};
|
|
1576
|
-
const typeName = `${capitalize(tableName)}SelectItem`;
|
|
1577
|
-
const table = tables[tableName];
|
|
1578
|
-
return {
|
|
1579
|
-
name: queryName,
|
|
1580
|
-
resolver: async (source, args, context, info) => {
|
|
1581
|
-
try {
|
|
1582
|
-
const { offset, limit, orderBy, where } = args;
|
|
1583
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info3.parseResolveInfo)(info, {
|
|
1584
|
-
deep: true
|
|
1585
|
-
});
|
|
1586
|
-
const query = queryBase.findMany({
|
|
1587
|
-
columns: extractSelectedColumnsFromTree(
|
|
1588
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1589
|
-
table
|
|
1590
|
-
),
|
|
1591
|
-
offset,
|
|
1592
|
-
limit,
|
|
1593
|
-
orderBy: orderBy ? extractOrderBy(table, orderBy) : void 0,
|
|
1594
|
-
where: where ? extractFilters(table, tableName, where) : void 0,
|
|
1595
|
-
with: relationMap[tableName] ? extractRelationsParams(relationMap, tables, tableName, parsedInfo, typeName) : void 0
|
|
1596
|
-
});
|
|
1597
|
-
const result = await query;
|
|
1598
|
-
return remapToGraphQLArrayOutput(result, tableName, table, relationMap);
|
|
1599
|
-
} catch (e) {
|
|
1600
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1601
|
-
throw new import_graphql6.GraphQLError(e.message);
|
|
1602
|
-
}
|
|
1603
|
-
throw e;
|
|
1604
|
-
}
|
|
1605
|
-
},
|
|
1606
|
-
args: queryArgs
|
|
1607
|
-
};
|
|
1608
|
-
};
|
|
1609
|
-
var generateSelectSingle3 = (db, tableName, tables, relationMap, orderArgs, filterArgs) => {
|
|
1610
|
-
const queryName = `${uncapitalize(tableName)}Single`;
|
|
1611
|
-
const queryBase = db.query[tableName];
|
|
1612
|
-
if (!queryBase) {
|
|
1613
|
-
throw new Error(
|
|
1614
|
-
`Drizzle-GraphQL Error: Table ${tableName} not found in drizzle instance. Did you forget to pass schema to drizzle constructor?`
|
|
1615
|
-
);
|
|
1616
|
-
}
|
|
1617
|
-
const queryArgs = {
|
|
1618
|
-
offset: {
|
|
1619
|
-
type: import_graphql6.GraphQLInt
|
|
1620
|
-
},
|
|
1621
|
-
orderBy: {
|
|
1622
|
-
type: orderArgs
|
|
1623
|
-
},
|
|
1624
|
-
where: {
|
|
1625
|
-
type: filterArgs
|
|
1626
|
-
}
|
|
1627
|
-
};
|
|
1628
|
-
const typeName = `${capitalize(tableName)}SelectItem`;
|
|
1629
|
-
const table = tables[tableName];
|
|
1630
|
-
return {
|
|
1631
|
-
name: queryName,
|
|
1632
|
-
resolver: async (source, args, context, info) => {
|
|
1633
|
-
try {
|
|
1634
|
-
const { offset, orderBy, where } = args;
|
|
1635
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info3.parseResolveInfo)(info, {
|
|
1636
|
-
deep: true
|
|
1637
|
-
});
|
|
1638
|
-
const query = queryBase.findFirst({
|
|
1639
|
-
columns: extractSelectedColumnsFromTree(
|
|
1640
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1641
|
-
table
|
|
1642
|
-
),
|
|
1643
|
-
offset,
|
|
1644
|
-
orderBy: orderBy ? extractOrderBy(table, orderBy) : void 0,
|
|
1645
|
-
where: where ? extractFilters(table, tableName, where) : void 0,
|
|
1646
|
-
with: relationMap[tableName] ? extractRelationsParams(relationMap, tables, tableName, parsedInfo, typeName) : void 0
|
|
1647
|
-
});
|
|
1648
|
-
const result = await query;
|
|
1649
|
-
if (!result)
|
|
1650
|
-
return void 0;
|
|
1651
|
-
return remapToGraphQLSingleOutput(result, tableName, table, relationMap);
|
|
1652
|
-
} catch (e) {
|
|
1653
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1654
|
-
throw new import_graphql6.GraphQLError(e.message);
|
|
1655
|
-
}
|
|
1656
|
-
throw e;
|
|
1657
|
-
}
|
|
1658
|
-
},
|
|
1659
|
-
args: queryArgs
|
|
1660
|
-
};
|
|
1661
|
-
};
|
|
1662
|
-
var generateInsertArray3 = (db, tableName, table, baseType) => {
|
|
1663
|
-
const queryName = `insertInto${capitalize(tableName)}`;
|
|
1664
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1665
|
-
const queryArgs = {
|
|
1666
|
-
values: {
|
|
1667
|
-
type: new import_graphql6.GraphQLNonNull(new import_graphql6.GraphQLList(new import_graphql6.GraphQLNonNull(baseType)))
|
|
1668
|
-
}
|
|
1669
|
-
};
|
|
1670
|
-
return {
|
|
1671
|
-
name: queryName,
|
|
1672
|
-
resolver: async (source, args, context, info) => {
|
|
1673
|
-
try {
|
|
1674
|
-
const input = remapFromGraphQLArrayInput(args.values, table);
|
|
1675
|
-
if (!input.length)
|
|
1676
|
-
throw new import_graphql6.GraphQLError("No values were provided!");
|
|
1677
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info3.parseResolveInfo)(info, {
|
|
1678
|
-
deep: true
|
|
1679
|
-
});
|
|
1680
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1681
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1682
|
-
table
|
|
1683
|
-
);
|
|
1684
|
-
const result = await db.insert(table).values(input).returning(columns).onConflictDoNothing();
|
|
1685
|
-
return remapToGraphQLArrayOutput(result, tableName, table);
|
|
1686
|
-
} catch (e) {
|
|
1687
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1688
|
-
throw new import_graphql6.GraphQLError(e.message);
|
|
1689
|
-
}
|
|
1690
|
-
throw e;
|
|
1691
|
-
}
|
|
1692
|
-
},
|
|
1693
|
-
args: queryArgs
|
|
1694
|
-
};
|
|
1695
|
-
};
|
|
1696
|
-
var generateInsertSingle3 = (db, tableName, table, baseType) => {
|
|
1697
|
-
const queryName = `insertInto${capitalize(tableName)}Single`;
|
|
1698
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1699
|
-
const queryArgs = {
|
|
1700
|
-
values: {
|
|
1701
|
-
type: new import_graphql6.GraphQLNonNull(baseType)
|
|
1702
|
-
}
|
|
1703
|
-
};
|
|
1704
|
-
return {
|
|
1705
|
-
name: queryName,
|
|
1706
|
-
resolver: async (source, args, context, info) => {
|
|
1707
|
-
try {
|
|
1708
|
-
const input = remapFromGraphQLSingleInput(args.values, table);
|
|
1709
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info3.parseResolveInfo)(info, {
|
|
1710
|
-
deep: true
|
|
1711
|
-
});
|
|
1712
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1713
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1714
|
-
table
|
|
1715
|
-
);
|
|
1716
|
-
const result = await db.insert(table).values(input).returning(columns).onConflictDoNothing();
|
|
1717
|
-
if (!result[0])
|
|
1718
|
-
return void 0;
|
|
1719
|
-
return remapToGraphQLSingleOutput(result[0], tableName, table);
|
|
1720
|
-
} catch (e) {
|
|
1721
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1722
|
-
throw new import_graphql6.GraphQLError(e.message);
|
|
1723
|
-
}
|
|
1724
|
-
throw e;
|
|
1725
|
-
}
|
|
1726
|
-
},
|
|
1727
|
-
args: queryArgs
|
|
1728
|
-
};
|
|
1729
|
-
};
|
|
1730
|
-
var generateUpdate3 = (db, tableName, table, setArgs, filterArgs) => {
|
|
1731
|
-
const queryName = `update${capitalize(tableName)}`;
|
|
1732
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1733
|
-
const queryArgs = {
|
|
1734
|
-
set: {
|
|
1735
|
-
type: new import_graphql6.GraphQLNonNull(setArgs)
|
|
1736
|
-
},
|
|
1737
|
-
where: {
|
|
1738
|
-
type: filterArgs
|
|
1739
|
-
}
|
|
1740
|
-
};
|
|
1741
|
-
return {
|
|
1742
|
-
name: queryName,
|
|
1743
|
-
resolver: async (source, args, context, info) => {
|
|
1744
|
-
try {
|
|
1745
|
-
const { where, set } = args;
|
|
1746
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info3.parseResolveInfo)(info, {
|
|
1747
|
-
deep: true
|
|
1748
|
-
});
|
|
1749
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1750
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1751
|
-
table
|
|
1752
|
-
);
|
|
1753
|
-
const input = remapFromGraphQLSingleInput(set, table);
|
|
1754
|
-
if (!Object.keys(input).length)
|
|
1755
|
-
throw new import_graphql6.GraphQLError("Unable to update with no values specified!");
|
|
1756
|
-
let query = db.update(table).set(input);
|
|
1757
|
-
if (where) {
|
|
1758
|
-
const filters = extractFilters(table, tableName, where);
|
|
1759
|
-
query = query.where(filters);
|
|
1760
|
-
}
|
|
1761
|
-
query = query.returning(columns);
|
|
1762
|
-
const result = await query;
|
|
1763
|
-
return remapToGraphQLArrayOutput(result, tableName, table);
|
|
1764
|
-
} catch (e) {
|
|
1765
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1766
|
-
throw new import_graphql6.GraphQLError(e.message);
|
|
1767
|
-
}
|
|
1768
|
-
throw e;
|
|
1769
|
-
}
|
|
1770
|
-
},
|
|
1771
|
-
args: queryArgs
|
|
1772
|
-
};
|
|
1773
|
-
};
|
|
1774
|
-
var generateDelete3 = (db, tableName, table, filterArgs) => {
|
|
1775
|
-
const queryName = `deleteFrom${capitalize(tableName)}`;
|
|
1776
|
-
const typeName = `${capitalize(tableName)}Item`;
|
|
1777
|
-
const queryArgs = {
|
|
1778
|
-
where: {
|
|
1779
|
-
type: filterArgs
|
|
1780
|
-
}
|
|
1781
|
-
};
|
|
1782
|
-
return {
|
|
1783
|
-
name: queryName,
|
|
1784
|
-
resolver: async (source, args, context, info) => {
|
|
1785
|
-
try {
|
|
1786
|
-
const { where } = args;
|
|
1787
|
-
const parsedInfo = (0, import_graphql_parse_resolve_info3.parseResolveInfo)(info, {
|
|
1788
|
-
deep: true
|
|
1789
|
-
});
|
|
1790
|
-
const columns = extractSelectedColumnsFromTreeSQLFormat(
|
|
1791
|
-
parsedInfo.fieldsByTypeName[typeName],
|
|
1792
|
-
table
|
|
1793
|
-
);
|
|
1794
|
-
let query = db.delete(table);
|
|
1795
|
-
if (where) {
|
|
1796
|
-
const filters = extractFilters(table, tableName, where);
|
|
1797
|
-
query = query.where(filters);
|
|
1798
|
-
}
|
|
1799
|
-
query = query.returning(columns);
|
|
1800
|
-
const result = await query;
|
|
1801
|
-
return remapToGraphQLArrayOutput(result, tableName, table);
|
|
1802
|
-
} catch (e) {
|
|
1803
|
-
if (typeof e === "object" && typeof e.message === "string") {
|
|
1804
|
-
throw new import_graphql6.GraphQLError(e.message);
|
|
1805
|
-
}
|
|
1806
|
-
throw e;
|
|
1807
|
-
}
|
|
1808
|
-
},
|
|
1809
|
-
args: queryArgs
|
|
1810
|
-
};
|
|
1811
|
-
};
|
|
1812
|
-
var generateSchemaData3 = (db, schema, relationsDepthLimit) => {
|
|
1813
|
-
const rawSchema = schema;
|
|
1814
|
-
const schemaEntries = Object.entries(rawSchema);
|
|
1815
|
-
const tableEntries = schemaEntries.filter(([key, value]) => (0, import_drizzle_orm6.is)(value, import_sqlite_core2.SQLiteTable));
|
|
1816
|
-
const tables = Object.fromEntries(tableEntries);
|
|
1817
|
-
if (!tableEntries.length) {
|
|
1818
|
-
throw new Error(
|
|
1819
|
-
"Drizzle-GraphQL Error: No tables detected in Drizzle-ORM's database instance. Did you forget to pass schema to drizzle constructor?"
|
|
1820
|
-
);
|
|
1821
|
-
}
|
|
1822
|
-
const rawRelations = schemaEntries.filter(([key, value]) => (0, import_drizzle_orm6.is)(value, import_drizzle_orm6.Relations)).map(([key, value]) => [
|
|
1823
|
-
tableEntries.find(
|
|
1824
|
-
([tableName, tableValue]) => tableValue === value.table
|
|
1825
|
-
)[0],
|
|
1826
|
-
value
|
|
1827
|
-
]).map(([tableName, relValue]) => [
|
|
1828
|
-
tableName,
|
|
1829
|
-
relValue.config((0, import_drizzle_orm6.createTableRelationsHelpers)(tables[tableName]))
|
|
1830
|
-
]);
|
|
1831
|
-
const namedRelations = Object.fromEntries(
|
|
1832
|
-
rawRelations.map(([relName, config]) => {
|
|
1833
|
-
const namedConfig = Object.fromEntries(
|
|
1834
|
-
Object.entries(config).map(([innerRelName, innerRelValue]) => [innerRelName, {
|
|
1835
|
-
relation: innerRelValue,
|
|
1836
|
-
targetTableName: tableEntries.find(
|
|
1837
|
-
([tableName, tableValue]) => tableValue === innerRelValue.referencedTable
|
|
1838
|
-
)[0]
|
|
1839
|
-
}])
|
|
1840
|
-
);
|
|
1841
|
-
return [
|
|
1842
|
-
relName,
|
|
1843
|
-
namedConfig
|
|
1844
|
-
];
|
|
1845
|
-
})
|
|
1846
|
-
);
|
|
1847
|
-
const queries = {};
|
|
1848
|
-
const mutations = {};
|
|
1849
|
-
const gqlSchemaTypes = Object.fromEntries(
|
|
1850
|
-
Object.entries(tables).map(([tableName, table]) => [
|
|
1851
|
-
tableName,
|
|
1852
|
-
generateTableTypes(tableName, tables, namedRelations, true, relationsDepthLimit)
|
|
1853
|
-
])
|
|
1854
|
-
);
|
|
1855
|
-
const inputs = {};
|
|
1856
|
-
const outputs = {};
|
|
1857
|
-
for (const [tableName, tableTypes] of Object.entries(gqlSchemaTypes)) {
|
|
1858
|
-
const { insertInput, updateInput, tableFilters, tableOrder } = tableTypes.inputs;
|
|
1859
|
-
const { selectSingleOutput, selectArrOutput, singleTableItemOutput, arrTableItemOutput } = tableTypes.outputs;
|
|
1860
|
-
const selectArrGenerated = generateSelectArray3(
|
|
1861
|
-
db,
|
|
1862
|
-
tableName,
|
|
1863
|
-
tables,
|
|
1864
|
-
namedRelations,
|
|
1865
|
-
tableOrder,
|
|
1866
|
-
tableFilters
|
|
1867
|
-
);
|
|
1868
|
-
const selectSingleGenerated = generateSelectSingle3(
|
|
1869
|
-
db,
|
|
1870
|
-
tableName,
|
|
1871
|
-
tables,
|
|
1872
|
-
namedRelations,
|
|
1873
|
-
tableOrder,
|
|
1874
|
-
tableFilters
|
|
1875
|
-
);
|
|
1876
|
-
const insertArrGenerated = generateInsertArray3(db, tableName, schema[tableName], insertInput);
|
|
1877
|
-
const insertSingleGenerated = generateInsertSingle3(db, tableName, schema[tableName], insertInput);
|
|
1878
|
-
const updateGenerated = generateUpdate3(
|
|
1879
|
-
db,
|
|
1880
|
-
tableName,
|
|
1881
|
-
schema[tableName],
|
|
1882
|
-
updateInput,
|
|
1883
|
-
tableFilters
|
|
1884
|
-
);
|
|
1885
|
-
const deleteGenerated = generateDelete3(db, tableName, schema[tableName], tableFilters);
|
|
1886
|
-
queries[selectArrGenerated.name] = {
|
|
1887
|
-
type: selectArrOutput,
|
|
1888
|
-
args: selectArrGenerated.args,
|
|
1889
|
-
resolve: selectArrGenerated.resolver
|
|
1890
|
-
};
|
|
1891
|
-
queries[selectSingleGenerated.name] = {
|
|
1892
|
-
type: selectSingleOutput,
|
|
1893
|
-
args: selectSingleGenerated.args,
|
|
1894
|
-
resolve: selectSingleGenerated.resolver
|
|
1895
|
-
};
|
|
1896
|
-
mutations[insertArrGenerated.name] = {
|
|
1897
|
-
type: arrTableItemOutput,
|
|
1898
|
-
args: insertArrGenerated.args,
|
|
1899
|
-
resolve: insertArrGenerated.resolver
|
|
1900
|
-
};
|
|
1901
|
-
mutations[insertSingleGenerated.name] = {
|
|
1902
|
-
type: singleTableItemOutput,
|
|
1903
|
-
args: insertSingleGenerated.args,
|
|
1904
|
-
resolve: insertSingleGenerated.resolver
|
|
1905
|
-
};
|
|
1906
|
-
mutations[updateGenerated.name] = {
|
|
1907
|
-
type: arrTableItemOutput,
|
|
1908
|
-
args: updateGenerated.args,
|
|
1909
|
-
resolve: updateGenerated.resolver
|
|
1910
|
-
};
|
|
1911
|
-
mutations[deleteGenerated.name] = {
|
|
1912
|
-
type: arrTableItemOutput,
|
|
1913
|
-
args: deleteGenerated.args,
|
|
1914
|
-
resolve: deleteGenerated.resolver
|
|
1915
|
-
};
|
|
1916
|
-
[insertInput, updateInput, tableFilters, tableOrder].forEach((e) => inputs[e.name] = e);
|
|
1917
|
-
outputs[selectSingleOutput.name] = selectSingleOutput;
|
|
1918
|
-
outputs[singleTableItemOutput.name] = singleTableItemOutput;
|
|
1919
|
-
}
|
|
1920
|
-
return { queries, mutations, inputs, types: outputs };
|
|
1921
|
-
};
|
|
1922
|
-
|
|
1923
|
-
// src/index.ts
|
|
1924
|
-
var buildSchema = (db, config) => {
|
|
1925
|
-
const schema = db._.fullSchema;
|
|
1926
|
-
if (!schema) {
|
|
1927
|
-
throw new Error(
|
|
1928
|
-
"Drizzle-GraphQL Error: Schema not found in drizzle instance. Make sure you're using drizzle-orm v0.30.9 or above and schema is passed to drizzle constructor!"
|
|
1929
|
-
);
|
|
1930
|
-
}
|
|
1931
|
-
if (typeof config?.relationsDepthLimit === "number") {
|
|
1932
|
-
if (config.relationsDepthLimit < 0) {
|
|
1933
|
-
throw new Error(
|
|
1934
|
-
"Drizzle-GraphQL Error: config.relationsDepthLimit is supposed to be nonnegative integer or undefined!"
|
|
1935
|
-
);
|
|
1936
|
-
}
|
|
1937
|
-
if (config.relationsDepthLimit !== ~~config.relationsDepthLimit) {
|
|
1938
|
-
throw new Error(
|
|
1939
|
-
"Drizzle-GraphQL Error: config.relationsDepthLimit is supposed to be nonnegative integer or undefined!"
|
|
1940
|
-
);
|
|
1941
|
-
}
|
|
1942
|
-
}
|
|
1943
|
-
let generatorOutput;
|
|
1944
|
-
if ((0, import_drizzle_orm7.is)(db, import_mysql_core3.MySqlDatabase)) {
|
|
1945
|
-
generatorOutput = generateSchemaData(db, schema, config?.relationsDepthLimit);
|
|
1946
|
-
} else if ((0, import_drizzle_orm7.is)(db, import_pg_core3.PgDatabase)) {
|
|
1947
|
-
generatorOutput = generateSchemaData2(db, schema, config?.relationsDepthLimit);
|
|
1948
|
-
} else if ((0, import_drizzle_orm7.is)(db, import_sqlite_core3.BaseSQLiteDatabase)) {
|
|
1949
|
-
generatorOutput = generateSchemaData3(db, schema, config?.relationsDepthLimit);
|
|
1950
|
-
} else
|
|
1951
|
-
throw new Error("Drizzle-GraphQL Error: Unknown database instance type");
|
|
1952
|
-
const { queries, mutations, inputs, types } = generatorOutput;
|
|
1953
|
-
const graphQLSchemaConfig = {
|
|
1954
|
-
types: [...Object.values(inputs), ...Object.values(types)],
|
|
1955
|
-
query: new import_graphql7.GraphQLObjectType({
|
|
1956
|
-
name: "Query",
|
|
1957
|
-
fields: queries
|
|
1958
|
-
})
|
|
1959
|
-
};
|
|
1960
|
-
if (config?.mutations !== false) {
|
|
1961
|
-
const mutation = new import_graphql7.GraphQLObjectType({
|
|
1962
|
-
name: "Mutation",
|
|
1963
|
-
fields: mutations
|
|
1964
|
-
});
|
|
1965
|
-
graphQLSchemaConfig.mutation = mutation;
|
|
1966
|
-
}
|
|
1967
|
-
const outputSchema = new import_graphql7.GraphQLSchema(graphQLSchemaConfig);
|
|
1968
|
-
return { schema: outputSchema, entities: generatorOutput };
|
|
1969
|
-
};
|
|
1970
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
1971
|
-
0 && (module.exports = {
|
|
1972
|
-
buildSchema
|
|
1973
|
-
});
|
|
1974
|
-
//# sourceMappingURL=index.cjs.map
|