@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/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(s)});
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(s){n==null||n.warn("Could not create enum type",u,s);}}}function Z(i,e){return i.some(t=>t.name===e)}function fn(i,e){return (i==null?void 0:i.columns.some(t=>t.name===e))??false}function Oe(i,e){let[t]=e.split(".");return Z(i,t)}function je(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&&Oe(t,e.references)&&(r=r.references(e.references)),r}function mn(i,e,t,n,r){let o=[];for(let[u,a]of Object.entries(i.fields)){let s=e==null?void 0:e.columns.find(d=>d.name===u),l=a.getStorageFieldType();s?(s.dataType,l.type):(o.push({name:u,storageFieldType:l}),l.references&&!Oe(t,l.references)&&n.push({tableName:r,columnName:u,references:l.references}));}return o}function rt(i,e){return e==="postgres"&&!!i.enumValues&&i.enumValues.length>0&&!!i.enumName}async function hn(i,e,t,n,r,o){if(t.length===0)return;let u=i.schema.createTable(e);for(let{name:a,storageFieldType:s}of t)if(rt(s,r))u=u.addColumn(a,kysely.sql.raw(s.enumName),l=>je(l,s,n));else {let l=Ee(s,r);u=u.addColumn(a,l,d=>je(d,s,n));}await u.execute().catch(a=>{if(!G(a))throw o==null||o.error("Error creating table",e,a),a});}async function Tn(i,e,t,n,r,o,u){for(let{name:a,storageFieldType:s}of t){let l=s.references?Oe(n,s.references):false,d=rt(s,o)?kysely.sql.raw(s.enumName):Ee(s,o);await i.schema.alterTable(e).addColumn(a,d,c=>je(c,s,n,!l)).execute().catch(c=>{if(!G(c))throw u==null||u.error("Error adding column",a,c),c}),s.references&&!l&&!r.some(c=>c.tableName===e&&c.columnName===a)&&r.push({tableName:e,columnName:a,references:s.references}),s.index&&await i.schema.createIndex(`${e}_${a}_index`).on(e).column(a).execute().catch(()=>{});}}async function gn(i,e,t,n,r,o){let u=`${e}_meta`,a=[];for(let[s,l]of Object.entries(t.fields)){let d=l.getStorageFieldType();fn(n,s)||a.push({name:s,storageFieldType:d});}if(!n&&a.length>0){let s=i.schema.createTable(u);for(let{name:l,storageFieldType:d}of a)s=s.addColumn(l,"varchar",c=>{let p=c;return d.primary&&(p=p.primaryKey(),Z(r,e)&&(p=p.references(`${e}.${l}`))),p});await s.execute().catch(l=>{if(!G(l))throw o==null||o.error("Error creating meta table",u,l),l});}else if(n)for(let{name:s,storageFieldType:l}of a)await i.schema.alterTable(u).addColumn(s,"varchar",d=>{let c=d;return l.primary&&(c=c.primaryKey(),Z(r,e)&&(c=c.references(`${e}.${s}`))),c}).execute().catch(d=>{if(!G(d))throw o==null||o.error("Error adding meta column",s,d),d});}async function it(i,e,t,n,r){let[o,u]=n.split("."),a=`${e}_${t}_fk`;try{await kysely.sql`
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(a)}
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 RouteRecord = Record<string, AnyRoute>;
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<any>;
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<any>;
277
+ db: ServerDB<TSchema>;
276
278
  }) => any>(handler: THandler) => Query<TInputValidator, ReturnType<THandler>>;
277
279
  };
278
280
  };
279
- declare const queryCreator: QueryCreator;
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<any>;
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<any>;
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<any>;
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<any>;
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<any>;
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<any>;
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: typeof mutationCreator;
367
- query: typeof queryCreator;
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 RouteFactory {
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
- use(...middlewares: Middleware<any>[]): RouteFactory;
385
- static create(): RouteFactory;
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 };