@m1212e/rumble 0.7.10 → 0.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.d.cts CHANGED
@@ -84,6 +84,73 @@ type RumbleInput<UserContext extends Record<string, any>, DB extends GenericDriz
84
84
  defaultLimit?: number | undefined | null;
85
85
  };
86
86
 
87
+ type NumberWhereInputArgument = {
88
+ eq?: number;
89
+ ne?: number;
90
+ gt?: number;
91
+ gte?: number;
92
+ lt?: number;
93
+ lte?: number;
94
+ in?: number[];
95
+ notIn?: number[];
96
+ like?: string;
97
+ ilike?: string;
98
+ notLike?: string;
99
+ notIlike?: string;
100
+ isNull?: boolean;
101
+ isNotNull?: boolean;
102
+ arrayOverlaps?: number[];
103
+ arrayContained?: number[];
104
+ arrayContains?: number[];
105
+ AND?: NumberWhereInputArgument[];
106
+ OR?: NumberWhereInputArgument[];
107
+ NOT?: NumberWhereInputArgument;
108
+ };
109
+ type StringWhereInputArgument = {
110
+ eq?: string;
111
+ ne?: string;
112
+ gt?: string;
113
+ gte?: string;
114
+ lt?: string;
115
+ lte?: string;
116
+ in?: string[];
117
+ notIn?: string[];
118
+ like?: string;
119
+ ilike?: string;
120
+ notLike?: string;
121
+ notIlike?: string;
122
+ isNull?: boolean;
123
+ isNotNull?: boolean;
124
+ arrayOverlaps?: string[];
125
+ arrayContained?: string[];
126
+ arrayContains?: string[];
127
+ AND?: StringWhereInputArgument[];
128
+ OR?: StringWhereInputArgument[];
129
+ NOT?: StringWhereInputArgument;
130
+ };
131
+ type DateWhereInputArgument = {
132
+ eq?: Date;
133
+ ne?: Date;
134
+ gt?: Date;
135
+ gte?: Date;
136
+ lt?: Date;
137
+ lte?: Date;
138
+ in?: Date[];
139
+ notIn?: Date[];
140
+ like?: string;
141
+ ilike?: string;
142
+ notLike?: string;
143
+ notIlike?: string;
144
+ isNull?: boolean;
145
+ isNotNull?: boolean;
146
+ arrayOverlaps?: Date[];
147
+ arrayContained?: Date[];
148
+ arrayContains?: Date[];
149
+ AND?: DateWhereInputArgument[];
150
+ OR?: DateWhereInputArgument[];
151
+ NOT?: DateWhereInputArgument;
152
+ };
153
+
87
154
  type EnumTypes = PgEnum<any>;
88
155
  type NonEnumFields<T> = {
89
156
  [K in keyof T as T[K] extends EnumTypes ? never : K]: T[K];
@@ -184,6 +251,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
184
251
  Output: Date;
185
252
  };
186
253
  };
254
+ Inputs: {
255
+ IntWhereInputArgument: NumberWhereInputArgument;
256
+ FloatWhereInputArgument: NumberWhereInputArgument;
257
+ StringWhereInputArgument: StringWhereInputArgument;
258
+ DateWhereInputArgument: DateWhereInputArgument;
259
+ };
187
260
  }>>;
188
261
  /**
189
262
  * Creates the native yoga instance. Can be used to run an actual HTTP server.
@@ -247,6 +320,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
247
320
  Output: Date;
248
321
  };
249
322
  };
323
+ Inputs: {
324
+ IntWhereInputArgument: NumberWhereInputArgument;
325
+ FloatWhereInputArgument: NumberWhereInputArgument;
326
+ StringWhereInputArgument: StringWhereInputArgument;
327
+ DateWhereInputArgument: DateWhereInputArgument;
328
+ };
250
329
  }>, 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
330
  _: {
252
331
  brand: "Table";
@@ -321,6 +400,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
321
400
  Output: Date;
322
401
  };
323
402
  };
403
+ Inputs: {
404
+ IntWhereInputArgument: NumberWhereInputArgument;
405
+ FloatWhereInputArgument: NumberWhereInputArgument;
406
+ StringWhereInputArgument: StringWhereInputArgument;
407
+ DateWhereInputArgument: DateWhereInputArgument;
408
+ };
324
409
  }>, ExplicitTableName, drizzle_orm.BuildQueryResult<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>, drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName], true | drizzle_orm.DBQueryConfig<"one", drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>, drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]>>>;
325
410
  /**
326
411
  * A function for creating where args to filter entities
@@ -374,6 +459,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
374
459
  Output: Date;
375
460
  };
376
461
  };
462
+ Inputs: {
463
+ IntWhereInputArgument: NumberWhereInputArgument;
464
+ FloatWhereInputArgument: NumberWhereInputArgument;
465
+ StringWhereInputArgument: StringWhereInputArgument;
466
+ DateWhereInputArgument: DateWhereInputArgument;
467
+ };
377
468
  }>, {
378
469
  [x: string]: unknown;
379
470
  }>;
@@ -457,6 +548,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
457
548
  Output: Date;
458
549
  };
459
550
  };
551
+ Inputs: {
552
+ IntWhereInputArgument: NumberWhereInputArgument;
553
+ FloatWhereInputArgument: NumberWhereInputArgument;
554
+ StringWhereInputArgument: StringWhereInputArgument;
555
+ DateWhereInputArgument: DateWhereInputArgument;
556
+ };
460
557
  }>, any, any>;
461
558
  };
462
559
 
package/index.d.ts CHANGED
@@ -84,6 +84,73 @@ type RumbleInput<UserContext extends Record<string, any>, DB extends GenericDriz
84
84
  defaultLimit?: number | undefined | null;
85
85
  };
86
86
 
87
+ type NumberWhereInputArgument = {
88
+ eq?: number;
89
+ ne?: number;
90
+ gt?: number;
91
+ gte?: number;
92
+ lt?: number;
93
+ lte?: number;
94
+ in?: number[];
95
+ notIn?: number[];
96
+ like?: string;
97
+ ilike?: string;
98
+ notLike?: string;
99
+ notIlike?: string;
100
+ isNull?: boolean;
101
+ isNotNull?: boolean;
102
+ arrayOverlaps?: number[];
103
+ arrayContained?: number[];
104
+ arrayContains?: number[];
105
+ AND?: NumberWhereInputArgument[];
106
+ OR?: NumberWhereInputArgument[];
107
+ NOT?: NumberWhereInputArgument;
108
+ };
109
+ type StringWhereInputArgument = {
110
+ eq?: string;
111
+ ne?: string;
112
+ gt?: string;
113
+ gte?: string;
114
+ lt?: string;
115
+ lte?: string;
116
+ in?: string[];
117
+ notIn?: string[];
118
+ like?: string;
119
+ ilike?: string;
120
+ notLike?: string;
121
+ notIlike?: string;
122
+ isNull?: boolean;
123
+ isNotNull?: boolean;
124
+ arrayOverlaps?: string[];
125
+ arrayContained?: string[];
126
+ arrayContains?: string[];
127
+ AND?: StringWhereInputArgument[];
128
+ OR?: StringWhereInputArgument[];
129
+ NOT?: StringWhereInputArgument;
130
+ };
131
+ type DateWhereInputArgument = {
132
+ eq?: Date;
133
+ ne?: Date;
134
+ gt?: Date;
135
+ gte?: Date;
136
+ lt?: Date;
137
+ lte?: Date;
138
+ in?: Date[];
139
+ notIn?: Date[];
140
+ like?: string;
141
+ ilike?: string;
142
+ notLike?: string;
143
+ notIlike?: string;
144
+ isNull?: boolean;
145
+ isNotNull?: boolean;
146
+ arrayOverlaps?: Date[];
147
+ arrayContained?: Date[];
148
+ arrayContains?: Date[];
149
+ AND?: DateWhereInputArgument[];
150
+ OR?: DateWhereInputArgument[];
151
+ NOT?: DateWhereInputArgument;
152
+ };
153
+
87
154
  type EnumTypes = PgEnum<any>;
88
155
  type NonEnumFields<T> = {
89
156
  [K in keyof T as T[K] extends EnumTypes ? never : K]: T[K];
@@ -184,6 +251,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
184
251
  Output: Date;
185
252
  };
186
253
  };
254
+ Inputs: {
255
+ IntWhereInputArgument: NumberWhereInputArgument;
256
+ FloatWhereInputArgument: NumberWhereInputArgument;
257
+ StringWhereInputArgument: StringWhereInputArgument;
258
+ DateWhereInputArgument: DateWhereInputArgument;
259
+ };
187
260
  }>>;
188
261
  /**
189
262
  * Creates the native yoga instance. Can be used to run an actual HTTP server.
@@ -247,6 +320,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
247
320
  Output: Date;
248
321
  };
249
322
  };
323
+ Inputs: {
324
+ IntWhereInputArgument: NumberWhereInputArgument;
325
+ FloatWhereInputArgument: NumberWhereInputArgument;
326
+ StringWhereInputArgument: StringWhereInputArgument;
327
+ DateWhereInputArgument: DateWhereInputArgument;
328
+ };
250
329
  }>, 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
330
  _: {
252
331
  brand: "Table";
@@ -321,6 +400,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
321
400
  Output: Date;
322
401
  };
323
402
  };
403
+ Inputs: {
404
+ IntWhereInputArgument: NumberWhereInputArgument;
405
+ FloatWhereInputArgument: NumberWhereInputArgument;
406
+ StringWhereInputArgument: StringWhereInputArgument;
407
+ DateWhereInputArgument: DateWhereInputArgument;
408
+ };
324
409
  }>, ExplicitTableName, drizzle_orm.BuildQueryResult<drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>, drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName], true | drizzle_orm.DBQueryConfig<"one", drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>, drizzle_orm.ExtractTablesWithRelations<DB["_"]["relations"] & {}, (DB["_"]["relations"] & {})["tables"]>[ExplicitTableName]>>>;
325
410
  /**
326
411
  * A function for creating where args to filter entities
@@ -374,6 +459,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
374
459
  Output: Date;
375
460
  };
376
461
  };
462
+ Inputs: {
463
+ IntWhereInputArgument: NumberWhereInputArgument;
464
+ FloatWhereInputArgument: NumberWhereInputArgument;
465
+ StringWhereInputArgument: StringWhereInputArgument;
466
+ DateWhereInputArgument: DateWhereInputArgument;
467
+ };
377
468
  }>, {
378
469
  [x: string]: unknown;
379
470
  }>;
@@ -457,6 +548,12 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
457
548
  Output: Date;
458
549
  };
459
550
  };
551
+ Inputs: {
552
+ IntWhereInputArgument: NumberWhereInputArgument;
553
+ FloatWhereInputArgument: NumberWhereInputArgument;
554
+ StringWhereInputArgument: StringWhereInputArgument;
555
+ DateWhereInputArgument: DateWhereInputArgument;
556
+ };
460
557
  }>, any, any>;
461
558
  };
462
559
 
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 Ie,{BasePlugin}from'@pothos/core';import Ne from'@pothos/plugin-drizzle';import ze,{subscribeOptionsFromIterator}from'@pothos/plugin-smart-subscriptions';import {JSONResolver,DateResolver,DateTimeISOResolver}from'graphql-scalars';function L(e){let t,r=false;return ()=>(r||(t=e(),r=true),t)}function $(e){return typeof e=="object"&&e!==null}function W(e,t){throw new Error("Unexpected invariant triggered.")}var ce=/\r\n|[\n\r]/g;function q(e,t){let r=0,m=1;for(let n of e.body.matchAll(ce)){if(typeof n.index=="number"||W(),n.index>=t)break;r=n.index+n[0].length,m+=1;}return {line:m,column:t+1-r}}function J(e){return K(e.source,q(e.source,e.start))}function K(e,t){let r=e.locationOffset.column-1,m="".padStart(r)+e.body,n=t.line-1,l=e.locationOffset.line-1,s=t.line+l,u=t.line===1?r:0,a=t.column+u,c=`${e.name}:${s}:${a}
2
- `,i=m.split(/\r\n|[\n\r]/g),b=i[n];if(b.length>120){let o=Math.floor(a/80),d=a%80,y=[];for(let g=0;g<b.length;g+=80)y.push(b.slice(g,g+80));return c+H([[`${s} |`,y[0]],...y.slice(1,o+1).map(g=>["|",g]),["|","^".padStart(d)],["|",y[o+1]]])}return c+H([[`${s-1} |`,i[n-1]],[`${s} |`,b],["|","^".padStart(a)],[`${s+1} |`,i[n+1]]])}function H(e){let t=e.filter(([m,n])=>n!==void 0),r=Math.max(...t.map(([m])=>m.length));return t.map(([m,n])=>m.padStart(r)+(n?" "+n:"")).join(`
3
- `)}function ye(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 O=class e extends Error{constructor(t,...r){var m,n,l;let{nodes:s,source:u,positions:a,path:c,originalError:i,extensions:b}=ye(r);super(t),this.name="GraphQLError",this.path=c??void 0,this.originalError=i??void 0,this.nodes=Y(Array.isArray(s)?s:s?[s]:void 0);let o=Y((m=this.nodes)===null||m===void 0?void 0:m.map(y=>y.loc).filter(y=>y!=null));this.source=u??(o==null||(n=o[0])===null||n===void 0?void 0:n.source),this.positions=a??o?.map(y=>y.start),this.locations=a&&u?a.map(y=>q(u,y)):o?.map(y=>q(y.source,y.start));let d=$(i?.extensions)?i?.extensions:void 0;this.extensions=(l=b??d)!==null&&l!==void 0?l: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}}),i!=null&&i.stack?Object.defineProperty(this,"stack",{value:i.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 r of this.nodes)r.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 Le from'@pothos/plugin-drizzle';import qe,{subscribeOptionsFromIterator}from'@pothos/plugin-smart-subscriptions';import {JSONResolver,DateResolver,DateTimeISOResolver}from'graphql-scalars';function k(t){let n,o=false;return ()=>(o||(n=t(),o=true),n)}function M(t){return typeof t=="object"&&t!==null}function $(t,n){throw new Error("Unexpected invariant triggered.")}var ye=/\r\n|[\n\r]/g;function U(t,n){let o=0,u=1;for(let r of t.body.matchAll(ye)){if(typeof r.index=="number"||$(),r.index>=n)break;o=r.index+r[0].length,u+=1;}return {line:u,column:n+1-o}}function H(t){return W(t.source,U(t.source,t.start))}function W(t,n){let o=t.locationOffset.column-1,u="".padStart(o)+t.body,r=n.line-1,e=t.locationOffset.line-1,a=n.line+e,p=n.line===1?o:0,l=n.column+p,c=`${t.name}:${a}:${l}
2
+ `,s=u.split(/\r\n|[\n\r]/g),g=s[r];if(g.length>120){let i=Math.floor(l/80),y=l%80,d=[];for(let b=0;b<g.length;b+=80)d.push(g.slice(b,b+80));return c+J([[`${a} |`,d[0]],...d.slice(1,i+1).map(b=>["|",b]),["|","^".padStart(y)],["|",d[i+1]]])}return c+J([[`${a-1} |`,s[r-1]],[`${a} |`,g],["|","^".padStart(l)],[`${a+1} |`,s[r+1]]])}function J(t){let n=t.filter(([u,r])=>r!==void 0),o=Math.max(...n.map(([u])=>u.length));return n.map(([u,r])=>u.padStart(o)+(r?" "+r:"")).join(`
3
+ `)}function de(t){let n=t[0];return n==null||"kind"in n||"length"in n?{nodes:n,source:t[1],positions:t[2],path:t[3],originalError:t[4],extensions:t[5]}:n}var L=class t extends Error{constructor(n,...o){var u,r,e;let{nodes:a,source:p,positions:l,path:c,originalError:s,extensions:g}=de(o);super(n),this.name="GraphQLError",this.path=c??void 0,this.originalError=s??void 0,this.nodes=Y(Array.isArray(a)?a:a?[a]:void 0);let i=Y((u=this.nodes)===null||u===void 0?void 0:u.map(d=>d.loc).filter(d=>d!=null));this.source=p??(i==null||(r=i[0])===null||r===void 0?void 0:r.source),this.positions=l??i?.map(d=>d.start),this.locations=l&&p?l.map(d=>U(p,d)):i?.map(d=>U(d.source,d.start));let y=M(s?.extensions)?s?.extensions:void 0;this.extensions=(e=g??y)!==null&&e!==void 0?e: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}}),s!=null&&s.stack?Object.defineProperty(this,"stack",{value:s.stack,writable:true,configurable:true}):Error.captureStackTrace?Error.captureStackTrace(this,t):Object.defineProperty(this,"stack",{value:Error().stack,writable:true,configurable:true});}get[Symbol.toStringTag](){return "GraphQLError"}toString(){let n=this.message;if(this.nodes)for(let o of this.nodes)o.loc&&(n+=`
4
4
 
5
- `+J(r.loc));else if(this.source&&this.locations)for(let r of this.locations)t+=`
5
+ `+H(o.loc));else if(this.source&&this.locations)for(let o of this.locations)n+=`
6
6
 
7
- `+K(this.source,r);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 Y(e){return e===void 0||e.length===0?void 0:e}var D=class extends Error{constructor(t){super(t),this.name="RumbleError";}},w=class extends O{};var j=(e,t)=>new D(`RumbleError: Unknown SQL type '${e}'. Please open an issue (https://github.com/m1212e/rumble/issues) so it can be added. (${t})`);function X(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 j(e,"Distinct")}var _=Symbol.for("drizzle:Name"),Z=Symbol.for("drizzle:Columns");function I({dbName:e,tsName:t,table:r,db:m}){let n=r;if(t&&(n=m._.relations.schema[t]),e&&(n=Object.values(m._.relations.schema).find(l=>l[_]===e)),!n)throw new D(`Could not find schema for ${JSON.stringify({tsName:t,dbName:e,table:r?.[_]}).toString()}`);return {tableSchema:n,columns:n[Z],get primaryColumns(){return Object.entries(n[Z]).filter(([l,s])=>s.primary).reduce((l,[s,u])=>(l[s]=u,l),{})},relations:m._.relations.config[t],dbName:n[_],get tsName(){return Object.entries(m._.relations.schema).find(([l,s])=>s===n).at(0)}}}function Te(e){return typeof e!="function"}function ge(e){return typeof e=="function"&&e.constructor.name!=="AsyncFunction"}var ee=({db:e,actions:t,defaultLimit:r})=>{let m={},n={},l={},s=u=>{for(let a of t)l[u]||(l[u]={}),l[u][a]||(l[u][a]=[]);return {allow:a=>{let c=n[u];c||(c={},n[u]=c);let i=Array.isArray(a)?a:[a];for(let b of i){let o=c[b];o||(o="unspecified",c[b]=o);}return {when:b=>{for(let o of i)c[o]==="unspecified"&&(c[o]=[]),c[o].push(b);}}},filter:a=>{let c=Array.isArray(a)?a:[a];return {by:i=>{for(let b of c)l[u][b].push(i);}}}}};for(let u of Object.keys(e.query))m[u]=s(u);return {...m,registeredQueryFilters:n,registeredFilters:l,buildWithUserContext:u=>{let a={},c=i=>({filter:(b,o)=>{let d=p=>{let B=L(()=>{if(!(!p?.where&&!o?.inject?.where)){if(o?.inject?.where&&p?.where)return {AND:[p?.where,o?.inject?.where]};if(o?.inject?.where&&!p?.where)return o?.inject?.where;if(!o?.inject?.where&&p?.where)return p?.where;!o?.inject?.where&&p?.where;}}),v=L(()=>{let R=B();if(!R)return;let z=I({tsName:i,db:e});return relationsFilterToSQL(z.tableSchema,R)}),U=L(()=>{let R=p?.limit??r;return o?.inject?.limit&&(!R||R>o.inject.limit)&&(R=o.inject.limit),p?.limit&&(!R||p.limit>R)&&(R=p.limit),R??void 0}),F=L(()=>{if(!(!p?.columns&&!o?.inject?.columns))return {...p?.columns,...o?.inject?.columns}}),N={query:{single:{get where(){return B()},columns:F()},many:{get where(){return B()},columns:F(),get limit(){return U()}}},sql:{get where(){return v()},columns:F(),get limit(){return U()}}};return F()||(delete N.sql.columns,delete N.query.many.columns,delete N.query.single.columns),N},y=()=>{let p=I({db:e,tsName:i});if(Object.keys(p.primaryColumns).length===0)throw new D(`No primary key found for entity ${i.toString()}`);let B=Object.values(p.primaryColumns)[0],v=X(B.getSQLType());return {where:{AND:[{[B.name]:v.value1},{[B.name]:v.value2}]}}},g=n?.[i]?.[b];if(g==="unspecified")return d();g||(g=[y()]);let h=g.filter(Te),C=g.filter(ge).map(p=>p(u)),E=C.some(p=>p==="allow"),P=[...h,...C].filter(p=>p!==void 0).filter(p=>p!=="allow");!E&&P.length===0&&(P=[y()]);let x;for(let p of P)p?.limit&&(x===void 0||p.limit>x)&&(x=p.limit);let f;for(let p of [...P,o?.inject])p?.columns&&(f===void 0?f=p.columns:f={...f,...p.columns});let T=E?[]:P.filter(p=>p?.where).map(p=>p.where),S=T.length>0?{OR:T}:void 0;return d({where:S,columns:f,limit:x})},explicitFilters:b=>l[i][b]});for(let i of Object.keys(e.query))a[i]=c(i);return a}}};var te=({context:e,abilityBuilder:t})=>async r=>{let m=e?await e(r):{};return {...m,abilities:t.buildWithUserContext(m)}};function A(e){return String(e).charAt(0).toUpperCase()+String(e).slice(1)}function k(e){return e instanceof PgEnumColumn}var ne=({db:e,schemaBuilder:t})=>{let r=new Map;return ({tsName:n,enumColumn:l,refName:s})=>{let u,a;if(n){let o=e._.relations.schema[n];u=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===o);if(!d)throw new D(`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!`);a=d.enumValues;}else if(l){let o=Object.entries(e._.relations.schema).find(([d,y])=>y===l.config.enum);if(!o)throw new D(`Could not find enum in schema for ${l.name}!`);u=o[0],a=l.enumValues;}if(!u||!a)throw new D("Could not determine enum structure!");let c=s??`${A(toCamelCase(u))}Enum`,i=r.get(c);return i||(i=t.enumType(c,{values:a}),r.set(c,i),i)}};function G({sqlType:e,fieldName:t}){let r;if(["serial","int","integer","tinyint","smallint","mediumint"].includes(e)&&(r="Int"),["real","decimal","double","float"].includes(e)&&(r="Float"),["string","text","varchar","char","text(256)"].includes(e)&&(t&&(t.toLowerCase().endsWith("_id")||t.toLowerCase().endsWith("id"))?r="ID":r="String"),["uuid"].includes(e)&&(r="ID"),["boolean"].includes(e)&&(r="Boolean"),["timestamp","datetime"].includes(e)&&(r="DateTime"),["date"].includes(e)&&(r="Date"),["json"].includes(e)&&(r="JSON"),r!==void 0)return r;throw j(e,"SQL to GQL")}var De=e=>typeof e!="object"?false:!!Object.keys(e).some(t=>["args","nullable","query","subscribe","description","type","resolve"].find(r=>r===t)),re=({db:e,schemaBuilder:t,makePubSubInstance:r,argImplementer:m,enumImplementer:n,abilityBuilder:l})=>({table:s,refName:u,readAction:a="read",adjust:c})=>{let i=I({db:e,tsName:s});Object.keys(i.primaryColumns).length===0&&console.warn(`Could not find primary key for ${s.toString()}. Cannot register subscriptions!`);let b=Object.values(i.primaryColumns)[0],{registerOnInstance:o}=r({table:s});return t.drizzleObject(s,{name:u??A(s.toString()),subscribe:(d,y,g)=>{if(!b)return;let h=y[b.name];if(!h){console.warn(`Could not find primary key value for ${JSON.stringify(y)}. Cannot register subscription!`);return}o({instance:d,action:"updated",primaryKeyValue:h});},applyFilters:l?.registeredFilters?.[s]?.[a],fields:d=>{let y=i.columns,g=(x,f,T)=>{let S=G({sqlType:x,fieldName:f});switch(S){case "Int":return d.exposeInt(f,{nullable:T});case "String":return d.exposeString(f,{nullable:T});case "Boolean":return d.exposeBoolean(f,{nullable:T});case "Date":return d.field({type:"Date",resolve:p=>p[f],nullable:T});case "DateTime":return d.field({type:"DateTime",resolve:p=>p[f],nullable:T});case "Float":return d.exposeFloat(f,{nullable:T});case "ID":return d.exposeID(f,{nullable:T});case "JSON":return d.field({type:"JSON",resolve:p=>p[f],nullable:T});default:throw new D(`Unsupported object type ${S} for column ${f}`)}},h=new Map,C=c?.(new Proxy(d,{get:(x,f)=>typeof x[f]=="function"?(...T)=>{let S=x[f](...T),p=T.find(De);if(!p)throw new D("Expected config object to be passed to adjust field");return h.set(S,{params:T,creatorFunction:x[f],configObject:p}),S}:x[f]}))??{},E=Object.entries(y).reduce((x,[f,T])=>{if(C[f]){let{params:S,creatorFunction:p,configObject:B}=h.get(C[f]);return typeof B.nullable!="boolean"&&(B.nullable=!T.notNull),C[f]=p.bind(d)(...S),x}if(k(T)){let S=n({enumColumn:T});x[f]=d.field({type:S,resolve:p=>p[f],nullable:!T.notNull});}else x[f]=g(T.getSQLType(),f,!T.notNull);return x},{}),P=Object.entries(i.relations??{}).reduce((x,[f,T])=>{let S=I({db:e,table:T.targetTable}),p=m({dbName:S.dbName}),B=r({table:S.tsName}),v=false,F="many";T instanceof One&&(v=T.optional,F="single");let N=(R,z)=>{B.registerOnInstance({instance:R,action:"created"}),B.registerOnInstance({instance:R,action:"removed"});};if(C[f]){let{params:R,creatorFunction:z,configObject:Q}=h.get(C[f]);return typeof Q.nullable!="boolean"&&(Q.nullable=v),typeof Q.subscribe!="function"&&(Q.subscribe=N),C[f]=z.bind(d)(...R),x}return x[f]=d.relation(f,{args:{where:d.arg({type:p,required:false})},subscribe:N,nullable:v,query:(R,z)=>z.abilities[S.tsName].filter(a,{inject:{where:R.where}}).query[F]}),x},{});return {...E,...P,...C}}})};var Re="RUMBLE_SUBSCRIPTION_NOTIFICATION",Se="REMOVED",Ee="UPDATED",Be="CREATED",oe=({subscriptions:e,db:t})=>{let r=e?createPubSub(...e):createPubSub();return {pubsub:r,makePubSubInstance:({table:n})=>{function l({action:s,tableName:u,primaryKeyValue:a}){let c;switch(s){case "created":c=Be;break;case "removed":c=Se;break;case "updated":c=Ee;break;default:throw new Error(`Unknown action: ${s}`)}return `${Re}/${u}${a?`/${a}`:""}/${c}`}return {registerOnInstance({instance:s,action:u,primaryKeyValue:a}){let c=l({tableName:n.toString(),action:u,primaryKeyValue:a});s.register(c);},created(){let s=l({tableName:n.toString(),action:"created"});return r.publish(s)},removed(s){let u=l({tableName:n.toString(),action:"removed"});return r.publish(u)},updated(s){let a=(Array.isArray(s)?s:[s]).map(i=>l({tableName:n.toString(),action:"updated",primaryKeyValue:i})),c=Array.from(new Set(a));for(let i of c)r.publish(i);}}}}};var V=e=>{if(!e)throw new w("Value not found but required (findFirst)");return e},Pe=e=>{let t=e.at(0);if(!t)throw new w("Value not found but required (firstEntry)");return t},se=async({filters:e,entities:t,context:r})=>(await Promise.all(e.map(m=>m({context:r,entities:t})))).reduce((m,n)=>(m.push(...n),m),[]);var ae=({db:e,schemaBuilder:t,argImplementer:r,makePubSubInstance:m})=>({table:n,readAction:l="read",listAction:s="read"})=>{let u=r({table:n}),{registerOnInstance:a}=m({table:n});return t.queryFields(c=>({[`findMany${A(n.toString())}`]:c.drizzleField({type:[n],nullable:false,smartSubscription:true,subscribe:(i,b,o,d,y)=>{a({instance:i,action:"created"}),a({instance:i,action:"removed"});},args:{where:c.arg({type:u,required:false})},resolve:(i,b,o,d,y)=>{let g=d.abilities[n].filter(s,o.where?{inject:{where:o.where}}:void 0).query.many,h=i(g);return g.columns&&(h.columns=g.columns),e.query[n].findMany(h)}}),[`findFirst${A(n.toString())}`]:c.drizzleField({type:n,nullable:false,smartSubscription:true,args:{where:c.arg({type:u,required:false})},resolve:(i,b,o,d,y)=>{let g=d.abilities[n].filter(l,o.where?{inject:{where:o.where}}:void 0).query.single,h=i(g);return g.columns&&(h.columns=g.columns),e.query[n].findFirst(h).then(V)}})}))};var le="ManualFiltersPlugin",ue=le,ve="applyFilters",M=class extends BasePlugin{wrapResolve(t,r){return async(m,n,l,s)=>{let u=(r?.type).type?.ref.currentConfig.pothosOptions[ve];if(!u||!Array.isArray(u)||u.length===0)return t(m,n,l,s);let a=await t(m,n,l,s),c=Array.isArray(a)?a:[a],i=Array.isArray(u)?u:[u],b=await se({filters:i,entities:c,context:l});return Array.isArray(a)?b:b[0]??null}}};Ie.registerPlugin(le,M);var pe=({db:e,disableDefaultObjects:t,pubsub:r,pothosConfig:m})=>{let n=new Ie({...m,plugins:[ue,Ne,ze,...m?.plugins??[]],drizzle:{client:e,relations:e._.relations,getTableConfig(l){return {columns:Object.values(l[Symbol.for("drizzle:Columns")]),primaryKeys:Object.values(l[Symbol.for("drizzle:Columns")]).filter(s=>s.primary)}}},smartSubscriptions:{...subscribeOptionsFromIterator((l,s)=>r.subscribe(l))}});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 Qe=e=>`${A(toCamelCase(e.toString()))}WhereInputArgument`,me=({db:e,schemaBuilder:t,enumImplementer:r})=>{let m=new Map,n=({table:l,refName:s,dbName:u})=>{let a=I({db:e,dbName:u,tsName:l}),c=s??Qe(a.tsName),i=m.get(c);return i||(i=t.inputType(c,{fields:o=>{let d=(h,C)=>{let E=G({sqlType:h,fieldName:C});switch(E){case "Int":return o.int({required:false});case "String":return o.string({required:false});case "Boolean":return o.boolean({required:false});case "Date":return o.field({type:"Date",required:false});case "DateTime":return o.field({type:"DateTime",required:false});case "Float":return o.float({required:false});case "ID":return o.id({required:false});case "JSON":return o.field({type:"JSON",required:false});default:throw new D(`Unsupported argument type ${E} for column ${h}`)}},y=Object.entries(a.columns).reduce((h,[C,E])=>{if(k(E)){let P=r({enumColumn:E});h[C]=o.field({type:P,required:false});}else h[C]=d(E.getSQLType(),C);return h},{}),g=Object.entries(a.relations??{}).reduce((h,[C,E])=>{let P=I({db:e,table:E.targetTable}),x=n({dbName:P.dbName});return h[C]=o.field({type:x,required:false}),h},{});return {...y,...g}}}),m.set(c,i),i)};return n};var ke=e=>{e.actions||(e.actions=["read","update","delete"]),e.defaultLimit===void 0&&(e.defaultLimit=100);let t=ee(e),r=te({...e,abilityBuilder:t}),{makePubSubInstance:m,pubsub:n}=oe({...e}),{schemaBuilder:l}=pe({...e,pubsub:n}),s=ne({...e,schemaBuilder:l}),u=me({...e,schemaBuilder:l,enumImplementer:s}),a=re({...e,schemaBuilder:l,makePubSubInstance:m,argImplementer:u,enumImplementer:s,abilityBuilder:t}),c=ae({...e,schemaBuilder:l,argImplementer:u,makePubSubInstance:m});return {abilityBuilder:t,schemaBuilder:l,createYoga:b=>createYoga({...b,schema:l.toSchema(),context:r}),object:a,arg:u,query:c,pubsub:m,enum_:s}};export{D as RumbleError,w as RumbleErrorSafe,V as assertFindFirstExists,Pe as assertFirstEntryExists,ke as rumble};//# sourceMappingURL=index.js.map
7
+ `+W(this.source,o);return n}toJSON(){let n={message:this.message};return this.locations!=null&&(n.locations=this.locations),this.path!=null&&(n.path=this.path),this.extensions!=null&&Object.keys(this.extensions).length>0&&(n.extensions=this.extensions),n}};function Y(t){return t===void 0||t.length===0?void 0:t}var R=class extends Error{constructor(n){super(n),this.name="RumbleError";}},q=class extends L{};var Q=(t,n)=>new R(`RumbleError: Unknown SQL type '${t}'. Please open an issue (https://github.com/m1212e/rumble/issues) so it can be added. (${n})`);function X(t){if(["serial","int","integer","tinyint","smallint","mediumint"].includes(t))return {value1:1,value2:2};if(["real","decimal","double","float"].includes(t))return {value1:1.1,value2:2.2};if(["string","text","varchar","char","text(256)"].includes(t))return {value1:"a",value2:"b"};if(["uuid"].includes(t))return {value1:"fba31870-5528-42d7-b27e-2e5ee657aea5",value2:"fc65db81-c2d1-483d-8a25-a30e2cf6e02d"};if(["boolean"].includes(t))return {value1:true,value2:false};if(["timestamp","datetime"].includes(t))return {value1:new Date(2022,1,1),value2:new Date(2022,1,2)};if(["date"].includes(t))return {value1:new Date(2022,1,1),value2:new Date(2022,1,2)};if(["json"].includes(t))return {value1:{a:1},value2:{b:2}};throw Q(t,"Distinct")}var K=Symbol.for("drizzle:Name"),Z=Symbol.for("drizzle:Columns");function N({dbName:t,tsName:n,table:o,db:u}){let r=o;if(n&&(r=u._.relations.schema[n]),t&&(r=Object.values(u._.relations.schema).find(e=>e[K]===t)),!r)throw new R(`Could not find schema for ${JSON.stringify({tsName:n,dbName:t,table:o?.[K]}).toString()}`);return {tableSchema:r,columns:r[Z],get primaryColumns(){return Object.entries(r[Z]).filter(([e,a])=>a.primary).reduce((e,[a,p])=>(e[a]=p,e),{})},relations:u._.relations.config[n],dbName:r[K],get tsName(){return Object.entries(u._.relations.schema).find(([e,a])=>a===r).at(0)}}}function Te(t){return typeof t!="function"}function he(t){return typeof t=="function"&&t.constructor.name!=="AsyncFunction"}var ee=({db:t,actions:n,defaultLimit:o})=>{let u={},r={},e={},a=p=>{for(let l of n)e[p]||(e[p]={}),e[p][l]||(e[p][l]=[]);return {allow:l=>{let c=r[p];c||(c={},r[p]=c);let s=Array.isArray(l)?l:[l];for(let g of s){let i=c[g];i||(i="unspecified",c[g]=i);}return {when:g=>{for(let i of s)c[i]==="unspecified"&&(c[i]=[]),c[i].push(g);}}},filter:l=>{let c=Array.isArray(l)?l:[l];return {by:s=>{for(let g of c)e[p][g].push(s);}}}}};for(let p of Object.keys(t.query))u[p]=a(p);return {...u,registeredQueryFilters:r,registeredFilters:e,buildWithUserContext:p=>{let l={},c=s=>({filter:(g,i)=>{let y=m=>{let A=k(()=>{if(!(!m?.where&&!i?.inject?.where)){if(i?.inject?.where&&m?.where)return {AND:[m?.where,i?.inject?.where]};if(i?.inject?.where&&!m?.where)return i?.inject?.where;if(!i?.inject?.where&&m?.where)return m?.where;!i?.inject?.where&&m?.where;}}),P=k(()=>{let C=A();if(!C)return;let z=N({tsName:s,db:t});return relationsFilterToSQL(z.tableSchema,C)}),w=k(()=>{let C=m?.limit??o;return i?.inject?.limit&&(!C||C>i.inject.limit)&&(C=i.inject.limit),m?.limit&&(!C||m.limit>C)&&(C=m.limit),C??void 0}),v=k(()=>{if(!(!m?.columns&&!i?.inject?.columns))return {...m?.columns,...i?.inject?.columns}}),F={query:{single:{get where(){return A()},columns:v()},many:{get where(){return A()},columns:v(),get limit(){return w()}}},sql:{get where(){return P()},columns:v(),get limit(){return w()}}};return v()||(delete F.sql.columns,delete F.query.many.columns,delete F.query.single.columns),F},d=()=>{let m=N({db:t,tsName:s});if(Object.keys(m.primaryColumns).length===0)throw new R(`No primary key found for entity ${s.toString()}`);let A=Object.values(m.primaryColumns)[0],P=X(A.getSQLType());return {where:{AND:[{[A.name]:P.value1},{[A.name]:P.value2}]}}},b=r?.[s]?.[g];if(b==="unspecified")return y();b||(b=[d()]);let h=b.filter(Te),D=b.filter(he).map(m=>m(p)),I=D.some(m=>m==="allow"),E=[...h,...D].filter(m=>m!==void 0).filter(m=>m!=="allow");!I&&E.length===0&&(E=[d()]);let x;for(let m of E)m?.limit&&(x===void 0||m.limit>x)&&(x=m.limit);let f;for(let m of [...E,i?.inject])m?.columns&&(f===void 0?f=m.columns:f={...f,...m.columns});let T=I?[]:E.filter(m=>m?.where).map(m=>m.where),S=T.length>0?{OR:T}:void 0;return y({where:S,columns:f,limit:x})},explicitFilters:g=>e[s][g]});for(let s of Object.keys(t.query))l[s]=c(s);return l}}};var te=({context:t,abilityBuilder:n})=>async o=>{let u=t?await t(o):{};return {...u,abilities:n.buildWithUserContext(u)}};function B(t){return String(t).charAt(0).toUpperCase()+String(t).slice(1)}function j(t){return t instanceof PgEnumColumn}var ne=({db:t,schemaBuilder:n})=>{let o=new Map;return ({tsName:r,enumColumn:e,refName:a})=>{let p,l;if(r){let i=t._.relations.schema[r];p=r.toString();let y=Object.values(t._.relations.schema).filter(d=>typeof d=="object").map(d=>Object.values(d[Symbol.for("drizzle:Columns")])).flat(2).find(d=>d.config?.enum===i);if(!y)throw new R(`Could not find applied enum column for ${r.toString()}.
8
+ Please ensure that you use the enum at least once as a column of a table!`);l=y.enumValues;}else if(e){let i=Object.entries(t._.relations.schema).find(([y,d])=>d===e.config.enum);if(!i)throw new R(`Could not find enum in schema for ${e.name}!`);p=i[0],l=e.enumValues;}if(!p||!l)throw new R("Could not determine enum structure!");let c=a??`${B(toCamelCase(p))}Enum`,s=o.get(c);return s||(s=n.enumType(c,{values:l}),o.set(c,s),s)}};function G({sqlType:t,fieldName:n}){let o;if(["serial","int","integer","tinyint","smallint","mediumint"].includes(t)&&(o="Int"),["real","decimal","double","float"].includes(t)&&(o="Float"),["string","text","varchar","char","text(256)"].includes(t)&&(n&&(n.toLowerCase().endsWith("_id")||n.toLowerCase().endsWith("id"))?o="ID":o="String"),["uuid"].includes(t)&&(o="ID"),["boolean"].includes(t)&&(o="Boolean"),["timestamp","datetime"].includes(t)&&(o="DateTime"),["date"].includes(t)&&(o="Date"),["json"].includes(t)&&(o="JSON"),o!==void 0)return o;throw Q(t,"SQL to GQL")}var Re=t=>typeof t!="object"?false:!!Object.keys(t).some(n=>["args","nullable","query","subscribe","description","type","resolve"].find(o=>o===n)),re=({db:t,schemaBuilder:n,makePubSubInstance:o,argImplementer:u,enumImplementer:r,abilityBuilder:e})=>({table:a,refName:p,readAction:l="read",adjust:c})=>{let s=N({db:t,tsName:a});Object.keys(s.primaryColumns).length===0&&console.warn(`Could not find primary key for ${a.toString()}. Cannot register subscriptions!`);let g=Object.values(s.primaryColumns)[0],{registerOnInstance:i}=o({table:a});return n.drizzleObject(a,{name:p??B(a.toString()),subscribe:(y,d,b)=>{if(!g)return;let h=d[g.name];if(!h){console.warn(`Could not find primary key value for ${JSON.stringify(d)}. Cannot register subscription!`);return}i({instance:y,action:"updated",primaryKeyValue:h});},applyFilters:e?.registeredFilters?.[a]?.[l],fields:y=>{let d=s.columns,b=(x,f,T)=>{let S=G({sqlType:x,fieldName:f});switch(S){case "Int":return y.exposeInt(f,{nullable:T});case "String":return y.exposeString(f,{nullable:T});case "Boolean":return y.exposeBoolean(f,{nullable:T});case "Date":return y.field({type:"Date",resolve:m=>m[f],nullable:T});case "DateTime":return y.field({type:"DateTime",resolve:m=>m[f],nullable:T});case "Float":return y.exposeFloat(f,{nullable:T});case "ID":return y.exposeID(f,{nullable:T});case "JSON":return y.field({type:"JSON",resolve:m=>m[f],nullable:T});default:throw new R(`Unsupported object type ${S} for column ${f}`)}},h=new Map,D=c?.(new Proxy(y,{get:(x,f)=>typeof x[f]=="function"?(...T)=>{let S=x[f](...T),m=T.find(Re);if(!m)throw new R("Expected config object to be passed to adjust field");return h.set(S,{params:T,creatorFunction:x[f],configObject:m}),S}:x[f]}))??{},I=Object.entries(d).reduce((x,[f,T])=>{if(D[f]){let{params:S,creatorFunction:m,configObject:A}=h.get(D[f]);return typeof A.nullable!="boolean"&&(A.nullable=!T.notNull),D[f]=m.bind(y)(...S),x}if(j(T)){let S=r({enumColumn:T});x[f]=y.field({type:S,resolve:m=>m[f],nullable:!T.notNull});}else x[f]=b(T.getSQLType(),f,!T.notNull);return x},{}),E=Object.entries(s.relations??{}).reduce((x,[f,T])=>{let S=N({db:t,table:T.targetTable}),m=u({dbName:S.dbName}),A=o({table:S.tsName}),P=false,w=true,v="many";T instanceof One&&(w=false,P=T.optional,v="single");let F=(C,z)=>{A.registerOnInstance({instance:C,action:"created"}),A.registerOnInstance({instance:C,action:"removed"});};if(D[f]){let{params:C,creatorFunction:z,configObject:O}=h.get(D[f]);return typeof O.nullable!="boolean"&&(O.nullable=P),typeof O.subscribe!="function"&&(O.subscribe=F),D[f]=z.bind(y)(...C),x}return x[f]=y.relation(f,{args:{where:y.arg({type:m,required:false}),...w?{offset:y.arg.int({required:false}),limit:y.arg.int({required:false})}:{}},subscribe:F,nullable:P,query:(C,z)=>{C=JSON.parse(JSON.stringify(C));let O=z.abilities[S.tsName].filter(l,{inject:{where:C.where,limit:C.limit}}).query[v];return C.offset&&(O.offset=C.offset),O}}),x},{});return {...I,...E,...D}}})};var Se="RUMBLE_SUBSCRIPTION_NOTIFICATION",Ie="REMOVED",Ae="UPDATED",Ee="CREATED",oe=({subscriptions:t,db:n})=>{let o=t?createPubSub(...t):createPubSub();return {pubsub:o,makePubSubInstance:({table:r})=>{function e({action:a,tableName:p,primaryKeyValue:l}){let c;switch(a){case "created":c=Ee;break;case "removed":c=Ie;break;case "updated":c=Ae;break;default:throw new Error(`Unknown action: ${a}`)}return `${Se}/${p}${l?`/${l}`:""}/${c}`}return {registerOnInstance({instance:a,action:p,primaryKeyValue:l}){let c=e({tableName:r.toString(),action:p,primaryKeyValue:l});a.register(c);},created(){let a=e({tableName:r.toString(),action:"created"});return o.publish(a)},removed(a){let p=e({tableName:r.toString(),action:"removed"});return o.publish(p)},updated(a){let l=(Array.isArray(a)?a:[a]).map(s=>e({tableName:r.toString(),action:"updated",primaryKeyValue:s})),c=Array.from(new Set(l));for(let s of c)o.publish(s);}}}}};var _=t=>{if(!t)throw new q("Value not found but required (findFirst)");return t},Ne=t=>{let n=t.at(0);if(!n)throw new q("Value not found but required (firstEntry)");return n},se=async({filters:t,entities:n,context:o})=>(await Promise.all(t.map(u=>u({context:o,entities:n})))).reduce((u,r)=>(u.push(...r),u),[]);var ae=({db:t,schemaBuilder:n,argImplementer:o,makePubSubInstance:u})=>({table:r,readAction:e="read",listAction:a="read"})=>{let p=o({table:r}),{registerOnInstance:l}=u({table:r});return n.queryFields(c=>({[`findMany${B(r.toString())}`]:c.drizzleField({type:[r],nullable:false,smartSubscription:true,subscribe:(s,g,i,y,d)=>{l({instance:s,action:"created"}),l({instance:s,action:"removed"});},args:{where:c.arg({type:p,required:false}),limit:c.arg.int({required:false}),offset:c.arg.int({required:false})},resolve:(s,g,i,y,d)=>{i=JSON.parse(JSON.stringify(i));let b=y.abilities[r].filter(a,i.where||i.limit||i.offset?{inject:{where:i.where,limit:i.limit}}:void 0).query.many;i.offset&&(b.offset=i.offset);let h=s(b);return b.columns&&(h.columns=b.columns),t.query[r].findMany(h)}}),[`findFirst${B(r.toString())}`]:c.drizzleField({type:r,nullable:false,smartSubscription:true,args:{where:c.arg({type:p,required:false})},resolve:(s,g,i,y,d)=>{i=JSON.parse(JSON.stringify(i));let b=y.abilities[r].filter(e,i.where?{inject:{where:i.where}}:void 0).query.single,h=s(b);return b.columns&&(h.columns=b.columns),t.query[r].findFirst(h).then(_)}})}))};var le="ManualFiltersPlugin",ue=le,ve="applyFilters",V=class extends BasePlugin{wrapResolve(n,o){return async(u,r,e,a)=>{let p=(o?.type).type?.ref.currentConfig.pothosOptions[ve];if(!p||!Array.isArray(p)||p.length===0)return n(u,r,e,a);let l=await n(u,r,e,a),c=Array.isArray(l)?l:[l],s=Array.isArray(p)?p:[p],g=await se({filters:s,entities:c,context:e});return Array.isArray(l)?g:g[0]??null}}};Be.registerPlugin(le,V);var Oe=t=>`${B(toCamelCase(t.toString()))}WhereInputArgument`,pe=({db:t,schemaBuilder:n,enumImplementer:o})=>{let u=new Map,r=({table:e,refName:a,dbName:p})=>{let l=N({db:t,dbName:p,tsName:e}),c=a??Oe(l.tsName),s=u.get(c);return s||(s=n.inputType(c,{fields:i=>{let y=(h,D)=>{let I=G({sqlType:h,fieldName:D});switch(I){case "Int":return i.field({type:"IntWhereInputArgument"});case "String":return i.field({type:"StringWhereInputArgument"});case "Boolean":return i.boolean({required:false});case "Date":return i.field({type:"DateWhereInputArgument"});case "DateTime":return i.field({type:"DateWhereInputArgument"});case "Float":return i.field({type:"FloatWhereInputArgument"});case "ID":return i.id({required:false});case "JSON":return i.field({type:"JSON",required:false});default:throw new R(`Unsupported argument type ${I} for column ${h}`)}},d=Object.entries(l.columns).reduce((h,[D,I])=>{if(j(I)){let E=o({enumColumn:I});h[D]=i.field({type:E,required:false});}else h[D]=y(I.getSQLType(),D);return h},{}),b=Object.entries(l.relations??{}).reduce((h,[D,I])=>{let E=N({db:t,table:I.targetTable}),x=r({dbName:E.dbName});return h[D]=i.field({type:x,required:false}),h},{});return {...d,...b}}}),u.set(c,s),s)};return r};function me(t){let n=t.inputRef("IntWhereInputArgument").implement({fields:e=>({eq:e.int(),ne:e.int(),gt:e.int(),gte:e.int(),lt:e.int(),lte:e.int(),in:e.intList(),notIn:e.intList(),like:e.string(),ilike:e.string(),notLike:e.string(),notIlike:e.string(),isNull:e.boolean(),isNotNull:e.boolean(),arrayOverlaps:e.intList(),arrayContained:e.intList(),arrayContains:e.intList(),AND:e.field({type:[n]}),OR:e.field({type:[n]}),NOT:e.field({type:n})})}),o=t.inputRef("FloatWhereInputArgument").implement({fields:e=>({eq:e.float(),ne:e.float(),gt:e.float(),gte:e.float(),lt:e.float(),lte:e.float(),in:e.floatList(),notIn:e.floatList(),like:e.string(),ilike:e.string(),notLike:e.string(),notIlike:e.string(),isNull:e.boolean(),isNotNull:e.boolean(),arrayOverlaps:e.floatList(),arrayContained:e.floatList(),arrayContains:e.floatList(),AND:e.field({type:[o]}),OR:e.field({type:[o]}),NOT:e.field({type:o})})}),u=t.inputRef("StringWhereInputArgument").implement({fields:e=>({eq:e.string(),ne:e.string(),gt:e.string(),gte:e.string(),lt:e.string(),lte:e.string(),in:e.stringList(),notIn:e.stringList(),like:e.string(),ilike:e.string(),notLike:e.string(),notIlike:e.string(),isNull:e.boolean(),isNotNull:e.boolean(),arrayOverlaps:e.stringList(),arrayContained:e.stringList(),arrayContains:e.stringList(),AND:e.field({type:[u]}),OR:e.field({type:[u]}),NOT:e.field({type:u})})}),r=t.inputRef("DateWhereInputArgument").implement({fields:e=>({eq:e.field({type:"Date"}),ne:e.field({type:"Date"}),gt:e.field({type:"Date"}),gte:e.field({type:"Date"}),lt:e.field({type:"Date"}),lte:e.field({type:"Date"}),in:e.field({type:["Date"]}),notIn:e.field({type:["Date"]}),like:e.string(),ilike:e.string(),notLike:e.string(),notIlike:e.string(),isNull:e.boolean(),isNotNull:e.boolean(),arrayOverlaps:e.field({type:["Date"]}),arrayContained:e.field({type:["Date"]}),arrayContains:e.field({type:["Date"]}),AND:e.field({type:[r]}),OR:e.field({type:[r]}),NOT:e.field({type:r})})});}var ce=({db:t,disableDefaultObjects:n,pubsub:o,pothosConfig:u})=>{let r=new Be({...u,plugins:[ue,Le,qe,...u?.plugins??[]],drizzle:{client:t,relations:t._.relations,getTableConfig(e){return {columns:Object.values(e[Symbol.for("drizzle:Columns")]),primaryKeys:Object.values(e[Symbol.for("drizzle:Columns")]).filter(a=>a.primary)}}},smartSubscriptions:{...subscribeOptionsFromIterator((e,a)=>o.subscribe(e))}});return r.addScalarType("JSON",JSONResolver),r.addScalarType("Date",DateResolver),r.addScalarType("DateTime",DateTimeISOResolver),me(r),n?.query||r.queryType({}),n?.subscription||r.subscriptionType({}),n?.mutation||r.mutationType({}),{schemaBuilder:r}};var Ge=t=>{t.actions||(t.actions=["read","update","delete"]),t.defaultLimit===void 0&&(t.defaultLimit=100);let n=ee(t),o=te({...t,abilityBuilder:n}),{makePubSubInstance:u,pubsub:r}=oe({...t}),{schemaBuilder:e}=ce({...t,pubsub:r}),a=ne({...t,schemaBuilder:e}),p=pe({...t,schemaBuilder:e,enumImplementer:a}),l=re({...t,schemaBuilder:e,makePubSubInstance:u,argImplementer:p,enumImplementer:a,abilityBuilder:n}),c=ae({...t,schemaBuilder:e,argImplementer:p,makePubSubInstance:u});return {abilityBuilder:n,schemaBuilder:e,createYoga:g=>createYoga({...g,schema:e.toSchema(),context:o}),object:l,arg:p,query:c,pubsub:u,enum_:a}};export{R as RumbleError,q as RumbleErrorSafe,_ as assertFindFirstExists,Ne as assertFirstEntryExists,Ge as rumble};//# sourceMappingURL=index.js.map
9
9
  //# sourceMappingURL=index.js.map