drizzle-graphql-plus 0.8.7 → 0.8.8

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/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