@live-state/sync 0.0.7-canary-1 → 0.0.7-canary-2
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/dist/client.d.ts +1 -1
- package/dist/client.js +1 -1
- package/dist/fetch-client.d.ts +1 -1
- package/dist/fetch-client.js +1 -1
- package/dist/{index-BfD4vfVs.d.ts → index-CLkafi56.d.ts} +18 -12
- package/dist/optimistic-client.d.ts +1 -1
- package/dist/server.cjs +5 -5
- package/dist/server.d.cts +51 -36
- package/dist/server.d.ts +51 -36
- package/dist/server.js +6 -6
- package/package.json +1 -1
package/dist/server.cjs
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
'use strict';var ie=require('crypto'),jsXxhash=require('js-xxhash'),Wt=require('qs'),zod=require('zod'),kysely=require('kysely'),mysql=require('kysely/helpers/mysql'),postgres=require('kysely/helpers/postgres'),sqlite=require('kysely/helpers/sqlite');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var ie__default=/*#__PURE__*/_interopDefault(ie);var Wt__default=/*#__PURE__*/_interopDefault(Wt);var ut=Object.create;var Pe=Object.defineProperty;var lt=Object.getOwnPropertyDescriptor;var ct=Object.getOwnPropertyNames;var dt=Object.getPrototypeOf,yt=Object.prototype.hasOwnProperty;var pt=(i,e)=>()=>(e||i((e={exports:{}}).exports,e),e.exports);var ft=(i,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of ct(e))!yt.call(i,r)&&r!==t&&Pe(i,r,{get:()=>e[r],enumerable:!(n=lt(e,r))||n.enumerable});return i};var qe=(i,e,t)=>(t=i!=null?ut(dt(i)):{},ft(Pe(t,"default",{value:i,enumerable:true}),i));var be=pt(le=>{Object.defineProperty(le,"__esModule",{value:true});le.parse=Dt;le.serialize=Ft;var Vt=/^[\u0021-\u003A\u003C\u003E-\u007E]+$/,Nt=/^[\u0021-\u003A\u003C-\u007E]*$/,Pt=/^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i,qt=/^[\u0020-\u003A\u003D-\u007E]*$/,Qt=Object.prototype.toString,$t=(()=>{let i=function(){};return i.prototype=Object.create(null),i})();function Dt(i,e){let t=new $t,n=i.length;if(n<2)return t;let r=(e==null?void 0:e.decode)||_t,o=0;do{let u=i.indexOf("=",o);if(u===-1)break;let a=i.indexOf(";",o),s=a===-1?n:a;if(u>s){o=i.lastIndexOf(";",u-1)+1;continue}let l=ke(i,o,u),d=Be(i,u,l),c=i.slice(l,d);if(t[c]===void 0){let p=ke(i,u+1,s),y=Be(i,s,p),m=r(i.slice(p,y));t[c]=m;}o=s+1;}while(o<n);return t}function ke(i,e,t){do{let n=i.charCodeAt(e);if(n!==32&&n!==9)return e}while(++e<t);return t}function Be(i,e,t){for(;e>t;){let n=i.charCodeAt(--e);if(n!==32&&n!==9)return e+1}return t}function Ft(i,e,t){let n=(t==null?void 0:t.encode)||encodeURIComponent;if(!Vt.test(i))throw new TypeError(`argument name is invalid: ${i}`);let r=n(e);if(!Nt.test(r))throw new TypeError(`argument val is invalid: ${e}`);let o=i+"="+r;if(!t)return o;if(t.maxAge!==void 0){if(!Number.isInteger(t.maxAge))throw new TypeError(`option maxAge is invalid: ${t.maxAge}`);o+="; Max-Age="+t.maxAge;}if(t.domain){if(!Pt.test(t.domain))throw new TypeError(`option domain is invalid: ${t.domain}`);o+="; Domain="+t.domain;}if(t.path){if(!qt.test(t.path))throw new TypeError(`option path is invalid: ${t.path}`);o+="; Path="+t.path;}if(t.expires){if(!kt(t.expires)||!Number.isFinite(t.expires.valueOf()))throw new TypeError(`option expires is invalid: ${t.expires}`);o+="; Expires="+t.expires.toUTCString();}if(t.httpOnly&&(o+="; HttpOnly"),t.secure&&(o+="; Secure"),t.partitioned&&(o+="; Partitioned"),t.priority)switch(typeof t.priority=="string"?t.priority.toLowerCase():void 0){case "low":o+="; Priority=Low";break;case "medium":o+="; Priority=Medium";break;case "high":o+="; Priority=High";break;default:throw new TypeError(`option priority is invalid: ${t.priority}`)}if(t.sameSite)switch(typeof t.sameSite=="string"?t.sameSite.toLowerCase():t.sameSite){case true:case "strict":o+="; SameSite=Strict";break;case "lax":o+="; SameSite=Lax";break;case "none":o+="; SameSite=None";break;default:throw new TypeError(`option sameSite is invalid: ${t.sameSite}`)}return o}function _t(i){if(i.indexOf("%")===-1)return i;try{return decodeURIComponent(i)}catch{return i}}function kt(i){return Qt.call(i)==="[object Date]"}});var he=i=>typeof i=="object"&&i!==null&&"value"in i&&!Array.isArray(i),x=i=>i?Array.isArray(i.value)?i.value.map(t=>he(t)?x(t):t):typeof i.value!="object"||i.value===null||i.value instanceof Date?i.value:Object.fromEntries(Object.entries(i.value).map(([t,n])=>Array.isArray(n)?[t,n.map(r=>he(r)?x(r):r)]:he(n)?[t,x(n)]:[t,n])):void 0;var $e="0123456789ABCDEFGHJKMNPQRSTVWXYZ",U=32;var It=16,De=10,Qe=0xffffffffffff;var D;(function(i){i.Base32IncorrectEncoding="B32_ENC_INVALID",i.DecodeTimeInvalidCharacter="DEC_TIME_CHAR",i.DecodeTimeValueMalformed="DEC_TIME_MALFORMED",i.EncodeTimeNegative="ENC_TIME_NEG",i.EncodeTimeSizeExceeded="ENC_TIME_SIZE_EXCEED",i.EncodeTimeValueMalformed="ENC_TIME_MALFORMED",i.PRNGDetectFailure="PRNG_DETECT",i.ULIDInvalid="ULID_INVALID",i.Unexpected="UNEXPECTED",i.UUIDInvalid="UUID_INVALID";})(D||(D={}));var F=class extends Error{constructor(e,t){super(`${t} (${e})`),this.name="ULIDError",this.code=e;}};function Mt(i){let e=Math.floor(i()*U);return e===U&&(e=U-1),$e.charAt(e)}function Lt(i){var n;let e=At(),t=e&&(e.crypto||e.msCrypto)||(typeof ie__default.default<"u"?ie__default.default:null);if(typeof(t==null?void 0:t.getRandomValues)=="function")return ()=>{let r=new Uint8Array(1);return t.getRandomValues(r),r[0]/255};if(typeof(t==null?void 0:t.randomBytes)=="function")return ()=>t.randomBytes(1).readUInt8()/255;if((n=ie__default.default)!=null&&n.randomBytes)return ()=>ie__default.default.randomBytes(1).readUInt8()/255;throw new F(D.PRNGDetectFailure,"Failed to find a reliable PRNG")}function At(){return Et()?self:typeof window<"u"?window:typeof global<"u"?global:typeof globalThis<"u"?globalThis:null}function Ct(i,e){let t="";for(;i>0;i--)t=Mt(e)+t;return t}function jt(i,e=De){if(isNaN(i))throw new F(D.EncodeTimeValueMalformed,`Time must be a number: ${i}`);if(i>Qe)throw new F(D.EncodeTimeSizeExceeded,`Cannot encode a time larger than ${Qe}: ${i}`);if(i<0)throw new F(D.EncodeTimeNegative,`Time must be positive: ${i}`);if(Number.isInteger(i)===false)throw new F(D.EncodeTimeValueMalformed,`Time must be an integer: ${i}`);let t,n="";for(let r=e;r>0;r--)t=i%U,n=$e.charAt(t)+n,i=(i-t)/U;return n}function Et(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}function Fe(i,e){let t=Lt(),n=Date.now();return jt(n,De)+Ct(It,t)}var se=()=>Fe().toLowerCase(),ae=i=>({then(e,t){try{if(e){let n=e(i);return n instanceof Promise?n:ae(n)}return ae(i)}catch(n){if(t){let r=t(n);return r instanceof Promise?r:ae(r)}throw n}}}),Te=i=>i instanceof Promise?i:ae(i);var z=(...i)=>{let e=i.filter(t=>!!t);return e.length===0?{}:e.length===1?e[0]:{$and:e}};var oe=class{storage;queue=new Map;scheduled=false;constructor(e){this.storage=e;}async rawFind({resource:e,commonWhere:t,uniqueWhere:n,...r}){return new Promise((o,u)=>{let a=this.getBatchKey({resource:e,commonWhere:t,...r}),s={resource:e,commonWhere:t,uniqueWhere:n,...r,resolve:o,reject:u};this.queue.has(a)||this.queue.set(a,[]);let l=this.queue.get(a);l&&l.push(s),this.scheduled||(this.scheduled=true,setImmediate(()=>{this.processBatch();}));})}getBatchKey(e){let{resource:t,commonWhere:n,...r}=e;return `${t}:${JSON.stringify(n??{})}:${JSON.stringify(r??{})}`}async processBatch(){this.scheduled=false;let e=Array.from(this.queue.entries());this.queue.clear();for(let[,t]of e)try{await this.executeBatchedRequests(t);}catch(n){t.forEach(r=>{r.reject(n);});}}async executeBatchedRequests(e){var p;if(e.length===0)return;let t=e[0],{resource:n,commonWhere:r,include:o,sort:u}=t,a=e.length===1?t.limit:void 0,s=e.map(y=>y.uniqueWhere).filter(y=>y!==void 0),l=r,d=(p=Object.entries(s[0]??{})[0])==null?void 0:p[0];if(s.length>0){let y=s.map(m=>m[d]).filter(m=>m!=null);y.length>0&&(l=z(r,{[d]:{$in:y}}));}let c=await this.storage.get({resource:n,where:l,include:o,sort:u,limit:a});for(let y of e){let m=c;if(y.uniqueWhere){let[f,T]=Object.entries(y.uniqueWhere)[0];m=c.filter(g=>{var h;return ((h=g.value[f])==null?void 0:h.value)===T});}y.resolve(m);}}};var P=i=>jsXxhash.xxHash32(JSON.stringify(i)).toString(32),_=(i,e,t)=>{let n={},r=t[e];if(!r)return n;let o=u=>{u.$and?u.$and.forEach(o):u.$or?u.$or.forEach(o):Object.entries(u).forEach(([a,s])=>{var l;if((l=r.relations)!=null&&l[a]&&(n[a]=true,typeof s=="object"&&s!==null&&!Array.isArray(s))){let d=_(s,r.relations[a].entity.name,t);Object.keys(d).length>0&&(n[a]={include:d});}});};return o(i),n},C=(i,e,t=false)=>Object.entries(e).every(([n,r])=>{if(n==="$and")return r.every(u=>C(i,u,t));if(n==="$or")return r.some(u=>C(i,u,t));let o=(r==null?void 0:r.$eq)!==void 0?r==null?void 0:r.$eq:r;if(typeof r=="object"&&r!==null&&(r==null?void 0:r.$eq)===void 0){if(r.$in!==void 0){let a=i[n];return a===void 0?false:t?!r.$in.includes(a):r.$in.includes(a)}if(r.$not!==void 0&&!t)return C(i,{[n]:r.$not},true);if(r.$gt!==void 0){let a=i[n];return typeof a!="number"?false:t?a<=r.$gt:a>r.$gt}if(r.$gte!==void 0){let a=i[n];return typeof a!="number"?false:t?a<r.$gte:a>=r.$gte}if(r.$lt!==void 0){let a=i[n];return typeof a!="number"?false:t?a>=r.$lt:a<r.$lt}if(r.$lte!==void 0){let a=i[n];return typeof a!="number"?false:t?a>r.$lte:a<=r.$lte}let u=i[n];return !u||typeof u!="object"&&!Array.isArray(u)?false:Array.isArray(u)?t?!u.some(a=>C(a,r,false)):u.some(a=>C(a,r,false)):C(u,r,t)}return t?i[n]!==o:i[n]===o}),Q={CRITICAL:0,ERROR:1,WARN:2,INFO:3,DEBUG:4},ge=class{level;prefix;constructor(e={}){this.level=e.level??Q.INFO,this.prefix=e.prefix?`[${e.prefix}] `:"";}critical(...e){this.level>=Q.CRITICAL&&console.error(`${this.prefix}[CRITICAL]`,...e);}error(...e){this.level>=Q.ERROR&&console.error(`${this.prefix}[ERROR]`,...e);}warn(...e){this.level>=Q.WARN&&console.warn(`${this.prefix}[WARN]`,...e);}info(...e){this.level>=Q.INFO&&console.log(`${this.prefix}[INFO]`,...e);}debug(...e){this.level>=Q.DEBUG&&console.log(`${this.prefix}[DEBUG]`,...e);}setLevel(e){this.level=e;}getLevel(){return this.level}},_e=i=>new ge(i);function Re(i){return P({resource:i.query.resource,where:i.query.where,include:i.query.include,stepPath:i.stepPath,isMany:i.isMany,relationName:i.relationName})}var ue=class{router;storage;schema;logger;queryNodes=new Map;objectNodes=new Map;constructor(e){this.router=e.router,this.storage=e.storage,this.schema=e.schema,this.logger=e.logger;}getRelationalColumns(e){let t=new Map,n=this.schema[e];if(!(n!=null&&n.relations))return t;for(let[r,o]of Object.entries(n.relations))o.type==="one"&&o.relationalColumn&&t.set(String(o.relationalColumn),{relationName:r,targetResource:o.entity.name});return t}ensureObjectNode(e,t,n){let r=this.objectNodes.get(e);return r?n&&r.matchedQueries.add(n):(r={id:e,type:t,matchedQueries:new Set(n?[n]:[]),referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e,r)),r}storeRelation(e,t,n,r){let o=this.objectNodes.get(e),u=this.objectNodes.get(t);if(o&&o.referencesObjects.set(n,t),u&&r){let a=u.referencedByObjects.get(r);a||(a=new Set,u.referencedByObjects.set(r,a)),a.add(e);}}removeRelation(e,t,n,r){let o=this.objectNodes.get(e),u=this.objectNodes.get(t);if(o&&o.referencesObjects.delete(n),u&&r){let a=u.referencedByObjects.get(r);a&&(a.delete(e),a.size===0&&u.referencedByObjects.delete(r));}}getInverseRelationName(e,t,n){let r=this.schema[e];if(!(r!=null&&r.relations))return;let o=r.relations[n];if(!o)return;let u=this.schema[t];if(u!=null&&u.relations){if(o.type==="many"&&o.foreignColumn){for(let[a,s]of Object.entries(u.relations))if(s.entity.name===e&&s.type==="one"&&s.relationalColumn===o.foreignColumn)return a}if(o.type==="one"&&o.relationalColumn){for(let[a,s]of Object.entries(u.relations))if(s.entity.name===e&&s.type==="many"&&s.foreignColumn===o.relationalColumn)return a}}}updateRelationsFromMutation(e,t,n,r){let o=this.getRelationalColumns(e),u=this.objectNodes.get(t);if(u)for(let[a,{relationName:s,targetResource:l}]of Array.from(o)){if(!(r&&a in r))continue;let c=this.getInverseRelationName(e,l,s),p=u.referencesObjects.get(s),y=n[a];p!==y&&(p&&this.removeRelation(t,p,s,c),y&&(this.ensureObjectNode(y,l),this.storeRelation(t,y,s,c)));}}get(e,t){let n=this.breakdownQuery({query:e,context:(t==null?void 0:t.context)??{}});return this.resolveQuery(n,{context:(t==null?void 0:t.context)??{},batcher:(t==null?void 0:t.batcher)??new oe(this.storage)})}subscribe(e,t,n={}){let r=this.breakdownQuery({query:e,context:n}),o={},u=[];for(let a of r){this.logger.debug("[QueryEngine] Subscribing to step",a.stepPath.join("."));let s=Re(a),l=o[a.stepPath.at(-2)??""],d=a.stepPath.at(-1)??"",c=this.queryNodes.get(s);if(c)c.subscriptions.add(t);else if(c={hash:s,queryStep:a,relationName:d,trackedObjects:new Set,subscriptions:new Set([t]),parentQuery:l,childQueries:new Set},this.queryNodes.set(c.hash,c),l){let p=this.queryNodes.get(l);p&&p.childQueries.add(c.hash);}o[d]=s,u.push(()=>{let p=this.queryNodes.get(s);p&&(p.subscriptions.delete(t),p.subscriptions.size===0&&this.queryNodes.delete(s));});}return ()=>{for(let a of u)a();}}breakdownQuery(e){var T;let{query:t,stepPath:n=[],context:r={},parentResource:o}=e,{include:u}=t,a=n.length===0,s=n.at(-1),l,d,c;if(!a&&o&&s){let g=this.schema[o],h=(T=g==null?void 0:g.relations)==null?void 0:T[s];h&&(c=h.type==="many",h.type==="one"?(l=R=>({id:R}),d=R=>R.map(b=>{var v,M;return (M=(v=b.value)==null?void 0:v[h.relationalColumn])==null?void 0:M.value}).filter(b=>b!==void 0)):(l=R=>({[h.foreignColumn]:R}),d=R=>R.map(b=>{var v,M;return (M=(v=b.value)==null?void 0:v.id)==null?void 0:M.value}).filter(b=>b!==void 0)));}let{include:p,...y}=t,f=[this.router.incrementQueryStep({query:y,stepPath:[...n],getWhere:l,referenceGetter:d,isMany:c,relationName:s},r)];if(u&&typeof u=="object"&&Object.keys(u).length>0){let g=this.schema[t.resource];if(!g)throw new Error(`Resource ${t.resource} not found`);f.push(...Object.entries(u).flatMap(([h,R])=>{let b=g.relations[h];if(!b)throw new Error(`Relation ${h} not found for resource ${t.resource}`);let v=b.entity.name;return this.breakdownQuery({query:{resource:v,include:typeof R=="object"?R:void 0},stepPath:[...n,h],context:r,parentResource:t.resource})}));}return f}resolveQuery(e,t){this.logger.debug("[QueryEngine] Resolving query",e.map(o=>o.stepPath.join(".")).join(" -> "));let n={},r=this.resolveStep(e[0],t).then(o=>{this.logger.debug("[QueryEngine] Resolved step",e[0].stepPath.join("."),"with results count:",o.length),n[e[0].stepPath.join(".")]=[{data:o}];});for(let o=1;o<e.length;o++){let u=e[o],a=u.stepPath.slice(0,-1).join(".");r=r.then(async()=>{var l,d;let s=n[a];if(!s){n[u.stepPath.join(".")]=[];return}if(u.referenceGetter&&u.getWhere){let c=new Map;for(let m of s)for(let f of m.data){let T=(d=(l=f==null?void 0:f.value)==null?void 0:l.id)==null?void 0:d.value;if(!T)continue;let h=u.referenceGetter([f])[0];if(h){c.has(h)||c.set(h,new Set);let R=c.get(h);R&&R.add(T);}}let p=Array.from(c.keys());if(p.length===0){n[u.stepPath.join(".")]=[];return}let y=[];for(let m of p){let f=u.getWhere(m),T={...u,relationalWhere:f},g=await this.resolveStep(T,t),h=c.get(m);if(h)for(let R of Array.from(h))y.push({includedBy:R,data:g});}this.logger.debug("[QueryEngine] Resolved step",u.stepPath.join("."),"with results count:",y.reduce((m,f)=>m+f.data.length,0)),n[u.stepPath.join(".")]=y;}else {let c=await this.resolveStep(u,t);n[u.stepPath.join(".")]=[{data:c}];}});}return r=r.then((()=>(this.logger.debug("[QueryEngine] Assembling results"),this.assembleResults(e,n)))),r}assembleResults(e,t){var u,a,s,l,d;this.logger.debug("[QueryEngine] assembleResults: Starting assembly"),this.logger.debug("[QueryEngine] assembleResults: Plan steps:",e.length),this.logger.debug("[QueryEngine] assembleResults: Step results keys:",Object.keys(t));let n=new Map;for(let c of e){let p=c.stepPath.join("."),y=t[p]??[],m=Object.keys(c.query.include??{});this.logger.debug(`[QueryEngine] assembleResults: Processing step "${p}"`,{resource:c.query.resource,includedRelations:m,resultGroups:y.length,isMany:c.isMany,relationName:c.relationName});for(let f of y){this.logger.debug(`[QueryEngine] assembleResults: Processing result group for "${p}"`,{dataCount:f.data.length,includedBy:f.includedBy});for(let T of f.data){let g=(a=(u=T==null?void 0:T.value)==null?void 0:u.id)==null?void 0:a.value;if(!g){this.logger.debug(`[QueryEngine] assembleResults: Skipping data without id in step "${p}"`);continue}let h=p?`${p}.${g}`:g,R=[];if(c.stepPath.length>0&&f.includedBy){let v=c.stepPath.slice(0,-1).join(".");R=[v?`${v}.${f.includedBy}`:f.includedBy],this.logger.debug(`[QueryEngine] assembleResults: Child entity "${h}" has parent keys:`,R,{stepPath:p,parentStepPath:v,includedBy:f.includedBy});}else this.logger.debug(`[QueryEngine] assembleResults: Root entity "${h}" (no parent)`);let b=n.get(h);if(b){this.logger.debug(`[QueryEngine] assembleResults: Entity "${h}" already exists, adding parent keys:`,R);for(let v of R)b.includedBy.add(v);}else this.logger.debug(`[QueryEngine] assembleResults: Adding new entity "${h}"`,{resource:c.query.resource,path:c.stepPath.at(-1)??"",isMany:c.isMany??false,relationName:c.relationName,includedRelations:m,parentKeys:R}),n.set(h,{data:T,includedBy:new Set(R),path:c.stepPath.at(-1)??"",isMany:c.isMany??false,relationName:c.relationName,resourceName:c.query.resource,includedRelations:m});}}}this.logger.debug(`[QueryEngine] assembleResults: Built entriesMap with ${n.size} entries`),this.logger.debug("[QueryEngine] assembleResults: EntriesMap keys:",Array.from(n.keys()));let r=Array.from(n.entries()),o=[];this.logger.debug(`[QueryEngine] assembleResults: Starting assembly phase with ${r.length} entries`);for(let c=r.length-1;c>=0;c--){let[p,y]=r[c],m=this.schema[y.resourceName];this.logger.debug(`[QueryEngine] assembleResults: Processing entry "${p}"`,{resource:y.resourceName,path:y.path,isMany:y.isMany,relationName:y.relationName,includedRelations:y.includedRelations,parentKeys:Array.from(y.includedBy)});for(let f of y.includedRelations){let T=(l=(s=m==null?void 0:m.relations)==null?void 0:s[f])==null?void 0:l.type,g=!!y.data.value[f];if(this.logger.debug(`[QueryEngine] assembleResults: Checking included relation "${f}" for "${p}"`,{relationType:T,hasRelation:g,resourceHasRelation:!!((d=m==null?void 0:m.relations)!=null&&d[f])}),y.data.value[f])this.logger.debug(`[QueryEngine] assembleResults: Relation "${f}" already exists for "${p}"`,y.data.value[f]);else {let h=T==="many"?{value:[]}:{value:null};y.data.value[f]=h,this.logger.debug(`[QueryEngine] assembleResults: Initialized relation "${f}" for "${p}" with`,h);}}if(y.path===""){this.logger.debug(`[QueryEngine] assembleResults: Adding root entity "${p}" to resultData`),o.push(y.data);continue}this.logger.debug(`[QueryEngine] assembleResults: Attaching "${p}" to ${y.includedBy.size} parent(s)`);for(let f of Array.from(y.includedBy)){let T=n.get(f);if(!T){this.logger.warn(`[QueryEngine] assembleResults: WARNING - Parent "${f}" not found in entriesMap for child "${p}"`);continue}let g=y.relationName??y.path;this.logger.debug(`[QueryEngine] assembleResults: Attaching "${p}" to parent "${f}" via relation "${g}"`,{isMany:y.isMany,parentHasRelation:!!T.data.value[g]}),y.isMany?(T.data.value[g]??={value:[]},T.data.value[g].value.push(y.data),this.logger.debug(`[QueryEngine] assembleResults: Added "${p}" to many relation "${g}" on parent "${f}"`,{arrayLength:T.data.value[g].value.length})):(T.data.value[g]=y.data,this.logger.debug(`[QueryEngine] assembleResults: Set one relation "${g}" on parent "${f}" to "${p}"`));}}return this.logger.debug(`[QueryEngine] assembleResults: Assembly complete. Returning ${o.length} root items`),o}resolveStep(e,t){this.logger.debug("[QueryEngine] Resolving step",e.stepPath.join("."),"with query",JSON.stringify(e.query,null,2),"relationalWhere",JSON.stringify(e.relationalWhere,null,2));let{query:n,relationalWhere:r}=e,o=n.where&&r?z(n.where,r):r??n.where,u=o?{...n,where:o}:n;return Te(this.router.get(u,t)).then(a=>(this.loadStepResults(e,a),a))}loadStepResults(e,t){this.logger.debug("[QueryEngine] Loading step results",e.stepPath.join("."),"with results",JSON.stringify(t,null,2));let n=Re(e),r=this.queryNodes.get(n),o=e.query.resource;if(!r)return;let u=this.getRelationalColumns(o);for(let a of t){let s=x(a),l=s.id;this.ensureObjectNode(l,o,n),r.trackedObjects.add(l);for(let[d,{relationName:c,targetResource:p}]of Array.from(u)){let y=s[d];if(y){this.ensureObjectNode(y,p);let m=this.getInverseRelationName(o,p,c);this.storeRelation(l,y,c,m);}}this.loadNestedRelations(o,l,s),this.logger.debug("[QueryEngine] Loaded nested relations for",l);}}loadNestedRelations(e,t,n){let r=this.schema[e];if(r!=null&&r.relations)for(let[o,u]of Object.entries(r.relations)){let a=n[o];if(!a)continue;let s=u.entity.name,l=this.getInverseRelationName(e,s,o);if(u.type==="one")a&&typeof a=="object"&&a.id&&(this.ensureObjectNode(a.id,s),this.storeRelation(t,a.id,o,l),this.loadNestedRelations(s,a.id,a));else if(u.type==="many"&&Array.isArray(a)){for(let d of a)if(d&&typeof d=="object"&&d.id){this.ensureObjectNode(d.id,s);let c=this.getInverseRelationName(s,e,o);c&&this.storeRelation(d.id,t,c,o),this.loadNestedRelations(s,d.id,d);}}}}buildIncludeFromChildQueries(e){let t=this.queryNodes.get(e);if(!t||t.childQueries.size===0)return {};let n={};for(let r of Array.from(t.childQueries)){let o=this.queryNodes.get(r);if(!o||!o.relationName)continue;let u=this.buildIncludeFromChildQueries(r);n[o.relationName]=Object.keys(u).length>0?u:true;}return n}sendInsertsForTree(e,t,n){var a,s;let r=(s=(a=t==null?void 0:t.value)==null?void 0:a.id)==null?void 0:s.value;if(!r)return;let o={procedure:"INSERT",resource:n,resourceId:r,type:"MUTATE",payload:t.value};for(let l of Array.from(e.subscriptions))try{l(o);}catch(d){this.logger.error("[QueryEngine] Error in subscription callback during sendInsertsForTree",{error:d,queryHash:e.hash,resource:n,resourceId:r,stepPath:e.queryStep.stepPath.join(".")});}e.trackedObjects.add(r),this.ensureObjectNode(r,n,e.hash).matchedQueries.add(e.hash);for(let l of Array.from(e.childQueries)){let d=this.queryNodes.get(l);if(!d||!d.relationName)continue;let c=d.relationName,p=d.queryStep.query.resource,y=t.value[c];if(!y)continue;let m=y.value;if(Array.isArray(m))for(let f of m)this.sendInsertsForTree(d,f,p);else m&&typeof m=="object"&&this.sendInsertsForTree(d,m,p);}}handleMutation(e,t){if(e.procedure==="INSERT"){if(this.objectNodes.has(e.resourceId))return;let n=x(t);if(!n)return;let r={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map};this.objectNodes.set(e.resourceId,r);let o=this.getRelationalColumns(e.resource);for(let[a,{relationName:s,targetResource:l}]of Array.from(o)){let d=n[a];if(d){this.ensureObjectNode(d,l);let c=this.getInverseRelationName(e.resource,l,s);this.storeRelation(e.resourceId,d,s,c);}}let u=this.objectNodes.get(e.resourceId);this.getMatchingQueries(e,n).then(a=>{for(let s of a){let l=this.queryNodes.get(s);if(l){l.trackedObjects.add(e.resourceId),u&&u.matchedQueries.add(s);for(let d of Array.from(l.subscriptions))try{d(e);}catch(c){this.logger.error("[QueryEngine] Error in subscription callback during INSERT mutation",{error:c,queryHash:l.hash,resource:e.resource,resourceId:e.resourceId,stepPath:l.queryStep.stepPath.join(".")});}}}});return}if(e.procedure==="UPDATE"){let n=x(t);if(!n)return;let r=this.objectNodes.get(e.resourceId),o=new Set((r==null?void 0:r.matchedQueries)??[]);r||(r={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e.resourceId,r)),this.updateRelationsFromMutation(e.resource,e.resourceId,n,e.payload),this.getMatchingQueries(e,n).then(u=>{let a=new Set(u),s=[],l=[],d=[];for(let p of u)o.has(p)?d.push(p):s.push(p);for(let p of Array.from(o))a.has(p)||l.push(p);for(let p of s){let y=this.queryNodes.get(p);y&&y.trackedObjects.add(e.resourceId);}for(let p of l){let y=this.queryNodes.get(p);y&&y.trackedObjects.delete(e.resourceId);}let c=this.objectNodes.get(e.resourceId);if(c){for(let p of s)c.matchedQueries.add(p);for(let p of l)c.matchedQueries.delete(p);}for(let p of [...l,...d]){let y=this.queryNodes.get(p);if(y)for(let m of Array.from(y.subscriptions))try{m(e);}catch(f){this.logger.error("[QueryEngine] Error in subscription callback during UPDATE mutation",{error:f,queryHash:y.hash,resource:e.resource,resourceId:e.resourceId,stepPath:y.queryStep.stepPath.join(".")});}}if(s.length>0)for(let p of s){let y=this.queryNodes.get(p);if(!y)continue;let m=this.buildIncludeFromChildQueries(p);this.get({resource:e.resource,where:{id:e.resourceId},include:Object.keys(m).length>0?m:void 0}).then(f=>{!f||f.length===0||this.sendInsertsForTree(y,f[0],e.resource);});}});return}}getMatchingQueries(e,t){let n=[];for(let r of Array.from(this.queryNodes.values()))r.queryStep.query.resource===e.resource&&n.push(r);return n.length===0?Te([]):Promise.all(n.map(async r=>{let o=r.queryStep.query.where,u=r.queryStep.query.resource,a=e.resourceId,s=this.objectNodes.get(a);if(!s)return {hash:r.hash,matches:false};if(r.relationName){let y=r.parentQuery?this.queryNodes.get(r.parentQuery):void 0,m=y==null?void 0:y.queryStep.query.resource,f=m?this.getInverseRelationName(m,u,r.relationName):void 0,T=f?s.referencesObjects.get(f):void 0;if(!T)return {hash:r.hash,matches:false};let g=this.objectNodes.get(T);return !g||!y||!g.matchedQueries.has(y.hash)?{hash:r.hash,matches:false}:{hash:r.hash,matches:true}}if(!o)return {hash:r.hash,matches:true};let l=_(o,u,this.schema),d=Object.keys(l).length>0;if(!d&&t!==void 0)return {hash:r.hash,matches:C(t,o)};let c=await this.storage.get({resource:u,where:{id:a},include:d?l:void 0});if(!c||c.length===0)return {hash:r.hash,matches:false};let p=x(c[0]);return p?{hash:r.hash,matches:C(p,o)}:{hash:r.hash,matches:false}})).then(r=>r.filter(o=>o.matches).map(o=>o.hash))}};var He=qe(be());var ce=zod.z.object({resource:zod.z.string(),where:zod.z.record(zod.z.string(),zod.z.any()).optional(),include:zod.z.record(zod.z.string(),zod.z.any()).optional(),lastSyncedAt:zod.z.string().optional(),limit:zod.z.coerce.number().optional(),sort:zod.z.array(zod.z.object({key:zod.z.string(),direction:zod.z.enum(["asc","desc"])})).optional()}),ve=zod.z.record(zod.z.string(),zod.z.object({value:zod.z.any().nullable(),_meta:zod.z.object({timestamp:zod.z.string().optional().nullable()}).optional()})),Bt=ve.superRefine((i,e)=>{i.id&&e.addIssue({code:zod.z.ZodIssueCode.custom,message:"Payload cannot have an id"});}),ze=zod.z.object({id:zod.z.string().optional(),type:zod.z.literal("MUTATE"),resource:zod.z.string(),resourceId:zod.z.string().optional()}),We=zod.z.object({timestamp:zod.z.string().optional()}).optional(),W=ze.extend({procedure:zod.z.string(),payload:zod.z.any().optional(),meta:We}),K=ze.extend({procedure:zod.z.enum(["INSERT","UPDATE"]),payload:Bt,meta:We});zod.z.union([K,W]);var Ue=zod.z.object({resource:zod.z.string(),procedure:zod.z.string(),input:zod.z.any().optional()});var Ke=ce.omit({resource:true}),Se=W.omit({id:true,type:true,resource:true,procedure:true}).extend({meta:W.shape.meta}),xe=K.omit({id:true,type:true,resource:true,procedure:true});zod.z.union([xe,Se]);var we=i=>{if(i==null)return i;if(i==="null")return null;if(Array.isArray(i))return i.map(we);if(typeof i=="object"&&i.constructor===Object){let e={};for(let[t,n]of Object.entries(i))e[t]=we(n);return e}return i},Je=i=>{let e=i.logger;return async t=>{var n;try{let r=typeof t.headers.getSetCookie=="function"?Object.fromEntries(t.headers):t.headers,o={headers:r,cookies:r.cookie?He.default.parse(r.cookie):{}},u=new URL(t.url),a=u.pathname.split("/"),s=u.searchParams,l=we(Wt__default.default.parse(s.toString())),d=await((n=i.contextProvider)==null?void 0:n.call(i,{transport:"HTTP",headers:o.headers,cookies:o.cookies,queryParams:l}))??{};if(t.method==="GET"){let c=a[a.length-1],{success:p,data:y,error:m}=Ke.safeParse(l);if(!p)return Response.json({message:"Invalid query",code:"INVALID_QUERY",details:m},{status:400});let f=await i.handleQuery({req:{...o,...y,type:"QUERY",resource:c,context:d,queryParams:l}});return !f||!f.data?Response.json({message:"Invalid resource",code:"INVALID_RESOURCE"},{status:400}):Response.json(f.data)}if(t.method==="POST")try{let c=a[a.length-1],p=a[a.length-2];if(p==="query"){if(a.length<3)return Response.json({message:"Invalid path structure for custom query",code:"INVALID_PATH"},{status:400});let g=a[a.length-3],h=t.body?await t.json():{};if(!g||g.trim()==="")return Response.json({message:"Invalid resource in path",code:"INVALID_RESOURCE"},{status:400});let R=await i.handleCustomQuery({req:{...o,type:"CUSTOM_QUERY",resource:g,procedure:c,input:h.input,context:d,queryParams:l}});return Response.json(R)}let y=p,m=t.body?await t.json():{},f;if(c==="insert"||c==="update"){let{success:g,data:h,error:R}=xe.safeParse(m);if(!g)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:R},{status:400});f=h;}else {let{success:g,data:h,error:R}=Se.safeParse(m);if(!g)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:R},{status:400});f=h;}let T=await i.handleMutation({req:{...o,type:"MUTATE",resource:y,input:f.payload,context:d,resourceId:f.resourceId,procedure:c==="insert"||c==="update"?c.toUpperCase():c,queryParams:{},meta:f.meta}});return Response.json(T)}catch(c){return e.error("Error parsing mutation from the client:",c),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}return Response.json({message:"Not found",code:"NOT_FOUND"},{status:404})}catch(r){return e.error("Unexpected error:",r),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}}};var Ye=qe(be());var $=zod.z.string(),Ie=zod.z.union([Ue,ce]),Ut=zod.z.object({id:$,type:zod.z.literal("SUBSCRIBE")}).and(Ie),Kt=zod.z.object({id:$,type:zod.z.literal("UNSUBSCRIBE")}).and(Ie),Ht=zod.z.object({id:$,type:zod.z.literal("QUERY")}).and(Ie),Jt=zod.z.object({id:$,type:zod.z.literal("CUSTOM_QUERY"),resource:zod.z.string(),procedure:zod.z.string(),input:zod.z.any().optional()}),Ge=K.extend({id:$}),Gt=W.extend({id:$}),Zt=zod.z.union([Gt,Ge]),Ze=zod.z.union([Ut,Ht,Jt,Zt,Kt]),Yt=zod.z.object({id:$,type:zod.z.literal("REJECT"),resource:zod.z.string(),message:zod.z.string().optional()}),Xt=zod.z.object({id:$,type:zod.z.literal("REPLY"),data:zod.z.any()});zod.z.union([Yt,Xt,Ge]);zod.z.object({resource:zod.z.string(),data:zod.z.array(ve)});var Xe=i=>{let e={},t=i.logger;return (n,r)=>{var c;let o=p=>{n.send(JSON.stringify(p));},u=se(),a=new Map,s={headers:r.headers,cookies:typeof r.headers.cookie=="string"?Ye.default.parse(r.headers.cookie):{}},l=Wt.parse(r.url.split("?")[1]),d=(c=i.contextProvider)==null?void 0:c.call(i,{transport:"WEBSOCKET",headers:s.headers,cookies:s.cookies,queryParams:l});e[u]=n,t.info("Client connected:",u),n.on("message",async p=>{try{t.debug("Message received from the client:",p);let y=Ze.parse(JSON.parse(p.toString()));if(y.type==="SUBSCRIBE"||y.type==="QUERY"){let{type:m,id:f,...T}=y,g=m==="SUBSCRIBE";if("procedure"in T){let h=await i.handleCustomQuery({req:{...s,type:"CUSTOM_QUERY",resource:T.resource,procedure:T.procedure,input:T.input,context:await d??{},queryParams:l},subscription:g?R=>{var b;!R.resourceId||!R.payload||!Object.keys(R.payload).length||(b=e[u])==null||b.send(JSON.stringify(R));}:void 0});if(g){if(!h||!h.data||!h.query)throw new Error("Invalid resource");h.unsubscribe&&a.set(P(T),h.unsubscribe),o({id:f,type:"REPLY",data:{resource:h.query.resource,data:(h.data??[]).map(R=>R.value)}});}else o({id:f,type:"REPLY",data:h});}else {let h=await i.handleQuery({req:{...s,...T,type:"QUERY",context:await d??{},queryParams:l},subscription:g?R=>{var b;!R.resourceId||!R.payload||!Object.keys(R.payload).length||(b=e[u])==null||b.send(JSON.stringify(R));}:void 0});if(!h||!h.data)throw new Error("Invalid resource");g&&h.unsubscribe&&a.set(P(T),h.unsubscribe),o({id:f,type:"REPLY",data:{resource:T.resource,data:(h.data??[]).map(R=>R.value)}});}}else if(y.type==="UNSUBSCRIBE"){let{type:m,id:f,...T}=y,g=a.get(P(T));g&&(g(),a.delete(P(T)));}else if(y.type==="CUSTOM_QUERY"){let{resource:m,procedure:f,input:T,id:g}=y;t.debug("Received custom query from client:",y);try{let h=await i.handleCustomQuery({req:{...s,type:"CUSTOM_QUERY",resource:m,procedure:f,input:T,context:await d??{},queryParams:l}});o({id:g,type:"REPLY",data:h});}catch(h){o({id:g,type:"REJECT",resource:m,message:h.message}),t.error("Error handling custom query from the client:",h);}}else if(y.type==="MUTATE"){let{resource:m}=y;t.debug("Received mutation from client:",y);try{let f=await i.handleMutation({req:{...s,type:"MUTATE",resource:m,input:y.payload,context:{messageId:y.id,...await d??{}},resourceId:y.resourceId,procedure:y.procedure,queryParams:l,meta:y.meta}});y.procedure&&y.procedure!=="INSERT"&&y.procedure!=="UPDATE"&&o({id:y.id,type:"REPLY",data:f});}catch(f){o({id:y.id,type:"REJECT",resource:m,message:f.message}),t.error("Error parsing mutation from the client:",f);}}}catch(y){t.error("Error handling message from the client:",y);}}),n.on("close",()=>{t.info("Connection closed",u),delete e[u];for(let p of Array.from(a.values()))p();});}};function et(i){let e=`${i.protocol}://${i.hostname}${i.url}`,t=new Headers;return Object.entries(i.headers).forEach(([n,r])=>{r&&t.set(n,Array.isArray(r)?r.join(","):r);}),new Request(e,{method:i.method,headers:t,body:i.body&&i.method!=="GET"?JSON.stringify(i.body):void 0})}var Nr=(i,e,t)=>{i.ws(`${(t==null?void 0:t.basePath)??""}/ws`,Xe(e)),i.use(`${(t==null?void 0:t.basePath)??""}/`,(n,r)=>{Je(e)(et(n)).then(u=>u.json().then(a=>r.status(u.status).send(a)));});};var de=class i{_collection;_client;_where;_include;_limit;_single;_sort;_shouldAwait;constructor(e,t,n,r,o,u,a,s){this._collection=e,this._client=t,this._where=n??{},this._include=r??{},this._limit=o,this._single=u,this._sort=a,this._shouldAwait=s,this.get=this.get.bind(this),this.subscribe=this.subscribe.bind(this);}where(e){return new i(this._collection,this._client,{...this._where,...e},this._include,this._limit,this._single,this._sort,this._shouldAwait)}include(e){return new i(this._collection,this._client,this._where,{...this._include,...e},this._limit,this._single,this._sort,this._shouldAwait)}limit(e){return new i(this._collection,this._client,this._where,this._include,e,this._single,this._sort,this._shouldAwait)}one(e){return this.first({id:e})}first(e){return new i(this._collection,this._client,e??this._where,this._include,1,true,this._sort,this._shouldAwait)}orderBy(e,t="asc"){let n=[...this._sort??[],{key:e,direction:t}];return new i(this._collection,this._client,this._where,this._include,this._limit,this._single,n,this._shouldAwait)}toJSON(){return {resource:this._collection.name,where:this._where,include:this._include,limit:this._limit,sort:this._sort}}buildQueryRequest(){return {resource:this._collection.name,where:this._where,include:this._include,limit:this._limit,sort:this._sort}}get(){let e=this._client.get(this.buildQueryRequest());return this._shouldAwait?Promise.resolve(e).then(t=>this._single?t[0]:t):this._single?e[0]:e}subscribe(e){return this._client.subscribe(this.buildQueryRequest(),t=>{if(this._single)return e(t[0]);e(t);})}static _init(e,t,n){return new i(e,t,void 0,void 0,void 0,void 0,void 0,n??false)}};var tn=i=>typeof i=="object"&&i!==null&&"value"in i&&!Array.isArray(i),Me=class{constructor(e){this.storage=e;}get(e){return Promise.resolve(this.storage.get(e)).then(t=>t.map(n=>tn(n)?x(n):n))}subscribe(){throw new Error("Subscriptions are not supported server-side. Use .get() instead.")}};function H(i,e){let t=new Me(i),n=o=>{let u=de._init(o,t,true);return Object.assign(Object.create(u),{insert:s=>i.insert(o,s),update:(s,l)=>i.update(o,s,l)})},r={get(o,u){if(u==="findOne")return i.findOne.bind(i);if(u==="find")return i.find.bind(i);if(u==="insert")return i.insert.bind(i);if(u==="update")return i.update.bind(i);if(u==="transaction")return async a=>i.transaction(async({trx:s,commit:l,rollback:d})=>{let c=H(s,e);return a({trx:c,commit:l,rollback:d})});if(u in e){let a=e[u];return n(a)}}};return new Proxy({},r)}var Le=class i{routes;hooksRegistry=new Map;constructor(e){this.routes=e.routes;for(let t of Object.values(e.routes)){let n=t;n.hooks&&this.hooksRegistry.set(n.resourceSchema.name,n.hooks);}}static create(e){return new i(e)}getHooks(e){return this.hooksRegistry.get(e)}},zr=i=>Le.create({...i}),nn=(i=>({handler:e=>({_type:"query",inputValidator:i??zod.z.undefined(),handler:e})})),rn=(i=>({handler:e=>({_type:"mutation",inputValidator:i??zod.z.undefined(),handler:e})})),Ae=class i{resourceSchema;middlewares;customMutations;customQueries;authorization;hooks;constructor(e,t,n,r,o){this.resourceSchema=e,this.middlewares=new Set,this.customMutations=t??{},this.customQueries=n??{},this.authorization=r,this.hooks=o;}use(...e){for(let t of e)this.middlewares.add(t);return this}withProcedures(e){let t=e({mutation:rn,query:nn}),n={},r={};for(let[o,u]of Object.entries(t))u._type==="mutation"?n[o]=u:r[o]=u;return new i(this.resourceSchema,n,r,this.authorization,this.hooks)}withMutations(e){return this.withProcedures(({mutation:t})=>e({mutation:t}))}withHooks(e){return new i(this.resourceSchema,this.customMutations,this.customQueries,this.authorization,e)}handleQuery=async({req:e,batcher:t})=>await this.wrapInMiddlewares(async n=>{let r={resource:n.resource,where:n.where,include:n.include,lastSyncedAt:n.lastSyncedAt,limit:n.limit,sort:n.sort},o=P(r);return {data:await t.rawFind({resource:n.resource,commonWhere:n.where,uniqueWhere:n.relationalWhere,include:n.include,limit:n.limit,sort:n.sort}),unsubscribe:void 0,queryHash:o}})(e);handleMutation=async({req:e,db:t,schema:n})=>{var a;let r=((a=e.meta)==null?void 0:a.timestamp)??new Date().toISOString(),o=t._setMutationTimestamp(r),u=H(o,n);return await this.wrapInMiddlewares(async s=>{if(!s.procedure)throw new Error("Procedure is required for mutations");let l=this.customMutations[s.procedure];if(l){let d=l.inputValidator["~standard"].validate(s.input),c=d instanceof Promise?await d:d;if(c.issues){let p=c.issues.map(y=>{var f;let m=(f=y.path)==null?void 0:f.map(T=>typeof T=="object"&&"key"in T?String(T.key):String(T)).join(".");return m?`${m}: ${y.message}`:y.message}).join(", ");throw new Error(`Validation failed: ${p}`)}return s.input=c.value,l.handler({req:s,db:u})}else {if(s.procedure==="INSERT"||s.procedure==="UPDATE")return this.handleSet({req:s,db:o,operation:s.procedure,schema:n});throw new Error(`Unknown procedure: ${s.procedure}`)}})(e)};handleCustomQuery=async({req:e,db:t,schema:n})=>{let r=H(t,n);return await this.wrapInMiddlewares(async o=>{let u=this.customQueries[o.procedure];if(!u)throw new Error(`Unknown query procedure: ${o.procedure}`);let a=u.inputValidator["~standard"].validate(o.input),s=a instanceof Promise?await a:a;if(s.issues){let l=s.issues.map(d=>{var p;let c=(p=d.path)==null?void 0:p.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return c?`${c}: ${d.message}`:d.message}).join(", ");throw new Error(`Validation failed: ${l}`)}return o.input=s.value,u.handler({req:o,db:r})})(e)};getAuthorizationClause(e){var t,n;return (n=(t=this.authorization)==null?void 0:t.read)==null?void 0:n.call(t,{ctx:e.context})}handleSet=async({req:e,db:t,operation:n,schema:r})=>{if(!e.input)throw new Error("Payload is required");if(!e.resourceId)throw new Error("ResourceId is required");let o=await t.rawFindById(e.resource,e.resourceId);if(n==="INSERT"&&o)throw new Error("Resource already exists");if(n==="UPDATE"&&!o)throw new Error("Resource not found");let u={value:e.input};return t.transaction(async({trx:a})=>{var d,c,p,y,m,f,T;if(n==="INSERT"){let{data:g,acceptedValues:h}=await a.rawInsert(e.resource,e.resourceId,u,(d=e.context)==null?void 0:d.messageId,e.context);if(!h)throw new Error("Mutation rejected");let R=x(g);if(R.id=R.id??e.resourceId,(c=this.authorization)!=null&&c.insert){let b=this.authorization.insert({ctx:e.context,value:R});if(typeof b=="boolean"){if(!b)throw new Error("Not authorized")}else {let v=_(b,e.resource,r),M=Object.keys(v).length>0?await a.rawFindById(e.resource,e.resourceId,v):g,w=x(M);if(w.id=w.id??e.resourceId,!C(w,b))throw new Error("Not authorized")}}return {data:g,acceptedValues:h}}if((y=(p=this.authorization)==null?void 0:p.update)!=null&&y.preMutation){let g=x(o);g.id=g.id??e.resourceId;let h=this.authorization.update.preMutation({ctx:e.context,value:g});if(typeof h=="boolean"){if(!h)throw new Error("Not authorized")}else {let R=_(h,e.resource,r),b=Object.keys(R).length>0?await a.rawFindById(e.resource,e.resourceId,R):o,v=x(b);if(v.id=v.id??e.resourceId,!C(v,h))throw new Error("Not authorized")}}let{data:s,acceptedValues:l}=await a.rawUpdate(e.resource,e.resourceId,u,(m=e.context)==null?void 0:m.messageId,e.context);if(!l)throw new Error("Mutation rejected");if((T=(f=this.authorization)==null?void 0:f.update)!=null&&T.postMutation){let g=x(s);g.id=g.id??e.resourceId;let h=this.authorization.update.postMutation({ctx:e.context,value:g});if(typeof h=="boolean"){if(!h)throw new Error("Not authorized")}else {let R=_(h,e.resource,r),b=Object.keys(R).length>0?await a.rawFindById(e.resource,e.resourceId,R):s,v=x(b);if(v.id=v.id??e.resourceId,!C(v,h))throw new Error("Not authorized")}}return {data:s,acceptedValues:l}})};wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((n,r)=>o=>r({req:o,next:n}),e)(t)}},Ce=class i{middlewares;constructor(e=[]){this.middlewares=e;}collectionRoute(e,t){return new Ae(e,void 0,void 0,t,void 0).use(...this.middlewares)}use(...e){return new i([...this.middlewares,...e])}static create(){return new i}},Wr=Ce.create;var J=class{_mutationTimestamp;_setMutationTimestamp(e){let t=this._clone();return t._mutationTimestamp=e,t}_getTimestamp(){return this._mutationTimestamp??new Date().toISOString()}_clone(){return Object.assign(Object.create(Object.getPrototypeOf(this)),this)}async insert(e,t){let n=this._getTimestamp(),r=await this.rawInsert(e.name,t.id,{value:Object.fromEntries(Object.entries(t).map(([o,u])=>[o,{value:u,_meta:{timestamp:n}}]))});return x(r.data)}async update(e,t,n){let r=this._getTimestamp(),{id:o,...u}=n,a=await this.rawUpdate(e.name,t,{value:Object.fromEntries(Object.entries(u).map(([d,c])=>[d,{value:c,_meta:{timestamp:r}}]))}),s=x(a.data),l={};for(let d of Object.keys(u))d in s&&(l[d]=s[d]);return l}};var dn={postgres:{jsonObjectFrom:postgres.jsonObjectFrom,jsonArrayFrom:postgres.jsonArrayFrom},mysql:{jsonObjectFrom:mysql.jsonObjectFrom,jsonArrayFrom:mysql.jsonArrayFrom},sqlite:{jsonObjectFrom:sqlite.jsonObjectFrom,jsonArrayFrom:sqlite.jsonArrayFrom}};function q(i){var r,o,u;let e=(r=i.getExecutor)==null?void 0:r.call(i),t=e==null?void 0:e.adapter;if(!t)return "postgres";let n=((u=(o=t.constructor)==null?void 0:o.name)==null?void 0:u.toLowerCase())??"";return n.includes("postgres")?"postgres":n.includes("mysql")?"mysql":n.includes("sqlite")?"sqlite":"postgres"}function nt(i){let e=q(i);return dn[e]}var yn="42701";function G(i){var t;if(i.code===yn)return true;let e=((t=i.message)==null?void 0:t.toLowerCase())||"";return e.includes("already exists")||e.includes("duplicate")||e.includes("already defined")}function Ee(i,e){let{type:t,enumValues:n,enumName:r}=i;if(n&&n.length>0)return e==="postgres"&&r?r:"varchar";if(t==="jsonb"||t==="json")switch(e){case "postgres":return "jsonb";case "mysql":return "json";case "sqlite":return "text"}return t}async function pn(i,e,t,n){if(t!=="postgres")return;let r=new Map;for(let o of Object.values(e))for(let u of Object.values(o.fields)){let a=u.getStorageFieldType();a.enumValues&&a.enumName&&r.set(a.enumName,{name:a.enumName,values:a.enumValues});}for(let o of Array.from(r.values())){let{name:u,values:a}=o;try{let s=a.map(l=>`'${l}'`).join(", ");await kysely.sql`
|
|
1
|
+
'use strict';var ie=require('crypto'),jsXxhash=require('js-xxhash'),Ht=require('qs'),zod=require('zod'),kysely=require('kysely'),mysql=require('kysely/helpers/mysql'),postgres=require('kysely/helpers/postgres'),sqlite=require('kysely/helpers/sqlite');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var ie__default=/*#__PURE__*/_interopDefault(ie);var Ht__default=/*#__PURE__*/_interopDefault(Ht);var dt=Object.create;var qe=Object.defineProperty;var yt=Object.getOwnPropertyDescriptor;var pt=Object.getOwnPropertyNames;var ft=Object.getPrototypeOf,mt=Object.prototype.hasOwnProperty;var ht=(i,e)=>()=>(e||i((e={exports:{}}).exports,e),e.exports);var Tt=(i,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of pt(e))!mt.call(i,r)&&r!==t&&qe(i,r,{get:()=>e[r],enumerable:!(n=yt(e,r))||n.enumerable});return i};var Qe=(i,e,t)=>(t=i!=null?dt(ft(i)):{},Tt(qe(t,"default",{value:i,enumerable:true}),i));var be=ht(ce=>{Object.defineProperty(ce,"__esModule",{value:true});ce.parse=kt;ce.serialize=Bt;var qt=/^[\u0021-\u003A\u003C\u003E-\u007E]+$/,Qt=/^[\u0021-\u003A\u003C-\u007E]*$/,$t=/^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i,Dt=/^[\u0020-\u003A\u003D-\u007E]*$/,Ft=Object.prototype.toString,_t=(()=>{let i=function(){};return i.prototype=Object.create(null),i})();function kt(i,e){let t=new _t,n=i.length;if(n<2)return t;let r=(e==null?void 0:e.decode)||zt,o=0;do{let u=i.indexOf("=",o);if(u===-1)break;let s=i.indexOf(";",o),a=s===-1?n:s;if(u>a){o=i.lastIndexOf(";",u-1)+1;continue}let c=Be(i,o,u),d=ze(i,u,c),l=i.slice(c,d);if(t[l]===void 0){let p=Be(i,u+1,a),y=ze(i,a,p),m=r(i.slice(p,y));t[l]=m;}o=a+1;}while(o<n);return t}function Be(i,e,t){do{let n=i.charCodeAt(e);if(n!==32&&n!==9)return e}while(++e<t);return t}function ze(i,e,t){for(;e>t;){let n=i.charCodeAt(--e);if(n!==32&&n!==9)return e+1}return t}function Bt(i,e,t){let n=(t==null?void 0:t.encode)||encodeURIComponent;if(!qt.test(i))throw new TypeError(`argument name is invalid: ${i}`);let r=n(e);if(!Qt.test(r))throw new TypeError(`argument val is invalid: ${e}`);let o=i+"="+r;if(!t)return o;if(t.maxAge!==void 0){if(!Number.isInteger(t.maxAge))throw new TypeError(`option maxAge is invalid: ${t.maxAge}`);o+="; Max-Age="+t.maxAge;}if(t.domain){if(!$t.test(t.domain))throw new TypeError(`option domain is invalid: ${t.domain}`);o+="; Domain="+t.domain;}if(t.path){if(!Dt.test(t.path))throw new TypeError(`option path is invalid: ${t.path}`);o+="; Path="+t.path;}if(t.expires){if(!Kt(t.expires)||!Number.isFinite(t.expires.valueOf()))throw new TypeError(`option expires is invalid: ${t.expires}`);o+="; Expires="+t.expires.toUTCString();}if(t.httpOnly&&(o+="; HttpOnly"),t.secure&&(o+="; Secure"),t.partitioned&&(o+="; Partitioned"),t.priority)switch(typeof t.priority=="string"?t.priority.toLowerCase():void 0){case "low":o+="; Priority=Low";break;case "medium":o+="; Priority=Medium";break;case "high":o+="; Priority=High";break;default:throw new TypeError(`option priority is invalid: ${t.priority}`)}if(t.sameSite)switch(typeof t.sameSite=="string"?t.sameSite.toLowerCase():t.sameSite){case true:case "strict":o+="; SameSite=Strict";break;case "lax":o+="; SameSite=Lax";break;case "none":o+="; SameSite=None";break;default:throw new TypeError(`option sameSite is invalid: ${t.sameSite}`)}return o}function zt(i){if(i.indexOf("%")===-1)return i;try{return decodeURIComponent(i)}catch{return i}}function Kt(i){return Ft.call(i)==="[object Date]"}});var he=i=>typeof i=="object"&&i!==null&&"value"in i&&!Array.isArray(i),x=i=>i?Array.isArray(i.value)?i.value.map(t=>he(t)?x(t):t):typeof i.value!="object"||i.value===null||i.value instanceof Date?i.value:Object.fromEntries(Object.entries(i.value).map(([t,n])=>Array.isArray(n)?[t,n.map(r=>he(r)?x(r):r)]:he(n)?[t,x(n)]:[t,n])):void 0;var De="0123456789ABCDEFGHJKMNPQRSTVWXYZ",W=32;var Ct=16,Fe=10,$e=0xffffffffffff;var D;(function(i){i.Base32IncorrectEncoding="B32_ENC_INVALID",i.DecodeTimeInvalidCharacter="DEC_TIME_CHAR",i.DecodeTimeValueMalformed="DEC_TIME_MALFORMED",i.EncodeTimeNegative="ENC_TIME_NEG",i.EncodeTimeSizeExceeded="ENC_TIME_SIZE_EXCEED",i.EncodeTimeValueMalformed="ENC_TIME_MALFORMED",i.PRNGDetectFailure="PRNG_DETECT",i.ULIDInvalid="ULID_INVALID",i.Unexpected="UNEXPECTED",i.UUIDInvalid="UUID_INVALID";})(D||(D={}));var F=class extends Error{constructor(e,t){super(`${t} (${e})`),this.name="ULIDError",this.code=e;}};function At(i){let e=Math.floor(i()*W);return e===W&&(e=W-1),De.charAt(e)}function jt(i){var n;let e=Et(),t=e&&(e.crypto||e.msCrypto)||(typeof ie__default.default<"u"?ie__default.default:null);if(typeof(t==null?void 0:t.getRandomValues)=="function")return ()=>{let r=new Uint8Array(1);return t.getRandomValues(r),r[0]/255};if(typeof(t==null?void 0:t.randomBytes)=="function")return ()=>t.randomBytes(1).readUInt8()/255;if((n=ie__default.default)!=null&&n.randomBytes)return ()=>ie__default.default.randomBytes(1).readUInt8()/255;throw new F(D.PRNGDetectFailure,"Failed to find a reliable PRNG")}function Et(){return Vt()?self:typeof window<"u"?window:typeof global<"u"?global:typeof globalThis<"u"?globalThis:null}function Ot(i,e){let t="";for(;i>0;i--)t=At(e)+t;return t}function Pt(i,e=Fe){if(isNaN(i))throw new F(D.EncodeTimeValueMalformed,`Time must be a number: ${i}`);if(i>$e)throw new F(D.EncodeTimeSizeExceeded,`Cannot encode a time larger than ${$e}: ${i}`);if(i<0)throw new F(D.EncodeTimeNegative,`Time must be positive: ${i}`);if(Number.isInteger(i)===false)throw new F(D.EncodeTimeValueMalformed,`Time must be an integer: ${i}`);let t,n="";for(let r=e;r>0;r--)t=i%W,n=De.charAt(t)+n,i=(i-t)/W;return n}function Vt(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}function _e(i,e){let t=jt(),n=Date.now();return Pt(n,Fe)+Ot(Ct,t)}var se=()=>_e().toLowerCase(),ae=i=>({then(e,t){try{if(e){let n=e(i);return n instanceof Promise?n:ae(n)}return ae(i)}catch(n){if(t){let r=t(n);return r instanceof Promise?r:ae(r)}throw n}}}),Te=i=>i instanceof Promise?i:ae(i);var K=(...i)=>{let e=i.filter(t=>!!t);return e.length===0?{}:e.length===1?e[0]:{$and:e}};var oe=class{storage;queue=new Map;scheduled=false;constructor(e){this.storage=e;}async rawFind({resource:e,commonWhere:t,uniqueWhere:n,...r}){return new Promise((o,u)=>{let s=this.getBatchKey({resource:e,commonWhere:t,...r}),a={resource:e,commonWhere:t,uniqueWhere:n,...r,resolve:o,reject:u};this.queue.has(s)||this.queue.set(s,[]);let c=this.queue.get(s);c&&c.push(a),this.scheduled||(this.scheduled=true,setImmediate(()=>{this.processBatch();}));})}getBatchKey(e){let{resource:t,commonWhere:n,...r}=e;return `${t}:${JSON.stringify(n??{})}:${JSON.stringify(r??{})}`}async processBatch(){this.scheduled=false;let e=Array.from(this.queue.entries());this.queue.clear();for(let[,t]of e)try{await this.executeBatchedRequests(t);}catch(n){t.forEach(r=>{r.reject(n);});}}async executeBatchedRequests(e){var p;if(e.length===0)return;let t=e[0],{resource:n,commonWhere:r,include:o,sort:u}=t,s=e.length===1?t.limit:void 0,a=e.map(y=>y.uniqueWhere).filter(y=>y!==void 0),c=r,d=(p=Object.entries(a[0]??{})[0])==null?void 0:p[0];if(a.length>0){let y=a.map(m=>m[d]).filter(m=>m!=null);y.length>0&&(c=K(r,{[d]:{$in:y}}));}let l=await this.storage.get({resource:n,where:c,include:o,sort:u,limit:s});for(let y of e){let m=l;if(y.uniqueWhere){let[f,h]=Object.entries(y.uniqueWhere)[0];m=l.filter(g=>{var T;return ((T=g.value[f])==null?void 0:T.value)===h});}y.resolve(m);}}};var N=i=>jsXxhash.xxHash32(JSON.stringify(i)).toString(32),_=(i,e,t)=>{let n={},r=t[e];if(!r)return n;let o=u=>{u.$and?u.$and.forEach(o):u.$or?u.$or.forEach(o):Object.entries(u).forEach(([s,a])=>{var c;if((c=r.relations)!=null&&c[s]&&(n[s]=true,typeof a=="object"&&a!==null&&!Array.isArray(a))){let d=_(a,r.relations[s].entity.name,t);Object.keys(d).length>0&&(n[s]={include:d});}});};return o(i),n},A=(i,e,t=false)=>Object.entries(e).every(([n,r])=>{if(n==="$and")return r.every(u=>A(i,u,t));if(n==="$or")return r.some(u=>A(i,u,t));let o=(r==null?void 0:r.$eq)!==void 0?r==null?void 0:r.$eq:r;if(typeof r=="object"&&r!==null&&(r==null?void 0:r.$eq)===void 0){if(r.$in!==void 0){let s=i[n];return s===void 0?false:t?!r.$in.includes(s):r.$in.includes(s)}if(r.$not!==void 0&&!t)return A(i,{[n]:r.$not},true);if(r.$gt!==void 0){let s=i[n];return typeof s!="number"?false:t?s<=r.$gt:s>r.$gt}if(r.$gte!==void 0){let s=i[n];return typeof s!="number"?false:t?s<r.$gte:s>=r.$gte}if(r.$lt!==void 0){let s=i[n];return typeof s!="number"?false:t?s>=r.$lt:s<r.$lt}if(r.$lte!==void 0){let s=i[n];return typeof s!="number"?false:t?s>r.$lte:s<=r.$lte}let u=i[n];return !u||typeof u!="object"&&!Array.isArray(u)?false:Array.isArray(u)?t?!u.some(s=>A(s,r,false)):u.some(s=>A(s,r,false)):A(u,r,t)}return t?i[n]!==o:i[n]===o}),Q={CRITICAL:0,ERROR:1,WARN:2,INFO:3,DEBUG:4},ge=class{level;prefix;constructor(e={}){this.level=e.level??Q.INFO,this.prefix=e.prefix?`[${e.prefix}] `:"";}critical(...e){this.level>=Q.CRITICAL&&console.error(`${this.prefix}[CRITICAL]`,...e);}error(...e){this.level>=Q.ERROR&&console.error(`${this.prefix}[ERROR]`,...e);}warn(...e){this.level>=Q.WARN&&console.warn(`${this.prefix}[WARN]`,...e);}info(...e){this.level>=Q.INFO&&console.log(`${this.prefix}[INFO]`,...e);}debug(...e){this.level>=Q.DEBUG&&console.log(`${this.prefix}[DEBUG]`,...e);}setLevel(e){this.level=e;}getLevel(){return this.level}},ke=i=>new ge(i);function Re(i){return N({resource:i.query.resource,where:i.query.where,include:i.query.include,stepPath:i.stepPath,isMany:i.isMany,relationName:i.relationName})}var ue=class{router;storage;schema;logger;queryNodes=new Map;objectNodes=new Map;constructor(e){this.router=e.router,this.storage=e.storage,this.schema=e.schema,this.logger=e.logger;}getRelationalColumns(e){let t=new Map,n=this.schema[e];if(!(n!=null&&n.relations))return t;for(let[r,o]of Object.entries(n.relations))o.type==="one"&&o.relationalColumn&&t.set(String(o.relationalColumn),{relationName:r,targetResource:o.entity.name});return t}ensureObjectNode(e,t,n){let r=this.objectNodes.get(e);return r?n&&r.matchedQueries.add(n):(r={id:e,type:t,matchedQueries:new Set(n?[n]:[]),referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e,r)),r}storeRelation(e,t,n,r){let o=this.objectNodes.get(e),u=this.objectNodes.get(t);if(o&&o.referencesObjects.set(n,t),u&&r){let s=u.referencedByObjects.get(r);s||(s=new Set,u.referencedByObjects.set(r,s)),s.add(e);}}removeRelation(e,t,n,r){let o=this.objectNodes.get(e),u=this.objectNodes.get(t);if(o&&o.referencesObjects.delete(n),u&&r){let s=u.referencedByObjects.get(r);s&&(s.delete(e),s.size===0&&u.referencedByObjects.delete(r));}}getInverseRelationName(e,t,n){let r=this.schema[e];if(!(r!=null&&r.relations))return;let o=r.relations[n];if(!o)return;let u=this.schema[t];if(u!=null&&u.relations){if(o.type==="many"&&o.foreignColumn){for(let[s,a]of Object.entries(u.relations))if(a.entity.name===e&&a.type==="one"&&a.relationalColumn===o.foreignColumn)return s}if(o.type==="one"&&o.relationalColumn){for(let[s,a]of Object.entries(u.relations))if(a.entity.name===e&&a.type==="many"&&a.foreignColumn===o.relationalColumn)return s}}}updateRelationsFromMutation(e,t,n,r){let o=this.getRelationalColumns(e),u=this.objectNodes.get(t);if(u)for(let[s,{relationName:a,targetResource:c}]of Array.from(o)){if(!(r&&s in r))continue;let l=this.getInverseRelationName(e,c,a),p=u.referencesObjects.get(a),y=n[s];p!==y&&(p&&this.removeRelation(t,p,a,l),y&&(this.ensureObjectNode(y,c),this.storeRelation(t,y,a,l)));}}get(e,t){let n=this.breakdownQuery({query:e,context:(t==null?void 0:t.context)??{}});return this.resolveQuery(n,{context:(t==null?void 0:t.context)??{},batcher:(t==null?void 0:t.batcher)??new oe(this.storage)})}subscribe(e,t,n={}){let r=this.breakdownQuery({query:e,context:n}),o={},u=[];for(let s of r){this.logger.debug("[QueryEngine] Subscribing to step",s.stepPath.join("."));let a=Re(s),c=o[s.stepPath.at(-2)??""],d=s.stepPath.at(-1)??"",l=this.queryNodes.get(a);if(l)l.subscriptions.add(t);else if(l={hash:a,queryStep:s,relationName:d,trackedObjects:new Set,subscriptions:new Set([t]),parentQuery:c,childQueries:new Set},this.queryNodes.set(l.hash,l),c){let p=this.queryNodes.get(c);p&&p.childQueries.add(l.hash);}o[d]=a,u.push(()=>{let p=this.queryNodes.get(a);p&&(p.subscriptions.delete(t),p.subscriptions.size===0&&this.queryNodes.delete(a));});}return ()=>{for(let s of u)s();}}breakdownQuery(e){var h;let{query:t,stepPath:n=[],context:r={},parentResource:o}=e,{include:u}=t,s=n.length===0,a=n.at(-1),c,d,l;if(!s&&o&&a){let g=this.schema[o],T=(h=g==null?void 0:g.relations)==null?void 0:h[a];T&&(l=T.type==="many",T.type==="one"?(c=R=>({id:R}),d=R=>R.map(b=>{var S,I;return (I=(S=b.value)==null?void 0:S[T.relationalColumn])==null?void 0:I.value}).filter(b=>b!==void 0)):(c=R=>({[T.foreignColumn]:R}),d=R=>R.map(b=>{var S,I;return (I=(S=b.value)==null?void 0:S.id)==null?void 0:I.value}).filter(b=>b!==void 0)));}let{include:p,...y}=t,f=[this.router.incrementQueryStep({query:y,stepPath:[...n],getWhere:c,referenceGetter:d,isMany:l,relationName:a},r)];if(u&&typeof u=="object"&&Object.keys(u).length>0){let g=this.schema[t.resource];if(!g)throw new Error(`Resource ${t.resource} not found`);f.push(...Object.entries(u).flatMap(([T,R])=>{let b=g.relations[T];if(!b)throw new Error(`Relation ${T} not found for resource ${t.resource}`);let S=b.entity.name;return this.breakdownQuery({query:{resource:S,include:typeof R=="object"?R:void 0},stepPath:[...n,T],context:r,parentResource:t.resource})}));}return f}resolveQuery(e,t){this.logger.debug("[QueryEngine] Resolving query",e.map(o=>o.stepPath.join(".")).join(" -> "));let n={},r=this.resolveStep(e[0],t).then(o=>{this.logger.debug("[QueryEngine] Resolved step",e[0].stepPath.join("."),"with results count:",o.length),n[e[0].stepPath.join(".")]=[{data:o}];});for(let o=1;o<e.length;o++){let u=e[o],s=u.stepPath.slice(0,-1).join(".");r=r.then(async()=>{var c,d;let a=n[s];if(!a){n[u.stepPath.join(".")]=[];return}if(u.referenceGetter&&u.getWhere){let l=new Map;for(let m of a)for(let f of m.data){let h=(d=(c=f==null?void 0:f.value)==null?void 0:c.id)==null?void 0:d.value;if(!h)continue;let T=u.referenceGetter([f])[0];if(T){l.has(T)||l.set(T,new Set);let R=l.get(T);R&&R.add(h);}}let p=Array.from(l.keys());if(p.length===0){n[u.stepPath.join(".")]=[];return}let y=[];for(let m of p){let f=u.getWhere(m),h={...u,relationalWhere:f},g=await this.resolveStep(h,t),T=l.get(m);if(T)for(let R of Array.from(T))y.push({includedBy:R,data:g});}this.logger.debug("[QueryEngine] Resolved step",u.stepPath.join("."),"with results count:",y.reduce((m,f)=>m+f.data.length,0)),n[u.stepPath.join(".")]=y;}else {let l=await this.resolveStep(u,t);n[u.stepPath.join(".")]=[{data:l}];}});}return r=r.then((()=>(this.logger.debug("[QueryEngine] Assembling results"),this.assembleResults(e,n)))),r}assembleResults(e,t){var u,s,a,c,d;this.logger.debug("[QueryEngine] assembleResults: Starting assembly"),this.logger.debug("[QueryEngine] assembleResults: Plan steps:",e.length),this.logger.debug("[QueryEngine] assembleResults: Step results keys:",Object.keys(t));let n=new Map;for(let l of e){let p=l.stepPath.join("."),y=t[p]??[],m=Object.keys(l.query.include??{});this.logger.debug(`[QueryEngine] assembleResults: Processing step "${p}"`,{resource:l.query.resource,includedRelations:m,resultGroups:y.length,isMany:l.isMany,relationName:l.relationName});for(let f of y){this.logger.debug(`[QueryEngine] assembleResults: Processing result group for "${p}"`,{dataCount:f.data.length,includedBy:f.includedBy});for(let h of f.data){let g=(s=(u=h==null?void 0:h.value)==null?void 0:u.id)==null?void 0:s.value;if(!g){this.logger.debug(`[QueryEngine] assembleResults: Skipping data without id in step "${p}"`);continue}let T=p?`${p}.${g}`:g,R=[];if(l.stepPath.length>0&&f.includedBy){let S=l.stepPath.slice(0,-1).join(".");R=[S?`${S}.${f.includedBy}`:f.includedBy],this.logger.debug(`[QueryEngine] assembleResults: Child entity "${T}" has parent keys:`,R,{stepPath:p,parentStepPath:S,includedBy:f.includedBy});}else this.logger.debug(`[QueryEngine] assembleResults: Root entity "${T}" (no parent)`);let b=n.get(T);if(b){this.logger.debug(`[QueryEngine] assembleResults: Entity "${T}" already exists, adding parent keys:`,R);for(let S of R)b.includedBy.add(S);}else this.logger.debug(`[QueryEngine] assembleResults: Adding new entity "${T}"`,{resource:l.query.resource,path:l.stepPath.at(-1)??"",isMany:l.isMany??false,relationName:l.relationName,includedRelations:m,parentKeys:R}),n.set(T,{data:h,includedBy:new Set(R),path:l.stepPath.at(-1)??"",isMany:l.isMany??false,relationName:l.relationName,resourceName:l.query.resource,includedRelations:m});}}}this.logger.debug(`[QueryEngine] assembleResults: Built entriesMap with ${n.size} entries`),this.logger.debug("[QueryEngine] assembleResults: EntriesMap keys:",Array.from(n.keys()));let r=Array.from(n.entries()),o=[];this.logger.debug(`[QueryEngine] assembleResults: Starting assembly phase with ${r.length} entries`);for(let l=r.length-1;l>=0;l--){let[p,y]=r[l],m=this.schema[y.resourceName];this.logger.debug(`[QueryEngine] assembleResults: Processing entry "${p}"`,{resource:y.resourceName,path:y.path,isMany:y.isMany,relationName:y.relationName,includedRelations:y.includedRelations,parentKeys:Array.from(y.includedBy)});for(let f of y.includedRelations){let h=(c=(a=m==null?void 0:m.relations)==null?void 0:a[f])==null?void 0:c.type,g=!!y.data.value[f];if(this.logger.debug(`[QueryEngine] assembleResults: Checking included relation "${f}" for "${p}"`,{relationType:h,hasRelation:g,resourceHasRelation:!!((d=m==null?void 0:m.relations)!=null&&d[f])}),y.data.value[f])this.logger.debug(`[QueryEngine] assembleResults: Relation "${f}" already exists for "${p}"`,y.data.value[f]);else {let T=h==="many"?{value:[]}:{value:null};y.data.value[f]=T,this.logger.debug(`[QueryEngine] assembleResults: Initialized relation "${f}" for "${p}" with`,T);}}if(y.path===""){this.logger.debug(`[QueryEngine] assembleResults: Adding root entity "${p}" to resultData`),o.unshift(y.data);continue}this.logger.debug(`[QueryEngine] assembleResults: Attaching "${p}" to ${y.includedBy.size} parent(s)`);for(let f of Array.from(y.includedBy)){let h=n.get(f);if(!h){this.logger.warn(`[QueryEngine] assembleResults: WARNING - Parent "${f}" not found in entriesMap for child "${p}"`);continue}let g=y.relationName??y.path;this.logger.debug(`[QueryEngine] assembleResults: Attaching "${p}" to parent "${f}" via relation "${g}"`,{isMany:y.isMany,parentHasRelation:!!h.data.value[g]}),y.isMany?(h.data.value[g]??={value:[]},h.data.value[g].value.push(y.data),this.logger.debug(`[QueryEngine] assembleResults: Added "${p}" to many relation "${g}" on parent "${f}"`,{arrayLength:h.data.value[g].value.length})):(h.data.value[g]=y.data,this.logger.debug(`[QueryEngine] assembleResults: Set one relation "${g}" on parent "${f}" to "${p}"`));}}return this.logger.debug(`[QueryEngine] assembleResults: Assembly complete. Returning ${o.length} root items`),o}resolveStep(e,t){this.logger.debug("[QueryEngine] Resolving step",e.stepPath.join("."),"with query",JSON.stringify(e.query,null,2),"relationalWhere",JSON.stringify(e.relationalWhere,null,2));let{query:n,relationalWhere:r}=e,o=n.where&&r?K(n.where,r):r??n.where,u=o?{...n,where:o}:n;return Te(this.router.get(u,t)).then(s=>(this.loadStepResults(e,s),s))}loadStepResults(e,t){this.logger.debug("[QueryEngine] Loading step results",e.stepPath.join("."),"with results",JSON.stringify(t,null,2));let n=Re(e),r=this.queryNodes.get(n),o=e.query.resource;if(!r)return;let u=this.getRelationalColumns(o);for(let s of t){let a=x(s),c=a.id;this.ensureObjectNode(c,o,n),r.trackedObjects.add(c);for(let[d,{relationName:l,targetResource:p}]of Array.from(u)){let y=a[d];if(y){this.ensureObjectNode(y,p);let m=this.getInverseRelationName(o,p,l);this.storeRelation(c,y,l,m);}}this.loadNestedRelations(o,c,a),this.logger.debug("[QueryEngine] Loaded nested relations for",c);}}loadNestedRelations(e,t,n){let r=this.schema[e];if(r!=null&&r.relations)for(let[o,u]of Object.entries(r.relations)){let s=n[o];if(!s)continue;let a=u.entity.name,c=this.getInverseRelationName(e,a,o);if(u.type==="one")s&&typeof s=="object"&&s.id&&(this.ensureObjectNode(s.id,a),this.storeRelation(t,s.id,o,c),this.loadNestedRelations(a,s.id,s));else if(u.type==="many"&&Array.isArray(s)){for(let d of s)if(d&&typeof d=="object"&&d.id){this.ensureObjectNode(d.id,a);let l=this.getInverseRelationName(a,e,o);l&&this.storeRelation(d.id,t,l,o),this.loadNestedRelations(a,d.id,d);}}}}buildIncludeFromChildQueries(e){let t=this.queryNodes.get(e);if(!t||t.childQueries.size===0)return {};let n={};for(let r of Array.from(t.childQueries)){let o=this.queryNodes.get(r);if(!o||!o.relationName)continue;let u=this.buildIncludeFromChildQueries(r);n[o.relationName]=Object.keys(u).length>0?u:true;}return n}sendInsertsForTree(e,t,n){var s,a;let r=(a=(s=t==null?void 0:t.value)==null?void 0:s.id)==null?void 0:a.value;if(!r)return;let o={procedure:"INSERT",resource:n,resourceId:r,type:"MUTATE",payload:t.value};for(let c of Array.from(e.subscriptions))try{c(o);}catch(d){this.logger.error("[QueryEngine] Error in subscription callback during sendInsertsForTree",{error:d,queryHash:e.hash,resource:n,resourceId:r,stepPath:e.queryStep.stepPath.join(".")});}e.trackedObjects.add(r),this.ensureObjectNode(r,n,e.hash).matchedQueries.add(e.hash);for(let c of Array.from(e.childQueries)){let d=this.queryNodes.get(c);if(!d||!d.relationName)continue;let l=d.relationName,p=d.queryStep.query.resource,y=t.value[l];if(!y)continue;let m=y.value;if(Array.isArray(m))for(let f of m)this.sendInsertsForTree(d,f,p);else m&&typeof m=="object"&&this.sendInsertsForTree(d,m,p);}}handleMutation(e,t){if(e.procedure==="INSERT"){if(this.objectNodes.has(e.resourceId))return;let n=x(t);if(!n)return;let r={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map};this.objectNodes.set(e.resourceId,r);let o=this.getRelationalColumns(e.resource);for(let[s,{relationName:a,targetResource:c}]of Array.from(o)){let d=n[s];if(d){this.ensureObjectNode(d,c);let l=this.getInverseRelationName(e.resource,c,a);this.storeRelation(e.resourceId,d,a,l);}}let u=this.objectNodes.get(e.resourceId);this.getMatchingQueries(e,n).then(s=>{for(let a of s){let c=this.queryNodes.get(a);if(c){c.trackedObjects.add(e.resourceId),u&&u.matchedQueries.add(a);for(let d of Array.from(c.subscriptions))try{d(e);}catch(l){this.logger.error("[QueryEngine] Error in subscription callback during INSERT mutation",{error:l,queryHash:c.hash,resource:e.resource,resourceId:e.resourceId,stepPath:c.queryStep.stepPath.join(".")});}}}});return}if(e.procedure==="UPDATE"){let n=x(t);if(!n)return;let r=this.objectNodes.get(e.resourceId),o=new Set((r==null?void 0:r.matchedQueries)??[]);r||(r={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e.resourceId,r)),this.updateRelationsFromMutation(e.resource,e.resourceId,n,e.payload),this.getMatchingQueries(e,n).then(u=>{let s=new Set(u),a=[],c=[],d=[];for(let p of u)o.has(p)?d.push(p):a.push(p);for(let p of Array.from(o))s.has(p)||c.push(p);for(let p of a){let y=this.queryNodes.get(p);y&&y.trackedObjects.add(e.resourceId);}for(let p of c){let y=this.queryNodes.get(p);y&&y.trackedObjects.delete(e.resourceId);}let l=this.objectNodes.get(e.resourceId);if(l){for(let p of a)l.matchedQueries.add(p);for(let p of c)l.matchedQueries.delete(p);}for(let p of [...c,...d]){let y=this.queryNodes.get(p);if(y)for(let m of Array.from(y.subscriptions))try{m(e);}catch(f){this.logger.error("[QueryEngine] Error in subscription callback during UPDATE mutation",{error:f,queryHash:y.hash,resource:e.resource,resourceId:e.resourceId,stepPath:y.queryStep.stepPath.join(".")});}}if(a.length>0)for(let p of a){let y=this.queryNodes.get(p);if(!y)continue;let m=this.buildIncludeFromChildQueries(p);this.get({resource:e.resource,where:{id:e.resourceId},include:Object.keys(m).length>0?m:void 0}).then(f=>{!f||f.length===0||this.sendInsertsForTree(y,f[0],e.resource);});}});return}}getMatchingQueries(e,t){let n=[];for(let r of Array.from(this.queryNodes.values()))r.queryStep.query.resource===e.resource&&n.push(r);return n.length===0?Te([]):Promise.all(n.map(async r=>{let o=r.queryStep.query.where,u=r.queryStep.query.resource,s=e.resourceId,a=this.objectNodes.get(s);if(!a)return {hash:r.hash,matches:false};if(r.relationName){let y=r.parentQuery?this.queryNodes.get(r.parentQuery):void 0,m=y==null?void 0:y.queryStep.query.resource,f=m?this.getInverseRelationName(m,u,r.relationName):void 0,h=f?a.referencesObjects.get(f):void 0;if(!h)return {hash:r.hash,matches:false};let g=this.objectNodes.get(h);return !g||!y||!g.matchedQueries.has(y.hash)?{hash:r.hash,matches:false}:{hash:r.hash,matches:true}}if(!o)return {hash:r.hash,matches:true};let c=_(o,u,this.schema),d=Object.keys(c).length>0;if(!d&&t!==void 0)return {hash:r.hash,matches:A(t,o)};let l=await this.storage.get({resource:u,where:{id:s},include:d?c:void 0});if(!l||l.length===0)return {hash:r.hash,matches:false};let p=x(l[0]);return p?{hash:r.hash,matches:A(p,o)}:{hash:r.hash,matches:false}})).then(r=>r.filter(o=>o.matches).map(o=>o.hash))}};var Je=Qe(be());var le=zod.z.object({resource:zod.z.string(),where:zod.z.record(zod.z.string(),zod.z.any()).optional(),include:zod.z.record(zod.z.string(),zod.z.any()).optional(),lastSyncedAt:zod.z.string().optional(),limit:zod.z.coerce.number().optional(),sort:zod.z.array(zod.z.object({key:zod.z.string(),direction:zod.z.enum(["asc","desc"])})).optional()}),Se=zod.z.record(zod.z.string(),zod.z.object({value:zod.z.any().nullable(),_meta:zod.z.object({timestamp:zod.z.string().optional().nullable()}).optional()})),Ut=Se.superRefine((i,e)=>{i.id&&e.addIssue({code:zod.z.ZodIssueCode.custom,message:"Payload cannot have an id"});}),Ke=zod.z.object({id:zod.z.string().optional(),type:zod.z.literal("MUTATE"),resource:zod.z.string(),resourceId:zod.z.string().optional()}),Ue=zod.z.object({timestamp:zod.z.string().optional()}).optional(),U=Ke.extend({procedure:zod.z.string(),payload:zod.z.any().optional(),meta:Ue}),H=Ke.extend({procedure:zod.z.enum(["INSERT","UPDATE"]),payload:Ut,meta:Ue});zod.z.union([H,U]);var We=zod.z.object({resource:zod.z.string(),procedure:zod.z.string(),input:zod.z.any().optional()});var He=le.omit({resource:true}),ve=U.omit({id:true,type:true,resource:true,procedure:true}).extend({meta:U.shape.meta}),xe=H.omit({id:true,type:true,resource:true,procedure:true});zod.z.union([xe,ve]);var we=i=>{if(i==null)return i;if(i==="null")return null;if(Array.isArray(i))return i.map(we);if(typeof i=="object"&&i.constructor===Object){let e={};for(let[t,n]of Object.entries(i))e[t]=we(n);return e}return i},Ge=i=>{let e=i.logger;return async t=>{var n;try{let r=typeof t.headers.getSetCookie=="function"?Object.fromEntries(t.headers):t.headers,o={headers:r,cookies:r.cookie?Je.default.parse(r.cookie):{}},u=new URL(t.url),s=u.pathname.split("/"),a=u.searchParams,c=we(Ht__default.default.parse(a.toString())),d=await((n=i.contextProvider)==null?void 0:n.call(i,{transport:"HTTP",headers:o.headers,cookies:o.cookies,queryParams:c}))??{};if(t.method==="GET"){let l=s[s.length-1],{success:p,data:y,error:m}=He.safeParse(c);if(!p)return Response.json({message:"Invalid query",code:"INVALID_QUERY",details:m},{status:400});let f=await i.handleQuery({req:{...o,...y,type:"QUERY",resource:l,context:d,queryParams:c}});return !f||!f.data?Response.json({message:"Invalid resource",code:"INVALID_RESOURCE"},{status:400}):Response.json(f.data)}if(t.method==="POST")try{let l=s[s.length-1],p=s[s.length-2];if(p==="query"){if(s.length<3)return Response.json({message:"Invalid path structure for custom query",code:"INVALID_PATH"},{status:400});let g=s[s.length-3],T=t.body?await t.json():{};if(!g||g.trim()==="")return Response.json({message:"Invalid resource in path",code:"INVALID_RESOURCE"},{status:400});let R=await i.handleCustomQuery({req:{...o,type:"CUSTOM_QUERY",resource:g,procedure:l,input:T.input,context:d,queryParams:c}});return Response.json(R)}let y=p,m=t.body?await t.json():{},f;if(l==="insert"||l==="update"){let{success:g,data:T,error:R}=xe.safeParse(m);if(!g)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:R},{status:400});f=T;}else {let{success:g,data:T,error:R}=ve.safeParse(m);if(!g)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:R},{status:400});f=T;}let h=await i.handleMutation({req:{...o,type:"MUTATE",resource:y,input:f.payload,context:d,resourceId:f.resourceId,procedure:l==="insert"||l==="update"?l.toUpperCase():l,queryParams:{},meta:f.meta}});return Response.json(h)}catch(l){return e.error("Error parsing mutation from the client:",l),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}return Response.json({message:"Not found",code:"NOT_FOUND"},{status:404})}catch(r){return e.error("Unexpected error:",r),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}}};var Xe=Qe(be());var $=zod.z.string(),Me=zod.z.union([We,le]),Jt=zod.z.object({id:$,type:zod.z.literal("SUBSCRIBE")}).and(Me),Gt=zod.z.object({id:$,type:zod.z.literal("UNSUBSCRIBE")}).and(Me),Zt=zod.z.object({id:$,type:zod.z.literal("QUERY")}).and(Me),Yt=zod.z.object({id:$,type:zod.z.literal("CUSTOM_QUERY"),resource:zod.z.string(),procedure:zod.z.string(),input:zod.z.any().optional()}),Ze=H.extend({id:$}),Xt=U.extend({id:$}),en=zod.z.union([Xt,Ze]),Ye=zod.z.union([Jt,Zt,Yt,en,Gt]),tn=zod.z.object({id:$,type:zod.z.literal("REJECT"),resource:zod.z.string(),message:zod.z.string().optional()}),nn=zod.z.object({id:$,type:zod.z.literal("REPLY"),data:zod.z.any()});zod.z.union([tn,nn,Ze]);zod.z.object({resource:zod.z.string(),data:zod.z.array(Se)});var et=i=>{let e={},t=i.logger;return (n,r)=>{var l;let o=p=>{n.send(JSON.stringify(p));},u=se(),s=new Map,a={headers:r.headers,cookies:typeof r.headers.cookie=="string"?Xe.default.parse(r.headers.cookie):{}},c=Ht.parse(r.url.split("?")[1]),d=(l=i.contextProvider)==null?void 0:l.call(i,{transport:"WEBSOCKET",headers:a.headers,cookies:a.cookies,queryParams:c});e[u]=n,t.info("Client connected:",u),n.on("message",async p=>{try{t.debug("Message received from the client:",p);let y=Ye.parse(JSON.parse(p.toString()));if(y.type==="SUBSCRIBE"||y.type==="QUERY"){let{type:m,id:f,...h}=y,g=m==="SUBSCRIBE";if("procedure"in h){let T=await i.handleCustomQuery({req:{...a,type:"CUSTOM_QUERY",resource:h.resource,procedure:h.procedure,input:h.input,context:await d??{},queryParams:c},subscription:g?R=>{var b;!R.resourceId||!R.payload||!Object.keys(R.payload).length||(b=e[u])==null||b.send(JSON.stringify(R));}:void 0});if(g){if(!T||!T.data||!T.query)throw new Error("Invalid resource");T.unsubscribe&&s.set(N(h),T.unsubscribe),o({id:f,type:"REPLY",data:{resource:T.query.resource,data:(T.data??[]).map(R=>R.value)}});}else o({id:f,type:"REPLY",data:T});}else {let T=await i.handleQuery({req:{...a,...h,type:"QUERY",context:await d??{},queryParams:c},subscription:g?R=>{var b;!R.resourceId||!R.payload||!Object.keys(R.payload).length||(b=e[u])==null||b.send(JSON.stringify(R));}:void 0});if(!T||!T.data)throw new Error("Invalid resource");g&&T.unsubscribe&&s.set(N(h),T.unsubscribe),o({id:f,type:"REPLY",data:{resource:h.resource,data:(T.data??[]).map(R=>R.value)}});}}else if(y.type==="UNSUBSCRIBE"){let{type:m,id:f,...h}=y,g=s.get(N(h));g&&(g(),s.delete(N(h)));}else if(y.type==="CUSTOM_QUERY"){let{resource:m,procedure:f,input:h,id:g}=y;t.debug("Received custom query from client:",y);try{let T=await i.handleCustomQuery({req:{...a,type:"CUSTOM_QUERY",resource:m,procedure:f,input:h,context:await d??{},queryParams:c}});o({id:g,type:"REPLY",data:T});}catch(T){o({id:g,type:"REJECT",resource:m,message:T.message}),t.error("Error handling custom query from the client:",T);}}else if(y.type==="MUTATE"){let{resource:m}=y;t.debug("Received mutation from client:",y);try{let f=await i.handleMutation({req:{...a,type:"MUTATE",resource:m,input:y.payload,context:{messageId:y.id,...await d??{}},resourceId:y.resourceId,procedure:y.procedure,queryParams:c,meta:y.meta}});y.procedure&&y.procedure!=="INSERT"&&y.procedure!=="UPDATE"&&o({id:y.id,type:"REPLY",data:f});}catch(f){o({id:y.id,type:"REJECT",resource:m,message:f.message}),t.error("Error parsing mutation from the client:",f);}}}catch(y){t.error("Error handling message from the client:",y);}}),n.on("close",()=>{t.info("Connection closed",u),delete e[u];for(let p of Array.from(s.values()))p();});}};function tt(i){let e=`${i.protocol}://${i.hostname}${i.url}`,t=new Headers;return Object.entries(i.headers).forEach(([n,r])=>{r&&t.set(n,Array.isArray(r)?r.join(","):r);}),new Request(e,{method:i.method,headers:t,body:i.body&&i.method!=="GET"?JSON.stringify(i.body):void 0})}var Nr=(i,e,t)=>{i.ws(`${(t==null?void 0:t.basePath)??""}/ws`,et(e)),i.use(`${(t==null?void 0:t.basePath)??""}/`,(n,r)=>{Ge(e)(tt(n)).then(u=>u.json().then(s=>r.status(u.status).send(s)));});};var de=class i{_collection;_client;_where;_include;_limit;_single;_sort;_shouldAwait;constructor(e,t,n,r,o,u,s,a){this._collection=e,this._client=t,this._where=n??{},this._include=r??{},this._limit=o,this._single=u,this._sort=s,this._shouldAwait=a,this.get=this.get.bind(this),this.subscribe=this.subscribe.bind(this);}where(e){return new i(this._collection,this._client,{...this._where,...e},this._include,this._limit,this._single,this._sort,this._shouldAwait)}include(e){return new i(this._collection,this._client,this._where,{...this._include,...e},this._limit,this._single,this._sort,this._shouldAwait)}limit(e){return new i(this._collection,this._client,this._where,this._include,e,this._single,this._sort,this._shouldAwait)}one(e){return this.first({id:e})}first(e){return new i(this._collection,this._client,e??this._where,this._include,1,true,this._sort,this._shouldAwait)}orderBy(e,t="asc"){let n=[...this._sort??[],{key:e,direction:t}];return new i(this._collection,this._client,this._where,this._include,this._limit,this._single,n,this._shouldAwait)}toJSON(){return {resource:this._collection.name,where:this._where,include:this._include,limit:this._limit,sort:this._sort}}buildQueryRequest(){return {resource:this._collection.name,where:this._where,include:this._include,limit:this._limit,sort:this._sort}}get(){let e=this._client.get(this.buildQueryRequest());return this._shouldAwait?Promise.resolve(e).then(t=>this._single?t[0]:t):this._single?e[0]:e}subscribe(e){return this._client.subscribe(this.buildQueryRequest(),t=>{if(this._single)return e(t[0]);e(t);})}static _init(e,t,n){return new i(e,t,void 0,void 0,void 0,void 0,void 0,n??false)}};var an=i=>typeof i=="object"&&i!==null&&"value"in i&&!Array.isArray(i),Ie=class{constructor(e){this.storage=e;}get(e){return Promise.resolve(this.storage.get(e)).then(t=>t.map(n=>an(n)?x(n):n))}subscribe(){throw new Error("Subscriptions are not supported server-side. Use .get() instead.")}};function k(i,e){let t=new Ie(i),n=o=>{let u=de._init(o,t,true);return Object.assign(Object.create(u),{insert:a=>i.insert(o,a),update:(a,c)=>i.update(o,a,c)})},r={get(o,u){if(u==="findOne")return i.findOne.bind(i);if(u==="find")return i.find.bind(i);if(u==="insert")return i.insert.bind(i);if(u==="update")return i.update.bind(i);if(u==="transaction")return async s=>i.transaction(async({trx:a,commit:c,rollback:d})=>{let l=k(a,e);return s({trx:l,commit:c,rollback:d})});if(u in e){let s=e[u];return n(s)}}};return new Proxy({},r)}var Le=class i{routes;hooksRegistry=new Map;constructor(e){this.routes=e.routes;for(let t of Object.values(e.routes)){if(t.resourceSchema===void 0)continue;let n=t;n.hooks&&this.hooksRegistry.set(n.resourceSchema.name,n.hooks);}}static create(e){return new i(e)}getHooks(e){return this.hooksRegistry.get(e)}},Kr=i=>Le.create({...i}),rt=(i=>({handler:e=>({_type:"query",inputValidator:i??zod.z.undefined(),handler:e})})),it=(i=>({handler:e=>({_type:"mutation",inputValidator:i??zod.z.undefined(),handler:e})})),Ce=class i{resourceSchema;middlewares;customMutations;customQueries;authorization;hooks;constructor(e,t,n,r,o){this.resourceSchema=e,this.middlewares=new Set,this.customMutations=t??{},this.customQueries=n??{},this.authorization=r,this.hooks=o;}use(...e){for(let t of e)this.middlewares.add(t);return this}withProcedures(e){let t=e({mutation:it,query:rt}),n={},r={};for(let[o,u]of Object.entries(t))u._type==="mutation"?n[o]=u:r[o]=u;return new i(this.resourceSchema,n,r,this.authorization,this.hooks)}withMutations(e){return this.withProcedures(({mutation:t})=>e({mutation:t}))}withHooks(e){return new i(this.resourceSchema,this.customMutations,this.customQueries,this.authorization,e)}handleQuery=async({req:e,batcher:t})=>await this.wrapInMiddlewares(async n=>{let r={resource:n.resource,where:n.where,include:n.include,lastSyncedAt:n.lastSyncedAt,limit:n.limit,sort:n.sort},o=N(r);return {data:await t.rawFind({resource:n.resource,commonWhere:n.where,uniqueWhere:n.relationalWhere,include:n.include,limit:n.limit,sort:n.sort}),unsubscribe:void 0,queryHash:o}})(e);handleMutation=async({req:e,db:t,schema:n})=>{var s;let r=((s=e.meta)==null?void 0:s.timestamp)??new Date().toISOString(),o=t._setMutationTimestamp(r),u=k(o,n);return await this.wrapInMiddlewares(async a=>{if(!a.procedure)throw new Error("Procedure is required for mutations");let c=this.customMutations[a.procedure];if(c){let d=c.inputValidator["~standard"].validate(a.input),l=d instanceof Promise?await d:d;if(l.issues){let p=l.issues.map(y=>{var f;let m=(f=y.path)==null?void 0:f.map(h=>typeof h=="object"&&"key"in h?String(h.key):String(h)).join(".");return m?`${m}: ${y.message}`:y.message}).join(", ");throw new Error(`Validation failed: ${p}`)}return a.input=l.value,c.handler({req:a,db:u})}else {if(a.procedure==="INSERT"||a.procedure==="UPDATE")return this.handleSet({req:a,db:o,operation:a.procedure,schema:n});throw new Error(`Unknown procedure: ${a.procedure}`)}})(e)};handleCustomQuery=async({req:e,db:t,schema:n})=>{let r=k(t,n);return await this.wrapInMiddlewares(async o=>{let u=this.customQueries[o.procedure];if(!u)throw new Error(`Unknown query procedure: ${o.procedure}`);let s=u.inputValidator["~standard"].validate(o.input),a=s instanceof Promise?await s:s;if(a.issues){let c=a.issues.map(d=>{var p;let l=(p=d.path)==null?void 0:p.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return l?`${l}: ${d.message}`:d.message}).join(", ");throw new Error(`Validation failed: ${c}`)}return o.input=a.value,u.handler({req:o,db:r})})(e)};getAuthorizationClause(e){var t,n;return (n=(t=this.authorization)==null?void 0:t.read)==null?void 0:n.call(t,{ctx:e.context})}handleSet=async({req:e,db:t,operation:n,schema:r})=>{if(!e.input)throw new Error("Payload is required");if(!e.resourceId)throw new Error("ResourceId is required");let o=await t.rawFindById(e.resource,e.resourceId);if(n==="INSERT"&&o)throw new Error("Resource already exists");if(n==="UPDATE"&&!o)throw new Error("Resource not found");let u={value:e.input};return t.transaction(async({trx:s})=>{var d,l,p,y,m,f,h;if(n==="INSERT"){let{data:g,acceptedValues:T}=await s.rawInsert(e.resource,e.resourceId,u,(d=e.context)==null?void 0:d.messageId,e.context);if(!T)throw new Error("Mutation rejected");let R=x(g);if(R.id=R.id??e.resourceId,(l=this.authorization)!=null&&l.insert){let b=this.authorization.insert({ctx:e.context,value:R});if(typeof b=="boolean"){if(!b)throw new Error("Not authorized")}else {let S=_(b,e.resource,r),I=Object.keys(S).length>0?await s.rawFindById(e.resource,e.resourceId,S):g,w=x(I);if(w.id=w.id??e.resourceId,!A(w,b))throw new Error("Not authorized")}}return {data:g,acceptedValues:T}}if((y=(p=this.authorization)==null?void 0:p.update)!=null&&y.preMutation){let g=x(o);g.id=g.id??e.resourceId;let T=this.authorization.update.preMutation({ctx:e.context,value:g});if(typeof T=="boolean"){if(!T)throw new Error("Not authorized")}else {let R=_(T,e.resource,r),b=Object.keys(R).length>0?await s.rawFindById(e.resource,e.resourceId,R):o,S=x(b);if(S.id=S.id??e.resourceId,!A(S,T))throw new Error("Not authorized")}}let{data:a,acceptedValues:c}=await s.rawUpdate(e.resource,e.resourceId,u,(m=e.context)==null?void 0:m.messageId,e.context);if(!c)throw new Error("Mutation rejected");if((h=(f=this.authorization)==null?void 0:f.update)!=null&&h.postMutation){let g=x(a);g.id=g.id??e.resourceId;let T=this.authorization.update.postMutation({ctx:e.context,value:g});if(typeof T=="boolean"){if(!T)throw new Error("Not authorized")}else {let R=_(T,e.resource,r),b=Object.keys(R).length>0?await s.rawFindById(e.resource,e.resourceId,R):a,S=x(b);if(S.id=S.id??e.resourceId,!A(S,T))throw new Error("Not authorized")}}return {data:a,acceptedValues:c}})};wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((n,r)=>o=>r({req:o,next:n}),e)(t)}},Ae=class{resourceSchema=void 0;middlewares;customMutations;customQueries;constructor(e,t){this.middlewares=new Set,this.customMutations=e??{},this.customQueries=t??{};}use(...e){for(let t of e)this.middlewares.add(t);return this}handleMutation=async({req:e,db:t,schema:n})=>{var s;let r=((s=e.meta)==null?void 0:s.timestamp)??new Date().toISOString(),o=t._setMutationTimestamp(r),u=k(o,n);return await this.wrapInMiddlewares(async a=>{if(!a.procedure)throw new Error("Procedure is required for mutations");let c=this.customMutations[a.procedure];if(c){let d=c.inputValidator["~standard"].validate(a.input),l=d instanceof Promise?await d:d;if(l.issues){let p=l.issues.map(y=>{var f;let m=(f=y.path)==null?void 0:f.map(h=>typeof h=="object"&&"key"in h?String(h.key):String(h)).join(".");return m?`${m}: ${y.message}`:y.message}).join(", ");throw new Error(`Validation failed: ${p}`)}return a.input=l.value,c.handler({req:a,db:u})}throw new Error(`Unknown procedure: ${a.procedure}`)})(e)};handleCustomQuery=async({req:e,db:t,schema:n})=>{let r=k(t,n);return await this.wrapInMiddlewares(async o=>{let u=this.customQueries[o.procedure];if(!u)throw new Error(`Unknown query procedure: ${o.procedure}`);let s=u.inputValidator["~standard"].validate(o.input),a=s instanceof Promise?await s:s;if(a.issues){let c=a.issues.map(d=>{var p;let l=(p=d.path)==null?void 0:p.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return l?`${l}: ${d.message}`:d.message}).join(", ");throw new Error(`Validation failed: ${c}`)}return o.input=a.value,u.handler({req:o,db:r})})(e)};getAuthorizationClause(){}wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((n,r)=>o=>r({req:o,next:n}),e)(t)}},je=class i{middlewares;constructor(e=[]){this.middlewares=e;}collectionRoute(e,t){return new Ce(e,void 0,void 0,t,void 0).use(...this.middlewares)}withProcedures(e){let t=e({mutation:it,query:rt}),n={},r={};for(let[o,u]of Object.entries(t))u._type==="mutation"?n[o]=u:r[o]=u;return new Ae(n,r).use(...this.middlewares)}use(...e){return new i([...this.middlewares,...e])}static create(){return new i}},Ur=je.create;var J=class{_mutationTimestamp;_setMutationTimestamp(e){let t=this._clone();return t._mutationTimestamp=e,t}_getTimestamp(){return this._mutationTimestamp??new Date().toISOString()}_clone(){return Object.assign(Object.create(Object.getPrototypeOf(this)),this)}async insert(e,t){let n=this._getTimestamp(),r=await this.rawInsert(e.name,t.id,{value:Object.fromEntries(Object.entries(t).map(([o,u])=>[o,{value:u,_meta:{timestamp:n}}]))});return x(r.data)}async update(e,t,n){let r=this._getTimestamp(),{id:o,...u}=n,s=await this.rawUpdate(e.name,t,{value:Object.fromEntries(Object.entries(u).map(([d,l])=>[d,{value:l,_meta:{timestamp:r}}]))}),a=x(s.data),c={};for(let d of Object.keys(u))d in a&&(c[d]=a[d]);return c}};var yn={postgres:{jsonObjectFrom:postgres.jsonObjectFrom,jsonArrayFrom:postgres.jsonArrayFrom},mysql:{jsonObjectFrom:mysql.jsonObjectFrom,jsonArrayFrom:mysql.jsonArrayFrom},sqlite:{jsonObjectFrom:sqlite.jsonObjectFrom,jsonArrayFrom:sqlite.jsonArrayFrom}};function q(i){var r,o,u;let e=(r=i.getExecutor)==null?void 0:r.call(i),t=e==null?void 0:e.adapter;if(!t)return "postgres";let n=((u=(o=t.constructor)==null?void 0:o.name)==null?void 0:u.toLowerCase())??"";return n.includes("postgres")?"postgres":n.includes("mysql")?"mysql":n.includes("sqlite")?"sqlite":"postgres"}function at(i){let e=q(i);return yn[e]}var pn="42701";function G(i){var t;if(i.code===pn)return true;let e=((t=i.message)==null?void 0:t.toLowerCase())||"";return e.includes("already exists")||e.includes("duplicate")||e.includes("already defined")}function Oe(i,e){let{type:t,enumValues:n,enumName:r}=i;if(n&&n.length>0)return e==="postgres"&&r?r:"varchar";if(t==="jsonb"||t==="json")switch(e){case "postgres":return "jsonb";case "mysql":return "json";case "sqlite":return "text"}return t}async function fn(i,e,t,n){if(t!=="postgres")return;let r=new Map;for(let o of Object.values(e))for(let u of Object.values(o.fields)){let s=u.getStorageFieldType();s.enumValues&&s.enumName&&r.set(s.enumName,{name:s.enumName,values:s.enumValues});}for(let o of Array.from(r.values())){let{name:u,values:s}=o;try{let a=s.map(c=>`'${c}'`).join(", ");await kysely.sql`
|
|
2
2
|
DO $$ BEGIN
|
|
3
|
-
CREATE TYPE ${kysely.sql.id(u)} AS ENUM (${kysely.sql.raw(
|
|
3
|
+
CREATE TYPE ${kysely.sql.id(u)} AS ENUM (${kysely.sql.raw(a)});
|
|
4
4
|
EXCEPTION
|
|
5
5
|
WHEN duplicate_object THEN null;
|
|
6
6
|
END $$;
|
|
7
|
-
`.execute(i);}catch(
|
|
7
|
+
`.execute(i);}catch(a){n==null||n.warn("Could not create enum type",u,a);}}}function Z(i,e){return i.some(t=>t.name===e)}function mn(i,e){return (i==null?void 0:i.columns.some(t=>t.name===e))??false}function Pe(i,e){let[t]=e.split(".");return Z(i,t)}function Ee(i,e,t,n=false){let r=i;return e.unique&&(r=r.unique()),e.nullable||(r=r.notNull()),e.primary&&(r=r.primaryKey()),e.default!==void 0&&(r=r.defaultTo(e.default)),!n&&e.references&&Pe(t,e.references)&&(r=r.references(e.references)),r}function hn(i,e,t,n,r){let o=[];for(let[u,s]of Object.entries(i.fields)){let a=e==null?void 0:e.columns.find(d=>d.name===u),c=s.getStorageFieldType();a?(a.dataType,c.type):(o.push({name:u,storageFieldType:c}),c.references&&!Pe(t,c.references)&&n.push({tableName:r,columnName:u,references:c.references}));}return o}function st(i,e){return e==="postgres"&&!!i.enumValues&&i.enumValues.length>0&&!!i.enumName}async function Tn(i,e,t,n,r,o){if(t.length===0)return;let u=i.schema.createTable(e);for(let{name:s,storageFieldType:a}of t)if(st(a,r))u=u.addColumn(s,kysely.sql.raw(a.enumName),c=>Ee(c,a,n));else {let c=Oe(a,r);u=u.addColumn(s,c,d=>Ee(d,a,n));}await u.execute().catch(s=>{if(!G(s))throw o==null||o.error("Error creating table",e,s),s});}async function gn(i,e,t,n,r,o,u){for(let{name:s,storageFieldType:a}of t){let c=a.references?Pe(n,a.references):false,d=st(a,o)?kysely.sql.raw(a.enumName):Oe(a,o);await i.schema.alterTable(e).addColumn(s,d,l=>Ee(l,a,n,!c)).execute().catch(l=>{if(!G(l))throw u==null||u.error("Error adding column",s,l),l}),a.references&&!c&&!r.some(l=>l.tableName===e&&l.columnName===s)&&r.push({tableName:e,columnName:s,references:a.references}),a.index&&await i.schema.createIndex(`${e}_${s}_index`).on(e).column(s).execute().catch(()=>{});}}async function Rn(i,e,t,n,r,o){let u=`${e}_meta`,s=[];for(let[a,c]of Object.entries(t.fields)){let d=c.getStorageFieldType();mn(n,a)||s.push({name:a,storageFieldType:d});}if(!n&&s.length>0){let a=i.schema.createTable(u);for(let{name:c,storageFieldType:d}of s)a=a.addColumn(c,"varchar",l=>{let p=l;return d.primary&&(p=p.primaryKey(),Z(r,e)&&(p=p.references(`${e}.${c}`))),p});await a.execute().catch(c=>{if(!G(c))throw o==null||o.error("Error creating meta table",u,c),c});}else if(n)for(let{name:a,storageFieldType:c}of s)await i.schema.alterTable(u).addColumn(a,"varchar",d=>{let l=d;return c.primary&&(l=l.primaryKey(),Z(r,e)&&(l=l.references(`${e}.${a}`))),l}).execute().catch(d=>{if(!G(d))throw o==null||o.error("Error adding meta column",a,d),d});}async function ot(i,e,t,n,r){let[o,u]=n.split("."),s=`${e}_${t}_fk`;try{await kysely.sql`
|
|
8
8
|
ALTER TABLE ${kysely.sql.id(e)}
|
|
9
|
-
ADD CONSTRAINT ${kysely.sql.id(
|
|
9
|
+
ADD CONSTRAINT ${kysely.sql.id(s)}
|
|
10
10
|
FOREIGN KEY (${kysely.sql.id(t)})
|
|
11
11
|
REFERENCES ${kysely.sql.id(o)} (${kysely.sql.id(u)})
|
|
12
|
-
`.execute(i);}catch(s){G(s)||r==null||r.warn("Could not add foreign key constraint",e,t,n,s);}}async function Rn(i,e,t,n){for(let{tableName:r,columnName:o,references:u}of e){let a=t.find(d=>d.name===r),s=a==null?void 0:a.columns.find(d=>d.name===o),[l]=u.split(".");a&&s&&Z(t,l)&&await it(i,r,o,u,n);}}async function bn(i,e,t,n){for(let[r,o]of Object.entries(e)){let u=`${r}_meta`,a=t.find(s=>s.name===u);if(a)for(let[s,l]of Object.entries(o.fields)){let d=l.getStorageFieldType(),c=a.columns.find(p=>p.name===s);d.primary&&c&&Z(t,r)&&await it(i,u,s,`${r}.${s}`,n);}}}async function at(i,e,t){let n=q(i),r=await i.introspection.getTables(),o=[];await pn(i,e,n,t);for(let[a,s]of Object.entries(e)){let l=r.find(p=>p.name===a),d=r.find(p=>p.name===`${a}_meta`),c=mn(s,l,r,o,a);if(l)for(let[p,y]of Object.entries(s.fields)){let m=l.columns.find(g=>g.name===p),f=y.getStorageFieldType(),T=Ee(f,n);m&&m.dataType!==T&&(t==null||t.warn("Column type mismatch:",p,"expected to have type:",T,"but has type:",m.dataType));}!l&&c.length>0?await hn(i,a,c,r,n,t):l&&await Tn(i,a,c,r,o,n,t),await gn(i,a,s,d,r,t);}let u=await i.introspection.getTables();await Rn(i,o,u,t),await bn(i,e,u,t);}function ye(i,e,t,n){if(!i)throw new Error("Schema not initialized");let r=i[e];if(!r)throw new Error("Resource not found");let o=n.$or,u=n.$and;return (o?t.or:t.and)(o?n.$or.map(a=>ye(i,e,t,a)):u?n.$and.map(a=>ye(i,e,t,a)):Object.entries(n).map(([a,s])=>{var l,d;if(r.fields[a])return (s==null?void 0:s.$eq)!==void 0?t(`${e}.${a}`,s.$eq===null?"is":"=",s.$eq):(s==null?void 0:s.$in)!==void 0?t(`${e}.${a}`,"in",s.$in):(s==null?void 0:s.$not)!==void 0?((l=s==null?void 0:s.$not)==null?void 0:l.$in)!==void 0?t(`${e}.${a}`,"not in",s.$not.$in):((d=s==null?void 0:s.$not)==null?void 0:d.$eq)!==void 0?t(`${e}.${a}`,s.$not.$eq===null?"is not":"!=",s.$not.$eq):t(`${e}.${a}`,s.$not===null?"is not":"!=",s.$not):(s==null?void 0:s.$gt)!==void 0?t(`${e}.${a}`,">",s.$gt):(s==null?void 0:s.$gte)!==void 0?t(`${e}.${a}`,">=",s.$gte):(s==null?void 0:s.$lt)!==void 0?t(`${e}.${a}`,"<",s.$lt):(s==null?void 0:s.$lte)!==void 0?t(`${e}.${a}`,"<=",s.$lte):t(`${e}.${a}`,s===null?"is":"=",s);if(r.relations[a]){let c=r.relations[a],p=c.entity.name;return c.type==="many"?t.exists(fe(i,p,t.selectFrom(p).select("id").whereRef(c.foreignColumn,"=",`${e}.id`),s)):ye(i,p,t,s)}return null}).filter(Boolean))}function pe(i,e,t,n){let r=i[e];if(!r)throw new Error("Resource not found");if(!n)return t;if(n.$and){for(let o of n.$and)t=pe(i,e,t,o);return t}else if(n.$or){for(let o of n.$or)t=pe(i,e,t,o);return t}for(let[o,u]of Object.entries(n)){if(!r.relations[o])continue;let a=r.relations[o],s=a.entity.name,l=a.type==="one"?"id":a.foreignColumn,d=a.type==="one"?a.relationalColumn:"id";t=t.leftJoin(s,`${s}.${l}`,`${e}.${d}`),u instanceof Object&&!Array.isArray(u)&&u!==null&&(t=pe(i,s,t,u));}return t}function fe(i,e,t,n){return !n||Object.keys(n).length===0?t:(t=pe(i,e,t,n),t.where(r=>ye(i,e,r,n)))}function vn(i,e,t,n,r){let o=q(r),u=e[t];if(o==="sqlite"&&(u!=null&&u.fields)){let a=Object.keys(u.fields),s=i.selectFrom(n);for(let l of a)s=s.select(`${n}.${l}`);return s}return i.selectFrom(n).selectAll(n)}function Sn(i,e,t,n,r){let o=q(r),u=e[t];if(o==="sqlite"&&(u!=null&&u.fields)){let a=Object.keys(u.fields),s=i.selectFrom(n);for(let l of a)s=s.select(`${n}.${l}`);return s}return i.selectFrom(n).selectAll(n)}function xn(i){if(typeof i!="object"||i===null)return false;let e=i;return "where"in e||"limit"in e||"orderBy"in e||"include"in e}function me(i,e,t,n,r,o){if(!n)return t;if(!i)throw new Error("Schema not initialized");let u=i[e];if(!u)throw new Error(`Resource not found: ${e}`);let{jsonObjectFrom:a,jsonArrayFrom:s}=r;for(let l of Object.keys(n)){if(!u.relations[l])throw new Error(`Relation ${l} not found in resource ${e}`);let d=u.relations[l],c=d.entity.name,p=n[l],y=d.type==="one"?"id":d.foreignColumn,m=d.type==="one"?d.relationalColumn:"id",f=d.type==="one"?a:s,T=xn(p)?p:null,g=T==null?void 0:T.include;t=t.select(h=>{let R=`${c}_meta`,b=Sn(h,i,c,c,o).whereRef(`${c}.${y}`,"=",`${e}.${m}`).select(v=>a(vn(v,i,c,R,o).whereRef(`${R}.id`,"=",`${c}.id`)).as("_meta"));if(T!=null&&T.where&&(b=fe(i,c,b,T.where)),T!=null&&T.orderBy)for(let v of T.orderBy)b=b.orderBy(`${c}.${v.key}`,v.direction);return (T==null?void 0:T.limit)!==void 0&&(b=b.limit(T.limit)),g&&Object.keys(g).length>0&&(b=me(i,c,b,g,r,o)),f(b).as(l)});}return t}var Ve=class i extends J{db;dialectHelpers;schema;logger;server;mutationStack=[];constructor(e,t,n,r){super(),this.isKyselyLike(e)?this.db=e:this.db=new kysely.Kysely({dialect:new kysely.PostgresDialect({pool:e})}),this.dialectHelpers=nt(this.db),this.schema=t,this.logger=n,this.server=r,this.rawInsert=this.rawInsert.bind(this),this.rawUpdate=this.rawUpdate.bind(this);}async init(e,t,n){this.schema=e,this.logger=t,this.server=n,await at(this.db,e,t);}selectMetaColumns(e,t,n){var u;let r=q(this.db),o=(u=this.schema)==null?void 0:u[t];if(r==="sqlite"&&(o!=null&&o.fields)){let a=Object.keys(o.fields),s=e.selectFrom(n);for(let l of a)s=s.select(`${n}.${l}`);return s}return e.selectFrom(n).selectAll(n)}async rawFindById(e,t,n){if(!this.schema)throw new Error("Schema not initialized");let r=`${e}_meta`,o=await this.db.selectFrom(e).where("id","=",t).selectAll(e).select(s=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(s,e,r).whereRef(`${r}.id`,"=",`${e}.id`)).as("_meta"));o=me(this.schema,e,o,n,this.dialectHelpers,this.db);let u=await o.executeTakeFirst();if(!u)return;let a=this.parseRelationalJsonStrings(u,e);return this.convertToMaterializedLiveType(a,e)}async findOne(e,t,n){let r=await this.rawFindById(e.name,t,n==null?void 0:n.include);if(r)return x(r)}async get(e){if(!this.schema)throw new Error("Schema not initialized");let{resource:t,where:n,include:r,limit:o,sort:u}=e,a=`${t}_meta`,s=this.db.selectFrom(t).selectAll(t).select(d=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(d,t,a).whereRef(`${a}.id`,"=",`${t}.id`)).as("_meta"));s=fe(this.schema,t,s,n),s=me(this.schema,t,s,r,this.dialectHelpers,this.db),o!==void 0&&(s=s.limit(o)),u!==void 0&&u.forEach(d=>{s=s.orderBy(d.key,d.direction);});let l=await s.execute();return l.length===0?[]:l.map(d=>{let c=this.parseRelationalJsonStrings(d,t);return this.convertToMaterializedLiveType(c,t)})}async find(e,t){return (await this.get({resource:e.name,where:t==null?void 0:t.where,include:t==null?void 0:t.include,limit:t==null?void 0:t.limit,sort:t==null?void 0:t.sort})).map(r=>x(r))}async rawInsert(e,t,n,r,o){var f,T,g,h,R,b,v;let u=(T=(f=this.server)==null?void 0:f.router)==null?void 0:T.getHooks(e),a=(g=this.schema)==null?void 0:g[e],[s,l]=((h=a==null?void 0:a.mergeMutation)==null?void 0:h.call(a,"set",n.value,void 0))??[n,n.value];if(!l)return {data:n,acceptedValues:null};let d=s,c={...d,value:{...d.value,id:{value:t}}};if(u!=null&&u.beforeInsert){let M=x(c);M.id=t;let w=await u.beforeInsert({ctx:o,value:M,rawValue:c,db:this});w&&(d=w);}let p={},y={};for(let[M,w]of Object.entries(d.value)){let A=(R=w._meta)==null?void 0:R.timestamp;if(!A)continue;let L=(v=(b=a==null?void 0:a.fields[M])==null?void 0:b.getStorageFieldType)==null?void 0:v.call(b);(L==null?void 0:L.type)==="jsonb"||(L==null?void 0:L.type)==="json"?p[M]=JSON.stringify(w.value):p[M]=w.value,y[M]=A;}await this.db.insertInto(e).values({...p,id:t}).execute(),await this.db.insertInto(`${e}_meta`).values({...y,id:t}).execute();let m=this.buildMutation(e,t,"INSERT",d,r);if(m&&this.trackMutation(m,d),u!=null&&u.afterInsert){let M={...d,value:{...d.value,id:{value:t}}},w=x(M);w.id=t,await u.afterInsert({ctx:o,value:w,rawValue:M,db:this});}return {data:d,acceptedValues:l}}async rawUpdate(e,t,n,r,o){var T,g,h,R,b,v,M;let u=(g=(T=this.server)==null?void 0:T.router)==null?void 0:g.getHooks(e),a=(h=this.schema)==null?void 0:h[e],s=await this.rawFindById(e,t),[l,d]=((R=a==null?void 0:a.mergeMutation)==null?void 0:R.call(a,"set",n.value,s))??[n,n.value];if(!d)return {data:n,acceptedValues:null};let c=l,p={...c,value:{...c.value,id:{value:t}}};if(u!=null&&u.beforeUpdate){let w=x(p);w.id=t;let A;if(s){let j={...s,value:{...s.value,id:{value:t}}};A=x(j),A.id=t;}let L=await u.beforeUpdate({ctx:o,value:w,rawValue:p,previousValue:A,previousRawValue:s,db:this});L&&(c=L);}let y={},m={};for(let[w,A]of Object.entries(c.value)){let L=(b=A._meta)==null?void 0:b.timestamp;if(!L)continue;let j=(M=(v=a==null?void 0:a.fields[w])==null?void 0:v.getStorageFieldType)==null?void 0:M.call(v);(j==null?void 0:j.type)==="jsonb"||(j==null?void 0:j.type)==="json"?y[w]=JSON.stringify(A.value):y[w]=A.value,m[w]=L;}if(Object.keys(y).length===0)return {data:c,acceptedValues:d};await Promise.all([this.db.updateTable(e).set(y).where("id","=",t).execute(),this.db.insertInto(`${e}_meta`).values({...m,id:t}).onConflict(w=>w.column("id").doUpdateSet(m)).execute()]);let f=this.buildMutation(e,t,"UPDATE",c,r);if(f){let w=await this.rawFindById(e,t);w&&this.trackMutation(f,w);}if(u!=null&&u.afterUpdate){let w=await this.rawFindById(e,t);if(w){let A={...w,value:{...w.value,id:{value:t}}},L=x(A);L.id=t;let j;if(s){let ot={...s,value:{...s.value,id:{value:t}}};j=x(ot),j.id=t;}await u.afterUpdate({ctx:o,value:L,rawValue:A,previousValue:j,previousRawValue:s,db:this});}}return {data:c,acceptedValues:d}}async transaction(e){if(!this.schema)throw new Error("Schema not initialized");if(this.db.isTransaction){let o=Math.random().toString(36).substring(2,15),u=this.mutationStack,a=[];this.mutationStack=a;let s=await this.db.savepoint(o).execute(),l=false,d=false;try{return await e({trx:this,commit:async()=>{await s.releaseSavepoint(o).execute(),l=!0,u.push(...a);},rollback:async()=>{await s.rollbackToSavepoint(o).execute(),d=!0,a.length=0;}}).then(c=>s.isCommitted||s.isRolledBack||l||d?c:s.releaseSavepoint(o).execute().then(()=>(u.push(...a),c)))}catch(c){throw d||await s.rollbackToSavepoint(o).execute().catch(()=>{}),a.length=0,c}finally{this.mutationStack=u;}}let t=[],n=this.mutationStack;this.mutationStack=t;let r=await this.db.startTransaction().execute();try{let o=new i(r,this.schema,this.logger,this.server);return o.mutationStack=t,await e({trx:o,commit:async()=>{await r.commit().execute(),this.notifyMutations(t);},rollback:async()=>{await r.rollback().execute(),t.length=0;}}).then(u=>r.isCommitted||r.isRolledBack?u:r.commit().execute().then(()=>(this.notifyMutations(t),u)))}catch(o){throw await r.rollback().execute(),t.length=0,o}finally{this.mutationStack=n;}}get internalDB(){return this.db}isRelationalField(e,t){var r;if(!this.schema)return false;let n=this.schema[e];return !!((r=n==null?void 0:n.relations)!=null&&r[t])}parseRelationalJsonStrings(e,t){var o,u;if(q(this.db)!=="sqlite"||typeof e!="object"||e===null||e instanceof Date)return e;if(Array.isArray(e))return e.map(a=>this.parseRelationalJsonStrings(a,t));let r={};for(let[a,s]of Object.entries(e))if(a==="_meta"&&typeof s=="string")if(s.startsWith("{")&&s.endsWith("}")||s.startsWith("[")&&s.endsWith("]"))try{r[a]=JSON.parse(s);}catch{r[a]=s;}else r[a]=s;else if(this.isRelationalField(t,a))if(typeof s=="string")if(s.startsWith("{")&&s.endsWith("}")||s.startsWith("[")&&s.endsWith("]"))try{let l=JSON.parse(s);if(this.schema){let d=this.schema[t],c=(o=d==null?void 0:d.relations)==null?void 0:o[a];if(c){let p=c.entity.name;r[a]=this.parseRelationalJsonStrings(l,p);}else r[a]=l;}else r[a]=l;}catch{r[a]=s;}else r[a]=s;else if(typeof s=="object"&&s!==null&&!Array.isArray(s))if(this.schema){let l=this.schema[t],d=(u=l==null?void 0:l.relations)==null?void 0:u[a];if(d){let c=d.entity.name;r[a]=this.parseRelationalJsonStrings(s,c);}else r[a]=s;}else r[a]=s;else Array.isArray(s)?r[a]=s.map(l=>{var d,c;if(typeof l=="string")try{let p=JSON.parse(l);if(this.schema){let y=this.schema[t],m=(d=y==null?void 0:y.relations)==null?void 0:d[a];if(m){let f=m.entity.name;return this.parseRelationalJsonStrings(p,f)}}return p}catch{return l}if(typeof l=="object"&&l!==null&&this.schema){let p=this.schema[t],y=(c=p==null?void 0:p.relations)==null?void 0:c[a];if(y){let m=y.entity.name;return this.parseRelationalJsonStrings(l,m)}}return l}):r[a]=s;else r[a]=s;return r}convertToMaterializedLiveType(e,t){var r;let n=(r=this.schema)==null?void 0:r[t];return {value:Object.entries(e).reduce((o,[u,a])=>{var c,p,y,m,f,T,g,h,R;if(u==="_meta")return o;let s=(p=(c=n==null?void 0:n.fields[u])==null?void 0:c.getStorageFieldType)==null?void 0:p.call(c),l=(s==null?void 0:s.type)==="jsonb"||(s==null?void 0:s.type)==="json",d=(n==null?void 0:n.relations)&&u in n.relations;if(u==="id")o[u]={value:a};else if(l)o[u]={value:a,_meta:{timestamp:(y=e==null?void 0:e._meta)==null?void 0:y[u]}};else if(d){let b=n.relations[u].entity,v=(b==null?void 0:b.name)??t;Array.isArray(a)?o[u]={value:a.map(M=>this.convertToMaterializedLiveType(M,v)),_meta:{timestamp:(m=e==null?void 0:e._meta)==null?void 0:m[u],relation:true}}:a!==null&&typeof a=="object"?o[u]={...this.convertToMaterializedLiveType(a,v),_meta:{timestamp:(f=e==null?void 0:e._meta)==null?void 0:f[u],relation:true}}:o[u]={value:a,_meta:{timestamp:(T=e==null?void 0:e._meta)==null?void 0:T[u],relation:true}};}else Array.isArray(a)?o[u]={value:a,_meta:{timestamp:(g=e==null?void 0:e._meta)==null?void 0:g[u]}}:typeof a=="object"&&a!==null&&!(a instanceof Date)?o[u]={value:a,_meta:{timestamp:(h=e==null?void 0:e._meta)==null?void 0:h[u]}}:o[u]={value:a,_meta:{timestamp:(R=e==null?void 0:e._meta)==null?void 0:R[u]}};return o},{})}}isKyselyLike(e){if(e instanceof kysely.Kysely)return true;if(!e||typeof e!="object")return false;let t=e,n=typeof t.selectFrom=="function",r=typeof t.startTransaction=="function",o=typeof t.savepoint=="function",u=typeof t.isTransaction=="boolean"||typeof t.isTransaction=="function";return n&&r||o&&u}buildMutation(e,t,n,r,o){var a;let u={};for(let[s,l]of Object.entries(r.value)){if(s==="id")continue;let d=(a=l._meta)==null?void 0:a.timestamp;d&&(u[s]={value:l.value,_meta:{timestamp:d}});}return Object.keys(u).length===0?null:{id:o??se(),type:"MUTATE",resource:e,resourceId:t,procedure:n,payload:u}}trackMutation(e,t){this.db.isTransaction?this.mutationStack.push({mutation:e,entityData:t}):this.notifyMutations([e],t);}notifyMutations(e,t){if(this.server)if(t!==void 0){let n=e;for(let r of n)this.server.notifySubscribers(r,t);}else {let n=e;for(let{mutation:r,entityData:o}of n)this.server.notifySubscribers(r,o);}}};var Ne=class i{router;storage;schema;middlewares=new Set;logger;contextProvider;queryEngine;constructor(e){var t;this.router=e.router,this.storage=e.storage,this.schema=e.schema,this.logger=_e({level:e.logLevel??Q.INFO}),(t=e.middlewares)==null||t.forEach(n=>{this.middlewares.add(n);}),this.storage.init(this.schema,this.logger,this),this.contextProvider=e.contextProvider,this.queryEngine=new ue({router:{get:async(n,r)=>{var c;let{headers:o,cookies:u,queryParams:a,context:s}=(r==null?void 0:r.context)??{};if(!(r!=null&&r.batcher))throw new Error("Batcher is required");let l={...n,type:"QUERY",headers:o,cookies:u,queryParams:a,context:s},d=await((c=this.router.routes[n.resource])==null?void 0:c.handleQuery({req:l,batcher:r.batcher}));return (d==null?void 0:d.data)??[]},incrementQueryStep:(n,r={})=>{var a;let o=(a=this.router.routes[n.query.resource])==null?void 0:a.getAuthorizationClause({...n.query,type:"QUERY",headers:r.headers,cookies:r.cookies,queryParams:r.queryParams,context:r.context});if(typeof o=="boolean"&&!o)throw new Error("Not authorized");let u=z(n.query.where,typeof o=="object"?o:void 0);return {...n,query:{...n.query,where:u}}}},storage:this.storage,schema:this.schema,logger:this.logger});}static create(e){return new i(e)}handleQuery(e){return this.wrapInMiddlewares(async t=>{let{headers:n,cookies:r,queryParams:o,context:u,...a}=t,s={headers:n,cookies:r,queryParams:o,context:u},l=e.subscription?this.queryEngine.subscribe(a,c=>{var p;(p=e.subscription)==null||p.call(e,c);},s):void 0;return {data:await this.queryEngine.get(a,{context:s}),unsubscribe:l}})(e.req)}async handleMutation(e){return await this.wrapInMiddlewares(async n=>{let r=this.router.routes[n.resource];if(!r)throw new Error("Invalid resource");return r.handleMutation({req:n,db:this.storage,schema:this.schema})})(e.req)}async handleCustomQuery(e){let t=await this.wrapInMiddlewares(async p=>{let y=this.router.routes[p.resource];if(!y)throw new Error("Invalid resource");return y.handleCustomQuery({req:p,db:this.storage,schema:this.schema})})(e.req);if(!(typeof t=="object"&&t!==null&&"buildQueryRequest"in t&&typeof t.buildQueryRequest=="function")){if(e.subscription)throw new Error("Subscriptions require custom queries to return a QueryBuilder");return t}let{headers:r,cookies:o,queryParams:u,context:a}=e.req,s={headers:r,cookies:o,queryParams:u,context:a},l=t.buildQueryRequest(),d=e.subscription?this.queryEngine.subscribe(l,p=>{var y;(y=e.subscription)==null||y.call(e,p);},s):void 0,c=await this.queryEngine.get(l,{context:s});return e.subscription?{data:c,unsubscribe:d,query:l}:c.map(p=>x(p))}use(e){return this.middlewares.add(e),this}context(e){return this.contextProvider=e,this}notifySubscribers(e,t){this.queryEngine.handleMutation(e,t);}wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((n,r)=>o=>r({req:o,next:n}),e)(t)}},bi=Ne.create;exports.Route=Ae;exports.RouteFactory=Ce;exports.Router=Le;exports.SQLStorage=Ve;exports.Server=Ne;exports.Storage=J;exports.createServerDB=H;exports.expressAdapter=Nr;exports.routeFactory=Wr;exports.router=zr;exports.server=bi;
|
|
12
|
+
`.execute(i);}catch(a){G(a)||r==null||r.warn("Could not add foreign key constraint",e,t,n,a);}}async function bn(i,e,t,n){for(let{tableName:r,columnName:o,references:u}of e){let s=t.find(d=>d.name===r),a=s==null?void 0:s.columns.find(d=>d.name===o),[c]=u.split(".");s&&a&&Z(t,c)&&await ot(i,r,o,u,n);}}async function Sn(i,e,t,n){for(let[r,o]of Object.entries(e)){let u=`${r}_meta`,s=t.find(a=>a.name===u);if(s)for(let[a,c]of Object.entries(o.fields)){let d=c.getStorageFieldType(),l=s.columns.find(p=>p.name===a);d.primary&&l&&Z(t,r)&&await ot(i,u,a,`${r}.${a}`,n);}}}async function ut(i,e,t){let n=q(i),r=await i.introspection.getTables(),o=[];await fn(i,e,n,t);for(let[s,a]of Object.entries(e)){let c=r.find(p=>p.name===s),d=r.find(p=>p.name===`${s}_meta`),l=hn(a,c,r,o,s);if(c)for(let[p,y]of Object.entries(a.fields)){let m=c.columns.find(g=>g.name===p),f=y.getStorageFieldType(),h=Oe(f,n);m&&m.dataType!==h&&(t==null||t.warn("Column type mismatch:",p,"expected to have type:",h,"but has type:",m.dataType));}!c&&l.length>0?await Tn(i,s,l,r,n,t):c&&await gn(i,s,l,r,o,n,t),await Rn(i,s,a,d,r,t);}let u=await i.introspection.getTables();await bn(i,o,u,t),await Sn(i,e,u,t);}function ye(i,e,t,n){if(!i)throw new Error("Schema not initialized");let r=i[e];if(!r)throw new Error("Resource not found");let o=n.$or,u=n.$and;return (o?t.or:t.and)(o?n.$or.map(s=>ye(i,e,t,s)):u?n.$and.map(s=>ye(i,e,t,s)):Object.entries(n).map(([s,a])=>{var c,d;if(r.fields[s])return (a==null?void 0:a.$eq)!==void 0?t(`${e}.${s}`,a.$eq===null?"is":"=",a.$eq):(a==null?void 0:a.$in)!==void 0?t(`${e}.${s}`,"in",a.$in):(a==null?void 0:a.$not)!==void 0?((c=a==null?void 0:a.$not)==null?void 0:c.$in)!==void 0?t(`${e}.${s}`,"not in",a.$not.$in):((d=a==null?void 0:a.$not)==null?void 0:d.$eq)!==void 0?t(`${e}.${s}`,a.$not.$eq===null?"is not":"!=",a.$not.$eq):t(`${e}.${s}`,a.$not===null?"is not":"!=",a.$not):(a==null?void 0:a.$gt)!==void 0?t(`${e}.${s}`,">",a.$gt):(a==null?void 0:a.$gte)!==void 0?t(`${e}.${s}`,">=",a.$gte):(a==null?void 0:a.$lt)!==void 0?t(`${e}.${s}`,"<",a.$lt):(a==null?void 0:a.$lte)!==void 0?t(`${e}.${s}`,"<=",a.$lte):t(`${e}.${s}`,a===null?"is":"=",a);if(r.relations[s]){let l=r.relations[s],p=l.entity.name;return l.type==="many"?t.exists(fe(i,p,t.selectFrom(p).select("id").whereRef(l.foreignColumn,"=",`${e}.id`),a)):ye(i,p,t,a)}return null}).filter(Boolean))}function pe(i,e,t,n){let r=i[e];if(!r)throw new Error("Resource not found");if(!n)return t;if(n.$and){for(let o of n.$and)t=pe(i,e,t,o);return t}else if(n.$or){for(let o of n.$or)t=pe(i,e,t,o);return t}for(let[o,u]of Object.entries(n)){if(!r.relations[o])continue;let s=r.relations[o],a=s.entity.name,c=s.type==="one"?"id":s.foreignColumn,d=s.type==="one"?s.relationalColumn:"id";t=t.leftJoin(a,`${a}.${c}`,`${e}.${d}`),u instanceof Object&&!Array.isArray(u)&&u!==null&&(t=pe(i,a,t,u));}return t}function fe(i,e,t,n){return !n||Object.keys(n).length===0?t:(t=pe(i,e,t,n),t.where(r=>ye(i,e,r,n)))}function vn(i,e,t,n,r){let o=q(r),u=e[t];if(o==="sqlite"&&(u!=null&&u.fields)){let s=Object.keys(u.fields),a=i.selectFrom(n);for(let c of s)a=a.select(`${n}.${c}`);return a}return i.selectFrom(n).selectAll(n)}function xn(i,e,t,n,r){let o=q(r),u=e[t];if(o==="sqlite"&&(u!=null&&u.fields)){let s=Object.keys(u.fields),a=i.selectFrom(n);for(let c of s)a=a.select(`${n}.${c}`);return a}return i.selectFrom(n).selectAll(n)}function wn(i){if(typeof i!="object"||i===null)return false;let e=i;return "where"in e||"limit"in e||"orderBy"in e||"include"in e}function me(i,e,t,n,r,o){if(!n)return t;if(!i)throw new Error("Schema not initialized");let u=i[e];if(!u)throw new Error(`Resource not found: ${e}`);let{jsonObjectFrom:s,jsonArrayFrom:a}=r;for(let c of Object.keys(n)){if(!u.relations[c])throw new Error(`Relation ${c} not found in resource ${e}`);let d=u.relations[c],l=d.entity.name,p=n[c],y=d.type==="one"?"id":d.foreignColumn,m=d.type==="one"?d.relationalColumn:"id",f=d.type==="one"?s:a,h=wn(p)?p:null,g=h==null?void 0:h.include;t=t.select(T=>{let R=`${l}_meta`,b=xn(T,i,l,l,o).whereRef(`${l}.${y}`,"=",`${e}.${m}`).select(S=>s(vn(S,i,l,R,o).whereRef(`${R}.id`,"=",`${l}.id`)).as("_meta"));if(h!=null&&h.where&&(b=fe(i,l,b,h.where)),h!=null&&h.orderBy)for(let S of h.orderBy)b=b.orderBy(`${l}.${S.key}`,S.direction);return (h==null?void 0:h.limit)!==void 0&&(b=b.limit(h.limit)),g&&Object.keys(g).length>0&&(b=me(i,l,b,g,r,o)),f(b).as(c)});}return t}var Ve=class i extends J{db;dialectHelpers;schema;logger;server;mutationStack=[];constructor(e,t,n,r){super(),this.isKyselyLike(e)?this.db=e:this.db=new kysely.Kysely({dialect:new kysely.PostgresDialect({pool:e})}),this.dialectHelpers=at(this.db),this.schema=t,this.logger=n,this.server=r,this.rawInsert=this.rawInsert.bind(this),this.rawUpdate=this.rawUpdate.bind(this);}async init(e,t,n){this.schema=e,this.logger=t,this.server=n,await ut(this.db,e,t);}selectMetaColumns(e,t,n){var u;let r=q(this.db),o=(u=this.schema)==null?void 0:u[t];if(r==="sqlite"&&(o!=null&&o.fields)){let s=Object.keys(o.fields),a=e.selectFrom(n);for(let c of s)a=a.select(`${n}.${c}`);return a}return e.selectFrom(n).selectAll(n)}async rawFindById(e,t,n){if(!this.schema)throw new Error("Schema not initialized");let r=`${e}_meta`,o=await this.db.selectFrom(e).where("id","=",t).selectAll(e).select(a=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(a,e,r).whereRef(`${r}.id`,"=",`${e}.id`)).as("_meta"));o=me(this.schema,e,o,n,this.dialectHelpers,this.db);let u=await o.executeTakeFirst();if(!u)return;let s=this.parseRelationalJsonStrings(u,e);return this.convertToMaterializedLiveType(s,e)}async findOne(e,t,n){let r=await this.rawFindById(e.name,t,n==null?void 0:n.include);if(r)return x(r)}async get(e){if(!this.schema)throw new Error("Schema not initialized");let{resource:t,where:n,include:r,limit:o,sort:u}=e,s=`${t}_meta`,a=this.db.selectFrom(t).selectAll(t).select(d=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(d,t,s).whereRef(`${s}.id`,"=",`${t}.id`)).as("_meta"));a=fe(this.schema,t,a,n),a=me(this.schema,t,a,r,this.dialectHelpers,this.db),o!==void 0&&(a=a.limit(o)),u!==void 0&&u.forEach(d=>{a=a.orderBy(d.key,d.direction);});let c=await a.execute();return c.length===0?[]:c.map(d=>{let l=this.parseRelationalJsonStrings(d,t);return this.convertToMaterializedLiveType(l,t)})}async find(e,t){return (await this.get({resource:e.name,where:t==null?void 0:t.where,include:t==null?void 0:t.include,limit:t==null?void 0:t.limit,sort:t==null?void 0:t.sort})).map(r=>x(r))}async rawInsert(e,t,n,r,o){var f,h,g,T,R,b,S;let u=(h=(f=this.server)==null?void 0:f.router)==null?void 0:h.getHooks(e),s=(g=this.schema)==null?void 0:g[e],[a,c]=((T=s==null?void 0:s.mergeMutation)==null?void 0:T.call(s,"set",n.value,void 0))??[n,n.value];if(!c)return {data:n,acceptedValues:null};let d=a,l={...d,value:{...d.value,id:{value:t}}};if(u!=null&&u.beforeInsert){let I=x(l);I.id=t;let w=await u.beforeInsert({ctx:o,value:I,rawValue:l,db:this});w&&(d=w);}let p={},y={};for(let[I,w]of Object.entries(d.value)){let C=(R=w._meta)==null?void 0:R.timestamp;if(!C)continue;let L=(S=(b=s==null?void 0:s.fields[I])==null?void 0:b.getStorageFieldType)==null?void 0:S.call(b);(L==null?void 0:L.type)==="jsonb"||(L==null?void 0:L.type)==="json"?p[I]=JSON.stringify(w.value):p[I]=w.value,y[I]=C;}await this.db.insertInto(e).values({...p,id:t}).execute(),await this.db.insertInto(`${e}_meta`).values({...y,id:t}).execute();let m=this.buildMutation(e,t,"INSERT",d,r);if(m&&this.trackMutation(m,d),u!=null&&u.afterInsert){let I={...d,value:{...d.value,id:{value:t}}},w=x(I);w.id=t,await u.afterInsert({ctx:o,value:w,rawValue:I,db:this});}return {data:d,acceptedValues:c}}async rawUpdate(e,t,n,r,o){var h,g,T,R,b,S,I;let u=(g=(h=this.server)==null?void 0:h.router)==null?void 0:g.getHooks(e),s=(T=this.schema)==null?void 0:T[e],a=await this.rawFindById(e,t),[c,d]=((R=s==null?void 0:s.mergeMutation)==null?void 0:R.call(s,"set",n.value,a))??[n,n.value];if(!d)return {data:n,acceptedValues:null};let l=c,p={...l,value:{...l.value,id:{value:t}}};if(u!=null&&u.beforeUpdate){let w=x(p);w.id=t;let C;if(a){let j={...a,value:{...a.value,id:{value:t}}};C=x(j),C.id=t;}let L=await u.beforeUpdate({ctx:o,value:w,rawValue:p,previousValue:C,previousRawValue:a,db:this});L&&(l=L);}let y={},m={};for(let[w,C]of Object.entries(l.value)){let L=(b=C._meta)==null?void 0:b.timestamp;if(!L)continue;let j=(I=(S=s==null?void 0:s.fields[w])==null?void 0:S.getStorageFieldType)==null?void 0:I.call(S);(j==null?void 0:j.type)==="jsonb"||(j==null?void 0:j.type)==="json"?y[w]=JSON.stringify(C.value):y[w]=C.value,m[w]=L;}if(Object.keys(y).length===0)return {data:l,acceptedValues:d};await Promise.all([this.db.updateTable(e).set(y).where("id","=",t).execute(),this.db.insertInto(`${e}_meta`).values({...m,id:t}).onConflict(w=>w.column("id").doUpdateSet(m)).execute()]);let f=this.buildMutation(e,t,"UPDATE",l,r);if(f){let w=await this.rawFindById(e,t);w&&this.trackMutation(f,w);}if(u!=null&&u.afterUpdate){let w=await this.rawFindById(e,t);if(w){let C={...w,value:{...w.value,id:{value:t}}},L=x(C);L.id=t;let j;if(a){let lt={...a,value:{...a.value,id:{value:t}}};j=x(lt),j.id=t;}await u.afterUpdate({ctx:o,value:L,rawValue:C,previousValue:j,previousRawValue:a,db:this});}}return {data:l,acceptedValues:d}}async transaction(e){if(!this.schema)throw new Error("Schema not initialized");if(this.db.isTransaction){let o=Math.random().toString(36).substring(2,15),u=this.mutationStack,s=[];this.mutationStack=s;let a=await this.db.savepoint(o).execute(),c=false,d=false;try{return await e({trx:this,commit:async()=>{await a.releaseSavepoint(o).execute(),c=!0,u.push(...s);},rollback:async()=>{await a.rollbackToSavepoint(o).execute(),d=!0,s.length=0;}}).then(l=>a.isCommitted||a.isRolledBack||c||d?l:a.releaseSavepoint(o).execute().then(()=>(u.push(...s),l)))}catch(l){throw d||await a.rollbackToSavepoint(o).execute().catch(()=>{}),s.length=0,l}finally{this.mutationStack=u;}}let t=[],n=this.mutationStack;this.mutationStack=t;let r=await this.db.startTransaction().execute();try{let o=new i(r,this.schema,this.logger,this.server);return o.mutationStack=t,await e({trx:o,commit:async()=>{await r.commit().execute(),this.notifyMutations(t);},rollback:async()=>{await r.rollback().execute(),t.length=0;}}).then(u=>r.isCommitted||r.isRolledBack?u:r.commit().execute().then(()=>(this.notifyMutations(t),u)))}catch(o){throw await r.rollback().execute(),t.length=0,o}finally{this.mutationStack=n;}}get internalDB(){return this.db}isRelationalField(e,t){var r;if(!this.schema)return false;let n=this.schema[e];return !!((r=n==null?void 0:n.relations)!=null&&r[t])}parseRelationalJsonStrings(e,t){var o,u;if(q(this.db)!=="sqlite"||typeof e!="object"||e===null||e instanceof Date)return e;if(Array.isArray(e))return e.map(s=>this.parseRelationalJsonStrings(s,t));let r={};for(let[s,a]of Object.entries(e))if(s==="_meta"&&typeof a=="string")if(a.startsWith("{")&&a.endsWith("}")||a.startsWith("[")&&a.endsWith("]"))try{r[s]=JSON.parse(a);}catch{r[s]=a;}else r[s]=a;else if(this.isRelationalField(t,s))if(typeof a=="string")if(a.startsWith("{")&&a.endsWith("}")||a.startsWith("[")&&a.endsWith("]"))try{let c=JSON.parse(a);if(this.schema){let d=this.schema[t],l=(o=d==null?void 0:d.relations)==null?void 0:o[s];if(l){let p=l.entity.name;r[s]=this.parseRelationalJsonStrings(c,p);}else r[s]=c;}else r[s]=c;}catch{r[s]=a;}else r[s]=a;else if(typeof a=="object"&&a!==null&&!Array.isArray(a))if(this.schema){let c=this.schema[t],d=(u=c==null?void 0:c.relations)==null?void 0:u[s];if(d){let l=d.entity.name;r[s]=this.parseRelationalJsonStrings(a,l);}else r[s]=a;}else r[s]=a;else Array.isArray(a)?r[s]=a.map(c=>{var d,l;if(typeof c=="string")try{let p=JSON.parse(c);if(this.schema){let y=this.schema[t],m=(d=y==null?void 0:y.relations)==null?void 0:d[s];if(m){let f=m.entity.name;return this.parseRelationalJsonStrings(p,f)}}return p}catch{return c}if(typeof c=="object"&&c!==null&&this.schema){let p=this.schema[t],y=(l=p==null?void 0:p.relations)==null?void 0:l[s];if(y){let m=y.entity.name;return this.parseRelationalJsonStrings(c,m)}}return c}):r[s]=a;else r[s]=a;return r}convertToMaterializedLiveType(e,t){var r;let n=(r=this.schema)==null?void 0:r[t];return {value:Object.entries(e).reduce((o,[u,s])=>{var l,p,y,m,f,h,g,T,R;if(u==="_meta")return o;let a=(p=(l=n==null?void 0:n.fields[u])==null?void 0:l.getStorageFieldType)==null?void 0:p.call(l),c=(a==null?void 0:a.type)==="jsonb"||(a==null?void 0:a.type)==="json",d=(n==null?void 0:n.relations)&&u in n.relations;if(u==="id")o[u]={value:s};else if(c)o[u]={value:s,_meta:{timestamp:(y=e==null?void 0:e._meta)==null?void 0:y[u]}};else if(d){let b=n.relations[u].entity,S=(b==null?void 0:b.name)??t;Array.isArray(s)?o[u]={value:s.map(I=>this.convertToMaterializedLiveType(I,S)),_meta:{timestamp:(m=e==null?void 0:e._meta)==null?void 0:m[u],relation:true}}:s!==null&&typeof s=="object"?o[u]={...this.convertToMaterializedLiveType(s,S),_meta:{timestamp:(f=e==null?void 0:e._meta)==null?void 0:f[u],relation:true}}:o[u]={value:s,_meta:{timestamp:(h=e==null?void 0:e._meta)==null?void 0:h[u],relation:true}};}else Array.isArray(s)?o[u]={value:s,_meta:{timestamp:(g=e==null?void 0:e._meta)==null?void 0:g[u]}}:typeof s=="object"&&s!==null&&!(s instanceof Date)?o[u]={value:s,_meta:{timestamp:(T=e==null?void 0:e._meta)==null?void 0:T[u]}}:o[u]={value:s,_meta:{timestamp:(R=e==null?void 0:e._meta)==null?void 0:R[u]}};return o},{})}}isKyselyLike(e){if(e instanceof kysely.Kysely)return true;if(!e||typeof e!="object")return false;let t=e,n=typeof t.selectFrom=="function",r=typeof t.startTransaction=="function",o=typeof t.savepoint=="function",u=typeof t.isTransaction=="boolean"||typeof t.isTransaction=="function";return n&&r||o&&u}buildMutation(e,t,n,r,o){var s;let u={};for(let[a,c]of Object.entries(r.value)){if(a==="id")continue;let d=(s=c._meta)==null?void 0:s.timestamp;d&&(u[a]={value:c.value,_meta:{timestamp:d}});}return Object.keys(u).length===0?null:{id:o??se(),type:"MUTATE",resource:e,resourceId:t,procedure:n,payload:u}}trackMutation(e,t){this.db.isTransaction?this.mutationStack.push({mutation:e,entityData:t}):this.notifyMutations([e],t);}notifyMutations(e,t){if(this.server)if(t!==void 0){let n=e;for(let r of n)this.server.notifySubscribers(r,t);}else {let n=e;for(let{mutation:r,entityData:o}of n)this.server.notifySubscribers(r,o);}}};var Ne=class i{router;storage;schema;middlewares=new Set;logger;contextProvider;queryEngine;constructor(e){var t;this.router=e.router,this.storage=e.storage,this.schema=e.schema,this.logger=ke({level:e.logLevel??Q.INFO}),(t=e.middlewares)==null||t.forEach(n=>{this.middlewares.add(n);}),this.storage.init(this.schema,this.logger,this),this.contextProvider=e.contextProvider,this.queryEngine=new ue({router:{get:async(n,r)=>{var l;let{headers:o,cookies:u,queryParams:s,context:a}=(r==null?void 0:r.context)??{};if(!(r!=null&&r.batcher))throw new Error("Batcher is required");let c={...n,type:"QUERY",headers:o,cookies:u,queryParams:s,context:a},d=await((l=this.router.routes[n.resource])==null?void 0:l.handleQuery({req:c,batcher:r.batcher}));return (d==null?void 0:d.data)??[]},incrementQueryStep:(n,r={})=>{var s;let o=(s=this.router.routes[n.query.resource])==null?void 0:s.getAuthorizationClause({...n.query,type:"QUERY",headers:r.headers,cookies:r.cookies,queryParams:r.queryParams,context:r.context});if(typeof o=="boolean"&&!o)throw new Error("Not authorized");let u=K(n.query.where,typeof o=="object"?o:void 0);return {...n,query:{...n.query,where:u}}}},storage:this.storage,schema:this.schema,logger:this.logger});}static create(e){return new i(e)}handleQuery(e){return this.wrapInMiddlewares(async t=>{let{headers:n,cookies:r,queryParams:o,context:u,...s}=t,a={headers:n,cookies:r,queryParams:o,context:u},c=e.subscription?this.queryEngine.subscribe(s,l=>{var p;(p=e.subscription)==null||p.call(e,l);},a):void 0;return {data:await this.queryEngine.get(s,{context:a}),unsubscribe:c}})(e.req)}async handleMutation(e){return await this.wrapInMiddlewares(async n=>{let r=this.router.routes[n.resource];if(!r)throw new Error("Invalid resource");return r.handleMutation({req:n,db:this.storage,schema:this.schema})})(e.req)}async handleCustomQuery(e){let t=await this.wrapInMiddlewares(async p=>{let y=this.router.routes[p.resource];if(!y)throw new Error("Invalid resource");return y.handleCustomQuery({req:p,db:this.storage,schema:this.schema})})(e.req);if(!(typeof t=="object"&&t!==null&&"buildQueryRequest"in t&&typeof t.buildQueryRequest=="function")){if(e.subscription)throw new Error("Subscriptions require custom queries to return a QueryBuilder");return t}let{headers:r,cookies:o,queryParams:u,context:s}=e.req,a={headers:r,cookies:o,queryParams:u,context:s},c=t.buildQueryRequest(),d=e.subscription?this.queryEngine.subscribe(c,p=>{var y;(y=e.subscription)==null||y.call(e,p);},a):void 0,l=await this.queryEngine.get(c,{context:a});return e.subscription?{data:l,unsubscribe:d,query:c}:l.map(p=>x(p))}use(e){return this.middlewares.add(e),this}context(e){return this.contextProvider=e,this}notifySubscribers(e,t){this.queryEngine.handleMutation(e,t);}wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((n,r)=>o=>r({req:o,next:n}),e)(t)}},Si=Ne.create;exports.ProcedureRoute=Ae;exports.Route=Ce;exports.RouteFactory=je;exports.Router=Le;exports.SQLStorage=Ve;exports.Server=Ne;exports.Storage=J;exports.createServerDB=k;exports.expressAdapter=Nr;exports.routeFactory=Ur;exports.router=Kr;exports.server=Si;
|
package/dist/server.d.cts
CHANGED
|
@@ -216,7 +216,9 @@ declare function createServerDB<TSchema extends Schema<any>>(storage: Storage, s
|
|
|
216
216
|
/** biome-ignore-all lint/suspicious/noExplicitAny: false positive */
|
|
217
217
|
/** biome-ignore-all lint/style/noNonNullAssertion: false positive */
|
|
218
218
|
|
|
219
|
-
type
|
|
219
|
+
type AnyProcedureRoute = ProcedureRoute<Middleware<any>, Record<string, any>, Record<string, any>, any>;
|
|
220
|
+
type AnyRouteOrProcedure = AnyRoute | AnyProcedureRoute;
|
|
221
|
+
type RouteRecord = Record<string, AnyRouteOrProcedure>;
|
|
220
222
|
declare class Router<TRoutes extends RouteRecord> {
|
|
221
223
|
readonly routes: TRoutes;
|
|
222
224
|
readonly hooksRegistry: Map<string, Hooks<any>>;
|
|
@@ -226,7 +228,7 @@ declare class Router<TRoutes extends RouteRecord> {
|
|
|
226
228
|
}): Router<TRoutes>;
|
|
227
229
|
getHooks(resourceName: string): Hooks<any> | undefined;
|
|
228
230
|
}
|
|
229
|
-
declare const router: <TSchema extends Schema<any>, TRoutes extends Record<keyof TSchema, Route<any, any, any, any>>>(opts: {
|
|
231
|
+
declare const router: <TSchema extends Schema<any>, TRoutes extends Record<keyof TSchema, Route<any, any, any, any, any>> & Record<string, Route<any, any, any, any, any> | ProcedureRoute<any, any, any, any>>>(opts: {
|
|
230
232
|
schema: TSchema;
|
|
231
233
|
routes: TRoutes;
|
|
232
234
|
}) => Router<TRoutes>;
|
|
@@ -262,32 +264,31 @@ type Query<TInputValidator extends StandardSchemaV1<any, any> | never, TOutput>
|
|
|
262
264
|
}) => TOutput;
|
|
263
265
|
};
|
|
264
266
|
type Procedure<TInputValidator extends StandardSchemaV1<any, any> | never, TOutput> = Mutation<TInputValidator, TOutput> | Query<TInputValidator, TOutput>;
|
|
265
|
-
type QueryCreator = {
|
|
267
|
+
type QueryCreator<TSchema extends Schema<any> = Schema<any>> = {
|
|
266
268
|
(): {
|
|
267
269
|
handler: <TOutput>(handler: (opts: {
|
|
268
270
|
req: QueryProcedureRequest<undefined>;
|
|
269
|
-
db: ServerDB<
|
|
271
|
+
db: ServerDB<TSchema>;
|
|
270
272
|
}) => TOutput) => Query<StandardSchemaV1<any, undefined>, TOutput>;
|
|
271
273
|
};
|
|
272
274
|
<TInputValidator extends StandardSchemaV1<any, any>>(validator: TInputValidator): {
|
|
273
275
|
handler: <THandler extends (opts: {
|
|
274
276
|
req: QueryProcedureRequest<StandardSchemaV1.InferOutput<TInputValidator>>;
|
|
275
|
-
db: ServerDB<
|
|
277
|
+
db: ServerDB<TSchema>;
|
|
276
278
|
}) => any>(handler: THandler) => Query<TInputValidator, ReturnType<THandler>>;
|
|
277
279
|
};
|
|
278
280
|
};
|
|
279
|
-
|
|
280
|
-
type MutationCreator = {
|
|
281
|
+
type MutationCreator<TSchema extends Schema<any> = Schema<any>> = {
|
|
281
282
|
(): {
|
|
282
283
|
handler: <TOutput>(handler: (opts: {
|
|
283
284
|
req: MutationRequest<undefined>;
|
|
284
|
-
db: ServerDB<
|
|
285
|
+
db: ServerDB<TSchema>;
|
|
285
286
|
}) => TOutput) => Mutation<StandardSchemaV1<any, undefined>, TOutput>;
|
|
286
287
|
};
|
|
287
288
|
<TInputValidator extends StandardSchemaV1<any, any>>(validator: TInputValidator): {
|
|
288
289
|
handler: <THandler extends (opts: {
|
|
289
290
|
req: MutationRequest<StandardSchemaV1.InferOutput<TInputValidator>>;
|
|
290
|
-
db: ServerDB<
|
|
291
|
+
db: ServerDB<TSchema>;
|
|
291
292
|
}) => any>(handler: THandler) => Mutation<TInputValidator, ReturnType<THandler>>;
|
|
292
293
|
};
|
|
293
294
|
};
|
|
@@ -307,23 +308,23 @@ type Authorization<TShape extends LiveObjectAny> = {
|
|
|
307
308
|
postMutation?: MutationAuthorizationHandler<TShape>;
|
|
308
309
|
};
|
|
309
310
|
};
|
|
310
|
-
type BeforeInsertHook<TShape extends LiveObjectAny> = (opts: {
|
|
311
|
+
type BeforeInsertHook<TShape extends LiveObjectAny, TSchema extends Schema<any> = Schema<any>> = (opts: {
|
|
311
312
|
ctx?: Record<string, any>;
|
|
312
313
|
value: Simplify<InferLiveObjectWithRelationalIds<TShape>> & {
|
|
313
314
|
id: string;
|
|
314
315
|
};
|
|
315
316
|
rawValue: MaterializedLiveType<TShape>;
|
|
316
|
-
db: ServerDB<
|
|
317
|
+
db: ServerDB<TSchema>;
|
|
317
318
|
}) => Promise<MaterializedLiveType<TShape> | void> | MaterializedLiveType<TShape> | void;
|
|
318
|
-
type AfterInsertHook<TShape extends LiveObjectAny> = (opts: {
|
|
319
|
+
type AfterInsertHook<TShape extends LiveObjectAny, TSchema extends Schema<any> = Schema<any>> = (opts: {
|
|
319
320
|
ctx?: Record<string, any>;
|
|
320
321
|
value: Simplify<InferLiveObjectWithRelationalIds<TShape>> & {
|
|
321
322
|
id: string;
|
|
322
323
|
};
|
|
323
324
|
rawValue: MaterializedLiveType<TShape>;
|
|
324
|
-
db: ServerDB<
|
|
325
|
+
db: ServerDB<TSchema>;
|
|
325
326
|
}) => Promise<void> | void;
|
|
326
|
-
type BeforeUpdateHook<TShape extends LiveObjectAny> = (opts: {
|
|
327
|
+
type BeforeUpdateHook<TShape extends LiveObjectAny, TSchema extends Schema<any> = Schema<any>> = (opts: {
|
|
327
328
|
ctx?: Record<string, any>;
|
|
328
329
|
value: Simplify<InferLiveObjectWithRelationalIds<TShape>> & {
|
|
329
330
|
id: string;
|
|
@@ -333,9 +334,9 @@ type BeforeUpdateHook<TShape extends LiveObjectAny> = (opts: {
|
|
|
333
334
|
id: string;
|
|
334
335
|
};
|
|
335
336
|
previousRawValue?: MaterializedLiveType<TShape>;
|
|
336
|
-
db: ServerDB<
|
|
337
|
+
db: ServerDB<TSchema>;
|
|
337
338
|
}) => Promise<MaterializedLiveType<TShape> | void> | MaterializedLiveType<TShape> | void;
|
|
338
|
-
type AfterUpdateHook<TShape extends LiveObjectAny> = (opts: {
|
|
339
|
+
type AfterUpdateHook<TShape extends LiveObjectAny, TSchema extends Schema<any> = Schema<any>> = (opts: {
|
|
339
340
|
ctx?: Record<string, any>;
|
|
340
341
|
value: Simplify<InferLiveObjectWithRelationalIds<TShape>> & {
|
|
341
342
|
id: string;
|
|
@@ -345,47 +346,61 @@ type AfterUpdateHook<TShape extends LiveObjectAny> = (opts: {
|
|
|
345
346
|
id: string;
|
|
346
347
|
};
|
|
347
348
|
previousRawValue?: MaterializedLiveType<TShape>;
|
|
348
|
-
db: ServerDB<
|
|
349
|
+
db: ServerDB<TSchema>;
|
|
349
350
|
}) => Promise<void> | void;
|
|
350
|
-
type Hooks<TShape extends LiveObjectAny> = {
|
|
351
|
-
beforeInsert?: BeforeInsertHook<TShape>;
|
|
352
|
-
afterInsert?: AfterInsertHook<TShape>;
|
|
353
|
-
beforeUpdate?: BeforeUpdateHook<TShape>;
|
|
354
|
-
afterUpdate?: AfterUpdateHook<TShape>;
|
|
351
|
+
type Hooks<TShape extends LiveObjectAny, TSchema extends Schema<any> = Schema<any>> = {
|
|
352
|
+
beforeInsert?: BeforeInsertHook<TShape, TSchema>;
|
|
353
|
+
afterInsert?: AfterInsertHook<TShape, TSchema>;
|
|
354
|
+
beforeUpdate?: BeforeUpdateHook<TShape, TSchema>;
|
|
355
|
+
afterUpdate?: AfterUpdateHook<TShape, TSchema>;
|
|
355
356
|
};
|
|
356
|
-
declare class Route<TResourceSchema extends LiveObjectAny, TMiddleware extends Middleware<any>, TCustomMutations extends Record<string, Mutation<any, any>>, TCustomQueries extends Record<string, Query<any, any
|
|
357
|
+
declare class Route<TResourceSchema extends LiveObjectAny, TMiddleware extends Middleware<any>, TCustomMutations extends Record<string, Mutation<any, any>>, TCustomQueries extends Record<string, Query<any, any>>, TSchema extends Schema<any> = Schema<any>> {
|
|
357
358
|
readonly resourceSchema: TResourceSchema;
|
|
358
359
|
readonly middlewares: Set<TMiddleware>;
|
|
359
360
|
readonly customMutations: TCustomMutations;
|
|
360
361
|
readonly customQueries: TCustomQueries;
|
|
361
362
|
readonly authorization?: Authorization<TResourceSchema>;
|
|
362
|
-
readonly hooks?: Hooks<TResourceSchema>;
|
|
363
|
-
constructor(resourceSchema: TResourceSchema, customMutations?: TCustomMutations, customQueries?: TCustomQueries, authorization?: Authorization<TResourceSchema>, hooks?: Hooks<TResourceSchema>);
|
|
363
|
+
readonly hooks?: Hooks<TResourceSchema, TSchema>;
|
|
364
|
+
constructor(resourceSchema: TResourceSchema, customMutations?: TCustomMutations, customQueries?: TCustomQueries, authorization?: Authorization<TResourceSchema>, hooks?: Hooks<TResourceSchema, TSchema>);
|
|
364
365
|
use(...middlewares: TMiddleware[]): this;
|
|
365
366
|
withProcedures<T extends Record<string, Procedure<any, any>>>(procedureFactory: (opts: {
|
|
366
|
-
mutation:
|
|
367
|
-
query:
|
|
368
|
-
}) => T): Route<TResourceSchema, TMiddleware, { [K in keyof T as T[K] extends Mutation<any, any> ? K : never]: T[K]; } & Record<string, Mutation<any, any>>, { [K_1 in keyof T as T[K_1] extends Query<any, any> ? K_1 : never]: T[K_1]; } & Record<string, Query<any, any
|
|
367
|
+
mutation: MutationCreator<TSchema>;
|
|
368
|
+
query: QueryCreator<TSchema>;
|
|
369
|
+
}) => T): Route<TResourceSchema, TMiddleware, { [K in keyof T as T[K] extends Mutation<any, any> ? K : never]: T[K]; } & Record<string, Mutation<any, any>>, { [K_1 in keyof T as T[K_1] extends Query<any, any> ? K_1 : never]: T[K_1]; } & Record<string, Query<any, any>>, TSchema>;
|
|
369
370
|
/**
|
|
370
371
|
* @deprecated Use `withProcedures` instead
|
|
371
372
|
*/
|
|
372
373
|
withMutations<T extends Record<string, Mutation<any, any>>>(mutationFactory: (opts: {
|
|
373
374
|
mutation: typeof mutationCreator;
|
|
374
|
-
}) => T): Route<TResourceSchema, TMiddleware, { [K in keyof T as T[K] extends Mutation<any, any> ? K : never]: T[K]; } & Record<string, Mutation<any, any>>, { [K_1 in keyof T as T[K_1] extends Query<any, any> ? K_1 : never]: T[K_1]; } & Record<string, Query<any, any
|
|
375
|
-
withHooks(hooks: Hooks<TResourceSchema>): Route<TResourceSchema, TMiddleware, TCustomMutations, TCustomQueries>;
|
|
375
|
+
}) => T): Route<TResourceSchema, TMiddleware, { [K in keyof T as T[K] extends Mutation<any, any> ? K : never]: T[K]; } & Record<string, Mutation<any, any>>, { [K_1 in keyof T as T[K_1] extends Query<any, any> ? K_1 : never]: T[K_1]; } & Record<string, Query<any, any>>, TSchema>;
|
|
376
|
+
withHooks(hooks: Hooks<TResourceSchema, TSchema>): Route<TResourceSchema, TMiddleware, TCustomMutations, TCustomQueries, TSchema>;
|
|
376
377
|
getAuthorizationClause(req: QueryRequest): WhereClause<TResourceSchema> | undefined | boolean;
|
|
377
378
|
private handleSet;
|
|
378
379
|
private wrapInMiddlewares;
|
|
379
380
|
}
|
|
380
|
-
declare class
|
|
381
|
+
declare class ProcedureRoute<TMiddleware extends Middleware<any>, TCustomMutations extends Record<string, Mutation<any, any>>, TCustomQueries extends Record<string, Query<any, any>>, TSchema extends Schema<any> = Schema<any>> {
|
|
382
|
+
readonly resourceSchema: undefined;
|
|
383
|
+
readonly middlewares: Set<TMiddleware>;
|
|
384
|
+
readonly customMutations: TCustomMutations;
|
|
385
|
+
readonly customQueries: TCustomQueries;
|
|
386
|
+
constructor(customMutations?: TCustomMutations, customQueries?: TCustomQueries);
|
|
387
|
+
use(...middlewares: TMiddleware[]): this;
|
|
388
|
+
getAuthorizationClause(): undefined;
|
|
389
|
+
private wrapInMiddlewares;
|
|
390
|
+
}
|
|
391
|
+
declare class RouteFactory<TSchema extends Schema<any> = Schema<any>> {
|
|
381
392
|
private middlewares;
|
|
382
393
|
private constructor();
|
|
383
|
-
collectionRoute<T extends LiveObjectAny>(shape: T, authorization?: Authorization<T>): Route<T, Middleware<any>, Record<string, never>, Record<string, never
|
|
384
|
-
|
|
385
|
-
|
|
394
|
+
collectionRoute<T extends LiveObjectAny>(shape: T, authorization?: Authorization<T>): Route<T, Middleware<any>, Record<string, never>, Record<string, never>, TSchema>;
|
|
395
|
+
withProcedures<T extends Record<string, Procedure<any, any>>>(procedureFactory: (opts: {
|
|
396
|
+
mutation: MutationCreator<TSchema>;
|
|
397
|
+
query: QueryCreator<TSchema>;
|
|
398
|
+
}) => T): ProcedureRoute<Middleware<any>, { [K in keyof T as T[K] extends Mutation<any, any> ? K : never]: T[K]; } & Record<string, Mutation<any, any>>, { [K_1 in keyof T as T[K_1] extends Query<any, any> ? K_1 : never]: T[K_1]; } & Record<string, Query<any, any>>, TSchema>;
|
|
399
|
+
use(...middlewares: Middleware<any>[]): RouteFactory<TSchema>;
|
|
400
|
+
static create<TSchema extends Schema<any> = Schema<any>>(): RouteFactory<TSchema>;
|
|
386
401
|
}
|
|
387
402
|
declare const routeFactory: typeof RouteFactory.create;
|
|
388
|
-
type AnyRoute = Route<LiveObjectAny, Middleware<any>, Record<string, any>, Record<string, any
|
|
403
|
+
type AnyRoute = Route<LiveObjectAny, Middleware<any>, Record<string, any>, Record<string, any>, any>;
|
|
389
404
|
|
|
390
405
|
/** biome-ignore-all lint/suspicious/noExplicitAny: false positive */
|
|
391
406
|
|
|
@@ -500,4 +515,4 @@ declare class Server<TRouter extends AnyRouter> {
|
|
|
500
515
|
}
|
|
501
516
|
declare const server: typeof Server.create;
|
|
502
517
|
|
|
503
|
-
export { type AfterInsertHook, type AfterUpdateHook, type AnyRoute, type AnyRouter, type Authorization, type BaseRequest, type BeforeInsertHook, type BeforeUpdateHook, type ContextProvider, type Hooks, type Middleware, type Mutation, type MutationAuthorizationHandler, type MutationRequest, type MutationResult, type NextFunction, type Procedure, type Query, type QueryProcedureRequest, type QueryRequest, type QueryResult, type ReadAuthorizationHandler, type Request, Route, RouteFactory, type RouteRecord, Router, SQLStorage, Server, type ServerCollection, type ServerDB, Storage, createServerDB, expressAdapter, routeFactory, router, server };
|
|
518
|
+
export { type AfterInsertHook, type AfterUpdateHook, type AnyProcedureRoute, type AnyRoute, type AnyRouteOrProcedure, type AnyRouter, type Authorization, type BaseRequest, type BeforeInsertHook, type BeforeUpdateHook, type ContextProvider, type Hooks, type Middleware, type Mutation, type MutationAuthorizationHandler, type MutationRequest, type MutationResult, type NextFunction, type Procedure, ProcedureRoute, type Query, type QueryProcedureRequest, type QueryRequest, type QueryResult, type ReadAuthorizationHandler, type Request, Route, RouteFactory, type RouteRecord, Router, SQLStorage, Server, type ServerCollection, type ServerDB, Storage, createServerDB, expressAdapter, routeFactory, router, server };
|