@m1212e/rumble 0.6.3 → 0.6.5

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.d.cts CHANGED
@@ -123,17 +123,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
123
123
  query: {
124
124
  single: {
125
125
  readonly where: any;
126
- readonly columns: undefined;
126
+ columns: undefined;
127
127
  };
128
128
  many: {
129
129
  readonly where: any;
130
- readonly columns: undefined;
130
+ columns: undefined;
131
131
  readonly limit: any;
132
132
  };
133
133
  };
134
134
  sql: {
135
135
  readonly where: drizzle_orm.SQL<unknown> | undefined;
136
- readonly columns: undefined;
136
+ columns: undefined;
137
137
  readonly limit: any;
138
138
  };
139
139
  };
@@ -152,17 +152,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
152
152
  query: {
153
153
  single: {
154
154
  readonly where: any;
155
- readonly columns: undefined;
155
+ columns: undefined;
156
156
  };
157
157
  many: {
158
158
  readonly where: any;
159
- readonly columns: undefined;
159
+ columns: undefined;
160
160
  readonly limit: any;
161
161
  };
162
162
  };
163
163
  sql: {
164
164
  readonly where: drizzle_orm.SQL<unknown> | undefined;
165
- readonly columns: undefined;
165
+ columns: undefined;
166
166
  readonly limit: any;
167
167
  };
168
168
  };
@@ -215,17 +215,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
215
215
  query: {
216
216
  single: {
217
217
  readonly where: any;
218
- readonly columns: undefined;
218
+ columns: undefined;
219
219
  };
220
220
  many: {
221
221
  readonly where: any;
222
- readonly columns: undefined;
222
+ columns: undefined;
223
223
  readonly limit: any;
224
224
  };
225
225
  };
226
226
  sql: {
227
227
  readonly where: drizzle_orm.SQL<unknown> | undefined;
228
- readonly columns: undefined;
228
+ columns: undefined;
229
229
  readonly limit: any;
230
230
  };
231
231
  };
@@ -247,7 +247,39 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
247
247
  Output: Date;
248
248
  };
249
249
  };
250
- }>, any, any, any>) => SchemaBuilder.FieldMap) | undefined;
250
+ }>, drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName], NonNullable<Awaited<ReturnType<DB["query"][ExplicitTableName]["findFirst"]>>>, { [Key in keyof Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
251
+ _: {
252
+ brand: "Table";
253
+ };
254
+ }>["_"]["columns"] & string as Key]: Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
255
+ _: {
256
+ brand: "Table";
257
+ };
258
+ }>["_"]["columns"][Key]["_"]["notNull"] extends true ? Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
259
+ _: {
260
+ brand: "Table";
261
+ };
262
+ }>["_"]["columns"][Key]["_"]["data"] : Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
263
+ _: {
264
+ brand: "Table";
265
+ };
266
+ }>["_"]["columns"][Key]["_"]["data"] | null; } extends infer T_5 ? { [K in keyof T_5]: { [Key in keyof Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
267
+ _: {
268
+ brand: "Table";
269
+ };
270
+ }>["_"]["columns"] & string as Key]: Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
271
+ _: {
272
+ brand: "Table";
273
+ };
274
+ }>["_"]["columns"][Key]["_"]["notNull"] extends true ? Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
275
+ _: {
276
+ brand: "Table";
277
+ };
278
+ }>["_"]["columns"][Key]["_"]["data"] : Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
279
+ _: {
280
+ brand: "Table";
281
+ };
282
+ }>["_"]["columns"][Key]["_"]["data"] | null; }[K]; } : never>) => SchemaBuilder.FieldMap) | undefined;
251
283
  }) => _pothos_plugin_drizzle.DrizzleObjectRef<PothosSchemaTypes.ExtendDefaultTypes<{
252
284
  Context: Awaited<UserContext & {
253
285
  abilities: keyof DB["query"] extends infer T_4 extends keyof DB["query"] ? { [key_5 in T_4]: {
@@ -257,17 +289,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
257
289
  query: {
258
290
  single: {
259
291
  readonly where: any;
260
- readonly columns: undefined;
292
+ columns: undefined;
261
293
  };
262
294
  many: {
263
295
  readonly where: any;
264
- readonly columns: undefined;
296
+ columns: undefined;
265
297
  readonly limit: any;
266
298
  };
267
299
  };
268
300
  sql: {
269
301
  readonly where: drizzle_orm.SQL<unknown> | undefined;
270
- readonly columns: undefined;
302
+ columns: undefined;
271
303
  readonly limit: any;
272
304
  };
273
305
  };
@@ -310,17 +342,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
310
342
  query: {
311
343
  single: {
312
344
  readonly where: any;
313
- readonly columns: undefined;
345
+ columns: undefined;
314
346
  };
315
347
  many: {
316
348
  readonly where: any;
317
- readonly columns: undefined;
349
+ columns: undefined;
318
350
  readonly limit: any;
319
351
  };
320
352
  };
321
353
  sql: {
322
354
  readonly where: drizzle_orm.SQL<unknown> | undefined;
323
- readonly columns: undefined;
355
+ columns: undefined;
324
356
  readonly limit: any;
325
357
  };
326
358
  };
@@ -393,17 +425,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
393
425
  query: {
394
426
  single: {
395
427
  readonly where: any;
396
- readonly columns: undefined;
428
+ columns: undefined;
397
429
  };
398
430
  many: {
399
431
  readonly where: any;
400
- readonly columns: undefined;
432
+ columns: undefined;
401
433
  readonly limit: any;
402
434
  };
403
435
  };
404
436
  sql: {
405
437
  readonly where: drizzle_orm.SQL<unknown> | undefined;
406
- readonly columns: undefined;
438
+ columns: undefined;
407
439
  readonly limit: any;
408
440
  };
409
441
  };
package/index.d.ts CHANGED
@@ -123,17 +123,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
123
123
  query: {
124
124
  single: {
125
125
  readonly where: any;
126
- readonly columns: undefined;
126
+ columns: undefined;
127
127
  };
128
128
  many: {
129
129
  readonly where: any;
130
- readonly columns: undefined;
130
+ columns: undefined;
131
131
  readonly limit: any;
132
132
  };
133
133
  };
134
134
  sql: {
135
135
  readonly where: drizzle_orm.SQL<unknown> | undefined;
136
- readonly columns: undefined;
136
+ columns: undefined;
137
137
  readonly limit: any;
138
138
  };
139
139
  };
@@ -152,17 +152,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
152
152
  query: {
153
153
  single: {
154
154
  readonly where: any;
155
- readonly columns: undefined;
155
+ columns: undefined;
156
156
  };
157
157
  many: {
158
158
  readonly where: any;
159
- readonly columns: undefined;
159
+ columns: undefined;
160
160
  readonly limit: any;
161
161
  };
162
162
  };
163
163
  sql: {
164
164
  readonly where: drizzle_orm.SQL<unknown> | undefined;
165
- readonly columns: undefined;
165
+ columns: undefined;
166
166
  readonly limit: any;
167
167
  };
168
168
  };
@@ -215,17 +215,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
215
215
  query: {
216
216
  single: {
217
217
  readonly where: any;
218
- readonly columns: undefined;
218
+ columns: undefined;
219
219
  };
220
220
  many: {
221
221
  readonly where: any;
222
- readonly columns: undefined;
222
+ columns: undefined;
223
223
  readonly limit: any;
224
224
  };
225
225
  };
226
226
  sql: {
227
227
  readonly where: drizzle_orm.SQL<unknown> | undefined;
228
- readonly columns: undefined;
228
+ columns: undefined;
229
229
  readonly limit: any;
230
230
  };
231
231
  };
@@ -247,7 +247,39 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
247
247
  Output: Date;
248
248
  };
249
249
  };
250
- }>, any, any, any>) => SchemaBuilder.FieldMap) | undefined;
250
+ }>, drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName], NonNullable<Awaited<ReturnType<DB["query"][ExplicitTableName]["findFirst"]>>>, { [Key in keyof Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
251
+ _: {
252
+ brand: "Table";
253
+ };
254
+ }>["_"]["columns"] & string as Key]: Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
255
+ _: {
256
+ brand: "Table";
257
+ };
258
+ }>["_"]["columns"][Key]["_"]["notNull"] extends true ? Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
259
+ _: {
260
+ brand: "Table";
261
+ };
262
+ }>["_"]["columns"][Key]["_"]["data"] : Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
263
+ _: {
264
+ brand: "Table";
265
+ };
266
+ }>["_"]["columns"][Key]["_"]["data"] | null; } extends infer T_5 ? { [K in keyof T_5]: { [Key in keyof Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
267
+ _: {
268
+ brand: "Table";
269
+ };
270
+ }>["_"]["columns"] & string as Key]: Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
271
+ _: {
272
+ brand: "Table";
273
+ };
274
+ }>["_"]["columns"][Key]["_"]["notNull"] extends true ? Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
275
+ _: {
276
+ brand: "Table";
277
+ };
278
+ }>["_"]["columns"][Key]["_"]["data"] : Extract<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]["table"], {
279
+ _: {
280
+ brand: "Table";
281
+ };
282
+ }>["_"]["columns"][Key]["_"]["data"] | null; }[K]; } : never>) => SchemaBuilder.FieldMap) | undefined;
251
283
  }) => _pothos_plugin_drizzle.DrizzleObjectRef<PothosSchemaTypes.ExtendDefaultTypes<{
252
284
  Context: Awaited<UserContext & {
253
285
  abilities: keyof DB["query"] extends infer T_4 extends keyof DB["query"] ? { [key_5 in T_4]: {
@@ -257,17 +289,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
257
289
  query: {
258
290
  single: {
259
291
  readonly where: any;
260
- readonly columns: undefined;
292
+ columns: undefined;
261
293
  };
262
294
  many: {
263
295
  readonly where: any;
264
- readonly columns: undefined;
296
+ columns: undefined;
265
297
  readonly limit: any;
266
298
  };
267
299
  };
268
300
  sql: {
269
301
  readonly where: drizzle_orm.SQL<unknown> | undefined;
270
- readonly columns: undefined;
302
+ columns: undefined;
271
303
  readonly limit: any;
272
304
  };
273
305
  };
@@ -310,17 +342,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
310
342
  query: {
311
343
  single: {
312
344
  readonly where: any;
313
- readonly columns: undefined;
345
+ columns: undefined;
314
346
  };
315
347
  many: {
316
348
  readonly where: any;
317
- readonly columns: undefined;
349
+ columns: undefined;
318
350
  readonly limit: any;
319
351
  };
320
352
  };
321
353
  sql: {
322
354
  readonly where: drizzle_orm.SQL<unknown> | undefined;
323
- readonly columns: undefined;
355
+ columns: undefined;
324
356
  readonly limit: any;
325
357
  };
326
358
  };
@@ -393,17 +425,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
393
425
  query: {
394
426
  single: {
395
427
  readonly where: any;
396
- readonly columns: undefined;
428
+ columns: undefined;
397
429
  };
398
430
  many: {
399
431
  readonly where: any;
400
- readonly columns: undefined;
432
+ columns: undefined;
401
433
  readonly limit: any;
402
434
  };
403
435
  };
404
436
  sql: {
405
437
  readonly where: drizzle_orm.SQL<unknown> | undefined;
406
- readonly columns: undefined;
438
+ columns: undefined;
407
439
  readonly limit: any;
408
440
  };
409
441
  };
package/index.js CHANGED
@@ -1,9 +1,9 @@
1
- import {createYoga,createPubSub}from'graphql-yoga';import {One,relationsFilterToSQL}from'drizzle-orm';import {toCamelCase}from'drizzle-orm/casing';import {PgEnumColumn}from'drizzle-orm/pg-core';import Ee,{BasePlugin}from'@pothos/core';import Ae from'@pothos/plugin-drizzle';import ve,{subscribeOptionsFromIterator}from'@pothos/plugin-smart-subscriptions';import {JSONResolver,DateResolver,DateTimeISOResolver}from'graphql-scalars';function N(e){let t,m=false;return ()=>(m||(t=e(),m=true),t)}function _(e){return typeof e=="object"&&e!==null}function V(e,t){throw new Error("Unexpected invariant triggered.")}var pe=/\r\n|[\n\r]/g;function z(e,t){let m=0,u=1;for(let n of e.body.matchAll(pe)){if(typeof n.index=="number"||V(),n.index>=t)break;m=n.index+n[0].length,u+=1;}return {line:u,column:t+1-m}}function $(e){return k(e.source,z(e.source,e.start))}function k(e,t){let m=e.locationOffset.column-1,u="".padStart(m)+e.body,n=t.line-1,a=e.locationOffset.line-1,o=t.line+a,l=t.line===1?m:0,s=t.column+l,p=`${e.name}:${o}:${s}
2
- `,r=u.split(/\r\n|[\n\r]/g),f=r[n];if(f.length>120){let i=Math.floor(s/80),d=s%80,y=[];for(let b=0;b<f.length;b+=80)y.push(f.slice(b,b+80));return p+M([[`${o} |`,y[0]],...y.slice(1,i+1).map(b=>["|",b]),["|","^".padStart(d)],["|",y[i+1]]])}return p+M([[`${o-1} |`,r[n-1]],[`${o} |`,f],["|","^".padStart(s)],[`${o+1} |`,r[n+1]]])}function M(e){let t=e.filter(([u,n])=>n!==void 0),m=Math.max(...t.map(([u])=>u.length));return t.map(([u,n])=>u.padStart(m)+(n?" "+n:"")).join(`
3
- `)}function me(e){let t=e[0];return t==null||"kind"in t||"length"in t?{nodes:t,source:e[1],positions:e[2],path:e[3],originalError:e[4],extensions:e[5]}:t}var v=class e extends Error{constructor(t,...m){var u,n,a;let{nodes:o,source:l,positions:s,path:p,originalError:r,extensions:f}=me(m);super(t),this.name="GraphQLError",this.path=p??void 0,this.originalError=r??void 0,this.nodes=H(Array.isArray(o)?o:o?[o]:void 0);let i=H((u=this.nodes)===null||u===void 0?void 0:u.map(y=>y.loc).filter(y=>y!=null));this.source=l??(i==null||(n=i[0])===null||n===void 0?void 0:n.source),this.positions=s??i?.map(y=>y.start),this.locations=s&&l?s.map(y=>z(l,y)):i?.map(y=>z(y.source,y.start));let d=_(r?.extensions)?r?.extensions:void 0;this.extensions=(a=f??d)!==null&&a!==void 0?a:Object.create(null),Object.defineProperties(this,{message:{writable:true,enumerable:true},name:{enumerable:false},nodes:{enumerable:false},source:{enumerable:false},positions:{enumerable:false},originalError:{enumerable:false}}),r!=null&&r.stack?Object.defineProperty(this,"stack",{value:r.stack,writable:true,configurable:true}):Error.captureStackTrace?Error.captureStackTrace(this,e):Object.defineProperty(this,"stack",{value:Error().stack,writable:true,configurable:true});}get[Symbol.toStringTag](){return "GraphQLError"}toString(){let t=this.message;if(this.nodes)for(let m of this.nodes)m.loc&&(t+=`
1
+ import {createYoga,createPubSub}from'graphql-yoga';import {One,relationsFilterToSQL}from'drizzle-orm';import {toCamelCase}from'drizzle-orm/casing';import {PgEnumColumn}from'drizzle-orm/pg-core';import Be,{BasePlugin}from'@pothos/core';import ve from'@pothos/plugin-drizzle';import Fe,{subscribeOptionsFromIterator}from'@pothos/plugin-smart-subscriptions';import {JSONResolver,DateResolver,DateTimeISOResolver}from'graphql-scalars';function N(e){let t,m=false;return ()=>(m||(t=e(),m=true),t)}function V(e){return typeof e=="object"&&e!==null}function M(e,t){throw new Error("Unexpected invariant triggered.")}var me=/\r\n|[\n\r]/g;function z(e,t){let m=0,u=1;for(let n of e.body.matchAll(me)){if(typeof n.index=="number"||M(),n.index>=t)break;m=n.index+n[0].length,u+=1;}return {line:u,column:t+1-m}}function H(e){return G(e.source,z(e.source,e.start))}function G(e,t){let m=e.locationOffset.column-1,u="".padStart(m)+e.body,n=t.line-1,a=e.locationOffset.line-1,o=t.line+a,l=t.line===1?m:0,s=t.column+l,p=`${e.name}:${o}:${s}
2
+ `,r=u.split(/\r\n|[\n\r]/g),f=r[n];if(f.length>120){let i=Math.floor(s/80),d=s%80,y=[];for(let b=0;b<f.length;b+=80)y.push(f.slice(b,b+80));return p+$([[`${o} |`,y[0]],...y.slice(1,i+1).map(b=>["|",b]),["|","^".padStart(d)],["|",y[i+1]]])}return p+$([[`${o-1} |`,r[n-1]],[`${o} |`,f],["|","^".padStart(s)],[`${o+1} |`,r[n+1]]])}function $(e){let t=e.filter(([u,n])=>n!==void 0),m=Math.max(...t.map(([u])=>u.length));return t.map(([u,n])=>u.padStart(m)+(n?" "+n:"")).join(`
3
+ `)}function ce(e){let t=e[0];return t==null||"kind"in t||"length"in t?{nodes:t,source:e[1],positions:e[2],path:e[3],originalError:e[4],extensions:e[5]}:t}var v=class e extends Error{constructor(t,...m){var u,n,a;let{nodes:o,source:l,positions:s,path:p,originalError:r,extensions:f}=ce(m);super(t),this.name="GraphQLError",this.path=p??void 0,this.originalError=r??void 0,this.nodes=J(Array.isArray(o)?o:o?[o]:void 0);let i=J((u=this.nodes)===null||u===void 0?void 0:u.map(y=>y.loc).filter(y=>y!=null));this.source=l??(i==null||(n=i[0])===null||n===void 0?void 0:n.source),this.positions=s??i?.map(y=>y.start),this.locations=s&&l?s.map(y=>z(l,y)):i?.map(y=>z(y.source,y.start));let d=V(r?.extensions)?r?.extensions:void 0;this.extensions=(a=f??d)!==null&&a!==void 0?a:Object.create(null),Object.defineProperties(this,{message:{writable:true,enumerable:true},name:{enumerable:false},nodes:{enumerable:false},source:{enumerable:false},positions:{enumerable:false},originalError:{enumerable:false}}),r!=null&&r.stack?Object.defineProperty(this,"stack",{value:r.stack,writable:true,configurable:true}):Error.captureStackTrace?Error.captureStackTrace(this,e):Object.defineProperty(this,"stack",{value:Error().stack,writable:true,configurable:true});}get[Symbol.toStringTag](){return "GraphQLError"}toString(){let t=this.message;if(this.nodes)for(let m of this.nodes)m.loc&&(t+=`
4
4
 
5
- `+$(m.loc));else if(this.source&&this.locations)for(let m of this.locations)t+=`
5
+ `+H(m.loc));else if(this.source&&this.locations)for(let m of this.locations)t+=`
6
6
 
7
- `+k(this.source,m);return t}toJSON(){let t={message:this.message};return this.locations!=null&&(t.locations=this.locations),this.path!=null&&(t.path=this.path),this.extensions!=null&&Object.keys(this.extensions).length>0&&(t.extensions=this.extensions),t}};function H(e){return e===void 0||e.length===0?void 0:e}var C=class extends Error{constructor(t){super(t),this.name="RumbleError";}},F=class extends v{};var w=(e,t)=>new C(`RumbleError: Unknown SQL type '${e}'. Please open an issue (https://github.com/m1212e/rumble/issues) so it can be added. (${t})`);function J(e){if(["serial","int","integer","tinyint","smallint","mediumint"].includes(e))return {value1:1,value2:2};if(["real","decimal","double","float"].includes(e))return {value1:1.1,value2:2.2};if(["string","text","varchar","char","text(256)"].includes(e))return {value1:"a",value2:"b"};if(["uuid"].includes(e))return {value1:"fba31870-5528-42d7-b27e-2e5ee657aea5",value2:"fc65db81-c2d1-483d-8a25-a30e2cf6e02d"};if(["boolean"].includes(e))return {value1:true,value2:false};if(["timestamp","datetime"].includes(e))return {value1:new Date(2022,1,1),value2:new Date(2022,1,2)};if(["date"].includes(e))return {value1:new Date(2022,1,1),value2:new Date(2022,1,2)};if(["json"].includes(e))return {value1:{a:1},value2:{b:2}};throw w(e,"Distinct")}var G=Symbol.for("drizzle:Name"),W=Symbol.for("drizzle:Columns");function P({dbName:e,tsName:t,table:m,db:u}){let n=m;if(t&&(n=u._.relations.schema[t]),e&&(n=Object.values(u._.relations.schema).find(a=>a[G]===e)),!n)throw new C(`Could not find schema for ${JSON.stringify({tsName:t,dbName:e,table:m?.[G]}).toString()}`);return {tableSchema:n,columns:n[W],get primaryColumns(){return Object.entries(n[W]).filter(([a,o])=>o.primary).reduce((a,[o,l])=>(a[o]=l,a),{})},relations:u._.relations.config[t],dbName:n[G],get tsName(){return Object.entries(u._.relations.schema).find(([a,o])=>o===n).at(0)}}}function fe(e){return typeof e!="function"}function Te(e){return typeof e=="function"&&e.constructor.name!=="AsyncFunction"}var Y=({db:e,actions:t,defaultLimit:m})=>{let u={},n={},a={},o=l=>{for(let s of t)a[l]||(a[l]={}),a[l][s]||(a[l][s]=[]);return {allow:s=>{let p=n[l];p||(p={},n[l]=p);let r=Array.isArray(s)?s:[s];for(let f of r){let i=p[f];i||(i="unspecified",p[f]=i);}return {when:f=>{for(let i of r)p[i]==="unspecified"&&(p[i]=[]),p[i].push(f);}}},filter:s=>{let p=Array.isArray(s)?s:[s];return {by:r=>{for(let f of p)a[l][f].push(r);}}}}};for(let l of Object.keys(e.query))u[l]=o(l);return {...u,registeredQueryFilters:n,registeredFilters:a,buildWithUserContext:l=>{let s={},p=r=>({filter:(f,i)=>{let d=c=>{let E=N(()=>{if(!(!c?.where&&!i?.inject?.where)){if(i?.inject?.where&&c?.where)return {AND:[c?.where,i?.inject?.where]};if(i?.inject?.where&&!c?.where)return i?.inject?.where;if(!i?.inject?.where&&c?.where)return c?.where;!i?.inject?.where&&c?.where;}}),A=N(()=>{let B=E();if(!B)return;let ue=P({tsName:r,db:e});return relationsFilterToSQL(ue.tableSchema,B)}),O=N(()=>{let B=c?.limit??m;return i?.inject?.limit&&(!B||B>i.inject.limit)&&(B=i.inject.limit),c?.limit&&(!B||c.limit>B)&&(B=c.limit),B??void 0}),Q=N(()=>{if(!(!c?.columns&&!i?.inject?.columns))return {...c?.columns,...i?.inject?.columns}});return {query:{single:{get where(){return E()},get columns(){return Q()}},many:{get where(){return E()},get columns(){return Q()},get limit(){return O()}}},sql:{get where(){return A()},get columns(){return Q()},get limit(){return O()}}}},y=()=>{let c=P({db:e,tsName:r});if(Object.keys(c.primaryColumns).length===0)throw new C(`No primary key found for entity ${r.toString()}`);let E=Object.values(c.primaryColumns)[0],A=J(E.getSQLType());return {where:{AND:[{[E.name]:A.value1},{[E.name]:A.value2}]}}},b=n?.[r]?.[f];if(b==="unspecified")return d();b||(b=[y()]);let h=b.filter(fe),D=b.filter(Te).map(c=>c(l)),x=D.some(c=>c==="allow"),T=[...h,...D].filter(c=>c!==void 0).filter(c=>c!=="allow");!x&&T.length===0&&(T=[y()]);let g;for(let c of T)c?.limit&&(g===void 0||c.limit>g)&&(g=c.limit);let S;for(let c of [...T,i?.inject])c?.columns&&(S===void 0?S=c.columns:S={...S,...c.columns});let R=x?[]:T.filter(c=>c?.where).map(c=>c.where),L=R.length>0?{OR:R}:void 0;return d({where:L,columns:S,limit:g})},explicitFilters:f=>a[r][f]});for(let r of Object.keys(e.query))s[r]=p(r);return s}}};var X=({context:e,abilityBuilder:t})=>async m=>{let u=e?await e(m):{};return {...u,abilities:t.buildWithUserContext(u)}};function I(e){return String(e).charAt(0).toUpperCase()+String(e).slice(1)}function U(e){return e instanceof PgEnumColumn}var Z=({db:e,schemaBuilder:t})=>{let m=new Map;return ({tsName:n,enumColumn:a,refName:o})=>{let l,s;if(n){let i=e._.relations.schema[n];l=n.toString();let d=Object.values(e._.relations.schema).filter(y=>typeof y=="object").map(y=>Object.values(y[Symbol.for("drizzle:Columns")])).flat(2).find(y=>y.config?.enum===i);if(!d)throw new C(`Could not find applied enum column for ${n.toString()}.
8
- Please ensure that you use the enum at least once as a column of a table!`);s=d.enumValues;}else if(a){let i=Object.entries(e._.relations.schema).find(([d,y])=>y===a.config.enum);if(!i)throw new C(`Could not find enum in schema for ${a.name}!`);l=i[0],s=a.enumValues;}if(!l||!s)throw new C("Could not determine enum structure!");let p=o??`${I(toCamelCase(l))}Enum`,r=m.get(p);return r||(r=t.enumType(p,{values:s}),m.set(p,r),r)}};function q(e){let t;if(["serial","int","integer","tinyint","smallint","mediumint"].includes(e)&&(t="Int"),["real","decimal","double","float"].includes(e)&&(t="Float"),["string","text","varchar","char","text(256)"].includes(e)&&(t="String"),["uuid"].includes(e)&&(t="ID"),["boolean"].includes(e)&&(t="Boolean"),["timestamp","datetime"].includes(e)&&(t="DateTime"),["date"].includes(e)&&(t="Date"),["json"].includes(e)&&(t="JSON"),t!==void 0)return t;throw w(e,"SQL to GQL")}var ee=({db:e,schemaBuilder:t,makePubSubInstance:m,argImplementer:u,enumImplementer:n,abilityBuilder:a})=>({table:o,refName:l,readAction:s="read",extend:p})=>{let r=P({db:e,tsName:o});Object.keys(r.primaryColumns).length===0&&console.warn(`Could not find primary key for ${o.toString()}. Cannot register subscriptions!`);let f=Object.values(r.primaryColumns)[0],{registerOnInstance:i}=m({table:o});return t.drizzleObject(o,{name:l??I(o.toString()),subscribe:(d,y,b)=>{if(!f)return;let h=y[f.name];if(!h){console.warn(`Could not find primary key value for ${JSON.stringify(y)}. Cannot register subscription!`);return}i({instance:d,action:"updated",primaryKeyValue:h});},applyFilters:a?.registeredFilters?.[o]?.[s],fields:d=>{let y=r.columns,b=(x,T,g)=>{let S=q(x);switch(S){case "Int":return d.exposeInt(T,{nullable:g});case "String":return d.exposeString(T,{nullable:g});case "Boolean":return d.exposeBoolean(T,{nullable:g});case "Date":return d.field({type:"Date",resolve:R=>R[T],nullable:g});case "DateTime":return d.field({type:"DateTime",resolve:R=>R[T],nullable:g});case "Float":return d.exposeFloat(T,{nullable:g});case "ID":return d.exposeID(T,{nullable:g});case "JSON":return d.field({type:"JSON",resolve:R=>R[T],nullable:g});default:throw new C(`Unsupported object type ${S} for column ${T}`)}},h=Object.entries(y).reduce((x,[T,g])=>{if(U(g)){let S=n({enumColumn:g});x[T]=d.field({type:S,resolve:R=>R[T],nullable:!g.notNull});}else x[T]=b(g.getSQLType(),T,!g.notNull);return x},{}),D=Object.entries(r.relations??{}).reduce((x,[T,g])=>{let S=P({db:e,table:g.targetTable}),R=u({dbName:S.dbName}),L=false,E="many";return g instanceof One&&(L=g.optional,E="single"),x[T]=d.relation(T,{args:{where:d.arg({type:R,required:false})},nullable:L,query:(A,O)=>O.abilities[S.tsName].filter(s,{inject:{where:A.where}}).query[E]}),x},{});return p?{...h,...D,...p(d)??{}}:{...h,...D}}})};var xe="RUMBLE_SUBSCRIPTION_NOTIFICATION",Ce="REMOVED",De="UPDATED",Se="CREATED",ne=({subscriptions:e,db:t})=>{let m=e?createPubSub(...e):createPubSub();return {pubsub:m,makePubSubInstance:({table:n})=>{function a({action:o,tableName:l,primaryKeyValue:s}){let p;switch(o){case "created":p=Se;break;case "removed":p=Ce;break;case "updated":p=De;break;default:throw new Error(`Unknown action: ${o}`)}return `${xe}/${l}${s?`/${s}`:""}/${p}`}return {registerOnInstance({instance:o,action:l,primaryKeyValue:s}){let p=a({tableName:n.toString(),action:l,primaryKeyValue:s});o.register(p);},created(){let o=a({tableName:n.toString(),action:"created"});return m.publish(o)},removed(o){let l=a({tableName:n.toString(),action:"removed"});return m.publish(l)},updated(o){let s=(Array.isArray(o)?o:[o]).map(r=>a({tableName:n.toString(),action:"updated",primaryKeyValue:r})),p=Array.from(new Set(s));for(let r of p)m.publish(r);}}}}};var j=e=>{if(!e)throw new F("Value not found but required (findFirst)");return e},Re=e=>{let t=e.at(0);if(!t)throw new F("Value not found but required (firstEntry)");return t},re=async({filters:e,entities:t,context:m})=>(await Promise.all(e.map(u=>u({context:m,entities:t})))).reduce((u,n)=>(u.push(...n),u),[]);var ie=({db:e,schemaBuilder:t,argImplementer:m,makePubSubInstance:u})=>({table:n,readAction:a="read",listAction:o="read"})=>{let l=m({table:n}),{registerOnInstance:s}=u({table:n});return t.queryFields(p=>({[`findMany${I(n.toString())}`]:p.drizzleField({type:[n],nullable:false,smartSubscription:true,subscribe:(r,f,i,d,y)=>{s({instance:r,action:"created"}),s({instance:r,action:"removed"});},args:{where:p.arg({type:l,required:false})},resolve:(r,f,i,d,y)=>{let b=d.abilities[n].filter(o,i.where?{inject:{where:i.where}}:void 0).query.many,h=r(b);return b.columns&&(h.columns=b.columns),e.query[n].findMany(h)}}),[`findFirst${I(n.toString())}`]:p.drizzleField({type:n,nullable:false,smartSubscription:true,args:{where:p.arg({type:l,required:false})},resolve:(r,f,i,d,y)=>{let b=d.abilities[n].filter(a,i.where?{inject:{where:i.where}}:void 0).query.single,h=r(b);return b.columns&&(h.columns=b.columns),e.query[n].findFirst(h).then(j)}})}))};var oe="ManualFiltersPlugin",se=oe,Pe="applyFilters",K=class extends BasePlugin{wrapResolve(t,m){return async(u,n,a,o)=>{let l=(m?.type).type?.ref.currentConfig.pothosOptions[Pe];if(!l||!Array.isArray(l)||l.length===0)return t(u,n,a,o);let s=await t(u,n,a,o),p=Array.isArray(s)?s:[s],r=Array.isArray(l)?l:[l],f=await re({filters:r,entities:p,context:a});return Array.isArray(s)?f:f[0]??null}}};Ee.registerPlugin(oe,K);var ae=({db:e,disableDefaultObjects:t,pubsub:m,pothosConfig:u})=>{let n=new Ee({plugins:[se,Ae,ve,...u?.plugins??[]],...u,drizzle:{client:e,relations:e._.relations,getTableConfig(a){return {columns:Object.values(a[Symbol.for("drizzle:Columns")]),primaryKeys:Object.values(a[Symbol.for("drizzle:Columns")]).filter(o=>o.primary)}}},smartSubscriptions:{...subscribeOptionsFromIterator((a,o)=>m.subscribe(a))}});return n.addScalarType("JSON",JSONResolver),n.addScalarType("Date",DateResolver),n.addScalarType("DateTime",DateTimeISOResolver),t?.query||n.queryType({}),t?.subscription||n.subscriptionType({}),t?.mutation||n.mutationType({}),{schemaBuilder:n}};var we=e=>`${I(toCamelCase(e.toString()))}WhereInputArgument`,le=({db:e,schemaBuilder:t,enumImplementer:m})=>{let u=new Map,n=({table:a,refName:o,dbName:l})=>{let s=P({db:e,dbName:l,tsName:a}),p=o??we(s.tsName),r=u.get(p);return r||(r=t.inputType(p,{fields:i=>{let d=h=>{let D=q(h);switch(D){case "Int":return i.int({required:false});case "String":return i.string({required:false});case "Boolean":return i.boolean({required:false});case "Date":return i.field({type:"Date",required:false});case "DateTime":return i.field({type:"DateTime",required:false});case "Float":return i.float({required:false});case "ID":return i.id({required:false});case "JSON":return i.field({type:"JSON",required:false});default:throw new C(`Unsupported argument type ${D} for column ${h}`)}},y=Object.entries(s.columns).reduce((h,[D,x])=>{if(U(x)){let T=m({enumColumn:x});h[D]=i.field({type:T,required:false});}else h[D]=d(x.getSQLType());return h},{}),b=Object.entries(s.relations??{}).reduce((h,[D,x])=>{let T=P({db:e,table:x.targetTable}),g=n({dbName:T.dbName});return h[D]=i.field({type:g,required:false}),h},{});return {...y,...b}}}),u.set(p,r),r)};return n};var qe=e=>{e.actions||(e.actions=["read","update","delete"]),e.defaultLimit===void 0&&(e.defaultLimit=100);let t=Y(e),m=X({...e,abilityBuilder:t}),{makePubSubInstance:u,pubsub:n}=ne({...e}),{schemaBuilder:a}=ae({...e,pubsub:n}),o=Z({...e,schemaBuilder:a}),l=le({...e,schemaBuilder:a,enumImplementer:o}),s=ee({...e,schemaBuilder:a,makePubSubInstance:u,argImplementer:l,enumImplementer:o,abilityBuilder:t}),p=ie({...e,schemaBuilder:a,argImplementer:l,makePubSubInstance:u});return {abilityBuilder:t,schemaBuilder:a,createYoga:f=>createYoga({...f,schema:a.toSchema(),context:m}),object:s,arg:l,query:p,pubsub:u,enum_:o}};export{C as RumbleError,F as RumbleErrorSafe,j as assertFindFirstExists,Re as assertFirstEntryExists,qe as rumble};//# sourceMappingURL=index.js.map
7
+ `+G(this.source,m);return t}toJSON(){let t={message:this.message};return this.locations!=null&&(t.locations=this.locations),this.path!=null&&(t.path=this.path),this.extensions!=null&&Object.keys(this.extensions).length>0&&(t.extensions=this.extensions),t}};function J(e){return e===void 0||e.length===0?void 0:e}var C=class extends Error{constructor(t){super(t),this.name="RumbleError";}},F=class extends v{};var U=(e,t)=>new C(`RumbleError: Unknown SQL type '${e}'. Please open an issue (https://github.com/m1212e/rumble/issues) so it can be added. (${t})`);function W(e){if(["serial","int","integer","tinyint","smallint","mediumint"].includes(e))return {value1:1,value2:2};if(["real","decimal","double","float"].includes(e))return {value1:1.1,value2:2.2};if(["string","text","varchar","char","text(256)"].includes(e))return {value1:"a",value2:"b"};if(["uuid"].includes(e))return {value1:"fba31870-5528-42d7-b27e-2e5ee657aea5",value2:"fc65db81-c2d1-483d-8a25-a30e2cf6e02d"};if(["boolean"].includes(e))return {value1:true,value2:false};if(["timestamp","datetime"].includes(e))return {value1:new Date(2022,1,1),value2:new Date(2022,1,2)};if(["date"].includes(e))return {value1:new Date(2022,1,1),value2:new Date(2022,1,2)};if(["json"].includes(e))return {value1:{a:1},value2:{b:2}};throw U(e,"Distinct")}var j=Symbol.for("drizzle:Name"),Y=Symbol.for("drizzle:Columns");function P({dbName:e,tsName:t,table:m,db:u}){let n=m;if(t&&(n=u._.relations.schema[t]),e&&(n=Object.values(u._.relations.schema).find(a=>a[j]===e)),!n)throw new C(`Could not find schema for ${JSON.stringify({tsName:t,dbName:e,table:m?.[j]}).toString()}`);return {tableSchema:n,columns:n[Y],get primaryColumns(){return Object.entries(n[Y]).filter(([a,o])=>o.primary).reduce((a,[o,l])=>(a[o]=l,a),{})},relations:u._.relations.config[t],dbName:n[j],get tsName(){return Object.entries(u._.relations.schema).find(([a,o])=>o===n).at(0)}}}function Te(e){return typeof e!="function"}function be(e){return typeof e=="function"&&e.constructor.name!=="AsyncFunction"}var X=({db:e,actions:t,defaultLimit:m})=>{let u={},n={},a={},o=l=>{for(let s of t)a[l]||(a[l]={}),a[l][s]||(a[l][s]=[]);return {allow:s=>{let p=n[l];p||(p={},n[l]=p);let r=Array.isArray(s)?s:[s];for(let f of r){let i=p[f];i||(i="unspecified",p[f]=i);}return {when:f=>{for(let i of r)p[i]==="unspecified"&&(p[i]=[]),p[i].push(f);}}},filter:s=>{let p=Array.isArray(s)?s:[s];return {by:r=>{for(let f of p)a[l][f].push(r);}}}}};for(let l of Object.keys(e.query))u[l]=o(l);return {...u,registeredQueryFilters:n,registeredFilters:a,buildWithUserContext:l=>{let s={},p=r=>({filter:(f,i)=>{let d=c=>{let E=N(()=>{if(!(!c?.where&&!i?.inject?.where)){if(i?.inject?.where&&c?.where)return {AND:[c?.where,i?.inject?.where]};if(i?.inject?.where&&!c?.where)return i?.inject?.where;if(!i?.inject?.where&&c?.where)return c?.where;!i?.inject?.where&&c?.where;}}),A=N(()=>{let B=E();if(!B)return;let pe=P({tsName:r,db:e});return relationsFilterToSQL(pe.tableSchema,B)}),q=N(()=>{let B=c?.limit??m;return i?.inject?.limit&&(!B||B>i.inject.limit)&&(B=i.inject.limit),c?.limit&&(!B||c.limit>B)&&(B=c.limit),B??void 0}),O=N(()=>{if(!(!c?.columns&&!i?.inject?.columns))return {...c?.columns,...i?.inject?.columns}}),w={query:{single:{get where(){return E()},columns:O()},many:{get where(){return E()},columns:O(),get limit(){return q()}}},sql:{get where(){return A()},columns:O(),get limit(){return q()}}};return O()||(delete w.sql.columns,delete w.query.many.columns,delete w.query.single.columns),w},y=()=>{let c=P({db:e,tsName:r});if(Object.keys(c.primaryColumns).length===0)throw new C(`No primary key found for entity ${r.toString()}`);let E=Object.values(c.primaryColumns)[0],A=W(E.getSQLType());return {where:{AND:[{[E.name]:A.value1},{[E.name]:A.value2}]}}},b=n?.[r]?.[f];if(b==="unspecified")return d();b||(b=[y()]);let h=b.filter(Te),D=b.filter(be).map(c=>c(l)),x=D.some(c=>c==="allow"),T=[...h,...D].filter(c=>c!==void 0).filter(c=>c!=="allow");!x&&T.length===0&&(T=[y()]);let g;for(let c of T)c?.limit&&(g===void 0||c.limit>g)&&(g=c.limit);let S;for(let c of [...T,i?.inject])c?.columns&&(S===void 0?S=c.columns:S={...S,...c.columns});let R=x?[]:T.filter(c=>c?.where).map(c=>c.where),L=R.length>0?{OR:R}:void 0;return d({where:L,columns:S,limit:g})},explicitFilters:f=>a[r][f]});for(let r of Object.keys(e.query))s[r]=p(r);return s}}};var Z=({context:e,abilityBuilder:t})=>async m=>{let u=e?await e(m):{};return {...u,abilities:t.buildWithUserContext(u)}};function I(e){return String(e).charAt(0).toUpperCase()+String(e).slice(1)}function Q(e){return e instanceof PgEnumColumn}var ee=({db:e,schemaBuilder:t})=>{let m=new Map;return ({tsName:n,enumColumn:a,refName:o})=>{let l,s;if(n){let i=e._.relations.schema[n];l=n.toString();let d=Object.values(e._.relations.schema).filter(y=>typeof y=="object").map(y=>Object.values(y[Symbol.for("drizzle:Columns")])).flat(2).find(y=>y.config?.enum===i);if(!d)throw new C(`Could not find applied enum column for ${n.toString()}.
8
+ Please ensure that you use the enum at least once as a column of a table!`);s=d.enumValues;}else if(a){let i=Object.entries(e._.relations.schema).find(([d,y])=>y===a.config.enum);if(!i)throw new C(`Could not find enum in schema for ${a.name}!`);l=i[0],s=a.enumValues;}if(!l||!s)throw new C("Could not determine enum structure!");let p=o??`${I(toCamelCase(l))}Enum`,r=m.get(p);return r||(r=t.enumType(p,{values:s}),m.set(p,r),r)}};function k(e){let t;if(["serial","int","integer","tinyint","smallint","mediumint"].includes(e)&&(t="Int"),["real","decimal","double","float"].includes(e)&&(t="Float"),["string","text","varchar","char","text(256)"].includes(e)&&(t="String"),["uuid"].includes(e)&&(t="ID"),["boolean"].includes(e)&&(t="Boolean"),["timestamp","datetime"].includes(e)&&(t="DateTime"),["date"].includes(e)&&(t="Date"),["json"].includes(e)&&(t="JSON"),t!==void 0)return t;throw U(e,"SQL to GQL")}var te=({db:e,schemaBuilder:t,makePubSubInstance:m,argImplementer:u,enumImplementer:n,abilityBuilder:a})=>({table:o,refName:l,readAction:s="read",extend:p})=>{let r=P({db:e,tsName:o});Object.keys(r.primaryColumns).length===0&&console.warn(`Could not find primary key for ${o.toString()}. Cannot register subscriptions!`);let f=Object.values(r.primaryColumns)[0],{registerOnInstance:i}=m({table:o});return t.drizzleObject(o,{name:l??I(o.toString()),subscribe:(d,y,b)=>{if(!f)return;let h=y[f.name];if(!h){console.warn(`Could not find primary key value for ${JSON.stringify(y)}. Cannot register subscription!`);return}i({instance:d,action:"updated",primaryKeyValue:h});},applyFilters:a?.registeredFilters?.[o]?.[s],fields:d=>{let y=r.columns,b=(x,T,g)=>{let S=k(x);switch(S){case "Int":return d.exposeInt(T,{nullable:g});case "String":return d.exposeString(T,{nullable:g});case "Boolean":return d.exposeBoolean(T,{nullable:g});case "Date":return d.field({type:"Date",resolve:R=>R[T],nullable:g});case "DateTime":return d.field({type:"DateTime",resolve:R=>R[T],nullable:g});case "Float":return d.exposeFloat(T,{nullable:g});case "ID":return d.exposeID(T,{nullable:g});case "JSON":return d.field({type:"JSON",resolve:R=>R[T],nullable:g});default:throw new C(`Unsupported object type ${S} for column ${T}`)}},h=Object.entries(y).reduce((x,[T,g])=>{if(Q(g)){let S=n({enumColumn:g});x[T]=d.field({type:S,resolve:R=>R[T],nullable:!g.notNull});}else x[T]=b(g.getSQLType(),T,!g.notNull);return x},{}),D=Object.entries(r.relations??{}).reduce((x,[T,g])=>{let S=P({db:e,table:g.targetTable}),R=u({dbName:S.dbName}),L=false,E="many";return g instanceof One&&(L=g.optional,E="single"),x[T]=d.relation(T,{args:{where:d.arg({type:R,required:false})},nullable:L,query:(A,q)=>q.abilities[S.tsName].filter(s,{inject:{where:A.where}}).query[E]}),x},{});return p?{...h,...D,...p(d)??{}}:{...h,...D}}})};var Ce="RUMBLE_SUBSCRIPTION_NOTIFICATION",De="REMOVED",Se="UPDATED",Re="CREATED",re=({subscriptions:e,db:t})=>{let m=e?createPubSub(...e):createPubSub();return {pubsub:m,makePubSubInstance:({table:n})=>{function a({action:o,tableName:l,primaryKeyValue:s}){let p;switch(o){case "created":p=Re;break;case "removed":p=De;break;case "updated":p=Se;break;default:throw new Error(`Unknown action: ${o}`)}return `${Ce}/${l}${s?`/${s}`:""}/${p}`}return {registerOnInstance({instance:o,action:l,primaryKeyValue:s}){let p=a({tableName:n.toString(),action:l,primaryKeyValue:s});o.register(p);},created(){let o=a({tableName:n.toString(),action:"created"});return m.publish(o)},removed(o){let l=a({tableName:n.toString(),action:"removed"});return m.publish(l)},updated(o){let s=(Array.isArray(o)?o:[o]).map(r=>a({tableName:n.toString(),action:"updated",primaryKeyValue:r})),p=Array.from(new Set(s));for(let r of p)m.publish(r);}}}}};var K=e=>{if(!e)throw new F("Value not found but required (findFirst)");return e},Ee=e=>{let t=e.at(0);if(!t)throw new F("Value not found but required (firstEntry)");return t},ie=async({filters:e,entities:t,context:m})=>(await Promise.all(e.map(u=>u({context:m,entities:t})))).reduce((u,n)=>(u.push(...n),u),[]);var oe=({db:e,schemaBuilder:t,argImplementer:m,makePubSubInstance:u})=>({table:n,readAction:a="read",listAction:o="read"})=>{let l=m({table:n}),{registerOnInstance:s}=u({table:n});return t.queryFields(p=>({[`findMany${I(n.toString())}`]:p.drizzleField({type:[n],nullable:false,smartSubscription:true,subscribe:(r,f,i,d,y)=>{s({instance:r,action:"created"}),s({instance:r,action:"removed"});},args:{where:p.arg({type:l,required:false})},resolve:(r,f,i,d,y)=>{let b=d.abilities[n].filter(o,i.where?{inject:{where:i.where}}:void 0).query.many,h=r(b);return b.columns&&(h.columns=b.columns),e.query[n].findMany(h)}}),[`findFirst${I(n.toString())}`]:p.drizzleField({type:n,nullable:false,smartSubscription:true,args:{where:p.arg({type:l,required:false})},resolve:(r,f,i,d,y)=>{let b=d.abilities[n].filter(a,i.where?{inject:{where:i.where}}:void 0).query.single,h=r(b);return b.columns&&(h.columns=b.columns),e.query[n].findFirst(h).then(K)}})}))};var se="ManualFiltersPlugin",ae=se,Ie="applyFilters",_=class extends BasePlugin{wrapResolve(t,m){return async(u,n,a,o)=>{let l=(m?.type).type?.ref.currentConfig.pothosOptions[Ie];if(!l||!Array.isArray(l)||l.length===0)return t(u,n,a,o);let s=await t(u,n,a,o),p=Array.isArray(s)?s:[s],r=Array.isArray(l)?l:[l],f=await ie({filters:r,entities:p,context:a});return Array.isArray(s)?f:f[0]??null}}};Be.registerPlugin(se,_);var le=({db:e,disableDefaultObjects:t,pubsub:m,pothosConfig:u})=>{let n=new Be({plugins:[ae,ve,Fe,...u?.plugins??[]],...u,drizzle:{client:e,relations:e._.relations,getTableConfig(a){return {columns:Object.values(a[Symbol.for("drizzle:Columns")]),primaryKeys:Object.values(a[Symbol.for("drizzle:Columns")]).filter(o=>o.primary)}}},smartSubscriptions:{...subscribeOptionsFromIterator((a,o)=>m.subscribe(a))}});return n.addScalarType("JSON",JSONResolver),n.addScalarType("Date",DateResolver),n.addScalarType("DateTime",DateTimeISOResolver),t?.query||n.queryType({}),t?.subscription||n.subscriptionType({}),t?.mutation||n.mutationType({}),{schemaBuilder:n}};var we=e=>`${I(toCamelCase(e.toString()))}WhereInputArgument`,ue=({db:e,schemaBuilder:t,enumImplementer:m})=>{let u=new Map,n=({table:a,refName:o,dbName:l})=>{let s=P({db:e,dbName:l,tsName:a}),p=o??we(s.tsName),r=u.get(p);return r||(r=t.inputType(p,{fields:i=>{let d=h=>{let D=k(h);switch(D){case "Int":return i.int({required:false});case "String":return i.string({required:false});case "Boolean":return i.boolean({required:false});case "Date":return i.field({type:"Date",required:false});case "DateTime":return i.field({type:"DateTime",required:false});case "Float":return i.float({required:false});case "ID":return i.id({required:false});case "JSON":return i.field({type:"JSON",required:false});default:throw new C(`Unsupported argument type ${D} for column ${h}`)}},y=Object.entries(s.columns).reduce((h,[D,x])=>{if(Q(x)){let T=m({enumColumn:x});h[D]=i.field({type:T,required:false});}else h[D]=d(x.getSQLType());return h},{}),b=Object.entries(s.relations??{}).reduce((h,[D,x])=>{let T=P({db:e,table:x.targetTable}),g=n({dbName:T.dbName});return h[D]=i.field({type:g,required:false}),h},{});return {...y,...b}}}),u.set(p,r),r)};return n};var Qe=e=>{e.actions||(e.actions=["read","update","delete"]),e.defaultLimit===void 0&&(e.defaultLimit=100);let t=X(e),m=Z({...e,abilityBuilder:t}),{makePubSubInstance:u,pubsub:n}=re({...e}),{schemaBuilder:a}=le({...e,pubsub:n}),o=ee({...e,schemaBuilder:a}),l=ue({...e,schemaBuilder:a,enumImplementer:o}),s=te({...e,schemaBuilder:a,makePubSubInstance:u,argImplementer:l,enumImplementer:o,abilityBuilder:t}),p=oe({...e,schemaBuilder:a,argImplementer:l,makePubSubInstance:u});return {abilityBuilder:t,schemaBuilder:a,createYoga:f=>createYoga({...f,schema:a.toSchema(),context:m}),object:s,arg:l,query:p,pubsub:u,enum_:o}};export{C as RumbleError,F as RumbleErrorSafe,K as assertFindFirstExists,Ee as assertFirstEntryExists,Qe as rumble};//# sourceMappingURL=index.js.map
9
9
  //# sourceMappingURL=index.js.map