@m1212e/rumble 0.6.6 → 0.7.7

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
@@ -202,11 +202,11 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
202
202
  /**
203
203
  * A function for creating default objects for your schema
204
204
  */
205
- object: <ExplicitTableName extends keyof NonEnumFields<NonNullable<DB["_"]["relations"]["schema"]>>, RefName extends string>({ table, refName, readAction, extend, }: {
205
+ object: <ExplicitTableName extends keyof NonEnumFields<NonNullable<DB["_"]["relations"]["schema"]>>, RefName extends string>({ table, refName, readAction, adjust, }: {
206
206
  table: ExplicitTableName;
207
207
  refName?: RefName | undefined;
208
208
  readAction?: Action | undefined;
209
- extend?: ((t: _pothos_plugin_drizzle.DrizzleObjectFieldBuilder<PothosSchemaTypes.ExtendDefaultTypes<{
209
+ adjust?: ((t: _pothos_plugin_drizzle.DrizzleObjectFieldBuilder<PothosSchemaTypes.ExtendDefaultTypes<{
210
210
  Context: Awaited<UserContext & {
211
211
  abilities: keyof DB["query"] extends infer T_4 extends keyof DB["query"] ? { [key_5 in T_4]: {
212
212
  filter: <Injection extends Parameters<DB["query"][key_5]["findMany"]>[0]>(action: Action, options?: {
package/index.d.ts CHANGED
@@ -202,11 +202,11 @@ declare const rumble: <UserContext extends Record<string, any>, DB extends Gener
202
202
  /**
203
203
  * A function for creating default objects for your schema
204
204
  */
205
- object: <ExplicitTableName extends keyof NonEnumFields<NonNullable<DB["_"]["relations"]["schema"]>>, RefName extends string>({ table, refName, readAction, extend, }: {
205
+ object: <ExplicitTableName extends keyof NonEnumFields<NonNullable<DB["_"]["relations"]["schema"]>>, RefName extends string>({ table, refName, readAction, adjust, }: {
206
206
  table: ExplicitTableName;
207
207
  refName?: RefName | undefined;
208
208
  readAction?: Action | undefined;
209
- extend?: ((t: _pothos_plugin_drizzle.DrizzleObjectFieldBuilder<PothosSchemaTypes.ExtendDefaultTypes<{
209
+ adjust?: ((t: _pothos_plugin_drizzle.DrizzleObjectFieldBuilder<PothosSchemaTypes.ExtendDefaultTypes<{
210
210
  Context: Awaited<UserContext & {
211
211
  abilities: keyof DB["query"] extends infer T_4 extends keyof DB["query"] ? { [key_5 in T_4]: {
212
212
  filter: <Injection extends Parameters<DB["query"][key_5]["findMany"]>[0]>(action: Action, options?: {
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 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 L(e){let t,u=false;return ()=>(u||(t=e(),u=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 O(e,t){let u=0,p=1;for(let n of e.body.matchAll(me)){if(typeof n.index=="number"||M(),n.index>=t)break;u=n.index+n[0].length,p+=1;}return {line:p,column:t+1-u}}function H(e){return G(e.source,O(e.source,e.start))}function G(e,t){let u=e.locationOffset.column-1,p="".padStart(u)+e.body,n=t.line-1,a=e.locationOffset.line-1,o=t.line+a,l=t.line===1?u:0,s=t.column+l,m=`${e.name}:${o}:${s}
2
- `,r=p.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 m+$([[`${o} |`,y[0]],...y.slice(1,i+1).map(b=>["|",b]),["|","^".padStart(d)],["|",y[i+1]]])}return m+$([[`${o-1} |`,r[n-1]],[`${o} |`,f],["|","^".padStart(s)],[`${o+1} |`,r[n+1]]])}function $(e){let t=e.filter(([p,n])=>n!==void 0),u=Math.max(...t.map(([p])=>p.length));return t.map(([p,n])=>p.padStart(u)+(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 N=class e extends Error{constructor(t,...u){var p,n,a;let{nodes:o,source:l,positions:s,path:m,originalError:r,extensions:f}=ce(u);super(t),this.name="GraphQLError",this.path=m??void 0,this.originalError=r??void 0,this.nodes=J(Array.isArray(o)?o:o?[o]:void 0);let i=J((p=this.nodes)===null||p===void 0?void 0:p.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=>O(l,y)):i?.map(y=>O(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 u of this.nodes)u.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 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 w(e){let t,p=false;return ()=>(p||(t=e(),p=true),t)}function $(e){return typeof e=="object"&&e!==null}function H(e,t){throw new Error("Unexpected invariant triggered.")}var ce=/\r\n|[\n\r]/g;function q(e,t){let p=0,m=1;for(let n of e.body.matchAll(ce)){if(typeof n.index=="number"||H(),n.index>=t)break;p=n.index+n[0].length,m+=1;}return {line:m,column:t+1-p}}function W(e){return K(e.source,q(e.source,e.start))}function K(e,t){let p=e.locationOffset.column-1,m="".padStart(p)+e.body,n=t.line-1,a=e.locationOffset.line-1,o=t.line+a,l=t.line===1?p:0,s=t.column+l,c=`${e.name}:${o}:${s}
2
+ `,r=m.split(/\r\n|[\n\r]/g),b=r[n];if(b.length>120){let i=Math.floor(s/80),d=s%80,y=[];for(let g=0;g<b.length;g+=80)y.push(b.slice(g,g+80));return c+J([[`${o} |`,y[0]],...y.slice(1,i+1).map(g=>["|",g]),["|","^".padStart(d)],["|",y[i+1]]])}return c+J([[`${o-1} |`,r[n-1]],[`${o} |`,b],["|","^".padStart(s)],[`${o+1} |`,r[n+1]]])}function J(e){let t=e.filter(([m,n])=>n!==void 0),p=Math.max(...t.map(([m])=>m.length));return t.map(([m,n])=>m.padStart(p)+(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,...p){var m,n,a;let{nodes:o,source:l,positions:s,path:c,originalError:r,extensions:b}=ye(p);super(t),this.name="GraphQLError",this.path=c??void 0,this.originalError=r??void 0,this.nodes=Y(Array.isArray(o)?o:o?[o]:void 0);let i=Y((m=this.nodes)===null||m===void 0?void 0:m.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=>q(l,y)):i?.map(y=>q(y.source,y.start));let d=$(r?.extensions)?r?.extensions:void 0;this.extensions=(a=b??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 p of this.nodes)p.loc&&(t+=`
4
4
 
5
- `+H(u.loc));else if(this.source&&this.locations)for(let u of this.locations)t+=`
5
+ `+W(p.loc));else if(this.source&&this.locations)for(let p of this.locations)t+=`
6
6
 
7
- `+G(this.source,u);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";}},z=class extends N{};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:u,db:p}){let n=u;if(t&&(n=p._.relations.schema[t]),e&&(n=Object.values(p._.relations.schema).find(a=>a[j]===e)),!n)throw new C(`Could not find schema for ${JSON.stringify({tsName:t,dbName:e,table:u?.[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:p._.relations.config[t],dbName:n[j],get tsName(){return Object.entries(p._.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:u})=>{let p={},n={},a={},o=l=>{for(let s of t)a[l]||(a[l]={}),a[l][s]||(a[l][s]=[]);return {allow:s=>{let m=n[l];m||(m={},n[l]=m);let r=Array.isArray(s)?s:[s];for(let f of r){let i=m[f];i||(i="unspecified",m[f]=i);}return {when:f=>{for(let i of r)m[i]==="unspecified"&&(m[i]=[]),m[i].push(f);}}},filter:s=>{let m=Array.isArray(s)?s:[s];return {by:r=>{for(let f of m)a[l][f].push(r);}}}}};for(let l of Object.keys(e.query))p[l]=o(l);return {...p,registeredQueryFilters:n,registeredFilters:a,buildWithUserContext:l=>{let s={},m=r=>({filter:(f,i)=>{let d=c=>{let B=L(()=>{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=L(()=>{let E=B();if(!E)return;let pe=P({tsName:r,db:e});return relationsFilterToSQL(pe.tableSchema,E)}),v=L(()=>{let E=c?.limit??u;return i?.inject?.limit&&(!E||E>i.inject.limit)&&(E=i.inject.limit),c?.limit&&(!E||c.limit>E)&&(E=c.limit),E??void 0}),F=L(()=>{if(!(!c?.columns&&!i?.inject?.columns))return {...c?.columns,...i?.inject?.columns}}),w={query:{single:{get where(){return B()},columns:F()},many:{get where(){return B()},columns:F(),get limit(){return v()}}},sql:{get where(){return A()},columns:F(),get limit(){return v()}}};return F()||(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 B=Object.values(c.primaryColumns)[0],A=W(B.getSQLType());return {where:{AND:[{[B.name]:A.value1},{[B.name]:A.value2}]}}},b=n?.[r]?.[f];if(b==="unspecified")return d();b||(b=[y()]);let h=b.filter(Te),S=b.filter(be).map(c=>c(l)),x=S.some(c=>c==="allow"),T=[...h,...S].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 D;for(let c of [...T,i?.inject])c?.columns&&(D===void 0?D=c.columns:D={...D,...c.columns});let R=x?[]:T.filter(c=>c?.where).map(c=>c.where),q=R.length>0?{OR:R}:void 0;return d({where:q,columns:D,limit:g})},explicitFilters:f=>a[r][f]});for(let r of Object.keys(e.query))s[r]=m(r);return s}}};var Z=({context:e,abilityBuilder:t})=>async u=>{let p=e?await e(u):{};return {...p,abilities:t.buildWithUserContext(p)}};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 u=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 m=o??`${I(toCamelCase(l))}Enum`,r=u.get(m);return r||(r=t.enumType(m,{values:s}),u.set(m,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:u,argImplementer:p,enumImplementer:n,abilityBuilder:a})=>({table:o,refName:l,readAction:s="read",extend:m})=>{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}=u({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 D=k(x);switch(D){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 ${D} for column ${T}`)}},h=Object.entries(y).reduce((x,[T,g])=>{if(Q(g)){let D=n({enumColumn:g});x[T]=d.field({type:D,resolve:R=>R[T],nullable:!g.notNull});}else x[T]=b(g.getSQLType(),T,!g.notNull);return x},{}),S=Object.entries(r.relations??{}).reduce((x,[T,g])=>{let D=P({db:e,table:g.targetTable}),R=p({dbName:D.dbName}),q=u({table:D.tsName}),c=false,A="many";return g instanceof One&&(c=g.optional,A="single"),x[T]=d.relation(T,{args:{where:d.arg({type:R,required:false})},subscribe:(v,F)=>{q.registerOnInstance({instance:v,action:"created"}),q.registerOnInstance({instance:v,action:"removed"});},nullable:c,query:(v,F)=>F.abilities[D.tsName].filter(s,{inject:{where:v.where}}).query[A]}),x},{});return m?{...h,...S,...m(d)??{}}:{...h,...S}}})};var Ce="RUMBLE_SUBSCRIPTION_NOTIFICATION",De="REMOVED",Se="UPDATED",Re="CREATED",re=({subscriptions:e,db:t})=>{let u=e?createPubSub(...e):createPubSub();return {pubsub:u,makePubSubInstance:({table:n})=>{function a({action:o,tableName:l,primaryKeyValue:s}){let m;switch(o){case "created":m=Re;break;case "removed":m=De;break;case "updated":m=Se;break;default:throw new Error(`Unknown action: ${o}`)}return `${Ce}/${l}${s?`/${s}`:""}/${m}`}return {registerOnInstance({instance:o,action:l,primaryKeyValue:s}){let m=a({tableName:n.toString(),action:l,primaryKeyValue:s});o.register(m);},created(){let o=a({tableName:n.toString(),action:"created"});return u.publish(o)},removed(o){let l=a({tableName:n.toString(),action:"removed"});return u.publish(l)},updated(o){let s=(Array.isArray(o)?o:[o]).map(r=>a({tableName:n.toString(),action:"updated",primaryKeyValue:r})),m=Array.from(new Set(s));for(let r of m)u.publish(r);}}}}};var K=e=>{if(!e)throw new z("Value not found but required (findFirst)");return e},Ee=e=>{let t=e.at(0);if(!t)throw new z("Value not found but required (firstEntry)");return t},ie=async({filters:e,entities:t,context:u})=>(await Promise.all(e.map(p=>p({context:u,entities:t})))).reduce((p,n)=>(p.push(...n),p),[]);var oe=({db:e,schemaBuilder:t,argImplementer:u,makePubSubInstance:p})=>({table:n,readAction:a="read",listAction:o="read"})=>{let l=u({table:n}),{registerOnInstance:s}=p({table:n});return t.queryFields(m=>({[`findMany${I(n.toString())}`]:m.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:m.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())}`]:m.drizzleField({type:n,nullable:false,smartSubscription:true,args:{where:m.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,u){return async(p,n,a,o)=>{let l=(u?.type).type?.ref.currentConfig.pothosOptions[Ie];if(!l||!Array.isArray(l)||l.length===0)return t(p,n,a,o);let s=await t(p,n,a,o),m=Array.isArray(s)?s:[s],r=Array.isArray(l)?l:[l],f=await ie({filters:r,entities:m,context:a});return Array.isArray(s)?f:f[0]??null}}};Be.registerPlugin(se,_);var le=({db:e,disableDefaultObjects:t,pubsub:u,pothosConfig:p})=>{let n=new Be({plugins:[ae,ve,Fe,...p?.plugins??[]],...p,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)=>u.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:u})=>{let p=new Map,n=({table:a,refName:o,dbName:l})=>{let s=P({db:e,dbName:l,tsName:a}),m=o??we(s.tsName),r=p.get(m);return r||(r=t.inputType(m,{fields:i=>{let d=h=>{let S=k(h);switch(S){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 ${S} for column ${h}`)}},y=Object.entries(s.columns).reduce((h,[S,x])=>{if(Q(x)){let T=u({enumColumn:x});h[S]=i.field({type:T,required:false});}else h[S]=d(x.getSQLType());return h},{}),b=Object.entries(s.relations??{}).reduce((h,[S,x])=>{let T=P({db:e,table:x.targetTable}),g=n({dbName:T.dbName});return h[S]=i.field({type:g,required:false}),h},{});return {...y,...b}}}),p.set(m,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),u=Z({...e,abilityBuilder:t}),{makePubSubInstance:p,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:p,argImplementer:l,enumImplementer:o,abilityBuilder:t}),m=oe({...e,schemaBuilder:a,argImplementer:l,makePubSubInstance:p});return {abilityBuilder:t,schemaBuilder:a,createYoga:f=>createYoga({...f,schema:a.toSchema(),context:u}),object:s,arg:l,query:m,pubsub:p,enum_:o}};export{C as RumbleError,z as RumbleErrorSafe,K as assertFindFirstExists,Ee as assertFirstEntryExists,Qe as rumble};//# sourceMappingURL=index.js.map
7
+ `+K(this.source,p);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";}},L=class extends O{};var k=(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 k(e,"Distinct")}var _=Symbol.for("drizzle:Name"),Z=Symbol.for("drizzle:Columns");function I({dbName:e,tsName:t,table:p,db:m}){let n=p;if(t&&(n=m._.relations.schema[t]),e&&(n=Object.values(m._.relations.schema).find(a=>a[_]===e)),!n)throw new D(`Could not find schema for ${JSON.stringify({tsName:t,dbName:e,table:p?.[_]}).toString()}`);return {tableSchema:n,columns:n[Z],get primaryColumns(){return Object.entries(n[Z]).filter(([a,o])=>o.primary).reduce((a,[o,l])=>(a[o]=l,a),{})},relations:m._.relations.config[t],dbName:n[_],get tsName(){return Object.entries(m._.relations.schema).find(([a,o])=>o===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:p})=>{let m={},n={},a={},o=l=>{for(let s of t)a[l]||(a[l]={}),a[l][s]||(a[l][s]=[]);return {allow:s=>{let c=n[l];c||(c={},n[l]=c);let r=Array.isArray(s)?s:[s];for(let b of r){let i=c[b];i||(i="unspecified",c[b]=i);}return {when:b=>{for(let i of r)c[i]==="unspecified"&&(c[i]=[]),c[i].push(b);}}},filter:s=>{let c=Array.isArray(s)?s:[s];return {by:r=>{for(let b of c)a[l][b].push(r);}}}}};for(let l of Object.keys(e.query))m[l]=o(l);return {...m,registeredQueryFilters:n,registeredFilters:a,buildWithUserContext:l=>{let s={},c=r=>({filter:(b,i)=>{let d=u=>{let E=w(()=>{if(!(!u?.where&&!i?.inject?.where)){if(i?.inject?.where&&u?.where)return {AND:[u?.where,i?.inject?.where]};if(i?.inject?.where&&!u?.where)return i?.inject?.where;if(!i?.inject?.where&&u?.where)return u?.where;!i?.inject?.where&&u?.where;}}),v=w(()=>{let S=E();if(!S)return;let z=I({tsName:r,db:e});return relationsFilterToSQL(z.tableSchema,S)}),U=w(()=>{let S=u?.limit??p;return i?.inject?.limit&&(!S||S>i.inject.limit)&&(S=i.inject.limit),u?.limit&&(!S||u.limit>S)&&(S=u.limit),S??void 0}),F=w(()=>{if(!(!u?.columns&&!i?.inject?.columns))return {...u?.columns,...i?.inject?.columns}}),N={query:{single:{get where(){return E()},columns:F()},many:{get where(){return E()},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 u=I({db:e,tsName:r});if(Object.keys(u.primaryColumns).length===0)throw new D(`No primary key found for entity ${r.toString()}`);let E=Object.values(u.primaryColumns)[0],v=X(E.getSQLType());return {where:{AND:[{[E.name]:v.value1},{[E.name]:v.value2}]}}},g=n?.[r]?.[b];if(g==="unspecified")return d();g||(g=[y()]);let h=g.filter(Te),C=g.filter(ge).map(u=>u(l)),P=C.some(u=>u==="allow"),B=[...h,...C].filter(u=>u!==void 0).filter(u=>u!=="allow");!P&&B.length===0&&(B=[y()]);let x;for(let u of B)u?.limit&&(x===void 0||u.limit>x)&&(x=u.limit);let f;for(let u of [...B,i?.inject])u?.columns&&(f===void 0?f=u.columns:f={...f,...u.columns});let T=P?[]:B.filter(u=>u?.where).map(u=>u.where),R=T.length>0?{OR:T}:void 0;return d({where:R,columns:f,limit:x})},explicitFilters:b=>a[r][b]});for(let r of Object.keys(e.query))s[r]=c(r);return s}}};var te=({context:e,abilityBuilder:t})=>async p=>{let m=e?await e(p):{};return {...m,abilities:t.buildWithUserContext(m)}};function A(e){return String(e).charAt(0).toUpperCase()+String(e).slice(1)}function j(e){return e instanceof PgEnumColumn}var ne=({db:e,schemaBuilder:t})=>{let p=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 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!`);s=d.enumValues;}else if(a){let i=Object.entries(e._.relations.schema).find(([d,y])=>y===a.config.enum);if(!i)throw new D(`Could not find enum in schema for ${a.name}!`);l=i[0],s=a.enumValues;}if(!l||!s)throw new D("Could not determine enum structure!");let c=o??`${A(toCamelCase(l))}Enum`,r=p.get(c);return r||(r=t.enumType(c,{values:s}),p.set(c,r),r)}};function G(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 k(e,"SQL to GQL")}var De=e=>typeof e!="object"?false:!!Object.keys(e).some(t=>["args","nullable","query","subscribe","description","type","resolve"].find(p=>p===t)),re=({db:e,schemaBuilder:t,makePubSubInstance:p,argImplementer:m,enumImplementer:n,abilityBuilder:a})=>({table:o,refName:l,readAction:s="read",adjust:c})=>{let r=I({db:e,tsName:o});Object.keys(r.primaryColumns).length===0&&console.warn(`Could not find primary key for ${o.toString()}. Cannot register subscriptions!`);let b=Object.values(r.primaryColumns)[0],{registerOnInstance:i}=p({table:o});return t.drizzleObject(o,{name:l??A(o.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}i({instance:d,action:"updated",primaryKeyValue:h});},applyFilters:a?.registeredFilters?.[o]?.[s],fields:d=>{let y=r.columns,g=(x,f,T)=>{let R=G(x);switch(R){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:u=>u[f],nullable:T});case "DateTime":return d.field({type:"DateTime",resolve:u=>u[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:u=>u[f],nullable:T});default:throw new D(`Unsupported object type ${R} for column ${f}`)}},h=new Map,C=c?.(new Proxy(d,{get:(x,f)=>typeof x[f]=="function"?(...T)=>{let R=x[f](...T),u=T.find(De);if(!u)throw new D("Expected config object to be passed to adjust field");return h.set(R,{params:T,creatorFunction:x[f],configObject:u}),R}:x[f]}))??{},P=Object.entries(y).reduce((x,[f,T])=>{if(C[f]){let{params:R,creatorFunction:u,configObject:E}=h.get(C[f]);return typeof E.nullable!="boolean"&&(E.nullable=!T.notNull),C[f]=u.bind(d)(...R),x}if(j(T)){let R=n({enumColumn:T});x[f]=d.field({type:R,resolve:u=>u[f],nullable:!T.notNull});}else x[f]=g(T.getSQLType(),f,!T.notNull);return x},{}),B=Object.entries(r.relations??{}).reduce((x,[f,T])=>{let R=I({db:e,table:T.targetTable}),u=m({dbName:R.dbName}),E=p({table:R.tsName}),v=false,F="many";T instanceof One&&(v=T.optional,F="single");let N=(S,z)=>{E.registerOnInstance({instance:S,action:"created"}),E.registerOnInstance({instance:S,action:"removed"});};if(C[f]){let{params:S,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)(...S),x}return x[f]=d.relation(f,{args:{where:d.arg({type:u,required:false})},subscribe:N,nullable:v,query:(S,z)=>z.abilities[R.tsName].filter(s,{inject:{where:S.where}}).query[F]}),x},{});return {...P,...B,...C}}})};var Se="RUMBLE_SUBSCRIPTION_NOTIFICATION",Re="REMOVED",Ee="UPDATED",Be="CREATED",oe=({subscriptions:e,db:t})=>{let p=e?createPubSub(...e):createPubSub();return {pubsub:p,makePubSubInstance:({table:n})=>{function a({action:o,tableName:l,primaryKeyValue:s}){let c;switch(o){case "created":c=Be;break;case "removed":c=Re;break;case "updated":c=Ee;break;default:throw new Error(`Unknown action: ${o}`)}return `${Se}/${l}${s?`/${s}`:""}/${c}`}return {registerOnInstance({instance:o,action:l,primaryKeyValue:s}){let c=a({tableName:n.toString(),action:l,primaryKeyValue:s});o.register(c);},created(){let o=a({tableName:n.toString(),action:"created"});return p.publish(o)},removed(o){let l=a({tableName:n.toString(),action:"removed"});return p.publish(l)},updated(o){let s=(Array.isArray(o)?o:[o]).map(r=>a({tableName:n.toString(),action:"updated",primaryKeyValue:r})),c=Array.from(new Set(s));for(let r of c)p.publish(r);}}}}};var V=e=>{if(!e)throw new L("Value not found but required (findFirst)");return e},Pe=e=>{let t=e.at(0);if(!t)throw new L("Value not found but required (firstEntry)");return t},se=async({filters:e,entities:t,context:p})=>(await Promise.all(e.map(m=>m({context:p,entities:t})))).reduce((m,n)=>(m.push(...n),m),[]);var ae=({db:e,schemaBuilder:t,argImplementer:p,makePubSubInstance:m})=>({table:n,readAction:a="read",listAction:o="read"})=>{let l=p({table:n}),{registerOnInstance:s}=m({table:n});return t.queryFields(c=>({[`findMany${A(n.toString())}`]:c.drizzleField({type:[n],nullable:false,smartSubscription:true,subscribe:(r,b,i,d,y)=>{s({instance:r,action:"created"}),s({instance:r,action:"removed"});},args:{where:c.arg({type:l,required:false})},resolve:(r,b,i,d,y)=>{let g=d.abilities[n].filter(o,i.where?{inject:{where:i.where}}:void 0).query.many,h=r(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:l,required:false})},resolve:(r,b,i,d,y)=>{let g=d.abilities[n].filter(a,i.where?{inject:{where:i.where}}:void 0).query.single,h=r(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,p){return async(m,n,a,o)=>{let l=(p?.type).type?.ref.currentConfig.pothosOptions[ve];if(!l||!Array.isArray(l)||l.length===0)return t(m,n,a,o);let s=await t(m,n,a,o),c=Array.isArray(s)?s:[s],r=Array.isArray(l)?l:[l],b=await se({filters:r,entities:c,context:a});return Array.isArray(s)?b:b[0]??null}}};Ie.registerPlugin(le,M);var pe=({db:e,disableDefaultObjects:t,pubsub:p,pothosConfig:m})=>{let n=new Ie({plugins:[ue,Ne,ze,...m?.plugins??[]],...m,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)=>p.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 Qe=e=>`${A(toCamelCase(e.toString()))}WhereInputArgument`,me=({db:e,schemaBuilder:t,enumImplementer:p})=>{let m=new Map,n=({table:a,refName:o,dbName:l})=>{let s=I({db:e,dbName:l,tsName:a}),c=o??Qe(s.tsName),r=m.get(c);return r||(r=t.inputType(c,{fields:i=>{let d=h=>{let C=G(h);switch(C){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 D(`Unsupported argument type ${C} for column ${h}`)}},y=Object.entries(s.columns).reduce((h,[C,P])=>{if(j(P)){let B=p({enumColumn:P});h[C]=i.field({type:B,required:false});}else h[C]=d(P.getSQLType());return h},{}),g=Object.entries(s.relations??{}).reduce((h,[C,P])=>{let B=I({db:e,table:P.targetTable}),x=n({dbName:B.dbName});return h[C]=i.field({type:x,required:false}),h},{});return {...y,...g}}}),m.set(c,r),r)};return n};var je=e=>{e.actions||(e.actions=["read","update","delete"]),e.defaultLimit===void 0&&(e.defaultLimit=100);let t=ee(e),p=te({...e,abilityBuilder:t}),{makePubSubInstance:m,pubsub:n}=oe({...e}),{schemaBuilder:a}=pe({...e,pubsub:n}),o=ne({...e,schemaBuilder:a}),l=me({...e,schemaBuilder:a,enumImplementer:o}),s=re({...e,schemaBuilder:a,makePubSubInstance:m,argImplementer:l,enumImplementer:o,abilityBuilder:t}),c=ae({...e,schemaBuilder:a,argImplementer:l,makePubSubInstance:m});return {abilityBuilder:t,schemaBuilder:a,createYoga:b=>createYoga({...b,schema:a.toSchema(),context:p}),object:s,arg:l,query:c,pubsub:m,enum_:o}};export{D as RumbleError,L as RumbleErrorSafe,V as assertFindFirstExists,Pe as assertFirstEntryExists,je as rumble};//# sourceMappingURL=index.js.map
9
9
  //# sourceMappingURL=index.js.map