@m1212e/rumble 0.6.6 → 0.7.6
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 +2 -2
- package/index.d.ts +2 -2
- 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'),drizzleOrm=require('drizzle-orm'),casing=require('drizzle-orm/casing'),pgCore=require('drizzle-orm/pg-core'),Be=require('@pothos/core'),ve=require('@pothos/plugin-drizzle'),Fe=require('@pothos/plugin-smart-subscriptions'),graphqlScalars=require('graphql-scalars');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Be__default=/*#__PURE__*/_interopDefault(Be);var ve__default=/*#__PURE__*/_interopDefault(ve);var Fe__default=/*#__PURE__*/_interopDefault(Fe);function
|
2
|
-
`,r=p.split(/\r\n|[\n\r]/g),
|
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
|
1
|
+
'use strict';var graphqlYoga=require('graphql-yoga'),drizzleOrm=require('drizzle-orm'),casing=require('drizzle-orm/casing'),pgCore=require('drizzle-orm/pg-core'),Be=require('@pothos/core'),ve=require('@pothos/plugin-drizzle'),Fe=require('@pothos/plugin-smart-subscriptions'),graphqlScalars=require('graphql-scalars');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Be__default=/*#__PURE__*/_interopDefault(Be);var ve__default=/*#__PURE__*/_interopDefault(ve);var Fe__default=/*#__PURE__*/_interopDefault(Fe);function q(e){let t,u=false;return ()=>(u||(t=e(),u=true),t)}function M(e){return typeof e=="object"&&e!==null}function $(e,t){throw new Error("Unexpected invariant triggered.")}var me=/\r\n|[\n\r]/g;function w(e,t){let u=0,p=1;for(let n of e.body.matchAll(me)){if(typeof n.index=="number"||$(),n.index>=t)break;u=n.index+n[0].length,p+=1;}return {line:p,column:t+1-u}}function J(e){return j(e.source,w(e.source,e.start))}function j(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,c=`${e.name}:${o}:${s}
|
2
|
+
`,r=p.split(/\r\n|[\n\r]/g),b=r[n];if(b.length>120){let i=Math.floor(s/80),f=s%80,y=[];for(let T=0;T<b.length;T+=80)y.push(b.slice(T,T+80));return c+H([[`${o} |`,y[0]],...y.slice(1,i+1).map(T=>["|",T]),["|","^".padStart(f)],["|",y[i+1]]])}return c+H([[`${o-1} |`,r[n-1]],[`${o} |`,b],["|","^".padStart(s)],[`${o+1} |`,r[n+1]]])}function H(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 L=class e extends Error{constructor(t,...u){var p,n,a;let{nodes:o,source:l,positions:s,path:c,originalError:r,extensions:b}=ce(u);super(t),this.name="GraphQLError",this.path=c??void 0,this.originalError=r??void 0,this.nodes=W(Array.isArray(o)?o:o?[o]:void 0);let i=W((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=>w(l,y)):i?.map(y=>w(y.source,y.start));let f=M(r?.extensions)?r?.extensions:void 0;this.extensions=(a=b??f)!==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+=`
|
4
4
|
|
5
|
-
`+
|
5
|
+
`+J(u.loc));else if(this.source&&this.locations)for(let u 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=
|
7
|
+
`+j(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 W(e){return e===void 0||e.length===0?void 0:e}var R=class extends Error{constructor(t){super(t),this.name="RumbleError";}},O=class extends L{};var Q=(e,t)=>new R(`RumbleError: Unknown SQL type '${e}'. Please open an issue (https://github.com/m1212e/rumble/issues) so it can be added. (${t})`);function Y(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 Q(e,"Distinct")}var K=Symbol.for("drizzle:Name"),X=Symbol.for("drizzle:Columns");function I({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[K]===e)),!n)throw new R(`Could not find schema for ${JSON.stringify({tsName:t,dbName:e,table:u?.[K]}).toString()}`);return {tableSchema:n,columns:n[X],get primaryColumns(){return Object.entries(n[X]).filter(([a,o])=>o.primary).reduce((a,[o,l])=>(a[o]=l,a),{})},relations:p._.relations.config[t],dbName:n[K],get tsName(){return Object.entries(p._.relations.schema).find(([a,o])=>o===n).at(0)}}}function be(e){return typeof e!="function"}function Te(e){return typeof e=="function"&&e.constructor.name!=="AsyncFunction"}var Z=({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 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))p[l]=o(l);return {...p,registeredQueryFilters:n,registeredFilters:a,buildWithUserContext:l=>{let s={},c=r=>({filter:(b,i)=>{let f=m=>{let P=q(()=>{if(!(!m?.where&&!i?.inject?.where)){if(i?.inject?.where&&m?.where)return {AND:[m?.where,i?.inject?.where]};if(i?.inject?.where&&!m?.where)return i?.inject?.where;if(!i?.inject?.where&&m?.where)return m?.where;!i?.inject?.where&&m?.where;}}),v=q(()=>{let C=P();if(!C)return;let z=I({tsName:r,db:e});return drizzleOrm.relationsFilterToSQL(z.tableSchema,C)}),U=q(()=>{let C=m?.limit??u;return i?.inject?.limit&&(!C||C>i.inject.limit)&&(C=i.inject.limit),m?.limit&&(!C||m.limit>C)&&(C=m.limit),C??void 0}),F=q(()=>{if(!(!m?.columns&&!i?.inject?.columns))return {...m?.columns,...i?.inject?.columns}}),N={query:{single:{get where(){return P()},columns:F()},many:{get where(){return P()},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 m=I({db:e,tsName:r});if(Object.keys(m.primaryColumns).length===0)throw new R(`No primary key found for entity ${r.toString()}`);let P=Object.values(m.primaryColumns)[0],v=Y(P.getSQLType());return {where:{AND:[{[P.name]:v.value1},{[P.name]:v.value2}]}}},T=n?.[r]?.[b];if(T==="unspecified")return f();T||(T=[y()]);let h=T.filter(be),D=T.filter(Te).map(m=>m(l)),B=D.some(m=>m==="allow"),E=[...h,...D].filter(m=>m!==void 0).filter(m=>m!=="allow");!B&&E.length===0&&(E=[y()]);let x;for(let m of E)m?.limit&&(x===void 0||m.limit>x)&&(x=m.limit);let d;for(let m of [...E,i?.inject])m?.columns&&(d===void 0?d=m.columns:d={...d,...m.columns});let g=B?[]:E.filter(m=>m?.where).map(m=>m.where),S=g.length>0?{OR:g}:void 0;return f({where:S,columns:d,limit:x})},explicitFilters:b=>a[r][b]});for(let r of Object.keys(e.query))s[r]=c(r);return s}}};var ee=({context:e,abilityBuilder:t})=>async u=>{let p=e?await e(u):{};return {...p,abilities:t.buildWithUserContext(p)}};function A(e){return String(e).charAt(0).toUpperCase()+String(e).slice(1)}function k(e){return e instanceof pgCore.PgEnumColumn}var te=({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 f=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(!f)throw new R(`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=f.enumValues;}else if(a){let i=Object.entries(e._.relations.schema).find(([f,y])=>y===a.config.enum);if(!i)throw new R(`Could not find enum in schema for ${a.name}!`);l=i[0],s=a.enumValues;}if(!l||!s)throw new R("Could not determine enum structure!");let c=o??`${A(casing.toCamelCase(l))}Enum`,r=u.get(c);return r||(r=t.enumType(c,{values:s}),u.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 Q(e,"SQL to GQL")}var ne=({db:e,schemaBuilder:t,makePubSubInstance:u,argImplementer:p,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}=u({table:o});return t.drizzleObject(o,{name:l??A(o.toString()),subscribe:(f,y,T)=>{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:f,action:"updated",primaryKeyValue:h});},applyFilters:a?.registeredFilters?.[o]?.[s],fields:f=>{let y=r.columns,T=(x,d,g)=>{let S=G(x);switch(S){case "Int":return f.exposeInt(d,{nullable:g});case "String":return f.exposeString(d,{nullable:g});case "Boolean":return f.exposeBoolean(d,{nullable:g});case "Date":return f.field({type:"Date",resolve:m=>m[d],nullable:g});case "DateTime":return f.field({type:"DateTime",resolve:m=>m[d],nullable:g});case "Float":return f.exposeFloat(d,{nullable:g});case "ID":return f.exposeID(d,{nullable:g});case "JSON":return f.field({type:"JSON",resolve:m=>m[d],nullable:g});default:throw new R(`Unsupported object type ${S} for column ${d}`)}},h=new Map,D=c?.(new Proxy(f,{get:(x,d)=>typeof x[d]=="function"?g=>{let S=x[d](g);return h.set(S,{config:g,creatorFunction:x[d]}),S}:x[d]}))??{},B=Object.entries(y).reduce((x,[d,g])=>{if(D[d]){let{config:S,creatorFunction:m}=h.get(D[d]);return typeof S.nullable!="boolean"&&(S.nullable=!g.notNull),D[d]=m(S),x}if(k(g)){let S=n({enumColumn:g});x[d]=f.field({type:S,resolve:m=>m[d],nullable:!g.notNull});}else x[d]=T(g.getSQLType(),d,!g.notNull);return x},{}),E=Object.entries(r.relations??{}).reduce((x,[d,g])=>{let S=I({db:e,table:g.targetTable}),m=p({dbName:S.dbName}),P=u({table:S.tsName}),v=false,F="many";g instanceof drizzleOrm.One&&(v=g.optional,F="single");let N=(C,z)=>{P.registerOnInstance({instance:C,action:"created"}),P.registerOnInstance({instance:C,action:"removed"});};if(D[d]){let{config:C,creatorFunction:z}=h.get(D[d]);return typeof C.nullable!="boolean"&&(C.nullable=v),typeof C.subscribe!="function"&&(C.subscribe=N),D[d]=z(C),x}return x[d]=f.relation(d,{args:{where:f.arg({type:m,required:false})},subscribe:N,nullable:v,query:(C,z)=>z.abilities[S.tsName].filter(s,{inject:{where:C.where}}).query[F]}),x},{});return {...B,...E,...D}}})};var Ce="RUMBLE_SUBSCRIPTION_NOTIFICATION",De="REMOVED",Se="UPDATED",Re="CREATED",ie=({subscriptions:e,db:t})=>{let u=e?graphqlYoga.createPubSub(...e):graphqlYoga.createPubSub();return {pubsub:u,makePubSubInstance:({table:n})=>{function a({action:o,tableName:l,primaryKeyValue:s}){let c;switch(o){case "created":c=Re;break;case "removed":c=De;break;case "updated":c=Se;break;default:throw new Error(`Unknown action: ${o}`)}return `${Ce}/${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 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})),c=Array.from(new Set(s));for(let r of c)u.publish(r);}}}}};var _=e=>{if(!e)throw new O("Value not found but required (findFirst)");return e},Ee=e=>{let t=e.at(0);if(!t)throw new O("Value not found but required (firstEntry)");return t},oe=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 se=({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(c=>({[`findMany${A(n.toString())}`]:c.drizzleField({type:[n],nullable:false,smartSubscription:true,subscribe:(r,b,i,f,y)=>{s({instance:r,action:"created"}),s({instance:r,action:"removed"});},args:{where:c.arg({type:l,required:false})},resolve:(r,b,i,f,y)=>{let T=f.abilities[n].filter(o,i.where?{inject:{where:i.where}}:void 0).query.many,h=r(T);return T.columns&&(h.columns=T.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,f,y)=>{let T=f.abilities[n].filter(a,i.where?{inject:{where:i.where}}:void 0).query.single,h=r(T);return T.columns&&(h.columns=T.columns),e.query[n].findFirst(h).then(_)}})}))};var ae="ManualFiltersPlugin",le=ae,Ie="applyFilters",V=class extends Be.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),c=Array.isArray(s)?s:[s],r=Array.isArray(l)?l:[l],b=await oe({filters:r,entities:c,context:a});return Array.isArray(s)?b:b[0]??null}}};Be__default.default.registerPlugin(ae,V);var ue=({db:e,disableDefaultObjects:t,pubsub:u,pothosConfig:p})=>{let n=new Be__default.default({plugins:[le,ve__default.default,Fe__default.default,...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:{...Fe.subscribeOptionsFromIterator((a,o)=>u.subscribe(a))}});return n.addScalarType("JSON",graphqlScalars.JSONResolver),n.addScalarType("Date",graphqlScalars.DateResolver),n.addScalarType("DateTime",graphqlScalars.DateTimeISOResolver),t?.query||n.queryType({}),t?.subscription||n.subscriptionType({}),t?.mutation||n.mutationType({}),{schemaBuilder:n}};var we=e=>`${A(casing.toCamelCase(e.toString()))}WhereInputArgument`,pe=({db:e,schemaBuilder:t,enumImplementer:u})=>{let p=new Map,n=({table:a,refName:o,dbName:l})=>{let s=I({db:e,dbName:l,tsName:a}),c=o??we(s.tsName),r=p.get(c);return r||(r=t.inputType(c,{fields:i=>{let f=h=>{let D=G(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 R(`Unsupported argument type ${D} for column ${h}`)}},y=Object.entries(s.columns).reduce((h,[D,B])=>{if(k(B)){let E=u({enumColumn:B});h[D]=i.field({type:E,required:false});}else h[D]=f(B.getSQLType());return h},{}),T=Object.entries(s.relations??{}).reduce((h,[D,B])=>{let E=I({db:e,table:B.targetTable}),x=n({dbName:E.dbName});return h[D]=i.field({type:x,required:false}),h},{});return {...y,...T}}}),p.set(c,r),r)};return n};var Qe=e=>{e.actions||(e.actions=["read","update","delete"]),e.defaultLimit===void 0&&(e.defaultLimit=100);let t=Z(e),u=ee({...e,abilityBuilder:t}),{makePubSubInstance:p,pubsub:n}=ie({...e}),{schemaBuilder:a}=ue({...e,pubsub:n}),o=te({...e,schemaBuilder:a}),l=pe({...e,schemaBuilder:a,enumImplementer:o}),s=ne({...e,schemaBuilder:a,makePubSubInstance:p,argImplementer:l,enumImplementer:o,abilityBuilder:t}),c=se({...e,schemaBuilder:a,argImplementer:l,makePubSubInstance:p});return {abilityBuilder:t,schemaBuilder:a,createYoga:b=>graphqlYoga.createYoga({...b,schema:a.toSchema(),context:u}),object:s,arg:l,query:c,pubsub:p,enum_:o}};exports.RumbleError=R;exports.RumbleErrorSafe=O;exports.assertFindFirstExists=_;exports.assertFirstEntryExists=Ee;exports.rumble=Qe;//# sourceMappingURL=index.cjs.map
|
9
9
|
//# sourceMappingURL=index.cjs.map
|