@m1212e/rumble 0.6.3 → 0.6.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.cjs +6 -6
- package/index.cjs.map +1 -1
- package/index.d.cts +18 -18
- package/index.d.ts +18 -18
- package/index.js +6 -6
- package/index.js.map +1 -1
- package/package.json +1 -1
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
|
-
|
126
|
+
columns: undefined;
|
127
127
|
};
|
128
128
|
many: {
|
129
129
|
readonly where: any;
|
130
|
-
|
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
|
-
|
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
|
-
|
155
|
+
columns: undefined;
|
156
156
|
};
|
157
157
|
many: {
|
158
158
|
readonly where: any;
|
159
|
-
|
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
|
-
|
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
|
-
|
218
|
+
columns: undefined;
|
219
219
|
};
|
220
220
|
many: {
|
221
221
|
readonly where: any;
|
222
|
-
|
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
|
-
|
228
|
+
columns: undefined;
|
229
229
|
readonly limit: any;
|
230
230
|
};
|
231
231
|
};
|
@@ -257,17 +257,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
|
|
257
257
|
query: {
|
258
258
|
single: {
|
259
259
|
readonly where: any;
|
260
|
-
|
260
|
+
columns: undefined;
|
261
261
|
};
|
262
262
|
many: {
|
263
263
|
readonly where: any;
|
264
|
-
|
264
|
+
columns: undefined;
|
265
265
|
readonly limit: any;
|
266
266
|
};
|
267
267
|
};
|
268
268
|
sql: {
|
269
269
|
readonly where: drizzle_orm.SQL<unknown> | undefined;
|
270
|
-
|
270
|
+
columns: undefined;
|
271
271
|
readonly limit: any;
|
272
272
|
};
|
273
273
|
};
|
@@ -310,17 +310,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
|
|
310
310
|
query: {
|
311
311
|
single: {
|
312
312
|
readonly where: any;
|
313
|
-
|
313
|
+
columns: undefined;
|
314
314
|
};
|
315
315
|
many: {
|
316
316
|
readonly where: any;
|
317
|
-
|
317
|
+
columns: undefined;
|
318
318
|
readonly limit: any;
|
319
319
|
};
|
320
320
|
};
|
321
321
|
sql: {
|
322
322
|
readonly where: drizzle_orm.SQL<unknown> | undefined;
|
323
|
-
|
323
|
+
columns: undefined;
|
324
324
|
readonly limit: any;
|
325
325
|
};
|
326
326
|
};
|
@@ -393,17 +393,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
|
|
393
393
|
query: {
|
394
394
|
single: {
|
395
395
|
readonly where: any;
|
396
|
-
|
396
|
+
columns: undefined;
|
397
397
|
};
|
398
398
|
many: {
|
399
399
|
readonly where: any;
|
400
|
-
|
400
|
+
columns: undefined;
|
401
401
|
readonly limit: any;
|
402
402
|
};
|
403
403
|
};
|
404
404
|
sql: {
|
405
405
|
readonly where: drizzle_orm.SQL<unknown> | undefined;
|
406
|
-
|
406
|
+
columns: undefined;
|
407
407
|
readonly limit: any;
|
408
408
|
};
|
409
409
|
};
|
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
|
-
|
126
|
+
columns: undefined;
|
127
127
|
};
|
128
128
|
many: {
|
129
129
|
readonly where: any;
|
130
|
-
|
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
|
-
|
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
|
-
|
155
|
+
columns: undefined;
|
156
156
|
};
|
157
157
|
many: {
|
158
158
|
readonly where: any;
|
159
|
-
|
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
|
-
|
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
|
-
|
218
|
+
columns: undefined;
|
219
219
|
};
|
220
220
|
many: {
|
221
221
|
readonly where: any;
|
222
|
-
|
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
|
-
|
228
|
+
columns: undefined;
|
229
229
|
readonly limit: any;
|
230
230
|
};
|
231
231
|
};
|
@@ -257,17 +257,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
|
|
257
257
|
query: {
|
258
258
|
single: {
|
259
259
|
readonly where: any;
|
260
|
-
|
260
|
+
columns: undefined;
|
261
261
|
};
|
262
262
|
many: {
|
263
263
|
readonly where: any;
|
264
|
-
|
264
|
+
columns: undefined;
|
265
265
|
readonly limit: any;
|
266
266
|
};
|
267
267
|
};
|
268
268
|
sql: {
|
269
269
|
readonly where: drizzle_orm.SQL<unknown> | undefined;
|
270
|
-
|
270
|
+
columns: undefined;
|
271
271
|
readonly limit: any;
|
272
272
|
};
|
273
273
|
};
|
@@ -310,17 +310,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
|
|
310
310
|
query: {
|
311
311
|
single: {
|
312
312
|
readonly where: any;
|
313
|
-
|
313
|
+
columns: undefined;
|
314
314
|
};
|
315
315
|
many: {
|
316
316
|
readonly where: any;
|
317
|
-
|
317
|
+
columns: undefined;
|
318
318
|
readonly limit: any;
|
319
319
|
};
|
320
320
|
};
|
321
321
|
sql: {
|
322
322
|
readonly where: drizzle_orm.SQL<unknown> | undefined;
|
323
|
-
|
323
|
+
columns: undefined;
|
324
324
|
readonly limit: any;
|
325
325
|
};
|
326
326
|
};
|
@@ -393,17 +393,17 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
|
|
393
393
|
query: {
|
394
394
|
single: {
|
395
395
|
readonly where: any;
|
396
|
-
|
396
|
+
columns: undefined;
|
397
397
|
};
|
398
398
|
many: {
|
399
399
|
readonly where: any;
|
400
|
-
|
400
|
+
columns: undefined;
|
401
401
|
readonly limit: any;
|
402
402
|
};
|
403
403
|
};
|
404
404
|
sql: {
|
405
405
|
readonly where: drizzle_orm.SQL<unknown> | undefined;
|
406
|
-
|
406
|
+
columns: undefined;
|
407
407
|
readonly limit: any;
|
408
408
|
};
|
409
409
|
};
|
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
|
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
|
3
|
-
`)}function
|
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
|
-
|
5
|
+
`+H(m.loc));else if(this.source&&this.locations)for(let m of this.locations)t+=`
|
6
6
|
|
7
|
-
`+
|
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
|
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)}),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}}),w={query:{single:{get where(){return E()},columns:q()},many:{get where(){return E()},columns:q(),get limit(){return O()}}},sql:{get where(){return A()},columns:q(),get limit(){return O()}}};return q()||(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,O)=>O.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
|