@m1212e/rumble 0.8.4 → 0.9.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.cjs +6 -6
- package/index.cjs.map +1 -1
- package/index.d.cts +64 -3
- package/index.d.ts +64 -3
- package/index.js +6 -6
- package/index.js.map +1 -1
- package/package.json +1 -1
package/index.cjs
CHANGED
@@ -1,9 +1,9 @@
|
|
1
|
-
'use strict';var graphqlYoga=require('graphql-yoga'),sofaApi=require('sofa-api'),drizzleOrm=require('drizzle-orm'),casing=require('drizzle-orm/casing'),pgCore=require('drizzle-orm/pg-core'),
|
2
|
-
`,
|
3
|
-
`)}function
|
1
|
+
'use strict';var graphqlYoga=require('graphql-yoga'),sofaApi=require('sofa-api'),drizzleOrm=require('drizzle-orm'),casing=require('drizzle-orm/casing'),pgCore=require('drizzle-orm/pg-core'),qe=require('@pothos/core'),je=require('@pothos/plugin-drizzle'),Ge=require('@pothos/plugin-smart-subscriptions'),graphqlScalars=require('graphql-scalars');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var qe__default=/*#__PURE__*/_interopDefault(qe);var je__default=/*#__PURE__*/_interopDefault(je);var Ge__default=/*#__PURE__*/_interopDefault(Ge);function J(t){return typeof t=="object"&&t!==null}function H(t,n){throw new Error("Unexpected invariant triggered.")}var be=/\r\n|[\n\r]/g;function U(t,n){let o=0,p=1;for(let i of t.body.matchAll(be)){if(typeof i.index=="number"||H(),i.index>=n)break;o=i.index+i[0].length,p+=1;}return {line:p,column:n+1-o}}function X(t){return K(t.source,U(t.source,t.start))}function K(t,n){let o=t.locationOffset.column-1,p="".padStart(o)+t.body,i=n.line-1,e=t.locationOffset.line-1,c=n.line+e,l=n.line===1?o:0,u=n.column+l,y=`${t.name}:${c}:${u}
|
2
|
+
`,a=p.split(/\r\n|[\n\r]/g),d=a[i];if(d.length>120){let s=Math.floor(u/80),C=u%80,r=[];for(let g=0;g<d.length;g+=80)r.push(d.slice(g,g+80));return y+Y([[`${c} |`,r[0]],...r.slice(1,s+1).map(g=>["|",g]),["|","^".padStart(C)],["|",r[s+1]]])}return y+Y([[`${c-1} |`,a[i-1]],[`${c} |`,d],["|","^".padStart(u)],[`${c+1} |`,a[i+1]]])}function Y(t){let n=t.filter(([p,i])=>i!==void 0),o=Math.max(...n.map(([p])=>p.length));return n.map(([p,i])=>p.padStart(o)+(i?" "+i:"")).join(`
|
3
|
+
`)}function he(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 p,i,e;let{nodes:c,source:l,positions:u,path:y,originalError:a,extensions:d}=he(o);super(n),this.name="GraphQLError",this.path=y??void 0,this.originalError=a??void 0,this.nodes=Z(Array.isArray(c)?c:c?[c]:void 0);let s=Z((p=this.nodes)===null||p===void 0?void 0:p.map(r=>r.loc).filter(r=>r!=null));this.source=l??(s==null||(i=s[0])===null||i===void 0?void 0:i.source),this.positions=u??s?.map(r=>r.start),this.locations=u&&l?u.map(r=>U(l,r)):s?.map(r=>U(r.source,r.start));let C=J(a?.extensions)?a?.extensions:void 0;this.extensions=(e=d??C)!==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}}),a!=null&&a.stack?Object.defineProperty(this,"stack",{value:a.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
|
-
`+
|
5
|
+
`+X(o.loc));else if(this.source&&this.locations)for(let o of this.locations)n+=`
|
6
6
|
|
7
|
-
`+
|
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 S(`Could not find enum in schema for ${e.name}!`);p=i[0],l=e.enumValues;}if(!p||!l)throw new S("Could not determine enum structure!");let c=a??`${B(casing.toCamelCase(p))}Enum`,s=o.get(c);return s||(s=n.enumType(c,{values:l}),o.set(c,s),s)}};var ie={paths:{"/webhook":{post:{operationId:"webhook_create",description:"Creates a webhook subscription.",tags:[],parameters:[],requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookCreateBody"}}}},responses:{200:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookDetailResponse"}}}}}}},"/webhook/{id}":{post:{operationId:"webhook_update",description:"Updates a webhook subscription.",parameters:[{name:"id",in:"path",description:"The ID of the webhook to update",required:true,schema:{type:"string"}}],requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookCreateBody"}}}},responses:{200:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookDetailResponse"}}}}}},delete:{operationId:"webhook_delete",description:"Removes a webhook subscription.",tags:[],parameters:[{name:"id",in:"path",description:"The ID of the webhook to delete",required:true,schema:{type:"string"}}],responses:{200:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookDetailResponse"}}}}}}}},components:{schemas:{WebhookCreateBody:{type:"object",properties:{subscription:{description:"The subscription to subscribe to. In many cases, these match the available query IDs without the '_query' suffix. E.g., 'findFirstUser_query' -> 'findFirstUser'. See the graphql schema for more details on what subscriptions are available.",type:"string"},variables:{description:"The variables to pass to the subscription.",type:"object"},url:{description:"The URL to send the webhook to.",type:"string"}}},WebhookDetailResponse:{type:"object",properties:{id:{description:"The ID of the webhook. Can be used as reference in update or delete calls.",type:"string"}}}}}};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 Ie=t=>typeof t!="object"?false:!!Object.keys(t).some(n=>["args","nullable","query","subscribe","description","type","resolve"].find(o=>o===n)),oe=({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 b=Object.values(s.primaryColumns)[0],{registerOnInstance:i}=o({table:a});return n.drizzleObject(a,{name:p??B(a.toString()),subscribe:(y,d,g)=>{if(!b)return;let T=d[b.name];if(!T){console.warn(`Could not find primary key value for ${JSON.stringify(d)}. Cannot register subscription!`);return}i({instance:y,action:"updated",primaryKeyValue:T});},applyFilters:e?.registeredFilters?.[a]?.[l],fields:y=>{let d=s.columns,g=(x,f,h)=>{let R=G({sqlType:x,fieldName:f});switch(R){case "Int":return y.exposeInt(f,{nullable:h});case "String":return y.exposeString(f,{nullable:h});case "Boolean":return y.exposeBoolean(f,{nullable:h});case "Date":return y.field({type:"Date",resolve:m=>m[f],nullable:h});case "DateTime":return y.field({type:"DateTime",resolve:m=>m[f],nullable:h});case "Float":return y.exposeFloat(f,{nullable:h});case "ID":return y.exposeID(f,{nullable:h});case "JSON":return y.field({type:"JSON",resolve:m=>m[f],nullable:h});default:throw new S(`Unsupported object type ${R} for column ${f}`)}},T=new Map,D=c?.(new Proxy(y,{get:(x,f)=>typeof x[f]=="function"?(...h)=>{let R=x[f](...h),m=h.find(Ie);if(!m)throw new S("Expected config object to be passed to adjust field");return T.set(R,{params:h,creatorFunction:x[f],configObject:m}),R}:x[f]}))??{},I=Object.entries(d).reduce((x,[f,h])=>{if(D[f]){let{params:R,creatorFunction:m,configObject:A}=T.get(D[f]);return typeof A.nullable!="boolean"&&(A.nullable=!h.notNull),D[f]=m.bind(y)(...R),x}if(j(h)){let R=r({enumColumn:h});x[f]=y.field({type:R,resolve:m=>m[f],nullable:!h.notNull});}else x[f]=g(h.getSQLType(),f,!h.notNull);return x},{}),E=Object.entries(s.relations??{}).reduce((x,[f,h])=>{let R=N({db:t,table:h.targetTable}),m=u({dbName:R.dbName}),A=o({table:R.tsName}),P=false,w=true,v="many";h instanceof drizzleOrm.One&&(w=false,P=h.optional,v="single");let F=(C,L)=>{A.registerOnInstance({instance:C,action:"created"}),A.registerOnInstance({instance:C,action:"removed"});};if(D[f]){let{params:C,creatorFunction:L,configObject:O}=T.get(D[f]);return typeof O.nullable!="boolean"&&(O.nullable=P),typeof O.subscribe!="function"&&(O.subscribe=F),D[f]=L.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,L)=>{C=JSON.parse(JSON.stringify(C));let O=L.abilities[R.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 Ae="RUMBLE_SUBSCRIPTION_NOTIFICATION",Ee="REMOVED",Ne="UPDATED",Be="CREATED",ae=({subscriptions:t,db:n})=>{let o=t?graphqlYoga.createPubSub(...t):graphqlYoga.createPubSub();return {pubsub:o,makePubSubInstance:({table:r})=>{function e({action:a,tableName:p,primaryKeyValue:l}){let c;switch(a){case "created":c=Be;break;case "removed":c=Ee;break;case "updated":c=Ne;break;default:throw new Error(`Unknown action: ${a}`)}return `${Ae}/${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 le=({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,b,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,b,i,y,d)=>{i=JSON.parse(JSON.stringify(i));let g=y.abilities[r].filter(a,i.where||i.limit||i.offset?{inject:{where:i.where,limit:i.limit}}:void 0).query.many;i.offset&&(g.offset=i.offset);let T=s(g);return g.columns&&(T.columns=g.columns),t.query[r].findMany(T)}}),[`findFirst${B(r.toString())}`]:c.drizzleField({type:r,nullable:false,smartSubscription:true,args:{where:c.arg({type:p,required:false})},resolve:(s,b,i,y,d)=>{i=JSON.parse(JSON.stringify(i));let g=y.abilities[r].filter(e,i.where?{inject:{where:i.where}}:void 0).query.single,T=s(g);return g.columns&&(T.columns=g.columns),t.query[r].findFirst(T).then(_)}})}))};var ue="ManualFiltersPlugin",pe=ue,Fe="applyFilters",V=class extends Pe.BasePlugin{wrapResolve(n,o){return async(u,r,e,a)=>{let p=(o?.type).type?.ref.currentConfig.pothosOptions[Fe];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],b=await X({filters:s,entities:c,context:e});return Array.isArray(l)?b:b[0]??null}}};Pe__default.default.registerPlugin(ue,V);var ze=t=>`${B(casing.toCamelCase(t.toString()))}WhereInputArgument`,me=({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??ze(l.tsName),s=u.get(c);return s||(s=n.inputType(c,{fields:i=>{let y=(T,D)=>{let I=G({sqlType:T,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 S(`Unsupported argument type ${I} for column ${T}`)}},d=Object.entries(l.columns).reduce((T,[D,I])=>{if(j(I)){let E=o({enumColumn:I});T[D]=i.field({type:E,required:false});}else T[D]=y(I.getSQLType(),D);return T},{}),g=Object.entries(l.relations??{}).reduce((T,[D,I])=>{let E=N({db:t,table:I.targetTable}),x=r({dbName:E.dbName});return T[D]=i.field({type:x,required:false}),T},{});return {...d,...g}}}),u.set(c,s),s)};return r};function ce(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 ye=({db:t,disableDefaultObjects:n,pubsub:o,pothosConfig:u})=>{let r=new Pe__default.default({...u,plugins:[pe,ke__default.default,qe__default.default,...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:{...qe.subscribeOptionsFromIterator((e,a)=>o.subscribe(e))}});return r.addScalarType("JSON",graphqlScalars.JSONResolver),r.addScalarType("Date",graphqlScalars.DateResolver),r.addScalarType("DateTime",graphqlScalars.DateTimeISOResolver),ce(r),n?.query||r.queryType({}),n?.subscription||r.subscriptionType({}),n?.mutation||r.mutationType({}),{schemaBuilder:r}};var _e=t=>{t.actions||(t.actions=["read","update","delete"]),t.defaultLimit===void 0&&(t.defaultLimit=100);let n=te(t),o=ne({...t,abilityBuilder:n}),{makePubSubInstance:u,pubsub:r}=ae({...t}),{schemaBuilder:e}=ye({...t,pubsub:r}),a=re({...t,schemaBuilder:e}),p=me({...t,schemaBuilder:e,enumImplementer:a}),l=oe({...t,schemaBuilder:e,makePubSubInstance:u,argImplementer:p,enumImplementer:a,abilityBuilder:n}),c=le({...t,schemaBuilder:e,argImplementer:p,makePubSubInstance:u}),s=z(()=>e.toSchema());return {abilityBuilder:n,schemaBuilder:e,createYoga:y=>graphqlYoga.createYoga({...y,schema:s(),context:o}),createSofa:y=>(y.openAPI&&(y.openAPI={...ie,...y.openAPI}),sofaApi.useSofa({...y,schema:s(),context:o})),object:l,arg:p,query:c,pubsub:u,enum_:a}};exports.RumbleError=S;exports.RumbleErrorSafe=q;exports.assertFindFirstExists=_;exports.assertFirstEntryExists=he;exports.rumble=_e;//# sourceMappingURL=index.cjs.map
|
7
|
+
`+K(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 Z(t){return t===void 0||t.length===0?void 0:t}var S=class extends Error{constructor(n){super(n),this.name="RumbleError";}},w=class extends L{};var V=t=>{if(!t)throw new w("Value not found but required (findFirst)");return t},Ce=t=>{let n=t.at(0);if(!n)throw new w("Value not found but required (firstEntry)");return n},ee=async({filters:t,entities:n,context:o})=>(await Promise.all(t.map(p=>p({context:o,entities:n})))).reduce((p,i)=>(p.push(...i),p),[]);function v(t){let n,o=false;return ()=>(o||(n=t(),o=true),n)}var G=(t,n)=>new S(`RumbleError: Unknown SQL type '${t}'. Please open an issue (https://github.com/m1212e/rumble/issues) so it can be added. (${n})`);function te(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 G(t,"Distinct")}var M=Symbol.for("drizzle:Name"),ne=Symbol.for("drizzle:Columns");function E({dbName:t,tsName:n,table:o,db:p}){let i=o;if(n&&(i=p._.relations.schema[n]),t&&(i=Object.values(p._.relations.schema).find(e=>e[M]===t)),!i)throw new S(`Could not find schema for ${JSON.stringify({tsName:n,dbName:t,table:o?.[M]}).toString()}`);return {tableSchema:i,columns:i[ne],get primaryColumns(){return Object.entries(i[ne]).filter(([e,c])=>c.primary).reduce((e,[c,l])=>(e[c]=l,e),{})},relations:p._.relations.config[n],dbName:i[M],get tsName(){return Object.entries(p._.relations.schema).find(([e,c])=>c===i).at(0)}}}function Re(t){return typeof t!="function"}function Se(t){return typeof t=="function"&&t.constructor.name!=="AsyncFunction"}var re=({db:t,actions:n,defaultLimit:o})=>{let p={},i={},e={},c=l=>{for(let u of n)e[l]||(e[l]={}),e[l][u]||(e[l][u]=[]);return {allow:u=>{let y=i[l];y||(y={},i[l]=y);let a=Array.isArray(u)?u:[u];for(let d of a){let s=y[d];s||(s="unspecified",y[d]=s);}return {when:d=>{for(let s of a)y[s]==="unspecified"&&(y[s]=[]),y[s].push(d);}}},filter:u=>{let y=Array.isArray(u)?u:[u];return {by:a=>{for(let d of y)e[l][d].push(a);}}}}};for(let l of Object.keys(t.query))p[l]=c(l);return {...p,registeredQueryFilters:i,registeredFilters:e,buildWithUserContext:l=>{let u={},y=a=>({filter:(d,s)=>{let C=m=>{let x=v(()=>{if(!(!m?.where&&!s?.inject?.where)){if(s?.inject?.where&&m?.where)return {AND:[m?.where,s?.inject?.where]};if(s?.inject?.where&&!m?.where)return s?.inject?.where;if(!s?.inject?.where&&m?.where)return m?.where;!s?.inject?.where&&m?.where;}}),P=v(()=>{let A=x();if(!A)return;let Q=E({tsName:a,db:t});return drizzleOrm.relationsFilterToSQL(Q.tableSchema,A)}),k=v(()=>{let A=m?.limit??o;return s?.inject?.limit&&(!A||A>s.inject.limit)&&(A=s.inject.limit),m?.limit&&(!A||m.limit>A)&&(A=m.limit),A??void 0}),O=v(()=>{if(!(!m?.columns&&!s?.inject?.columns))return {...m?.columns,...s?.inject?.columns}}),q={query:{single:{get where(){return x()},columns:O()},many:{get where(){return x()},columns:O(),get limit(){return k()}}},sql:{get where(){return P()},columns:O(),get limit(){return k()}}};return O()||(delete q.sql.columns,delete q.query.many.columns,delete q.query.single.columns),q},r=()=>{let m=E({db:t,tsName:a});if(Object.keys(m.primaryColumns).length===0)throw new S(`No primary key found for entity ${a.toString()}`);let x=Object.values(m.primaryColumns)[0],P=te(x.getSQLType());return {where:{AND:[{[x.name]:P.value1},{[x.name]:P.value2}]}}},g=i?.[a]?.[d];if(g==="unspecified")return C();g||(g=[r()]);let D=g.filter(Re),b=g.filter(Se).map(m=>m(l)),h=b.some(m=>m==="allow"),I=[...D,...b].filter(m=>m!==void 0).filter(m=>m!=="allow");!h&&I.length===0&&(I=[r()]);let F;for(let m of I)m?.limit&&(F===void 0||m.limit>F)&&(F=m.limit);let R;for(let m of [...I,s?.inject])m?.columns&&(R===void 0?R=m.columns:R={...R,...m.columns});let f=h?[]:I.filter(m=>m?.where).map(m=>m.where),T=f.length>0?{OR:f}:void 0;return C({where:T,columns:R,limit:F})},explicitFilters:d=>e[a][d]});for(let a of Object.keys(t.query))u[a]=y(a);return u}}};var ie=({context:t,abilityBuilder:n})=>async o=>{let p=t?await t(o):{};return {...p,abilities:n.buildWithUserContext(p)}};function N(t){return String(t).charAt(0).toUpperCase()+String(t).slice(1)}function W(t){return t instanceof pgCore.PgEnumColumn}var oe=({db:t,schemaBuilder:n})=>{let o=new Map;return ({tsName:i,enumColumn:e,refName:c})=>{let l,u;if(i){let s=t._.relations.schema[i];l=i.toString();let C=Object.values(t._.relations.schema).filter(r=>typeof r=="object").map(r=>Object.values(r[Symbol.for("drizzle:Columns")])).flat(2).find(r=>r.config?.enum===s);if(!C)throw new S(`Could not find applied enum column for ${i.toString()}.
|
8
|
+
Please ensure that you use the enum at least once as a column of a table!`);u=C.enumValues;}else if(e){let s=Object.entries(t._.relations.schema).find(([C,r])=>r===e.config.enum);if(!s)throw new S(`Could not find enum in schema for ${e.name}!`);l=s[0],u=e.enumValues;}if(!l||!u)throw new S("Could not determine enum structure!");let y=c??`${N(casing.toCamelCase(l))}Enum`,a=o.get(y);return a||(a=n.enumType(y,{values:u}),o.set(y,a),a)}};var se={paths:{"/webhook":{post:{operationId:"webhook_create",description:"Creates a webhook subscription.",tags:[],parameters:[],requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookCreateBody"}}}},responses:{200:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookDetailResponse"}}}}}}},"/webhook/{id}":{post:{operationId:"webhook_update",description:"Updates a webhook subscription.",parameters:[{name:"id",in:"path",description:"The ID of the webhook to update",required:true,schema:{type:"string"}}],requestBody:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookCreateBody"}}}},responses:{200:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookDetailResponse"}}}}}},delete:{operationId:"webhook_delete",description:"Removes a webhook subscription.",tags:[],parameters:[{name:"id",in:"path",description:"The ID of the webhook to delete",required:true,schema:{type:"string"}}],responses:{200:{content:{"application/json":{schema:{$ref:"#/components/schemas/WebhookDetailResponse"}}}}}}}},components:{schemas:{WebhookCreateBody:{type:"object",properties:{subscription:{description:"The subscription to subscribe to. In many cases, these match the available query IDs without the '_query' suffix. E.g., 'findFirstUser_query' -> 'findFirstUser'. See the graphql schema for more details on what subscriptions are available.",type:"string"},variables:{description:"The variables to pass to the subscription.",type:"object"},url:{description:"The URL to send the webhook to.",type:"string"}}},WebhookDetailResponse:{type:"object",properties:{id:{description:"The ID of the webhook. Can be used as reference in update or delete calls.",type:"string"}}}}}};function _({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 G(t,"SQL to GQL")}var Ee=t=>typeof t!="object"?false:!!Object.keys(t).some(n=>["args","nullable","query","subscribe","description","type","resolve"].find(o=>o===n)),ae=({db:t,schemaBuilder:n,makePubSubInstance:o,whereArgImplementer:p,orderArgImplementer:i,enumImplementer:e,abilityBuilder:c})=>({table:l,refName:u,readAction:y="read",adjust:a})=>{let d=E({db:t,tsName:l});Object.keys(d.primaryColumns).length===0&&console.warn(`Could not find primary key for ${l.toString()}. Cannot register subscriptions!`);let s=Object.values(d.primaryColumns)[0],{registerOnInstance:C}=o({table:l});return n.drizzleObject(l,{name:u??N(l.toString()),subscribe:(r,g,D)=>{if(!s)return;let b=g[s.name];if(!b){console.warn(`Could not find primary key value for ${JSON.stringify(g)}. Cannot register subscription!`);return}C({instance:r,action:"updated",primaryKeyValue:b});},applyFilters:c?.registeredFilters?.[l]?.[y],fields:r=>{let g=d.columns,D=(R,f,T)=>{let m=_({sqlType:R,fieldName:f});switch(m){case "Int":return r.exposeInt(f,{nullable:T});case "String":return r.exposeString(f,{nullable:T});case "Boolean":return r.exposeBoolean(f,{nullable:T});case "Date":return r.field({type:"Date",resolve:x=>x[f],nullable:T});case "DateTime":return r.field({type:"DateTime",resolve:x=>x[f],nullable:T});case "Float":return r.exposeFloat(f,{nullable:T});case "ID":return r.exposeID(f,{nullable:T});case "JSON":return r.field({type:"JSON",resolve:x=>x[f],nullable:T});default:throw new S(`Unsupported object type ${m} for column ${f}`)}},b=new Map,h=a?.(new Proxy(r,{get:(R,f)=>typeof R[f]=="function"?(...T)=>{let m=R[f](...T),x=T.find(Ee);if(!x)throw new S("Expected config object to be passed to adjust field");return b.set(m,{params:T,creatorFunction:R[f],configObject:x}),m}:R[f]}))??{},I=Object.entries(g).reduce((R,[f,T])=>{if(h[f]){let{params:m,creatorFunction:x,configObject:P}=b.get(h[f]);return typeof P.nullable!="boolean"&&(P.nullable=!T.notNull),h[f]=x.bind(r)(...m),R}if(W(T)){let m=e({enumColumn:T});R[f]=r.field({type:m,resolve:x=>x[f],nullable:!T.notNull});}else R[f]=D(T.getSQLType(),f,!T.notNull);return R},{}),F=Object.entries(d.relations??{}).reduce((R,[f,T])=>{let m=E({db:t,table:T.targetTable}),x=p({dbName:m.dbName}),P=i({dbName:m.dbName}),k=o({table:m.tsName}),O=false,q=true,A="many";T instanceof drizzleOrm.One&&(q=false,O=T.optional,A="single");let Q=(B,j)=>{k.registerOnInstance({instance:B,action:"created"}),k.registerOnInstance({instance:B,action:"removed"});};if(h[f]){let{params:B,creatorFunction:j,configObject:z}=b.get(h[f]);return typeof z.nullable!="boolean"&&(z.nullable=O),typeof z.subscribe!="function"&&(z.subscribe=Q),h[f]=j.bind(r)(...B),R}return R[f]=r.relation(f,{args:{where:r.arg({type:x,required:false}),orderBy:r.arg({type:P,required:false}),...q?{offset:r.arg.int({required:false}),limit:r.arg.int({required:false})}:{}},subscribe:Q,nullable:O,query:(B,j)=>{B=JSON.parse(JSON.stringify(B));let z=j.abilities[m.tsName].filter(y,{inject:{where:B.where,limit:B.limit}}).query[A];return B.offset&&(z.offset=B.offset),B.orderBy&&(z.orderBy=B.orderBy),z}}),R},{});return {...I,...F,...h}}})};var Pe=t=>`${N(casing.toCamelCase(t.toString()))}OrderInputArgument`,le=({db:t,schemaBuilder:n})=>{let o=new Map,p=v(()=>n.enumType("SortingParameter",{values:["asc","desc"]})),i=({table:e,refName:c,dbName:l})=>{let u=E({db:t,dbName:l,tsName:e}),y=c??Pe(u.tsName),a=o.get(y);return a||(a=n.inputType(y,{fields:s=>{let C=Object.entries(u.columns).reduce((g,[D,b])=>(g[D]=s.field({type:p(),required:false}),g),{}),r=Object.entries(u.relations??{}).reduce((g,[D,b])=>{let h=E({db:t,table:b.targetTable}),I=i({dbName:h.dbName});return g[D]=s.field({type:I,required:false}),g},{});return {...C,...r}}}),o.set(y,a),a)};return i};var ve="RUMBLE_SUBSCRIPTION_NOTIFICATION",Fe="REMOVED",Oe="UPDATED",ze="CREATED",pe=({subscriptions:t,db:n})=>{let o=t?graphqlYoga.createPubSub(...t):graphqlYoga.createPubSub();return {pubsub:o,makePubSubInstance:({table:i})=>{function e({action:c,tableName:l,primaryKeyValue:u}){let y;switch(c){case "created":y=ze;break;case "removed":y=Fe;break;case "updated":y=Oe;break;default:throw new Error(`Unknown action: ${c}`)}return `${ve}/${l}${u?`/${u}`:""}/${y}`}return {registerOnInstance({instance:c,action:l,primaryKeyValue:u}){let y=e({tableName:i.toString(),action:l,primaryKeyValue:u});c.register(y);},created(){let c=e({tableName:i.toString(),action:"created"});return o.publish(c)},removed(c){let l=e({tableName:i.toString(),action:"removed"});return o.publish(l)},updated(c){let u=(Array.isArray(c)?c:[c]).map(a=>e({tableName:i.toString(),action:"updated",primaryKeyValue:a})),y=Array.from(new Set(u));for(let a of y)o.publish(a);}}}}};var me=({db:t,schemaBuilder:n,whereArgImplementer:o,orderArgImplementer:p,makePubSubInstance:i})=>({table:e,readAction:c="read",listAction:l="read"})=>{let u=o({table:e}),y=p({table:e}),{registerOnInstance:a}=i({table:e});return n.queryFields(d=>({[`findMany${N(e.toString())}`]:d.drizzleField({type:[e],nullable:false,smartSubscription:true,subscribe:(s,C,r,g,D)=>{a({instance:s,action:"created"}),a({instance:s,action:"removed"});},args:{where:d.arg({type:u,required:false}),orderBy:d.arg({type:y,required:false}),limit:d.arg.int({required:false}),offset:d.arg.int({required:false})},resolve:(s,C,r,g,D)=>{r=JSON.parse(JSON.stringify(r));let b=g.abilities[e].filter(l,r.where||r.limit||r.offset?{inject:{where:r.where,limit:r.limit}}:void 0).query.many;r.offset&&(b.offset=r.offset),r.orderBy&&(b.orderBy=r.orderBy);let h=s(b);return b.columns&&(h.columns=b.columns),t.query[e].findMany(h)}}),[`findFirst${N(e.toString())}`]:d.drizzleField({type:e,nullable:false,smartSubscription:true,args:{where:d.arg({type:u,required:false})},resolve:(s,C,r,g,D)=>{r=JSON.parse(JSON.stringify(r));let b=g.abilities[e].filter(c,r.where?{inject:{where:r.where}}:void 0).query.single,h=s(b);return b.columns&&(h.columns=b.columns),t.query[e].findFirst(h).then(V)}})}))};var ce="ManualFiltersPlugin",ye=ce,we="applyFilters",$=class extends qe.BasePlugin{wrapResolve(n,o){return async(p,i,e,c)=>{let l=(o?.type).type?.ref.currentConfig.pothosOptions[we];if(!l||!Array.isArray(l)||l.length===0)return n(p,i,e,c);let u=await n(p,i,e,c),y=Array.isArray(u)?u:[u],a=Array.isArray(l)?l:[l],d=await ee({filters:a,entities:y,context:e});return Array.isArray(u)?d:d[0]??null}}};qe__default.default.registerPlugin(ce,$);var Ue=t=>`${N(casing.toCamelCase(t.toString()))}WhereInputArgument`,de=({db:t,schemaBuilder:n,enumImplementer:o})=>{let p=new Map,i=({table:e,refName:c,dbName:l})=>{let u=E({db:t,dbName:l,tsName:e}),y=c??Ue(u.tsName),a=p.get(y);return a||(a=n.inputType(y,{fields:s=>{let C=(D,b)=>{let h=_({sqlType:D,fieldName:b});switch(h){case "Int":return s.field({type:"IntWhereInputArgument"});case "String":return s.field({type:"StringWhereInputArgument"});case "Boolean":return s.boolean({required:false});case "Date":return s.field({type:"DateWhereInputArgument"});case "DateTime":return s.field({type:"DateWhereInputArgument"});case "Float":return s.field({type:"FloatWhereInputArgument"});case "ID":return s.id({required:false});case "JSON":return s.field({type:"JSON",required:false});default:throw new S(`Unsupported argument type ${h} for column ${D}`)}},r=Object.entries(u.columns).reduce((D,[b,h])=>{if(W(h)){let I=o({enumColumn:h});D[b]=s.field({type:I,required:false});}else D[b]=C(h.getSQLType(),b);return D},{}),g=Object.entries(u.relations??{}).reduce((D,[b,h])=>{let I=E({db:t,table:h.targetTable}),F=i({dbName:I.dbName});return D[b]=s.field({type:F,required:false}),D},{});return {...r,...g}}}),p.set(y,a),a)};return i};function fe(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})})}),p=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:[p]}),OR:e.field({type:[p]}),NOT:e.field({type:p})})}),i=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:[i]}),OR:e.field({type:[i]}),NOT:e.field({type:i})})});}var ge=({db:t,disableDefaultObjects:n,pubsub:o,pothosConfig:p})=>{let i=new qe__default.default({...p,plugins:[ye,je__default.default,Ge__default.default,...p?.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(c=>c.primary)}}},smartSubscriptions:{...Ge.subscribeOptionsFromIterator((e,c)=>o.subscribe(e))}});return i.addScalarType("JSON",graphqlScalars.JSONResolver),i.addScalarType("Date",graphqlScalars.DateResolver),i.addScalarType("DateTime",graphqlScalars.DateTimeISOResolver),fe(i),n?.query||i.queryType({}),n?.subscription||i.subscriptionType({}),n?.mutation||i.mutationType({}),{schemaBuilder:i}};var Je=t=>{t.actions||(t.actions=["read","update","delete"]),t.defaultLimit===void 0&&(t.defaultLimit=100);let n=re(t),o=ie({...t,abilityBuilder:n}),{makePubSubInstance:p,pubsub:i}=pe({...t}),{schemaBuilder:e}=ge({...t,pubsub:i}),c=oe({...t,schemaBuilder:e}),l=de({...t,schemaBuilder:e,enumImplementer:c}),u=le({...t,schemaBuilder:e}),y=ae({...t,schemaBuilder:e,makePubSubInstance:p,whereArgImplementer:l,orderArgImplementer:u,enumImplementer:c,abilityBuilder:n}),a=me({...t,schemaBuilder:e,whereArgImplementer:l,orderArgImplementer:u,makePubSubInstance:p}),d=v(()=>e.toSchema());return {abilityBuilder:n,schemaBuilder:e,createYoga:r=>graphqlYoga.createYoga({...r,schema:d(),context:o}),createSofa:r=>(r.openAPI&&(r.openAPI={...se,...r.openAPI}),sofaApi.useSofa({...r,schema:d(),context:o})),object:y,whereArg:l,orderArg:u,query:a,pubsub:p,enum_:c}};exports.RumbleError=S;exports.RumbleErrorSafe=w;exports.assertFindFirstExists=V;exports.assertFirstEntryExists=Ce;exports.rumble=Je;//# sourceMappingURL=index.cjs.map
|
9
9
|
//# sourceMappingURL=index.cjs.map
|