@live-state/sync 0.0.7-canary-7 → 0.0.7-pr-2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/client.d.ts +1 -1
- package/dist/client.js +1 -1
- package/dist/fetch-client.d.ts +1 -1
- package/dist/fetch-client.js +1 -1
- package/dist/{index-LV6LHPwh.d.ts → index-C0Qm5yHg.d.ts} +25 -12
- package/dist/optimistic-client.d.ts +1 -1
- package/dist/server.cjs +6 -6
- package/dist/server.d.cts +62 -3
- package/dist/server.d.ts +62 -3
- package/dist/server.js +3 -3
- package/package.json +1 -1
package/dist/server.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import {a,b,B,z as z$2,C,D as D$1,G as G$1,F as F$1,E}from'./chunk-3XEJ2M4E.js';import Y from'crypto';import xt,{parse}from'qs';import {z as z$1}from'zod';import {Kysely,PostgresDialect,sql}from'kysely';import {jsonArrayFrom as jsonArrayFrom$1,jsonObjectFrom as jsonObjectFrom$1}from'kysely/helpers/mysql';import {jsonArrayFrom as jsonArrayFrom$2,jsonObjectFrom as jsonObjectFrom$2}from'kysely/helpers/postgres';import {jsonArrayFrom,jsonObjectFrom}from'kysely/helpers/sqlite';var ye=a(ne=>{Object.defineProperty(ne,"__esModule",{value:true});ne.parse=gt;ne.serialize=Tt;var lt=/^[\u0021-\u003A\u003C\u003E-\u007E]+$/,yt=/^[\u0021-\u003A\u003C-\u007E]*$/,ht=/^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i,pt=/^[\u0020-\u003A\u003D-\u007E]*$/,mt=Object.prototype.toString,ft=(()=>{let c=function(){};return c.prototype=Object.create(null),c})();function gt(c,e){let t=new ft,r=c.length;if(r<2)return t;let i=(e==null?void 0:e.decode)||bt,s=0;do{let o=c.indexOf("=",s);if(o===-1)break;let a=c.indexOf(";",s),n=a===-1?r:a;if(o>n){s=c.lastIndexOf(";",o-1)+1;continue}let u=Ne(c,s,o),l=qe(c,o,u),d=c.slice(u,l);if(t[d]===void 0){let h=Ne(c,o+1,n),y=qe(c,n,h),m=i(c.slice(h,y));t[d]=m;}s=n+1;}while(s<r);return t}function Ne(c,e,t){do{let r=c.charCodeAt(e);if(r!==32&&r!==9)return e}while(++e<t);return t}function qe(c,e,t){for(;e>t;){let r=c.charCodeAt(--e);if(r!==32&&r!==9)return e+1}return t}function Tt(c,e,t){let r=(t==null?void 0:t.encode)||encodeURIComponent;if(!lt.test(c))throw new TypeError(`argument name is invalid: ${c}`);let i=r(e);if(!yt.test(i))throw new TypeError(`argument val is invalid: ${e}`);let s=c+"="+i;if(!t)return s;if(t.maxAge!==void 0){if(!Number.isInteger(t.maxAge))throw new TypeError(`option maxAge is invalid: ${t.maxAge}`);s+="; Max-Age="+t.maxAge;}if(t.domain){if(!ht.test(t.domain))throw new TypeError(`option domain is invalid: ${t.domain}`);s+="; Domain="+t.domain;}if(t.path){if(!pt.test(t.path))throw new TypeError(`option path is invalid: ${t.path}`);s+="; Path="+t.path;}if(t.expires){if(!Rt(t.expires)||!Number.isFinite(t.expires.valueOf()))throw new TypeError(`option expires is invalid: ${t.expires}`);s+="; Expires="+t.expires.toUTCString();}if(t.httpOnly&&(s+="; HttpOnly"),t.secure&&(s+="; Secure"),t.partitioned&&(s+="; Partitioned"),t.priority)switch(typeof t.priority=="string"?t.priority.toLowerCase():void 0){case "low":s+="; Priority=Low";break;case "medium":s+="; Priority=Medium";break;case "high":s+="; 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":s+="; SameSite=Strict";break;case "lax":s+="; SameSite=Lax";break;case "none":s+="; SameSite=None";break;default:throw new TypeError(`option sameSite is invalid: ${t.sameSite}`)}return s}function bt(c){if(c.indexOf("%")===-1)return c;try{return decodeURIComponent(c)}catch{return c}}function Rt(c){return mt.call(c)==="[object Date]"}});var Pe="0123456789ABCDEFGHJKMNPQRSTVWXYZ",W=32;var it=16,Le=10,Ee=0xffffffffffff;var _;(function(c){c.Base32IncorrectEncoding="B32_ENC_INVALID",c.DecodeTimeInvalidCharacter="DEC_TIME_CHAR",c.DecodeTimeValueMalformed="DEC_TIME_MALFORMED",c.EncodeTimeNegative="ENC_TIME_NEG",c.EncodeTimeSizeExceeded="ENC_TIME_SIZE_EXCEED",c.EncodeTimeValueMalformed="ENC_TIME_MALFORMED",c.PRNGDetectFailure="PRNG_DETECT",c.ULIDInvalid="ULID_INVALID",c.Unexpected="UNEXPECTED",c.UUIDInvalid="UUID_INVALID";})(_||(_={}));var D=class extends Error{constructor(e,t){super(`${t} (${e})`),this.name="ULIDError",this.code=e;}};function st(c){let e=Math.floor(c()*W);return e===W&&(e=W-1),Pe.charAt(e)}function at(c){var r;let e=ot(),t=e&&(e.crypto||e.msCrypto)||(typeof Y<"u"?Y:null);if(typeof(t==null?void 0:t.getRandomValues)=="function")return ()=>{let i=new Uint8Array(1);return t.getRandomValues(i),i[0]/255};if(typeof(t==null?void 0:t.randomBytes)=="function")return ()=>t.randomBytes(1).readUInt8()/255;if((r=Y)!=null&&r.randomBytes)return ()=>Y.randomBytes(1).readUInt8()/255;throw new D(_.PRNGDetectFailure,"Failed to find a reliable PRNG")}function ot(){return dt()?self:typeof window<"u"?window:typeof global<"u"?global:typeof globalThis<"u"?globalThis:null}function ct(c,e){let t="";for(;c>0;c--)t=st(e)+t;return t}function ut(c,e=Le){if(isNaN(c))throw new D(_.EncodeTimeValueMalformed,`Time must be a number: ${c}`);if(c>Ee)throw new D(_.EncodeTimeSizeExceeded,`Cannot encode a time larger than ${Ee}: ${c}`);if(c<0)throw new D(_.EncodeTimeNegative,`Time must be positive: ${c}`);if(Number.isInteger(c)===false)throw new D(_.EncodeTimeValueMalformed,`Time must be an integer: ${c}`);let t,r="";for(let i=e;i>0;i--)t=c%W,r=Pe.charAt(t)+r,c=(c-t)/W;return r}function dt(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}function Qe(c,e){let t=at(),r=Date.now();return ut(r,Le)+ct(it,t)}var ee=()=>Qe().toLowerCase(),X=c=>({then(e,t){try{if(e){let r=e(c);return r instanceof Promise?r:X(r)}return X(c)}catch(r){if(t){let i=t(r);return i instanceof Promise?i:X(i)}throw r}}}),de=c=>c instanceof Promise?c:X(c);var z=(...c)=>{let e=c.filter(t=>!!t);return e.length===0?{}:e.length===1?e[0]:{$and:e}};var te=class{storage;queue=new Map;scheduled=false;constructor(e){this.storage=e;}async rawFind({resource:e,commonWhere:t,uniqueWhere:r,...i}){return new Promise((s,o)=>{let a=this.getBatchKey({resource:e,commonWhere:t,...i}),n={resource:e,commonWhere:t,uniqueWhere:r,...i,resolve:s,reject:o};this.queue.has(a)||this.queue.set(a,[]);let u=this.queue.get(a);u&&u.push(n),this.scheduled||(this.scheduled=true,setImmediate(()=>{this.processBatch();}));})}getBatchKey(e){let{resource:t,commonWhere:r,...i}=e;return `${t}:${JSON.stringify(r??{})}:${JSON.stringify(i??{})}`}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(r){t.forEach(i=>{i.reject(r);});}}async executeBatchedRequests(e){var h;if(e.length===0)return;let t=e[0],{resource:r,commonWhere:i,include:s,sort:o}=t,a=e.length===1?t.limit:void 0,n=e.map(y=>y.uniqueWhere).filter(y=>y!==void 0),u=i,l=(h=Object.entries(n[0]??{})[0])==null?void 0:h[0];if(n.length>0){let y=n.map(m=>m[l]).filter(m=>m!=null);y.length>0&&(u=z(i,{[l]:{$in:y}}));}let d=await this.storage.get({resource:r,where:u,include:s,sort:o,limit:a});for(let y of e){let m=d;if(y.uniqueWhere){let[p,f]=Object.entries(y.uniqueWhere)[0];m=d.filter(g=>{var T;return ((T=g.value[p])==null?void 0:T.value)===f});}y.resolve(m);}}};function le(c){return B({resource:c.query.resource,where:c.query.where,include:c.query.include,stepPath:c.stepPath,isMany:c.isMany,relationName:c.relationName})}var re=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,r=this.schema[e];if(!(r!=null&&r.relations))return t;for(let[i,s]of Object.entries(r.relations))s.type==="one"&&s.relationalColumn&&t.set(String(s.relationalColumn),{relationName:i,targetResource:s.entity.name});return t}ensureObjectNode(e,t,r){let i=this.objectNodes.get(e);return i?r&&i.matchedQueries.add(r):(i={id:e,type:t,matchedQueries:new Set(r?[r]:[]),referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e,i)),i}storeRelation(e,t,r,i){let s=this.objectNodes.get(e),o=this.objectNodes.get(t);if(s&&s.referencesObjects.set(r,t),o&&i){let a=o.referencedByObjects.get(i);a||(a=new Set,o.referencedByObjects.set(i,a)),a.add(e);}}removeRelation(e,t,r,i){let s=this.objectNodes.get(e),o=this.objectNodes.get(t);if(s&&s.referencesObjects.delete(r),o&&i){let a=o.referencedByObjects.get(i);a&&(a.delete(e),a.size===0&&o.referencedByObjects.delete(i));}}getInverseRelationName(e,t,r){let i=this.schema[e];if(!(i!=null&&i.relations))return;let s=i.relations[r];if(!s)return;let o=this.schema[t];if(o!=null&&o.relations){if(s.type==="many"&&s.foreignColumn){for(let[a,n]of Object.entries(o.relations))if(n.entity.name===e&&n.type==="one"&&n.relationalColumn===s.foreignColumn)return a}if(s.type==="one"&&s.relationalColumn){for(let[a,n]of Object.entries(o.relations))if(n.entity.name===e&&n.type==="many"&&n.foreignColumn===s.relationalColumn)return a}}}updateRelationsFromMutation(e,t,r,i){let s=this.getRelationalColumns(e),o=this.objectNodes.get(t);if(o)for(let[a,{relationName:n,targetResource:u}]of Array.from(s)){if(!(i&&a in i))continue;let d=this.getInverseRelationName(e,u,n),h=o.referencesObjects.get(n),y=r[a];h!==y&&(h&&this.removeRelation(t,h,n,d),y&&(this.ensureObjectNode(y,u),this.storeRelation(t,y,n,d)));}}get(e,t){let r=this.breakdownQuery({query:e,context:(t==null?void 0:t.context)??{}});return this.resolveQuery(r,{context:(t==null?void 0:t.context)??{},batcher:(t==null?void 0:t.batcher)??new te(this.storage)})}subscribe(e,t,r={}){let i=this.breakdownQuery({query:e,context:r}),s={},o=[];for(let a of i){this.logger.debug("[QueryEngine] Subscribing to step",a.stepPath.join("."));let n=le(a),u=s[a.stepPath.at(-2)??""],l=a.stepPath.at(-1)??"",d=this.queryNodes.get(n);if(d)d.subscriptions.add(t);else if(d={hash:n,queryStep:a,relationName:l,trackedObjects:new Set,subscriptions:new Set([t]),parentQuery:u,childQueries:new Set},this.queryNodes.set(d.hash,d),u){let h=this.queryNodes.get(u);h&&h.childQueries.add(d.hash);}s[l]=n,o.push(()=>{let h=this.queryNodes.get(n);h&&(h.subscriptions.delete(t),h.subscriptions.size===0&&this.queryNodes.delete(n));});}return ()=>{for(let a of o)a();}}breakdownQuery(e){var f;let{query:t,stepPath:r=[],context:i={},parentResource:s}=e,{include:o}=t,a=r.length===0,n=r.at(-1),u,l,d;if(!a&&s&&n){let g=this.schema[s],T=(f=g==null?void 0:g.relations)==null?void 0:f[n];T&&(d=T.type==="many",T.type==="one"?(u=b=>({id:b}),l=b=>b.map(R=>{var S,v;return (v=(S=R.value)==null?void 0:S[T.relationalColumn])==null?void 0:v.value}).filter(R=>R!==void 0)):(u=b=>({[T.foreignColumn]:b}),l=b=>b.map(R=>{var S,v;return (v=(S=R.value)==null?void 0:S.id)==null?void 0:v.value}).filter(R=>R!==void 0)));}let{include:h,...y}=t,p=[this.router.incrementQueryStep({query:y,stepPath:[...r],getWhere:u,referenceGetter:l,isMany:d,relationName:n},i)];if(o&&typeof o=="object"&&Object.keys(o).length>0){let g=this.schema[t.resource];if(!g)throw new Error(`Resource ${t.resource} not found`);p.push(...Object.entries(o).flatMap(([T,b])=>{let R=g.relations[T];if(!R)throw new Error(`Relation ${T} not found for resource ${t.resource}`);let S=R.entity.name,v=E(b)?b:null;return this.breakdownQuery({query:{resource:S,include:v?v.include:typeof b=="object"?b:void 0,where:v==null?void 0:v.where,limit:v==null?void 0:v.limit,sort:v==null?void 0:v.orderBy},stepPath:[...r,T],context:i,parentResource:t.resource})}));}return p}resolveQuery(e,t){this.logger.debug("[QueryEngine] Resolving query",e.map(s=>s.stepPath.join(".")).join(" -> "));let r={},i=this.resolveStep(e[0],t).then(s=>{this.logger.debug("[QueryEngine] Resolved step",e[0].stepPath.join("."),"with results count:",s.length),r[e[0].stepPath.join(".")]=[{data:s}];});for(let s=1;s<e.length;s++){let o=e[s],a=o.stepPath.slice(0,-1).join(".");i=i.then(async()=>{var u,l;let n=r[a];if(!n){r[o.stepPath.join(".")]=[];return}if(o.referenceGetter&&o.getWhere){let d=new Map;for(let m of n)for(let p of m.data){let f=(l=(u=p==null?void 0:p.value)==null?void 0:u.id)==null?void 0:l.value;if(!f)continue;let T=o.referenceGetter([p])[0];if(T){d.has(T)||d.set(T,new Set);let b=d.get(T);b&&b.add(f);}}let h=Array.from(d.keys());if(h.length===0){r[o.stepPath.join(".")]=[];return}let y=[];for(let m of h){let p=o.getWhere(m),f={...o,relationalWhere:p},g=await this.resolveStep(f,t),T=d.get(m);if(T)for(let b of Array.from(T))y.push({includedBy:b,data:g});}this.logger.debug("[QueryEngine] Resolved step",o.stepPath.join("."),"with results count:",y.reduce((m,p)=>m+p.data.length,0)),r[o.stepPath.join(".")]=y;}else {let d=await this.resolveStep(o,t);r[o.stepPath.join(".")]=[{data:d}];}});}return i=i.then((()=>(this.logger.debug("[QueryEngine] Assembling results"),this.assembleResults(e,r)))),i}assembleResults(e,t){var o,a,n,u,l;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 r=new Map;for(let d of e){let h=d.stepPath.join("."),y=t[h]??[],m=Object.keys(d.query.include??{});this.logger.debug(`[QueryEngine] assembleResults: Processing step "${h}"`,{resource:d.query.resource,includedRelations:m,resultGroups:y.length,isMany:d.isMany,relationName:d.relationName});for(let p of y){this.logger.debug(`[QueryEngine] assembleResults: Processing result group for "${h}"`,{dataCount:p.data.length,includedBy:p.includedBy});for(let f of p.data){let g=(a=(o=f==null?void 0:f.value)==null?void 0:o.id)==null?void 0:a.value;if(!g){this.logger.debug(`[QueryEngine] assembleResults: Skipping data without id in step "${h}"`);continue}let T=h?`${h}.${g}`:g,b=[];if(d.stepPath.length>0&&p.includedBy){let S=d.stepPath.slice(0,-1).join(".");b=[S?`${S}.${p.includedBy}`:p.includedBy],this.logger.debug(`[QueryEngine] assembleResults: Child entity "${T}" has parent keys:`,b,{stepPath:h,parentStepPath:S,includedBy:p.includedBy});}else this.logger.debug(`[QueryEngine] assembleResults: Root entity "${T}" (no parent)`);let R=r.get(T);if(R){this.logger.debug(`[QueryEngine] assembleResults: Entity "${T}" already exists, adding parent keys:`,b);for(let S of b)R.includedBy.add(S);}else this.logger.debug(`[QueryEngine] assembleResults: Adding new entity "${T}"`,{resource:d.query.resource,path:d.stepPath.at(-1)??"",isMany:d.isMany??false,relationName:d.relationName,includedRelations:m,parentKeys:b}),r.set(T,{data:f,includedBy:new Set(b),path:d.stepPath.at(-1)??"",isMany:d.isMany??false,relationName:d.relationName,resourceName:d.query.resource,includedRelations:m});}}}this.logger.debug(`[QueryEngine] assembleResults: Built entriesMap with ${r.size} entries`),this.logger.debug("[QueryEngine] assembleResults: EntriesMap keys:",Array.from(r.keys()));let i=Array.from(r.entries()),s=[];this.logger.debug(`[QueryEngine] assembleResults: Starting assembly phase with ${i.length} entries`);for(let d=i.length-1;d>=0;d--){let[h,y]=i[d],m=this.schema[y.resourceName];this.logger.debug(`[QueryEngine] assembleResults: Processing entry "${h}"`,{resource:y.resourceName,path:y.path,isMany:y.isMany,relationName:y.relationName,includedRelations:y.includedRelations,parentKeys:Array.from(y.includedBy)});for(let p of y.includedRelations){let f=(u=(n=m==null?void 0:m.relations)==null?void 0:n[p])==null?void 0:u.type,g=!!y.data.value[p];if(this.logger.debug(`[QueryEngine] assembleResults: Checking included relation "${p}" for "${h}"`,{relationType:f,hasRelation:g,resourceHasRelation:!!((l=m==null?void 0:m.relations)!=null&&l[p])}),y.data.value[p])this.logger.debug(`[QueryEngine] assembleResults: Relation "${p}" already exists for "${h}"`,y.data.value[p]);else {let T=f==="many"?{value:[]}:{value:null};y.data.value[p]=T,this.logger.debug(`[QueryEngine] assembleResults: Initialized relation "${p}" for "${h}" with`,T);}}if(y.path===""){this.logger.debug(`[QueryEngine] assembleResults: Adding root entity "${h}" to resultData`),s.unshift(y.data);continue}this.logger.debug(`[QueryEngine] assembleResults: Attaching "${h}" to ${y.includedBy.size} parent(s)`);for(let p of Array.from(y.includedBy)){let f=r.get(p);if(!f){this.logger.warn(`[QueryEngine] assembleResults: WARNING - Parent "${p}" not found in entriesMap for child "${h}"`);continue}let g=y.relationName??y.path;this.logger.debug(`[QueryEngine] assembleResults: Attaching "${h}" to parent "${p}" via relation "${g}"`,{isMany:y.isMany,parentHasRelation:!!f.data.value[g]}),y.isMany?(f.data.value[g]??={value:[]},f.data.value[g].value.push(y.data),this.logger.debug(`[QueryEngine] assembleResults: Added "${h}" to many relation "${g}" on parent "${p}"`,{arrayLength:f.data.value[g].value.length})):(f.data.value[g]=y.data,this.logger.debug(`[QueryEngine] assembleResults: Set one relation "${g}" on parent "${p}" to "${h}"`));}}return this.logger.debug(`[QueryEngine] assembleResults: Assembly complete. Returning ${s.length} root items`),s}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:r,relationalWhere:i}=e,s=r.where&&i?z(r.where,i):i??r.where,o=s?{...r,where:s}:r;return de(this.router.get(o,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 r=le(e),i=this.queryNodes.get(r),s=e.query.resource;if(!i)return;let o=this.getRelationalColumns(s);for(let a of t){let n=z$2(a),u=n.id;this.ensureObjectNode(u,s,r),i.trackedObjects.add(u);for(let[l,{relationName:d,targetResource:h}]of Array.from(o)){let y=n[l];if(y){this.ensureObjectNode(y,h);let m=this.getInverseRelationName(s,h,d);this.storeRelation(u,y,d,m);}}this.loadNestedRelations(s,u,n),this.logger.debug("[QueryEngine] Loaded nested relations for",u);}}loadNestedRelations(e,t,r){let i=this.schema[e];if(i!=null&&i.relations)for(let[s,o]of Object.entries(i.relations)){let a=r[s];if(!a)continue;let n=o.entity.name,u=this.getInverseRelationName(e,n,s);if(o.type==="one")a&&typeof a=="object"&&a.id&&(this.ensureObjectNode(a.id,n),this.storeRelation(t,a.id,s,u),this.loadNestedRelations(n,a.id,a));else if(o.type==="many"&&Array.isArray(a)){for(let l of a)if(l&&typeof l=="object"&&l.id){this.ensureObjectNode(l.id,n);let d=this.getInverseRelationName(n,e,s);d&&this.storeRelation(l.id,t,d,s),this.loadNestedRelations(n,l.id,l);}}}}buildIncludeFromChildQueries(e){let t=this.queryNodes.get(e);if(!t||t.childQueries.size===0)return {};let r={};for(let i of Array.from(t.childQueries)){let s=this.queryNodes.get(i);if(!s||!s.relationName)continue;let o=this.buildIncludeFromChildQueries(i);r[s.relationName]=Object.keys(o).length>0?o:true;}return r}sendInsertsForTree(e,t,r){var a,n;let i=(n=(a=t==null?void 0:t.value)==null?void 0:a.id)==null?void 0:n.value;if(!i)return;let s={procedure:"INSERT",resource:r,resourceId:i,type:"MUTATE",payload:t.value};for(let u of Array.from(e.subscriptions))try{u(s);}catch(l){this.logger.error("[QueryEngine] Error in subscription callback during sendInsertsForTree",{error:l,queryHash:e.hash,resource:r,resourceId:i,stepPath:e.queryStep.stepPath.join(".")});}e.trackedObjects.add(i),this.ensureObjectNode(i,r,e.hash).matchedQueries.add(e.hash);for(let u of Array.from(e.childQueries)){let l=this.queryNodes.get(u);if(!l||!l.relationName)continue;let d=l.relationName,h=l.queryStep.query.resource,y=t.value[d];if(!y)continue;let m=y.value;if(Array.isArray(m))for(let p of m)this.sendInsertsForTree(l,p,h);else m&&typeof m=="object"&&this.sendInsertsForTree(l,m,h);}}handleMutation(e,t){if(e.procedure==="INSERT"){if(this.objectNodes.has(e.resourceId))return;let r=z$2(t);if(!r)return;let i={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map};this.objectNodes.set(e.resourceId,i);let s=this.getRelationalColumns(e.resource);for(let[a,{relationName:n,targetResource:u}]of Array.from(s)){let l=r[a];if(l){this.ensureObjectNode(l,u);let d=this.getInverseRelationName(e.resource,u,n);this.storeRelation(e.resourceId,l,n,d);}}let o=this.objectNodes.get(e.resourceId);this.getMatchingQueries(e,r).then(a=>{for(let n of a){let u=this.queryNodes.get(n);if(u){u.trackedObjects.add(e.resourceId),o&&o.matchedQueries.add(n);for(let l of Array.from(u.subscriptions))try{l(e);}catch(d){this.logger.error("[QueryEngine] Error in subscription callback during INSERT mutation",{error:d,queryHash:u.hash,resource:e.resource,resourceId:e.resourceId,stepPath:u.queryStep.stepPath.join(".")});}}}});return}if(e.procedure==="UPDATE"){let r=z$2(t);if(!r)return;let i=this.objectNodes.get(e.resourceId),s=new Set((i==null?void 0:i.matchedQueries)??[]);i||(i={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e.resourceId,i)),this.updateRelationsFromMutation(e.resource,e.resourceId,r,e.payload),this.getMatchingQueries(e,r).then(o=>{let a=new Set(o),n=[],u=[],l=[];for(let h of o)s.has(h)?l.push(h):n.push(h);for(let h of Array.from(s))a.has(h)||u.push(h);for(let h of n){let y=this.queryNodes.get(h);y&&y.trackedObjects.add(e.resourceId);}for(let h of u){let y=this.queryNodes.get(h);y&&y.trackedObjects.delete(e.resourceId);}let d=this.objectNodes.get(e.resourceId);if(d){for(let h of n)d.matchedQueries.add(h);for(let h of u)d.matchedQueries.delete(h);}for(let h of [...u,...l]){let y=this.queryNodes.get(h);if(y)for(let m of Array.from(y.subscriptions))try{m(e);}catch(p){this.logger.error("[QueryEngine] Error in subscription callback during UPDATE mutation",{error:p,queryHash:y.hash,resource:e.resource,resourceId:e.resourceId,stepPath:y.queryStep.stepPath.join(".")});}}if(n.length>0)for(let h of n){let y=this.queryNodes.get(h);if(!y)continue;let m=this.buildIncludeFromChildQueries(h);this.get({resource:e.resource,where:{id:e.resourceId},include:Object.keys(m).length>0?m:void 0}).then(p=>{!p||p.length===0||this.sendInsertsForTree(y,p[0],e.resource);});}});return}}getMatchingQueries(e,t){let r=[];for(let i of Array.from(this.queryNodes.values()))i.queryStep.query.resource===e.resource&&r.push(i);return r.length===0?de([]):Promise.all(r.map(async i=>{let s=i.queryStep.query.where,o=i.queryStep.query.resource,a=e.resourceId,n=this.objectNodes.get(a);if(!n)return {hash:i.hash,matches:false};if(i.relationName){let y=i.parentQuery?this.queryNodes.get(i.parentQuery):void 0,m=y==null?void 0:y.queryStep.query.resource,p=m?this.getInverseRelationName(m,o,i.relationName):void 0,f=p?n.referencesObjects.get(p):void 0;if(!f)return {hash:i.hash,matches:false};let g=this.objectNodes.get(f);return !g||!y||!g.matchedQueries.has(y.hash)?{hash:i.hash,matches:false}:{hash:i.hash,matches:true}}if(!s)return {hash:i.hash,matches:true};let u=C(s,o,this.schema),l=Object.keys(u).length>0;if(!l&&t!==void 0)return {hash:i.hash,matches:D$1(t,s)};let d=await this.storage.get({resource:o,where:{id:a},include:l?u:void 0});if(!d||d.length===0)return {hash:i.hash,matches:false};let h=z$2(d[0]);return h?{hash:i.hash,matches:D$1(h,s)}:{hash:i.hash,matches:false}})).then(i=>i.filter(s=>s.matches).map(s=>s.hash))}};var Ve=b(ye(),1);var ie=z$1.object({resource:z$1.string(),where:z$1.record(z$1.string(),z$1.any()).optional(),include:z$1.record(z$1.string(),z$1.any()).optional(),lastSyncedAt:z$1.string().optional(),limit:z$1.coerce.number().optional(),sort:z$1.array(z$1.object({key:z$1.string(),direction:z$1.enum(["asc","desc"])})).optional()}),he=z$1.record(z$1.string(),z$1.object({value:z$1.any().nullable(),_meta:z$1.object({timestamp:z$1.string().optional().nullable()}).optional()})),St=he.superRefine((c,e)=>{c.id&&e.addIssue({code:z$1.ZodIssueCode.custom,message:"Payload cannot have an id"});}),$e=z$1.object({id:z$1.string().optional(),type:z$1.literal("MUTATE"),resource:z$1.string(),resourceId:z$1.string().optional()}),ke=z$1.object({timestamp:z$1.string().optional(),originMutationId:z$1.string().optional()}).optional(),F=$e.extend({procedure:z$1.string(),payload:z$1.any().optional(),meta:ke}),H=$e.extend({procedure:z$1.enum(["INSERT","UPDATE"]),payload:St,meta:ke});z$1.union([H,F]);var _e=z$1.object({resource:z$1.string(),procedure:z$1.string(),input:z$1.any().optional()});var De=ie.omit({resource:true}),pe=F.omit({id:true,type:true,resource:true,procedure:true}).extend({meta:F.shape.meta}),me=H.omit({id:true,type:true,resource:true,procedure:true});z$1.union([me,pe]);var fe=c=>{if(c==null)return c;if(c==="null")return null;if(Array.isArray(c))return c.map(fe);if(typeof c=="object"&&c.constructor===Object){let e={};for(let[t,r]of Object.entries(c))e[t]=fe(r);return e}return c},Be=c=>{let e=c.logger;return async t=>{var r;try{let i=typeof t.headers.getSetCookie=="function"?Object.fromEntries(t.headers):t.headers,s={headers:i,cookies:i.cookie?Ve.default.parse(i.cookie):{}},o=new URL(t.url),a=o.pathname.split("/"),n=o.searchParams,u=fe(xt.parse(n.toString())),l=await((r=c.contextProvider)==null?void 0:r.call(c,{transport:"HTTP",headers:s.headers,cookies:s.cookies,queryParams:u}))??{};if(t.method==="GET"){let d=a[a.length-1],{success:h,data:y,error:m}=De.safeParse(u);if(!h)return Response.json({message:"Invalid query",code:"INVALID_QUERY",details:m},{status:400});let p=await c.handleQuery({req:{...s,...y,type:"QUERY",resource:d,context:l,queryParams:u}});return !p||!p.data?Response.json({message:"Invalid resource",code:"INVALID_RESOURCE"},{status:400}):Response.json(p.data)}if(t.method==="POST")try{let d=a[a.length-1],h=a[a.length-2];if(h==="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],T=t.body?await t.json():{};if(!g||g.trim()==="")return Response.json({message:"Invalid resource in path",code:"INVALID_RESOURCE"},{status:400});let b=await c.handleCustomQuery({req:{...s,type:"CUSTOM_QUERY",resource:g,procedure:d,input:T.input,context:l,queryParams:u}});return Response.json(b)}let y=h,m=t.body?await t.json():{},p;if(d==="insert"||d==="update"){let{success:g,data:T,error:b}=me.safeParse(m);if(!g)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:b},{status:400});p=T;}else {let{success:g,data:T,error:b}=pe.safeParse(m);if(!g)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:b},{status:400});p=T;}let f=await c.handleMutation({req:{...s,type:"MUTATE",resource:y,input:p.payload,context:l,resourceId:p.resourceId,procedure:d==="insert"||d==="update"?d.toUpperCase():d,queryParams:{},meta:p.meta}});return Response.json(f)}catch(d){return e.error("Error parsing mutation from the client:",d),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}return Response.json({message:"Not found",code:"NOT_FOUND"},{status:404})}catch(i){return e.error("Unexpected error:",i),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}}};var Ue=b(ye(),1);var q=z$1.string(),ge=z$1.union([_e,ie]),vt=z$1.object({id:q,type:z$1.literal("SUBSCRIBE")}).and(ge),Mt=z$1.object({id:q,type:z$1.literal("UNSUBSCRIBE")}).and(ge),It=z$1.object({id:q,type:z$1.literal("QUERY")}).and(ge),Ct=z$1.object({id:q,type:z$1.literal("CUSTOM_QUERY"),resource:z$1.string(),procedure:z$1.string(),input:z$1.any().optional()}),ze=H.extend({id:q}),jt=F.extend({id:q}),Ot=z$1.union([jt,ze]),Fe=z$1.union([vt,It,Ct,Ot,Mt]),At=z$1.object({id:q,type:z$1.literal("REJECT"),resource:z$1.string(),message:z$1.string().optional()}),Et=z$1.object({id:q,type:z$1.literal("REPLY"),data:z$1.any()});z$1.union([At,Et,ze]);z$1.object({resource:z$1.string(),data:z$1.array(he)});var We=c=>{let e={},t=c.logger;return (r,i)=>{var d;let s=h=>{r.send(JSON.stringify(h));},o=ee(),a=new Map,n={headers:i.headers,cookies:typeof i.headers.cookie=="string"?Ue.default.parse(i.headers.cookie):{}},u=parse(i.url.split("?")[1]),l=(d=c.contextProvider)==null?void 0:d.call(c,{transport:"WEBSOCKET",headers:n.headers,cookies:n.cookies,queryParams:u});e[o]=r,t.info("Client connected:",o),r.on("message",async h=>{try{t.debug("Message received from the client:",h);let y=Fe.parse(JSON.parse(h.toString()));if(y.type==="SUBSCRIBE"||y.type==="QUERY"){let{type:m,id:p,...f}=y,g=m==="SUBSCRIBE";if("procedure"in f){let T=await c.handleCustomQuery({req:{...n,type:"CUSTOM_QUERY",resource:f.resource,procedure:f.procedure,input:f.input,context:await l??{},queryParams:u},subscription:g?b=>{var R;!b.resourceId||!b.payload||!Object.keys(b.payload).length||(R=e[o])==null||R.send(JSON.stringify(b));}:void 0});if(g){if(!T||!T.data||!T.query)throw new Error("Invalid resource");T.unsubscribe&&a.set(B(f),T.unsubscribe),s({id:p,type:"REPLY",data:{resource:T.query.resource,data:(T.data??[]).map(b=>b.value)}});}else s({id:p,type:"REPLY",data:T});}else {let T=await c.handleQuery({req:{...n,...f,type:"QUERY",context:await l??{},queryParams:u},subscription:g?b=>{var R;!b.resourceId||!b.payload||!Object.keys(b.payload).length||(R=e[o])==null||R.send(JSON.stringify(b));}:void 0});if(!T||!T.data)throw new Error("Invalid resource");g&&T.unsubscribe&&a.set(B(f),T.unsubscribe),s({id:p,type:"REPLY",data:{resource:f.resource,data:(T.data??[]).map(b=>b.value)}});}}else if(y.type==="UNSUBSCRIBE"){let{type:m,id:p,...f}=y,g=a.get(B(f));g&&(g(),a.delete(B(f)));}else if(y.type==="CUSTOM_QUERY"){let{resource:m,procedure:p,input:f,id:g}=y;t.debug("Received custom query from client:",y);try{let T=await c.handleCustomQuery({req:{...n,type:"CUSTOM_QUERY",resource:m,procedure:p,input:f,context:await l??{},queryParams:u}});s({id:g,type:"REPLY",data:T});}catch(T){s({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 p=await c.handleMutation({req:{...n,type:"MUTATE",resource:m,input:y.payload,context:{messageId:y.id,...await l??{}},resourceId:y.resourceId,procedure:y.procedure,queryParams:u,meta:y.meta}});y.procedure&&y.procedure!=="INSERT"&&y.procedure!=="UPDATE"&&s({id:y.id,type:"REPLY",data:p});}catch(p){s({id:y.id,type:"REJECT",resource:m,message:p.message}),t.error("Error parsing mutation from the client:",p);}}}catch(y){t.error("Error handling message from the client:",y);}}),r.on("close",()=>{t.info("Connection closed",o),delete e[o];for(let h of Array.from(a.values()))h();});}};function He(c){let e=`${c.protocol}://${c.hostname}${c.url}`,t=new Headers;return Object.entries(c.headers).forEach(([r,i])=>{i&&t.set(r,Array.isArray(i)?i.join(","):i);}),new Request(e,{method:c.method,headers:t,body:c.body&&c.method!=="GET"?JSON.stringify(c.body):void 0})}var kr=(c,e,t)=>{c.ws(`${(t==null?void 0:t.basePath)??""}/ws`,We(e)),c.use(`${(t==null?void 0:t.basePath)??""}/`,(r,i)=>{Be(e)(He(r)).then(o=>o.json().then(a=>i.status(o.status).send(a)));});};var se=class c{_collection;_client;_where;_include;_limit;_single;_sort;_shouldAwait;constructor(e,t,r,i,s,o,a,n){this._collection=e,this._client=t,this._where=r??{},this._include=i??{},this._limit=s,this._single=o,this._sort=a,this._shouldAwait=n,this.get=this.get.bind(this),this.subscribe=this.subscribe.bind(this);}where(e){return new c(this._collection,this._client,{...this._where,...e},this._include,this._limit,this._single,this._sort,this._shouldAwait)}include(e){return new c(this._collection,this._client,this._where,{...this._include,...e},this._limit,this._single,this._sort,this._shouldAwait)}limit(e){return new c(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 c(this._collection,this._client,e??this._where,this._include,1,true,this._sort,this._shouldAwait)}orderBy(e,t="asc"){let r=[...this._sort??[],{key:e,direction:t}];return new c(this._collection,this._client,this._where,this._include,this._limit,this._single,r,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,r){return new c(e,t,void 0,void 0,void 0,void 0,void 0,r??false)}};var Lt=c=>typeof c=="object"&&c!==null&&"value"in c&&!Array.isArray(c),Te=class{constructor(e){this.storage=e;}get(e){return Promise.resolve(this.storage.get(e)).then(t=>t.map(r=>Lt(r)?z$2(r):r))}subscribe(){throw new Error("Subscriptions are not supported server-side. Use .get() instead.")}};function V(c,e,t){let r=new Te(c),i=o=>{let a=se._init(o,r,true);return Object.assign(Object.create(a),{insert:async u=>{let l=c._getTimestamp(),d=await c.rawInsert(o.name,u.id,{value:Object.fromEntries(Object.entries(u).map(([h,y])=>[h,{value:y,_meta:{timestamp:l}}]))},void 0,t);return z$2(d.data)},update:async(u,l)=>{let d=c._getTimestamp(),{id:h,...y}=l,m=await c.rawUpdate(o.name,u,{value:Object.fromEntries(Object.entries(y).map(([g,T])=>[g,{value:T,_meta:{timestamp:d}}]))},void 0,t),p=z$2(m.data),f={};for(let g of Object.keys(y))g in p&&(f[g]=p[g]);return f}})},s={get(o,a){if(a==="findOne")return c.findOne.bind(c);if(a==="find")return c.find.bind(c);if(a==="insert")return (n,u)=>{let l=c._getTimestamp();return c.rawInsert(n.name,u.id,{value:Object.fromEntries(Object.entries(u).map(([d,h])=>[d,{value:h,_meta:{timestamp:l}}]))},void 0,t).then(d=>z$2(d.data))};if(a==="update")return (n,u,l)=>{let d=c._getTimestamp(),{id:h,...y}=l;return c.rawUpdate(n.name,u,{value:Object.fromEntries(Object.entries(y).map(([m,p])=>[m,{value:p,_meta:{timestamp:d}}]))},void 0,t).then(m=>{let p=z$2(m.data),f={};for(let g of Object.keys(y))g in p&&(f[g]=p[g]);return f})};if(a==="transaction")return async n=>c.transaction(async({trx:u,commit:l,rollback:d})=>{let h=V(u,e,t);return n({trx:h,commit:l,rollback:d})});if(a in e){let n=e[a];return i(n)}}};return new Proxy({},s)}var be=class c{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 r=t;r.hooks&&this.hooksRegistry.set(r.resourceSchema.name,r.hooks);}}static create(e){return new c(e)}getHooks(e){return this.hooksRegistry.get(e)}},Kr=c=>be.create({...c}),Je=(c=>({handler:e=>({_type:"query",inputValidator:c??z$1.undefined(),handler:e})})),Ge=(c=>({handler:e=>({_type:"mutation",inputValidator:c??z$1.undefined(),handler:e})})),Re=class c{resourceSchema;middlewares;customMutations;customQueries;authorization;hooks;constructor(e,t,r,i,s){this.resourceSchema=e,this.middlewares=new Set,this.customMutations=t??{},this.customQueries=r??{},this.authorization=i,this.hooks=s;}use(...e){for(let t of e)this.middlewares.add(t);return this}withProcedures(e){let t=e({mutation:Ge,query:Je}),r={},i={};for(let[s,o]of Object.entries(t))o._type==="mutation"?r[s]=o:i[s]=o;return new c(this.resourceSchema,r,i,this.authorization,this.hooks)}withMutations(e){return this.withProcedures(({mutation:t})=>e({mutation:t}))}withHooks(e){return new c(this.resourceSchema,this.customMutations,this.customQueries,this.authorization,e)}handleQuery=async({req:e,batcher:t})=>await this.wrapInMiddlewares(async r=>{let i={resource:r.resource,where:r.where,include:r.include,lastSyncedAt:r.lastSyncedAt,limit:r.limit,sort:r.sort},s=B(i);return {data:await t.rawFind({resource:r.resource,commonWhere:r.where,uniqueWhere:r.relationalWhere,include:r.include,limit:r.limit,sort:r.sort}),unsubscribe:void 0,queryHash:s}})(e);handleMutation=async({req:e,db:t,schema:r})=>{var a;let i=((a=e.meta)==null?void 0:a.timestamp)??new Date().toISOString(),s=t._setMutationTimestamp(i),o=V(s,r,e.context);return await this.wrapInMiddlewares(async n=>{if(!n.procedure)throw new Error("Procedure is required for mutations");let u=this.customMutations[n.procedure];if(u){let l=u.inputValidator["~standard"].validate(n.input),d=l instanceof Promise?await l:l;if(d.issues){let h=d.issues.map(y=>{var p;let m=(p=y.path)==null?void 0:p.map(f=>typeof f=="object"&&"key"in f?String(f.key):String(f)).join(".");return m?`${m}: ${y.message}`:y.message}).join(", ");throw new Error(`Validation failed: ${h}`)}return n.input=d.value,u.handler({req:n,db:o})}else {if(n.procedure==="INSERT"||n.procedure==="UPDATE")return this.handleSet({req:n,db:s,operation:n.procedure,schema:r});throw new Error(`Unknown procedure: ${n.procedure}`)}})(e)};handleCustomQuery=async({req:e,db:t,schema:r})=>{let i=V(t,r,e.context);return await this.wrapInMiddlewares(async s=>{let o=this.customQueries[s.procedure];if(!o)throw new Error(`Unknown query procedure: ${s.procedure}`);let a=o.inputValidator["~standard"].validate(s.input),n=a instanceof Promise?await a:a;if(n.issues){let u=n.issues.map(l=>{var h;let d=(h=l.path)==null?void 0:h.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return d?`${d}: ${l.message}`:l.message}).join(", ");throw new Error(`Validation failed: ${u}`)}return s.input=n.value,o.handler({req:s,db:i})})(e)};getAuthorizationClause(e){var t,r;return (r=(t=this.authorization)==null?void 0:t.read)==null?void 0:r.call(t,{ctx:e.context})}handleSet=async({req:e,db:t,operation:r,schema:i})=>{if(!e.input)throw new Error("Payload is required");if(!e.resourceId)throw new Error("ResourceId is required");let s=await t.rawFindById(e.resource,e.resourceId);if(r==="INSERT"&&s)throw new Error("Resource already exists");if(r==="UPDATE"&&!s)throw new Error("Resource not found");let o={value:e.input};return t.transaction(async({trx:a})=>{var l,d,h,y,m,p,f;if(r==="INSERT"){let{data:g,acceptedValues:T}=await a.rawInsert(e.resource,e.resourceId,o,(l=e.context)==null?void 0:l.messageId,e.context);if(!T)throw new Error("Mutation rejected");let b=z$2(g);if(b.id=b.id??e.resourceId,(d=this.authorization)!=null&&d.insert){let R=this.authorization.insert({ctx:e.context,value:b});if(typeof R=="boolean"){if(!R)throw new Error("Not authorized")}else {let S=C(R,e.resource,i),v=Object.keys(S).length>0?await a.rawFindById(e.resource,e.resourceId,S):g,E=z$2(v);if(E.id=E.id??e.resourceId,!D$1(E,R))throw new Error("Not authorized")}}return {data:g,acceptedValues:T}}if((y=(h=this.authorization)==null?void 0:h.update)!=null&&y.preMutation){let g=z$2(s);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 b=C(T,e.resource,i),R=Object.keys(b).length>0?await a.rawFindById(e.resource,e.resourceId,b):s,S=z$2(R);if(S.id=S.id??e.resourceId,!D$1(S,T))throw new Error("Not authorized")}}let{data:n,acceptedValues:u}=await a.rawUpdate(e.resource,e.resourceId,o,(m=e.context)==null?void 0:m.messageId,e.context);if(!u)throw new Error("Mutation rejected");if((f=(p=this.authorization)==null?void 0:p.update)!=null&&f.postMutation){let g=z$2(n);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 b=C(T,e.resource,i),R=Object.keys(b).length>0?await a.rawFindById(e.resource,e.resourceId,b):n,S=z$2(R);if(S.id=S.id??e.resourceId,!D$1(S,T))throw new Error("Not authorized")}}return {data:n,acceptedValues:u}})};wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((r,i)=>s=>i({req:s,next:r}),e)(t)}},Se=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:r})=>{var a;let i=((a=e.meta)==null?void 0:a.timestamp)??new Date().toISOString(),s=t._setMutationTimestamp(i),o=V(s,r,e.context);return await this.wrapInMiddlewares(async n=>{if(!n.procedure)throw new Error("Procedure is required for mutations");let u=this.customMutations[n.procedure];if(u){let l=u.inputValidator["~standard"].validate(n.input),d=l instanceof Promise?await l:l;if(d.issues){let h=d.issues.map(y=>{var p;let m=(p=y.path)==null?void 0:p.map(f=>typeof f=="object"&&"key"in f?String(f.key):String(f)).join(".");return m?`${m}: ${y.message}`:y.message}).join(", ");throw new Error(`Validation failed: ${h}`)}return n.input=d.value,u.handler({req:n,db:o})}throw new Error(`Unknown procedure: ${n.procedure}`)})(e)};handleCustomQuery=async({req:e,db:t,schema:r})=>{let i=V(t,r,e.context);return await this.wrapInMiddlewares(async s=>{let o=this.customQueries[s.procedure];if(!o)throw new Error(`Unknown query procedure: ${s.procedure}`);let a=o.inputValidator["~standard"].validate(s.input),n=a instanceof Promise?await a:a;if(n.issues){let u=n.issues.map(l=>{var h;let d=(h=l.path)==null?void 0:h.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return d?`${d}: ${l.message}`:l.message}).join(", ");throw new Error(`Validation failed: ${u}`)}return s.input=n.value,o.handler({req:s,db:i})})(e)};getAuthorizationClause(){}wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((r,i)=>s=>i({req:s,next:r}),e)(t)}};function Jr(c){return {_brand:"TypedMiddleware",_rawMiddleware:({req:t,next:r})=>c({ctx:t.context,req:t,next:i=>(t.context=i,r(t))})}}var we=class c{middlewares;constructor(e=[]){this.middlewares=e;}collectionRoute(e,t){return new Re(e,void 0,void 0,t,void 0).use(...this.middlewares)}withProcedures(e){let t=e({mutation:Ge,query:Je}),r={},i={};for(let[s,o]of Object.entries(t))o._type==="mutation"?r[s]=o:i[s]=o;return new Se(r,i).use(...this.middlewares)}use(...e){let t=e.map(r=>r&&r._brand==="TypedMiddleware"?r._rawMiddleware:r);return new c([...this.middlewares,...t])}static create(){return new c}},Gr=we.create;var K=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 r=this._getTimestamp(),i=await this.rawInsert(e.name,t.id,{value:Object.fromEntries(Object.entries(t).map(([s,o])=>[s,{value:o,_meta:{timestamp:r}}]))});return z$2(i.data)}async update(e,t,r){let i=this._getTimestamp(),{id:s,...o}=r,a=await this.rawUpdate(e.name,t,{value:Object.fromEntries(Object.entries(o).map(([l,d])=>[l,{value:d,_meta:{timestamp:i}}]))}),n=z$2(a.data),u={};for(let l of Object.keys(o))l in n&&(u[l]=n[l]);return u}};var Dt={postgres:{jsonObjectFrom:jsonObjectFrom$2,jsonArrayFrom:jsonArrayFrom$2},mysql:{jsonObjectFrom:jsonObjectFrom$1,jsonArrayFrom:jsonArrayFrom$1},sqlite:{jsonObjectFrom:jsonObjectFrom,jsonArrayFrom:jsonArrayFrom}};function Q(c){var i,s,o;let e=(i=c.getExecutor)==null?void 0:i.call(c),t=e==null?void 0:e.adapter;if(!t)return "postgres";let r=((o=(s=t.constructor)==null?void 0:s.name)==null?void 0:o.toLowerCase())??"";return r.includes("postgres")?"postgres":r.includes("mysql")?"mysql":r.includes("sqlite")?"sqlite":"postgres"}function Ze(c){let e=Q(c);return Dt[e]}var Vt="42701";function J(c){var t;if(c.code===Vt)return true;let e=((t=c.message)==null?void 0:t.toLowerCase())||"";return e.includes("already exists")||e.includes("duplicate")||e.includes("already defined")}function ve(c,e){let{type:t,enumValues:r,enumName:i}=c;if(r&&r.length>0)return e==="postgres"&&i?i:"varchar";if(t==="jsonb"||t==="json")switch(e){case "postgres":return "jsonb";case "mysql":return "json";case "sqlite":return "text"}return t}async function Bt(c,e,t,r){if(t!=="postgres")return;let i=new Map;for(let s of Object.values(e))for(let o of Object.values(s.fields)){let a=o.getStorageFieldType();a.enumValues&&a.enumName&&i.set(a.enumName,{name:a.enumName,values:a.enumValues});}for(let s of Array.from(i.values())){let{name:o,values:a}=s;try{let n=a.map(u=>`'${u}'`).join(", ");await sql`
|
|
1
|
+
import {a,b,B as B$1,z as z$2,C,D as D$1,G,F,E}from'./chunk-3XEJ2M4E.js';import Z from'crypto';import Mt,{parse}from'qs';import {z as z$1}from'zod';import {Kysely,PostgresDialect,sql}from'kysely';import {jsonArrayFrom as jsonArrayFrom$1,jsonObjectFrom as jsonObjectFrom$1}from'kysely/helpers/mysql';import {jsonArrayFrom as jsonArrayFrom$2,jsonObjectFrom as jsonObjectFrom$2}from'kysely/helpers/postgres';import {jsonArrayFrom,jsonObjectFrom}from'kysely/helpers/sqlite';var he=a(re=>{Object.defineProperty(re,"__esModule",{value:true});re.parse=bt;re.serialize=St;var mt=/^[\u0021-\u003A\u003C\u003E-\u007E]+$/,pt=/^[\u0021-\u003A\u003C-\u007E]*$/,ft=/^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i,gt=/^[\u0020-\u003A\u003D-\u007E]*$/,Tt=Object.prototype.toString,Rt=(()=>{let c=function(){};return c.prototype=Object.create(null),c})();function bt(c,e){let t=new Rt,r=c.length;if(r<2)return t;let i=(e==null?void 0:e.decode)||wt,s=0;do{let o=c.indexOf("=",s);if(o===-1)break;let a=c.indexOf(";",s),n=a===-1?r:a;if(o>n){s=c.lastIndexOf(";",o-1)+1;continue}let u=Qe(c,s,o),l=Ne(c,o,u),d=c.slice(u,l);if(t[d]===void 0){let h=Qe(c,o+1,n),y=Ne(c,n,h),p=i(c.slice(h,y));t[d]=p;}s=n+1;}while(s<r);return t}function Qe(c,e,t){do{let r=c.charCodeAt(e);if(r!==32&&r!==9)return e}while(++e<t);return t}function Ne(c,e,t){for(;e>t;){let r=c.charCodeAt(--e);if(r!==32&&r!==9)return e+1}return t}function St(c,e,t){let r=(t==null?void 0:t.encode)||encodeURIComponent;if(!mt.test(c))throw new TypeError(`argument name is invalid: ${c}`);let i=r(e);if(!pt.test(i))throw new TypeError(`argument val is invalid: ${e}`);let s=c+"="+i;if(!t)return s;if(t.maxAge!==void 0){if(!Number.isInteger(t.maxAge))throw new TypeError(`option maxAge is invalid: ${t.maxAge}`);s+="; Max-Age="+t.maxAge;}if(t.domain){if(!ft.test(t.domain))throw new TypeError(`option domain is invalid: ${t.domain}`);s+="; Domain="+t.domain;}if(t.path){if(!gt.test(t.path))throw new TypeError(`option path is invalid: ${t.path}`);s+="; Path="+t.path;}if(t.expires){if(!xt(t.expires)||!Number.isFinite(t.expires.valueOf()))throw new TypeError(`option expires is invalid: ${t.expires}`);s+="; Expires="+t.expires.toUTCString();}if(t.httpOnly&&(s+="; HttpOnly"),t.secure&&(s+="; Secure"),t.partitioned&&(s+="; Partitioned"),t.priority)switch(typeof t.priority=="string"?t.priority.toLowerCase():void 0){case "low":s+="; Priority=Low";break;case "medium":s+="; Priority=Medium";break;case "high":s+="; 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":s+="; SameSite=Strict";break;case "lax":s+="; SameSite=Lax";break;case "none":s+="; SameSite=None";break;default:throw new TypeError(`option sameSite is invalid: ${t.sameSite}`)}return s}function wt(c){if(c.indexOf("%")===-1)return c;try{return decodeURIComponent(c)}catch{return c}}function xt(c){return Tt.call(c)==="[object Date]"}});var Pe="0123456789ABCDEFGHJKMNPQRSTVWXYZ",H=32;var it=16,Le=10,Ee=0xffffffffffff;var q;(function(c){c.Base32IncorrectEncoding="B32_ENC_INVALID",c.DecodeTimeInvalidCharacter="DEC_TIME_CHAR",c.DecodeTimeValueMalformed="DEC_TIME_MALFORMED",c.EncodeTimeNegative="ENC_TIME_NEG",c.EncodeTimeSizeExceeded="ENC_TIME_SIZE_EXCEED",c.EncodeTimeValueMalformed="ENC_TIME_MALFORMED",c.PRNGDetectFailure="PRNG_DETECT",c.ULIDInvalid="ULID_INVALID",c.Unexpected="UNEXPECTED",c.UUIDInvalid="UUID_INVALID";})(q||(q={}));var _=class extends Error{constructor(e,t){super(`${t} (${e})`),this.name="ULIDError",this.code=e;}};function st(c){let e=Math.floor(c()*H);return e===H&&(e=H-1),Pe.charAt(e)}function at(c){var r;let e=ot(),t=e&&(e.crypto||e.msCrypto)||(typeof Z<"u"?Z:null);if(typeof(t==null?void 0:t.getRandomValues)=="function")return ()=>{let i=new Uint8Array(1);return t.getRandomValues(i),i[0]/255};if(typeof(t==null?void 0:t.randomBytes)=="function")return ()=>t.randomBytes(1).readUInt8()/255;if((r=Z)!=null&&r.randomBytes)return ()=>Z.randomBytes(1).readUInt8()/255;throw new _(q.PRNGDetectFailure,"Failed to find a reliable PRNG")}function ot(){return dt()?self:typeof window<"u"?window:typeof global<"u"?global:typeof globalThis<"u"?globalThis:null}function ct(c,e){let t="";for(;c>0;c--)t=st(e)+t;return t}function ut(c,e=Le){if(isNaN(c))throw new _(q.EncodeTimeValueMalformed,`Time must be a number: ${c}`);if(c>Ee)throw new _(q.EncodeTimeSizeExceeded,`Cannot encode a time larger than ${Ee}: ${c}`);if(c<0)throw new _(q.EncodeTimeNegative,`Time must be positive: ${c}`);if(Number.isInteger(c)===false)throw new _(q.EncodeTimeValueMalformed,`Time must be an integer: ${c}`);let t,r="";for(let i=e;i>0;i--)t=c%H,r=Pe.charAt(t)+r,c=(c-t)/H;return r}function dt(){return typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope}function ke(c,e){let t=at(),r=Date.now();return ut(r,Le)+ct(it,t)}var X=()=>ke().toLowerCase(),Y=c=>({then(e,t){try{if(e){let r=e(c);return r instanceof Promise?r:Y(r)}return Y(c)}catch(r){if(t){let i=t(r);return i instanceof Promise?i:Y(i)}throw r}}}),de=c=>c instanceof Promise?c:Y(c);var z=(...c)=>{let e=c.filter(t=>!!t);return e.length===0?{}:e.length===1?e[0]:{$and:e}};var ee=class{storage;queue=new Map;scheduled=false;constructor(e){this.storage=e;}async rawFind({resource:e,commonWhere:t,uniqueWhere:r,...i}){return new Promise((s,o)=>{let a=this.getBatchKey({resource:e,commonWhere:t,...i}),n={resource:e,commonWhere:t,uniqueWhere:r,...i,resolve:s,reject:o};this.queue.has(a)||this.queue.set(a,[]);let u=this.queue.get(a);u&&u.push(n),this.scheduled||(this.scheduled=true,setImmediate(()=>{this.processBatch();}));})}getBatchKey(e){let{resource:t,commonWhere:r,...i}=e;return `${t}:${JSON.stringify(r??{})}:${JSON.stringify(i??{})}`}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(r){t.forEach(i=>{i.reject(r);});}}async executeBatchedRequests(e){var h;if(e.length===0)return;let t=e[0],{resource:r,commonWhere:i,include:s,sort:o}=t,a=e.length===1?t.limit:void 0,n=e.map(y=>y.uniqueWhere).filter(y=>y!==void 0),u=i,l=(h=Object.entries(n[0]??{})[0])==null?void 0:h[0];if(n.length>0){let y=n.map(p=>p[l]).filter(p=>p!=null);y.length>0&&(u=z(i,{[l]:{$in:y}}));}let d=await this.storage.get({resource:r,where:u,include:s,sort:o,limit:a});for(let y of e){let p=d;if(y.uniqueWhere){let[m,g]=Object.entries(y.uniqueWhere)[0];p=d.filter(T=>{var f;return ((f=T.value[m])==null?void 0:f.value)===g});}y.resolve(p);}}};function le(c){return B$1({resource:c.query.resource,where:c.query.where,include:c.query.include,stepPath:c.stepPath,isMany:c.isMany,relationName:c.relationName})}var te=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,r=this.schema[e];if(!(r!=null&&r.relations))return t;for(let[i,s]of Object.entries(r.relations))s.type==="one"&&s.relationalColumn&&t.set(String(s.relationalColumn),{relationName:i,targetResource:s.entity.name});return t}ensureObjectNode(e,t,r){let i=this.objectNodes.get(e);return i?r&&i.matchedQueries.add(r):(i={id:e,type:t,matchedQueries:new Set(r?[r]:[]),referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e,i)),i}storeRelation(e,t,r,i){let s=this.objectNodes.get(e),o=this.objectNodes.get(t);if(s&&s.referencesObjects.set(r,t),o&&i){let a=o.referencedByObjects.get(i);a||(a=new Set,o.referencedByObjects.set(i,a)),a.add(e);}}removeRelation(e,t,r,i){let s=this.objectNodes.get(e),o=this.objectNodes.get(t);if(s&&s.referencesObjects.delete(r),o&&i){let a=o.referencedByObjects.get(i);a&&(a.delete(e),a.size===0&&o.referencedByObjects.delete(i));}}getInverseRelationName(e,t,r){let i=this.schema[e];if(!(i!=null&&i.relations))return;let s=i.relations[r];if(!s)return;let o=this.schema[t];if(o!=null&&o.relations){if(s.type==="many"&&s.foreignColumn){for(let[a,n]of Object.entries(o.relations))if(n.entity.name===e&&n.type==="one"&&n.relationalColumn===s.foreignColumn)return a}if(s.type==="one"&&s.relationalColumn){for(let[a,n]of Object.entries(o.relations))if(n.entity.name===e&&n.type==="many"&&n.foreignColumn===s.relationalColumn)return a}}}updateRelationsFromMutation(e,t,r,i){let s=this.getRelationalColumns(e),o=this.objectNodes.get(t);if(o)for(let[a,{relationName:n,targetResource:u}]of Array.from(s)){if(!(i&&a in i))continue;let d=this.getInverseRelationName(e,u,n),h=o.referencesObjects.get(n),y=r[a];h!==y&&(h&&this.removeRelation(t,h,n,d),y&&(this.ensureObjectNode(y,u),this.storeRelation(t,y,n,d)));}}get(e,t){let r=this.breakdownQuery({query:e,context:(t==null?void 0:t.context)??{}});return this.resolveQuery(r,{context:(t==null?void 0:t.context)??{},batcher:(t==null?void 0:t.batcher)??new ee(this.storage)})}subscribe(e,t,r={}){let i=this.breakdownQuery({query:e,context:r}),s={},o=[];for(let a of i){this.logger.debug("[QueryEngine] Subscribing to step",a.stepPath.join("."));let n=le(a),u=s[a.stepPath.at(-2)??""],l=a.stepPath.at(-1)??"",d=this.queryNodes.get(n);if(d)d.subscriptions.add(t);else if(d={hash:n,queryStep:a,relationName:l,trackedObjects:new Set,subscriptions:new Set([t]),parentQuery:u,childQueries:new Set},this.queryNodes.set(d.hash,d),u){let h=this.queryNodes.get(u);h&&h.childQueries.add(d.hash);}s[l]=n,o.push(()=>{let h=this.queryNodes.get(n);h&&(h.subscriptions.delete(t),h.subscriptions.size===0&&this.queryNodes.delete(n));});}return ()=>{for(let a of o)a();}}breakdownQuery(e){var g;let{query:t,stepPath:r=[],context:i={},parentResource:s}=e,{include:o}=t,a=r.length===0,n=r.at(-1),u,l,d;if(!a&&s&&n){let T=this.schema[s],f=(g=T==null?void 0:T.relations)==null?void 0:g[n];f&&(d=f.type==="many",f.type==="one"?(u=R=>({id:R}),l=R=>R.map(b=>{var S,v;return (v=(S=b.value)==null?void 0:S[f.relationalColumn])==null?void 0:v.value}).filter(b=>b!==void 0)):(u=R=>({[f.foreignColumn]:R}),l=R=>R.map(b=>{var S,v;return (v=(S=b.value)==null?void 0:S.id)==null?void 0:v.value}).filter(b=>b!==void 0)));}let{include:h,...y}=t,m=[this.router.incrementQueryStep({query:y,stepPath:[...r],getWhere:u,referenceGetter:l,isMany:d,relationName:n},i)];if(o&&typeof o=="object"&&Object.keys(o).length>0){let T=this.schema[t.resource];if(!T)throw new Error(`Resource ${t.resource} not found`);m.push(...Object.entries(o).flatMap(([f,R])=>{let b=T.relations[f];if(!b)throw new Error(`Relation ${f} not found for resource ${t.resource}`);let S=b.entity.name,v=E(R)?R:null;return this.breakdownQuery({query:{resource:S,include:v?v.include:typeof R=="object"?R:void 0,where:v==null?void 0:v.where,limit:v==null?void 0:v.limit,sort:v==null?void 0:v.orderBy},stepPath:[...r,f],context:i,parentResource:t.resource})}));}return m}resolveQuery(e,t){this.logger.debug("[QueryEngine] Resolving query",e.map(s=>s.stepPath.join(".")).join(" -> "));let r={},i=this.resolveStep(e[0],t).then(s=>{this.logger.debug("[QueryEngine] Resolved step",e[0].stepPath.join("."),"with results count:",s.length),r[e[0].stepPath.join(".")]=[{data:s}];});for(let s=1;s<e.length;s++){let o=e[s],a=o.stepPath.slice(0,-1).join(".");i=i.then(async()=>{var u,l;let n=r[a];if(!n){r[o.stepPath.join(".")]=[];return}if(o.referenceGetter&&o.getWhere){let d=new Map;for(let p of n)for(let m of p.data){let g=(l=(u=m==null?void 0:m.value)==null?void 0:u.id)==null?void 0:l.value;if(!g)continue;let f=o.referenceGetter([m])[0];if(f){d.has(f)||d.set(f,new Set);let R=d.get(f);R&&R.add(g);}}let h=Array.from(d.keys());if(h.length===0){r[o.stepPath.join(".")]=[];return}let y=[];for(let p of h){let m=o.getWhere(p),g={...o,relationalWhere:m},T=await this.resolveStep(g,t),f=d.get(p);if(f)for(let R of Array.from(f))y.push({includedBy:R,data:T});}this.logger.debug("[QueryEngine] Resolved step",o.stepPath.join("."),"with results count:",y.reduce((p,m)=>p+m.data.length,0)),r[o.stepPath.join(".")]=y;}else {let d=await this.resolveStep(o,t);r[o.stepPath.join(".")]=[{data:d}];}});}return i=i.then((()=>(this.logger.debug("[QueryEngine] Assembling results"),this.assembleResults(e,r)))),i}assembleResults(e,t){var o,a,n,u,l;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 r=new Map;for(let d of e){let h=d.stepPath.join("."),y=t[h]??[],p=Object.keys(d.query.include??{});this.logger.debug(`[QueryEngine] assembleResults: Processing step "${h}"`,{resource:d.query.resource,includedRelations:p,resultGroups:y.length,isMany:d.isMany,relationName:d.relationName});for(let m of y){this.logger.debug(`[QueryEngine] assembleResults: Processing result group for "${h}"`,{dataCount:m.data.length,includedBy:m.includedBy});for(let g of m.data){let T=(a=(o=g==null?void 0:g.value)==null?void 0:o.id)==null?void 0:a.value;if(!T){this.logger.debug(`[QueryEngine] assembleResults: Skipping data without id in step "${h}"`);continue}let f=h?`${h}.${T}`:T,R=[];if(d.stepPath.length>0&&m.includedBy){let S=d.stepPath.slice(0,-1).join(".");R=[S?`${S}.${m.includedBy}`:m.includedBy],this.logger.debug(`[QueryEngine] assembleResults: Child entity "${f}" has parent keys:`,R,{stepPath:h,parentStepPath:S,includedBy:m.includedBy});}else this.logger.debug(`[QueryEngine] assembleResults: Root entity "${f}" (no parent)`);let b=r.get(f);if(b){this.logger.debug(`[QueryEngine] assembleResults: Entity "${f}" already exists, adding parent keys:`,R);for(let S of R)b.includedBy.add(S);}else this.logger.debug(`[QueryEngine] assembleResults: Adding new entity "${f}"`,{resource:d.query.resource,path:d.stepPath.at(-1)??"",isMany:d.isMany??false,relationName:d.relationName,includedRelations:p,parentKeys:R}),r.set(f,{data:g,includedBy:new Set(R),path:d.stepPath.at(-1)??"",isMany:d.isMany??false,relationName:d.relationName,resourceName:d.query.resource,includedRelations:p});}}}this.logger.debug(`[QueryEngine] assembleResults: Built entriesMap with ${r.size} entries`),this.logger.debug("[QueryEngine] assembleResults: EntriesMap keys:",Array.from(r.keys()));let i=Array.from(r.entries()),s=[];this.logger.debug(`[QueryEngine] assembleResults: Starting assembly phase with ${i.length} entries`);for(let d=i.length-1;d>=0;d--){let[h,y]=i[d],p=this.schema[y.resourceName];this.logger.debug(`[QueryEngine] assembleResults: Processing entry "${h}"`,{resource:y.resourceName,path:y.path,isMany:y.isMany,relationName:y.relationName,includedRelations:y.includedRelations,parentKeys:Array.from(y.includedBy)});for(let m of y.includedRelations){let g=(u=(n=p==null?void 0:p.relations)==null?void 0:n[m])==null?void 0:u.type,T=!!y.data.value[m];if(this.logger.debug(`[QueryEngine] assembleResults: Checking included relation "${m}" for "${h}"`,{relationType:g,hasRelation:T,resourceHasRelation:!!((l=p==null?void 0:p.relations)!=null&&l[m])}),y.data.value[m])this.logger.debug(`[QueryEngine] assembleResults: Relation "${m}" already exists for "${h}"`,y.data.value[m]);else {let f=g==="many"?{value:[]}:{value:null};y.data.value[m]=f,this.logger.debug(`[QueryEngine] assembleResults: Initialized relation "${m}" for "${h}" with`,f);}}if(y.path===""){this.logger.debug(`[QueryEngine] assembleResults: Adding root entity "${h}" to resultData`),s.unshift(y.data);continue}this.logger.debug(`[QueryEngine] assembleResults: Attaching "${h}" to ${y.includedBy.size} parent(s)`);for(let m of Array.from(y.includedBy)){let g=r.get(m);if(!g){this.logger.warn(`[QueryEngine] assembleResults: WARNING - Parent "${m}" not found in entriesMap for child "${h}"`);continue}let T=y.relationName??y.path;this.logger.debug(`[QueryEngine] assembleResults: Attaching "${h}" to parent "${m}" via relation "${T}"`,{isMany:y.isMany,parentHasRelation:!!g.data.value[T]}),y.isMany?(g.data.value[T]??={value:[]},g.data.value[T].value.push(y.data),this.logger.debug(`[QueryEngine] assembleResults: Added "${h}" to many relation "${T}" on parent "${m}"`,{arrayLength:g.data.value[T].value.length})):(g.data.value[T]=y.data,this.logger.debug(`[QueryEngine] assembleResults: Set one relation "${T}" on parent "${m}" to "${h}"`));}}return this.logger.debug(`[QueryEngine] assembleResults: Assembly complete. Returning ${s.length} root items`),s}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:r,relationalWhere:i}=e,s=r.where&&i?z(r.where,i):i??r.where,o=s?{...r,where:s}:r;return de(this.router.get(o,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 r=le(e),i=this.queryNodes.get(r),s=e.query.resource;if(!i)return;let o=this.getRelationalColumns(s);for(let a of t){let n=z$2(a),u=n.id;this.ensureObjectNode(u,s,r),i.trackedObjects.add(u);for(let[l,{relationName:d,targetResource:h}]of Array.from(o)){let y=n[l];if(y){this.ensureObjectNode(y,h);let p=this.getInverseRelationName(s,h,d);this.storeRelation(u,y,d,p);}}this.loadNestedRelations(s,u,n),this.logger.debug("[QueryEngine] Loaded nested relations for",u);}}loadNestedRelations(e,t,r){let i=this.schema[e];if(i!=null&&i.relations)for(let[s,o]of Object.entries(i.relations)){let a=r[s];if(!a)continue;let n=o.entity.name,u=this.getInverseRelationName(e,n,s);if(o.type==="one")a&&typeof a=="object"&&a.id&&(this.ensureObjectNode(a.id,n),this.storeRelation(t,a.id,s,u),this.loadNestedRelations(n,a.id,a));else if(o.type==="many"&&Array.isArray(a)){for(let l of a)if(l&&typeof l=="object"&&l.id){this.ensureObjectNode(l.id,n);let d=this.getInverseRelationName(n,e,s);d&&this.storeRelation(l.id,t,d,s),this.loadNestedRelations(n,l.id,l);}}}}buildIncludeFromChildQueries(e){let t=this.queryNodes.get(e);if(!t||t.childQueries.size===0)return {};let r={};for(let i of Array.from(t.childQueries)){let s=this.queryNodes.get(i);if(!s||!s.relationName)continue;let o=this.buildIncludeFromChildQueries(i);r[s.relationName]=Object.keys(o).length>0?o:true;}return r}sendInsertsForTree(e,t,r){var a,n;let i=(n=(a=t==null?void 0:t.value)==null?void 0:a.id)==null?void 0:n.value;if(!i)return;let s={procedure:"INSERT",resource:r,resourceId:i,type:"MUTATE",payload:t.value};for(let u of Array.from(e.subscriptions))try{u(s);}catch(l){this.logger.error("[QueryEngine] Error in subscription callback during sendInsertsForTree",{error:l,queryHash:e.hash,resource:r,resourceId:i,stepPath:e.queryStep.stepPath.join(".")});}e.trackedObjects.add(i),this.ensureObjectNode(i,r,e.hash).matchedQueries.add(e.hash);for(let u of Array.from(e.childQueries)){let l=this.queryNodes.get(u);if(!l||!l.relationName)continue;let d=l.relationName,h=l.queryStep.query.resource,y=t.value[d];if(!y)continue;let p=y.value;if(Array.isArray(p))for(let m of p)this.sendInsertsForTree(l,m,h);else p&&typeof p=="object"&&this.sendInsertsForTree(l,p,h);}}handleMutation(e,t){if(e.procedure==="INSERT"){if(this.objectNodes.has(e.resourceId))return;let r=z$2(t);if(!r)return;let i={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map};this.objectNodes.set(e.resourceId,i);let s=this.getRelationalColumns(e.resource);for(let[a,{relationName:n,targetResource:u}]of Array.from(s)){let l=r[a];if(l){this.ensureObjectNode(l,u);let d=this.getInverseRelationName(e.resource,u,n);this.storeRelation(e.resourceId,l,n,d);}}let o=this.objectNodes.get(e.resourceId);this.getMatchingQueries(e,r).then(a=>{for(let n of a){let u=this.queryNodes.get(n);if(u){u.trackedObjects.add(e.resourceId),o&&o.matchedQueries.add(n);for(let l of Array.from(u.subscriptions))try{l(e);}catch(d){this.logger.error("[QueryEngine] Error in subscription callback during INSERT mutation",{error:d,queryHash:u.hash,resource:e.resource,resourceId:e.resourceId,stepPath:u.queryStep.stepPath.join(".")});}}}});return}if(e.procedure==="UPDATE"){let r=z$2(t);if(!r)return;let i=this.objectNodes.get(e.resourceId),s=new Set((i==null?void 0:i.matchedQueries)??[]);i||(i={id:e.resourceId,type:e.resource,matchedQueries:new Set,referencesObjects:new Map,referencedByObjects:new Map},this.objectNodes.set(e.resourceId,i)),this.updateRelationsFromMutation(e.resource,e.resourceId,r,e.payload),this.getMatchingQueries(e,r).then(o=>{let a=new Set(o),n=[],u=[],l=[];for(let h of o)s.has(h)?l.push(h):n.push(h);for(let h of Array.from(s))a.has(h)||u.push(h);for(let h of n){let y=this.queryNodes.get(h);y&&y.trackedObjects.add(e.resourceId);}for(let h of u){let y=this.queryNodes.get(h);y&&y.trackedObjects.delete(e.resourceId);}let d=this.objectNodes.get(e.resourceId);if(d){for(let h of n)d.matchedQueries.add(h);for(let h of u)d.matchedQueries.delete(h);}for(let h of [...u,...l]){let y=this.queryNodes.get(h);if(y)for(let p of Array.from(y.subscriptions))try{p(e);}catch(m){this.logger.error("[QueryEngine] Error in subscription callback during UPDATE mutation",{error:m,queryHash:y.hash,resource:e.resource,resourceId:e.resourceId,stepPath:y.queryStep.stepPath.join(".")});}}if(n.length>0)for(let h of n){let y=this.queryNodes.get(h);if(!y)continue;let p=this.buildIncludeFromChildQueries(h);this.get({resource:e.resource,where:{id:e.resourceId},include:Object.keys(p).length>0?p:void 0}).then(m=>{!m||m.length===0||this.sendInsertsForTree(y,m[0],e.resource);});}});return}}getMatchingQueries(e,t){let r=[];for(let i of Array.from(this.queryNodes.values()))i.queryStep.query.resource===e.resource&&r.push(i);return r.length===0?de([]):Promise.all(r.map(async i=>{let s=i.queryStep.query.where,o=i.queryStep.query.resource,a=e.resourceId,n=this.objectNodes.get(a);if(!n)return {hash:i.hash,matches:false};if(i.relationName){let y=i.parentQuery?this.queryNodes.get(i.parentQuery):void 0,p=y==null?void 0:y.queryStep.query.resource,m=p?this.getInverseRelationName(p,o,i.relationName):void 0,g=m?n.referencesObjects.get(m):void 0;if(!g)return {hash:i.hash,matches:false};let T=this.objectNodes.get(g);return !T||!y||!T.matchedQueries.has(y.hash)?{hash:i.hash,matches:false}:{hash:i.hash,matches:true}}if(!s)return {hash:i.hash,matches:true};let u=C(s,o,this.schema),l=Object.keys(u).length>0;if(!l&&t!==void 0)return {hash:i.hash,matches:D$1(t,s)};let d=await this.storage.get({resource:o,where:{id:a},include:l?u:void 0});if(!d||d.length===0)return {hash:i.hash,matches:false};let h=z$2(d[0]);return h?{hash:i.hash,matches:D$1(h,s)}:{hash:i.hash,matches:false}})).then(i=>i.filter(s=>s.matches).map(s=>s.hash))}};var gr=c=>c,lt=["beforeInsert","afterInsert","beforeUpdate","afterUpdate"],yt=c=>c.length===1?c[0]:(async e=>{let t=e.rawValue,r=e.value,i=false;for(let s of c){let o=await s({...e,value:r,rawValue:t});o&&(t=o,r=z$2(t),r.id=e.value.id,i=true);}return i?t:void 0}),ht=c=>c.length===1?c[0]:(async e=>{for(let t of c)await t(e);}),ye=c=>{let e=c.filter(r=>r!=null);if(e.length===0)return;if(e.length===1)return e[0];let t={};for(let r of lt){let i=e.map(s=>s[r]).filter(s=>s!=null);i.length!==0&&(r==="afterInsert"||r==="afterUpdate"?t[r]=ht(i):t[r]=yt(i));}return t},Tr=(...c)=>{let e={},t=new Set;for(let r of c)for(let i of Object.keys(r))t.add(i);for(let r of Array.from(t)){let i=c.map(o=>o[r]),s=ye(i);s&&(e[r]=s);}return e};var Ve=b(he(),1);var ne=z$1.object({resource:z$1.string(),where:z$1.record(z$1.string(),z$1.any()).optional(),include:z$1.record(z$1.string(),z$1.any()).optional(),lastSyncedAt:z$1.string().optional(),limit:z$1.coerce.number().optional(),sort:z$1.array(z$1.object({key:z$1.string(),direction:z$1.enum(["asc","desc"])})).optional()}),me=z$1.record(z$1.string(),z$1.object({value:z$1.any().nullable(),_meta:z$1.object({timestamp:z$1.string().optional().nullable()}).optional()})),vt=me.superRefine((c,e)=>{c.id&&e.addIssue({code:z$1.ZodIssueCode.custom,message:"Payload cannot have an id"});}),$e=z$1.object({id:z$1.string().optional(),type:z$1.literal("MUTATE"),resource:z$1.string(),resourceId:z$1.string().optional()}),qe=z$1.object({timestamp:z$1.string().optional(),originMutationId:z$1.string().optional()}).optional(),B=$e.extend({procedure:z$1.string(),payload:z$1.any().optional(),meta:qe}),U=$e.extend({procedure:z$1.enum(["INSERT","UPDATE"]),payload:vt,meta:qe});z$1.union([U,B]);var _e=z$1.object({resource:z$1.string(),procedure:z$1.string(),input:z$1.any().optional()});var De=ne.omit({resource:true}),ie=B.omit({id:true,type:true,resource:true,procedure:true}).extend({meta:B.shape.meta}),pe=U.omit({id:true,type:true,resource:true,procedure:true});z$1.union([pe,ie]);var fe=c=>{if(c==null)return c;if(c==="null")return null;if(Array.isArray(c))return c.map(fe);if(typeof c=="object"&&c.constructor===Object){let e={};for(let[t,r]of Object.entries(c))e[t]=fe(r);return e}return c},ze=c=>{let e=c.logger;return async t=>{var r;try{let i=typeof t.headers.getSetCookie=="function"?Object.fromEntries(t.headers):t.headers,s={headers:i,cookies:i.cookie?Ve.default.parse(i.cookie):{}},o=new URL(t.url),a=o.pathname.split("/"),n=o.searchParams,u=fe(Mt.parse(n.toString())),l=await((r=c.contextProvider)==null?void 0:r.call(c,{transport:"HTTP",headers:s.headers,cookies:s.cookies,queryParams:u}))??{};if(t.method==="GET"){let d=a[a.length-1],{success:h,data:y,error:p}=De.safeParse(u);if(!h)return Response.json({message:"Invalid query",code:"INVALID_QUERY",details:p},{status:400});let m=await c.handleQuery({req:{...s,...y,type:"QUERY",resource:d,context:l,queryParams:u}});return !m||!m.data?Response.json({message:"Invalid resource",code:"INVALID_RESOURCE"},{status:400}):Response.json(m.data)}if(t.method==="POST")try{let d=a[a.length-1],h=a[a.length-2];if(h==="query"){if(a.length<3)return Response.json({message:"Invalid path structure for custom query",code:"INVALID_PATH"},{status:400});let f=a[a.length-3],R=t.body?await t.json():{};if(!f||f.trim()==="")return Response.json({message:"Invalid resource in path",code:"INVALID_RESOURCE"},{status:400});let b=await c.handleCustomQuery({req:{...s,type:"CUSTOM_QUERY",resource:f,procedure:d,input:R.input,context:l,queryParams:u}});return Response.json(b)}let y=h,p=t.body?await t.json():{},m,g=d;if(d==="insert"||d==="update"){let f=pe.safeParse(p);if(f.success)m=f.data,g=d.toUpperCase();else {if(!(typeof p=="object"&&p!==null&&"payload"in p&&"meta"in p))return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:f.error},{status:400});let b=ie.safeParse(p);if(!b.success)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:b.error},{status:400});m=b.data;}}else {let{success:f,data:R,error:b}=ie.safeParse(p);if(!f)return Response.json({message:"Invalid mutation",code:"INVALID_REQUEST",details:b},{status:400});m=R;}let T=await c.handleMutation({req:{...s,type:"MUTATE",resource:y,input:m.payload,context:l,resourceId:m.resourceId,procedure:g,queryParams:{},meta:m.meta}});return Response.json(T)}catch(d){return e.error("Error parsing mutation from the client:",d),d instanceof Error&&d.message.includes("Unknown procedure")?Response.json({message:d.message,code:"UNKNOWN_PROCEDURE"},{status:400}):Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}return Response.json({message:"Not found",code:"NOT_FOUND"},{status:404})}catch(i){return e.error("Unexpected error:",i),Response.json({message:"Internal server error",code:"INTERNAL_SERVER_ERROR"},{status:500})}}};var He=b(he(),1);var N=z$1.string(),ge=z$1.union([_e,ne]),Ct=z$1.object({id:N,type:z$1.literal("SUBSCRIBE")}).and(ge),jt=z$1.object({id:N,type:z$1.literal("UNSUBSCRIBE")}).and(ge),Ot=z$1.object({id:N,type:z$1.literal("QUERY")}).and(ge),At=z$1.object({id:N,type:z$1.literal("CUSTOM_QUERY"),resource:z$1.string(),procedure:z$1.string(),input:z$1.any().optional()}),Be=U.extend({id:N}),Et=B.extend({id:N}),Pt=z$1.union([Et,Be]),Fe=z$1.union([Ct,Ot,At,Pt,jt]),Lt=z$1.object({id:N,type:z$1.literal("REJECT"),resource:z$1.string(),message:z$1.string().optional()}),kt=z$1.object({id:N,type:z$1.literal("REPLY"),data:z$1.any()});z$1.union([Lt,kt,Be]);z$1.object({resource:z$1.string(),data:z$1.array(me)});var Ue=c=>{let e={},t=c.logger;return (r,i)=>{var d;let s=h=>{r.send(JSON.stringify(h));},o=X(),a=new Map,n={headers:i.headers,cookies:typeof i.headers.cookie=="string"?He.default.parse(i.headers.cookie):{}},u=parse(i.url.split("?")[1]),l=(d=c.contextProvider)==null?void 0:d.call(c,{transport:"WEBSOCKET",headers:n.headers,cookies:n.cookies,queryParams:u});e[o]=r,t.info("Client connected:",o),r.on("message",async h=>{try{t.debug("Message received from the client:",h);let y=Fe.parse(JSON.parse(h.toString()));if(y.type==="SUBSCRIBE"||y.type==="QUERY"){let{type:p,id:m,...g}=y,T=p==="SUBSCRIBE";if("procedure"in g){let f=await c.handleCustomQuery({req:{...n,type:"CUSTOM_QUERY",resource:g.resource,procedure:g.procedure,input:g.input,context:await l??{},queryParams:u},subscription:T?R=>{var b;!R.resourceId||!R.payload||!Object.keys(R.payload).length||(b=e[o])==null||b.send(JSON.stringify(R));}:void 0});if(T){if(!f||!f.data||!f.query)throw new Error("Invalid resource");f.unsubscribe&&a.set(B$1(g),f.unsubscribe),s({id:m,type:"REPLY",data:{resource:f.query.resource,data:(f.data??[]).map(R=>R.value)}});}else s({id:m,type:"REPLY",data:f});}else {let f=await c.handleQuery({req:{...n,...g,type:"QUERY",context:await l??{},queryParams:u},subscription:T?R=>{var b;!R.resourceId||!R.payload||!Object.keys(R.payload).length||(b=e[o])==null||b.send(JSON.stringify(R));}:void 0});if(!f||!f.data)throw new Error("Invalid resource");T&&f.unsubscribe&&a.set(B$1(g),f.unsubscribe),s({id:m,type:"REPLY",data:{resource:g.resource,data:(f.data??[]).map(R=>R.value)}});}}else if(y.type==="UNSUBSCRIBE"){let{type:p,id:m,...g}=y,T=a.get(B$1(g));T&&(T(),a.delete(B$1(g)));}else if(y.type==="CUSTOM_QUERY"){let{resource:p,procedure:m,input:g,id:T}=y;t.debug("Received custom query from client:",y);try{let f=await c.handleCustomQuery({req:{...n,type:"CUSTOM_QUERY",resource:p,procedure:m,input:g,context:await l??{},queryParams:u}});s({id:T,type:"REPLY",data:f});}catch(f){s({id:T,type:"REJECT",resource:p,message:f.message}),t.error("Error handling custom query from the client:",f);}}else if(y.type==="MUTATE"){let{resource:p}=y;t.debug("Received mutation from client:",y);try{let m=await c.handleMutation({req:{...n,type:"MUTATE",resource:p,input:y.payload,context:{messageId:y.id,...await l??{}},resourceId:y.resourceId,procedure:y.procedure,queryParams:u,meta:y.meta}});y.procedure&&y.procedure!=="INSERT"&&y.procedure!=="UPDATE"&&s({id:y.id,type:"REPLY",data:m});}catch(m){s({id:y.id,type:"REJECT",resource:p,message:m.message}),t.error("Error parsing mutation from the client:",m);}}}catch(y){t.error("Error handling message from the client:",y);}}),r.on("close",()=>{t.info("Connection closed",o),delete e[o];for(let h of Array.from(a.values()))h();});}};function We(c){let e=`${c.protocol}://${c.hostname}${c.url}`,t=new Headers;return Object.entries(c.headers).forEach(([r,i])=>{i&&t.set(r,Array.isArray(i)?i.join(","):i);}),new Request(e,{method:c.method,headers:t,body:c.body&&c.method!=="GET"?JSON.stringify(c.body):void 0})}var Hr=(c,e,t)=>{c.ws(`${(t==null?void 0:t.basePath)??""}/ws`,Ue(e)),c.use(`${(t==null?void 0:t.basePath)??""}/`,(r,i)=>{ze(e)(We(r)).then(o=>o.json().then(a=>i.status(o.status).send(a)));});};var se=class c{_collection;_client;_where;_include;_limit;_single;_sort;_shouldAwait;constructor(e,t,r,i,s,o,a,n){this._collection=e,this._client=t,this._where=r??{},this._include=i??{},this._limit=s,this._single=o,this._sort=a,this._shouldAwait=n,this.get=this.get.bind(this),this.subscribe=this.subscribe.bind(this);}where(e){return new c(this._collection,this._client,{...this._where,...e},this._include,this._limit,this._single,this._sort,this._shouldAwait)}include(e){return new c(this._collection,this._client,this._where,{...this._include,...e},this._limit,this._single,this._sort,this._shouldAwait)}limit(e){return new c(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 c(this._collection,this._client,e??this._where,this._include,1,true,this._sort,this._shouldAwait)}orderBy(e,t="asc"){let r=[...this._sort??[],{key:e,direction:t}];return new c(this._collection,this._client,this._where,this._include,this._limit,this._single,r,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,r){return new c(e,t,void 0,void 0,void 0,void 0,void 0,r??false)}};var Nt=c=>typeof c=="object"&&c!==null&&"value"in c&&!Array.isArray(c),Te=class{constructor(e){this.storage=e;}get(e){return Promise.resolve(this.storage.get(e)).then(t=>t.map(r=>Nt(r)?z$2(r):r))}subscribe(){throw new Error("Subscriptions are not supported server-side. Use .get() instead.")}};function D(c,e,t){let r=new Te(c),i=o=>{let a=se._init(o,r,true);return Object.assign(Object.create(a),{insert:async u=>{let l=c._getTimestamp(),d=await c.rawInsert(o.name,u.id,{value:Object.fromEntries(Object.entries(u).map(([h,y])=>[h,{value:y,_meta:{timestamp:l}}]))},void 0,t);return z$2(d.data)},update:async(u,l)=>{let d=c._getTimestamp(),{id:h,...y}=l,p=await c.rawUpdate(o.name,u,{value:Object.fromEntries(Object.entries(y).map(([T,f])=>[T,{value:f,_meta:{timestamp:d}}]))},void 0,t),m=z$2(p.data),g={};for(let T of Object.keys(y))T in m&&(g[T]=m[T]);return g}})},s={get(o,a){if(a==="findOne")return c.findOne.bind(c);if(a==="find")return c.find.bind(c);if(a==="insert")return (n,u)=>{let l=c._getTimestamp();return c.rawInsert(n.name,u.id,{value:Object.fromEntries(Object.entries(u).map(([d,h])=>[d,{value:h,_meta:{timestamp:l}}]))},void 0,t).then(d=>z$2(d.data))};if(a==="update")return (n,u,l)=>{let d=c._getTimestamp(),{id:h,...y}=l;return c.rawUpdate(n.name,u,{value:Object.fromEntries(Object.entries(y).map(([p,m])=>[p,{value:m,_meta:{timestamp:d}}]))},void 0,t).then(p=>{let m=z$2(p.data),g={};for(let T of Object.keys(y))T in m&&(g[T]=m[T]);return g})};if(a==="transaction")return async n=>c.transaction(async({trx:u,commit:l,rollback:d})=>{let h=D(u,e,t);return n({trx:h,commit:l,rollback:d})});if(a in e){let n=e[a];return i(n)}}};return new Proxy({},s)}var Re=class c{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 r=t;r.hooks&&this.hooksRegistry.set(r.resourceSchema.name,r.hooks);}}static create(e){return new c(e)}getHooks(e){return this.hooksRegistry.get(e)}},tn=c=>Re.create({...c}),Je=(c=>({handler:e=>({_type:"query",inputValidator:c??z$1.undefined(),handler:e})})),Ge=(c=>({handler:e=>({_type:"mutation",inputValidator:c??z$1.undefined(),handler:e})})),be=class c{resourceSchema;middlewares;customMutations;customQueries;authorization;hooks;constructor(e,t,r,i,s){this.resourceSchema=e,this.middlewares=new Set,this.customMutations=t??{},this.customQueries=r??{},this.authorization=i,this.hooks=s;}use(...e){for(let t of e)this.middlewares.add(t);return this}withProcedures(e){let t=e({mutation:Ge,query:Je}),r={},i={};for(let[s,o]of Object.entries(t))o._type==="mutation"?r[s]=o:i[s]=o;return new c(this.resourceSchema,r,i,this.authorization,this.hooks)}withMutations(e){return this.withProcedures(({mutation:t})=>e({mutation:t}))}withHooks(e){return new c(this.resourceSchema,this.customMutations,this.customQueries,this.authorization,e)}handleQuery=async({req:e,batcher:t})=>await this.wrapInMiddlewares(async r=>{let i={resource:r.resource,where:r.where,include:r.include,lastSyncedAt:r.lastSyncedAt,limit:r.limit,sort:r.sort},s=B$1(i);return {data:await t.rawFind({resource:r.resource,commonWhere:r.where,uniqueWhere:r.relationalWhere,include:r.include,limit:r.limit,sort:r.sort}),unsubscribe:void 0,queryHash:s}})(e);handleMutation=async({req:e,db:t,schema:r})=>{var a;let i=((a=e.meta)==null?void 0:a.timestamp)??new Date().toISOString(),s=t._setMutationTimestamp(i),o=D(s,r,e.context);return await this.wrapInMiddlewares(async n=>{if(!n.procedure)throw new Error("Procedure is required for mutations");let u=n.procedure==="INSERT"?"insert":n.procedure==="UPDATE"?"update":void 0,l=this.customMutations[n.procedure]?n.procedure:u&&this.customMutations[u]?u:n.procedure,d=this.customMutations[l];if(d){n.procedure=l;let h=d.inputValidator["~standard"].validate(n.input),y=h instanceof Promise?await h:h;if(y.issues){let p=y.issues.map(m=>{var T;let g=(T=m.path)==null?void 0:T.map(f=>typeof f=="object"&&"key"in f?String(f.key):String(f)).join(".");return g?`${g}: ${m.message}`:m.message}).join(", ");throw new Error(`Validation failed: ${p}`)}return n.input=y.value,d.handler({req:n,db:o})}else {if(n.procedure==="INSERT"||n.procedure==="UPDATE")return this.handleSet({req:n,db:s,operation:n.procedure,schema:r});throw new Error(`Unknown procedure: ${n.procedure}`)}})(e)};handleCustomQuery=async({req:e,db:t,schema:r})=>{let i=D(t,r,e.context);return await this.wrapInMiddlewares(async s=>{let o=this.customQueries[s.procedure];if(!o)throw new Error(`Unknown query procedure: ${s.procedure}`);let a=o.inputValidator["~standard"].validate(s.input),n=a instanceof Promise?await a:a;if(n.issues){let u=n.issues.map(l=>{var h;let d=(h=l.path)==null?void 0:h.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return d?`${d}: ${l.message}`:l.message}).join(", ");throw new Error(`Validation failed: ${u}`)}return s.input=n.value,o.handler({req:s,db:i})})(e)};getAuthorizationClause(e){var t,r;return (r=(t=this.authorization)==null?void 0:t.read)==null?void 0:r.call(t,{ctx:e.context})}handleSet=async({req:e,db:t,operation:r,schema:i})=>{if(!e.input)throw new Error("Payload is required");if(!e.resourceId)throw new Error("ResourceId is required");let s=await t.rawFindById(e.resource,e.resourceId);if(r==="INSERT"&&s)throw new Error("Resource already exists");if(r==="UPDATE"&&!s)throw new Error("Resource not found");let o={value:e.input};return t.transaction(async({trx:a})=>{var l,d,h,y,p,m,g;if(r==="INSERT"){let{data:T,acceptedValues:f}=await a.rawInsert(e.resource,e.resourceId,o,(l=e.context)==null?void 0:l.messageId,e.context);if(!f)throw new Error("Mutation rejected");let R=z$2(T);if(R.id=R.id??e.resourceId,(d=this.authorization)!=null&&d.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=C(b,e.resource,i),v=Object.keys(S).length>0?await a.rawFindById(e.resource,e.resourceId,S):T,E=z$2(v);if(E.id=E.id??e.resourceId,!D$1(E,b))throw new Error("Not authorized")}}return {data:T,acceptedValues:f}}if((y=(h=this.authorization)==null?void 0:h.update)!=null&&y.preMutation){let T=z$2(s);T.id=T.id??e.resourceId;let f=this.authorization.update.preMutation({ctx:e.context,value:T});if(typeof f=="boolean"){if(!f)throw new Error("Not authorized")}else {let R=C(f,e.resource,i),b=Object.keys(R).length>0?await a.rawFindById(e.resource,e.resourceId,R):s,S=z$2(b);if(S.id=S.id??e.resourceId,!D$1(S,f))throw new Error("Not authorized")}}let{data:n,acceptedValues:u}=await a.rawUpdate(e.resource,e.resourceId,o,(p=e.context)==null?void 0:p.messageId,e.context);if(!u)throw new Error("Mutation rejected");if((g=(m=this.authorization)==null?void 0:m.update)!=null&&g.postMutation){let T=z$2(n);T.id=T.id??e.resourceId;let f=this.authorization.update.postMutation({ctx:e.context,value:T});if(typeof f=="boolean"){if(!f)throw new Error("Not authorized")}else {let R=C(f,e.resource,i),b=Object.keys(R).length>0?await a.rawFindById(e.resource,e.resourceId,R):n,S=z$2(b);if(S.id=S.id??e.resourceId,!D$1(S,f))throw new Error("Not authorized")}}return {data:n,acceptedValues:u}})};wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((r,i)=>s=>i({req:s,next:r}),e)(t)}},Se=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:r})=>{var a;let i=((a=e.meta)==null?void 0:a.timestamp)??new Date().toISOString(),s=t._setMutationTimestamp(i),o=D(s,r,e.context);return await this.wrapInMiddlewares(async n=>{if(!n.procedure)throw new Error("Procedure is required for mutations");let u=this.customMutations[n.procedure];if(u){let l=u.inputValidator["~standard"].validate(n.input),d=l instanceof Promise?await l:l;if(d.issues){let h=d.issues.map(y=>{var m;let p=(m=y.path)==null?void 0:m.map(g=>typeof g=="object"&&"key"in g?String(g.key):String(g)).join(".");return p?`${p}: ${y.message}`:y.message}).join(", ");throw new Error(`Validation failed: ${h}`)}return n.input=d.value,u.handler({req:n,db:o})}throw new Error(`Unknown procedure: ${n.procedure}`)})(e)};handleCustomQuery=async({req:e,db:t,schema:r})=>{let i=D(t,r,e.context);return await this.wrapInMiddlewares(async s=>{let o=this.customQueries[s.procedure];if(!o)throw new Error(`Unknown query procedure: ${s.procedure}`);let a=o.inputValidator["~standard"].validate(s.input),n=a instanceof Promise?await a:a;if(n.issues){let u=n.issues.map(l=>{var h;let d=(h=l.path)==null?void 0:h.map(y=>typeof y=="object"&&"key"in y?String(y.key):String(y)).join(".");return d?`${d}: ${l.message}`:l.message}).join(", ");throw new Error(`Validation failed: ${u}`)}return s.input=n.value,o.handler({req:s,db:i})})(e)};getAuthorizationClause(){}wrapInMiddlewares(e){return t=>Array.from(this.middlewares.values()).reduceRight((r,i)=>s=>i({req:s,next:r}),e)(t)}};function rn(c){return {_brand:"TypedMiddleware",_rawMiddleware:({req:t,next:r})=>c({ctx:t.context,req:t,next:i=>(t.context=i,r(t))})}}var we=class c{middlewares;constructor(e=[]){this.middlewares=e;}collectionRoute(e,t){return new be(e,void 0,void 0,t,void 0).use(...this.middlewares)}withProcedures(e){let t=e({mutation:Ge,query:Je}),r={},i={};for(let[s,o]of Object.entries(t))o._type==="mutation"?r[s]=o:i[s]=o;return new Se(r,i).use(...this.middlewares)}use(...e){let t=e.map(r=>r&&r._brand==="TypedMiddleware"?r._rawMiddleware:r);return new c([...this.middlewares,...t])}static create(){return new c}},nn=we.create;var W=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 r=this._getTimestamp(),i=await this.rawInsert(e.name,t.id,{value:Object.fromEntries(Object.entries(t).map(([s,o])=>[s,{value:o,_meta:{timestamp:r}}]))});return z$2(i.data)}async update(e,t,r){let i=this._getTimestamp(),{id:s,...o}=r,a=await this.rawUpdate(e.name,t,{value:Object.fromEntries(Object.entries(o).map(([l,d])=>[l,{value:d,_meta:{timestamp:i}}]))}),n=z$2(a.data),u={};for(let l of Object.keys(o))l in n&&(u[l]=n[l]);return u}};var Bt={postgres:{jsonObjectFrom:jsonObjectFrom$2,jsonArrayFrom:jsonArrayFrom$2},mysql:{jsonObjectFrom:jsonObjectFrom$1,jsonArrayFrom:jsonArrayFrom$1},sqlite:{jsonObjectFrom:jsonObjectFrom,jsonArrayFrom:jsonArrayFrom}};function k(c){var i,s,o;let e=(i=c.getExecutor)==null?void 0:i.call(c),t=e==null?void 0:e.adapter;if(!t)return "postgres";let r=((o=(s=t.constructor)==null?void 0:s.name)==null?void 0:o.toLowerCase())??"";return r.includes("postgres")?"postgres":r.includes("mysql")?"mysql":r.includes("sqlite")?"sqlite":"postgres"}function Ze(c){let e=k(c);return Bt[e]}var Ft="42701";function K(c){var t;if(c.code===Ft)return true;let e=((t=c.message)==null?void 0:t.toLowerCase())||"";return e.includes("already exists")||e.includes("duplicate")||e.includes("already defined")}function ve(c,e){let{type:t,enumValues:r,enumName:i}=c;if(r&&r.length>0)return e==="postgres"&&i?i:"varchar";if(t==="jsonb"||t==="json")switch(e){case "postgres":return "jsonb";case "mysql":return "json";case "sqlite":return "text"}return t}async function Ht(c,e,t,r){if(t!=="postgres")return;let i=new Map;for(let s of Object.values(e))for(let o of Object.values(s.fields)){let a=o.getStorageFieldType();a.enumValues&&a.enumName&&i.set(a.enumName,{name:a.enumName,values:a.enumValues});}for(let s of Array.from(i.values())){let{name:o,values:a}=s;try{let n=a.map(u=>`'${u}'`).join(", ");await sql`
|
|
2
2
|
DO $$ BEGIN
|
|
3
3
|
CREATE TYPE ${sql.id(o)} AS ENUM (${sql.raw(n)});
|
|
4
4
|
EXCEPTION
|
|
5
5
|
WHEN duplicate_object THEN null;
|
|
6
6
|
END $$;
|
|
7
|
-
`.execute(c);}catch(n){r==null||r.warn("Could not create enum type",o,n);}}}function
|
|
7
|
+
`.execute(c);}catch(n){r==null||r.warn("Could not create enum type",o,n);}}}function J(c,e){return c.some(t=>t.name===e)}function Ut(c,e){return (c==null?void 0:c.columns.some(t=>t.name===e))??false}function Ie(c,e){let[t]=e.split(".");return J(c,t)}function xe(c,e,t,r=false){let i=c;return e.unique&&(i=i.unique()),e.nullable||(i=i.notNull()),e.primary&&(i=i.primaryKey()),e.default!==void 0&&(i=i.defaultTo(e.default)),!r&&e.references&&Ie(t,e.references)&&(i=i.references(e.references)),i}function Wt(c,e,t,r,i){let s=[];for(let[o,a]of Object.entries(c.fields)){let n=e==null?void 0:e.columns.find(l=>l.name===o),u=a.getStorageFieldType();n?(n.dataType,u.type):(s.push({name:o,storageFieldType:u}),u.references&&!Ie(t,u.references)&&r.push({tableName:i,columnName:o,references:u.references}));}return s}function Ye(c,e){return e==="postgres"&&!!c.enumValues&&c.enumValues.length>0&&!!c.enumName}async function Kt(c,e,t,r,i,s){if(t.length===0)return;let o=c.schema.createTable(e);for(let{name:a,storageFieldType:n}of t)if(Ye(n,i))o=o.addColumn(a,sql.raw(n.enumName),u=>xe(u,n,r));else {let u=ve(n,i);o=o.addColumn(a,u,l=>xe(l,n,r));}await o.execute().catch(a=>{if(!K(a))throw s==null||s.error("Error creating table",e,a),a});}async function Jt(c,e,t,r,i,s,o){for(let{name:a,storageFieldType:n}of t){let u=n.references?Ie(r,n.references):false,l=Ye(n,s)?sql.raw(n.enumName):ve(n,s);await c.schema.alterTable(e).addColumn(a,l,d=>xe(d,n,r,!u)).execute().catch(d=>{if(!K(d))throw o==null||o.error("Error adding column",a,d),d}),n.references&&!u&&!i.some(d=>d.tableName===e&&d.columnName===a)&&i.push({tableName:e,columnName:a,references:n.references}),n.index&&await c.schema.createIndex(`${e}_${a}_index`).on(e).column(a).execute().catch(()=>{});}}async function Gt(c,e,t,r,i,s){let o=`${e}_meta`,a=[];for(let[n,u]of Object.entries(t.fields)){let l=u.getStorageFieldType();Ut(r,n)||a.push({name:n,storageFieldType:l});}if(!r&&a.length>0){let n=c.schema.createTable(o);for(let{name:u,storageFieldType:l}of a)n=n.addColumn(u,"varchar",d=>{let h=d;return l.primary&&(h=h.primaryKey(),J(i,e)&&(h=h.references(`${e}.${u}`))),h});await n.execute().catch(u=>{if(!K(u))throw s==null||s.error("Error creating meta table",o,u),u});}else if(r)for(let{name:n,storageFieldType:u}of a)await c.schema.alterTable(o).addColumn(n,"varchar",l=>{let d=l;return u.primary&&(d=d.primaryKey(),J(i,e)&&(d=d.references(`${e}.${n}`))),d}).execute().catch(l=>{if(!K(l))throw s==null||s.error("Error adding meta column",n,l),l});}async function Xe(c,e,t,r,i){let[s,o]=r.split("."),a=`${e}_${t}_fk`;try{await sql`
|
|
8
8
|
ALTER TABLE ${sql.id(e)}
|
|
9
9
|
ADD CONSTRAINT ${sql.id(a)}
|
|
10
10
|
FOREIGN KEY (${sql.id(t)})
|
|
11
11
|
REFERENCES ${sql.id(s)} (${sql.id(o)})
|
|
12
|
-
`.execute(c);}catch(n){J(n)||i==null||i.warn("Could not add foreign key constraint",e,t,r,n);}}async function Kt(c,e,t,r){for(let{tableName:i,columnName:s,references:o}of e){let a=t.find(l=>l.name===i),n=a==null?void 0:a.columns.find(l=>l.name===s),[u]=o.split(".");a&&n&&G(t,u)&&await Xe(c,i,s,o,r);}}async function Jt(c,e,t,r){for(let[i,s]of Object.entries(e)){let o=`${i}_meta`,a=t.find(n=>n.name===o);if(a)for(let[n,u]of Object.entries(s.fields)){let l=u.getStorageFieldType(),d=a.columns.find(h=>h.name===n);l.primary&&d&&G(t,i)&&await Xe(c,o,n,`${i}.${n}`,r);}}}async function et(c,e,t){let r=Q(c),i=await c.introspection.getTables(),s=[];await Bt(c,e,r,t);for(let[a,n]of Object.entries(e)){let u=i.find(h=>h.name===a),l=i.find(h=>h.name===`${a}_meta`),d=Ft(n,u,i,s,a);if(u)for(let[h,y]of Object.entries(n.fields)){let m=u.columns.find(g=>g.name===h),p=y.getStorageFieldType(),f=ve(p,r);m&&m.dataType!==f&&(t==null||t.warn("Column type mismatch:",h,"expected to have type:",f,"but has type:",m.dataType));}!u&&d.length>0?await Ut(c,a,d,i,r,t):u&&await Wt(c,a,d,i,s,r,t),await Ht(c,a,n,l,i,t);}let o=await c.introspection.getTables();await Kt(c,s,o,t),await Jt(c,e,o,t);}function ae(c,e,t,r){if(!c)throw new Error("Schema not initialized");let i=c[e];if(!i)throw new Error("Resource not found");let s=r.$or,o=r.$and;return (s?t.or:t.and)(s?r.$or.map(a=>ae(c,e,t,a)):o?r.$and.map(a=>ae(c,e,t,a)):Object.entries(r).map(([a,n])=>{var u,l;if(i.fields[a])return (n==null?void 0:n.$eq)!==void 0?t(`${e}.${a}`,n.$eq===null?"is":"=",n.$eq):(n==null?void 0:n.$in)!==void 0?t(`${e}.${a}`,"in",n.$in):(n==null?void 0:n.$not)!==void 0?((u=n==null?void 0:n.$not)==null?void 0:u.$in)!==void 0?t(`${e}.${a}`,"not in",n.$not.$in):((l=n==null?void 0:n.$not)==null?void 0:l.$eq)!==void 0?t(`${e}.${a}`,n.$not.$eq===null?"is not":"!=",n.$not.$eq):t(`${e}.${a}`,n.$not===null?"is not":"!=",n.$not):(n==null?void 0:n.$gt)!==void 0?t(`${e}.${a}`,">",n.$gt):(n==null?void 0:n.$gte)!==void 0?t(`${e}.${a}`,">=",n.$gte):(n==null?void 0:n.$lt)!==void 0?t(`${e}.${a}`,"<",n.$lt):(n==null?void 0:n.$lte)!==void 0?t(`${e}.${a}`,"<=",n.$lte):t(`${e}.${a}`,n===null?"is":"=",n);if(i.relations[a]){let d=i.relations[a],h=d.entity.name;return d.type==="many"?t.exists(ce(c,h,t.selectFrom(h).select("id").whereRef(d.foreignColumn,"=",`${e}.id`),n)):ae(c,h,t,n)}return null}).filter(Boolean))}function oe(c,e,t,r){let i=c[e];if(!i)throw new Error("Resource not found");if(!r)return t;if(r.$and){for(let s of r.$and)t=oe(c,e,t,s);return t}else if(r.$or){for(let s of r.$or)t=oe(c,e,t,s);return t}for(let[s,o]of Object.entries(r)){if(!i.relations[s])continue;let a=i.relations[s],n=a.entity.name,u=a.type==="one"?"id":a.foreignColumn,l=a.type==="one"?a.relationalColumn:"id";t=t.leftJoin(n,`${n}.${u}`,`${e}.${l}`),o instanceof Object&&!Array.isArray(o)&&o!==null&&(t=oe(c,n,t,o));}return t}function ce(c,e,t,r){return !r||Object.keys(r).length===0?t:(t=oe(c,e,t,r),t.where(i=>ae(c,e,i,r)))}function Gt(c,e,t,r,i){let s=Q(i),o=e[t];if(s==="sqlite"&&(o!=null&&o.fields)){let a=Object.keys(o.fields),n=c.selectFrom(r);for(let u of a)n=n.select(`${r}.${u}`);return n}return c.selectFrom(r).selectAll(r)}function Zt(c,e,t,r,i){let s=Q(i),o=e[t];if(s==="sqlite"&&(o!=null&&o.fields)){let a=Object.keys(o.fields),n=c.selectFrom(r);for(let u of a)n=n.select(`${r}.${u}`);return n}return c.selectFrom(r).selectAll(r)}function ue(c,e,t,r,i,s){if(!r)return t;if(!c)throw new Error("Schema not initialized");let o=c[e];if(!o)throw new Error(`Resource not found: ${e}`);let{jsonObjectFrom:a,jsonArrayFrom:n}=i;for(let u of Object.keys(r)){if(!o.relations[u])throw new Error(`Relation ${u} not found in resource ${e}`);let l=o.relations[u],d=l.entity.name,h=r[u],y=l.type==="one"?"id":l.foreignColumn,m=l.type==="one"?l.relationalColumn:"id",p=l.type==="one"?a:n,f=E(h)?h:null,g=f==null?void 0:f.include;t=t.select(T=>{let b=`${d}_meta`,R=Zt(T,c,d,d,s).whereRef(`${d}.${y}`,"=",`${e}.${m}`).select(S=>a(Gt(S,c,d,b,s).whereRef(`${b}.id`,"=",`${d}.id`)).as("_meta"));if(f!=null&&f.where&&(R=ce(c,d,R,f.where)),f!=null&&f.orderBy)for(let S of f.orderBy)R=R.orderBy(`${d}.${S.key}`,S.direction);return (f==null?void 0:f.limit)!==void 0&&(R=R.limit(f.limit)),g&&Object.keys(g).length>0&&(R=ue(c,d,R,g,i,s)),p(R).as(u)});}return t}var Ie=class c extends K{db;dialectHelpers;schema;logger;server;mutationStack=[];constructor(e,t,r,i){super(),this.isKyselyLike(e)?this.db=e:this.db=new Kysely({dialect:new PostgresDialect({pool:e})}),this.dialectHelpers=Ze(this.db),this.schema=t,this.logger=r,this.server=i,this.rawInsert=this.rawInsert.bind(this),this.rawUpdate=this.rawUpdate.bind(this);}async init(e,t,r){this.schema=e,this.logger=t,this.server=r,await et(this.db,e,t);}selectMetaColumns(e,t,r){var o;let i=Q(this.db),s=(o=this.schema)==null?void 0:o[t];if(i==="sqlite"&&(s!=null&&s.fields)){let a=Object.keys(s.fields),n=e.selectFrom(r);for(let u of a)n=n.select(`${r}.${u}`);return n}return e.selectFrom(r).selectAll(r)}async rawFindById(e,t,r){if(!this.schema)throw new Error("Schema not initialized");let i=`${e}_meta`,s=await this.db.selectFrom(e).where("id","=",t).selectAll(e).select(n=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(n,e,i).whereRef(`${i}.id`,"=",`${e}.id`)).as("_meta"));s=ue(this.schema,e,s,r,this.dialectHelpers,this.db);let o=await s.executeTakeFirst();if(!o)return;let a=this.parseRelationalJsonStrings(o,e);return this.convertToMaterializedLiveType(a,e)}async findOne(e,t,r){let i=await this.rawFindById(e.name,t,r==null?void 0:r.include);if(i)return z$2(i)}async get(e){if(!this.schema)throw new Error("Schema not initialized");let{resource:t,where:r,include:i,limit:s,sort:o}=e,a=`${t}_meta`,n=this.db.selectFrom(t).selectAll(t).select(l=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(l,t,a).whereRef(`${a}.id`,"=",`${t}.id`)).as("_meta"));n=ce(this.schema,t,n,r),n=ue(this.schema,t,n,i,this.dialectHelpers,this.db),s!==void 0&&(n=n.limit(s)),o!==void 0&&o.forEach(l=>{n=n.orderBy(l.key,l.direction);});let u=await n.execute();return u.length===0?[]:u.map(l=>{let d=this.parseRelationalJsonStrings(l,t);return this.convertToMaterializedLiveType(d,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(i=>z$2(i))}async rawInsert(e,t,r,i,s){var p,f,g,T,b,R,S,v,E,N,$,U;let o=(f=(p=this.server)==null?void 0:p.router)==null?void 0:f.getHooks(e),a=(g=this.schema)==null?void 0:g[e],[n,u]=((T=a==null?void 0:a.mergeMutation)==null?void 0:T.call(a,"set",r.value,void 0))??[r,r.value];if(!u)return {data:r,acceptedValues:null};let l=n,d={...l,value:{...l.value,id:{value:t}}};if(o!=null&&o.beforeInsert){let j=z$2(d);j.id=t;let M=await o.beforeInsert({ctx:s,value:j,rawValue:d,db:this});M&&(l=M);}let h={},y={};for(let[j,M]of Object.entries(l.value)){let O=(b=M._meta)==null?void 0:b.timestamp;if(!O)continue;let C=(S=(R=a==null?void 0:a.fields[j])==null?void 0:R.getStorageFieldType)==null?void 0:S.call(R);(C==null?void 0:C.type)==="jsonb"||(C==null?void 0:C.type)==="json"?h[j]=JSON.stringify(M.value):h[j]=M.value,y[j]=O;}await this.db.insertInto(e).values({...h,id:t}).execute(),await this.db.insertInto(`${e}_meta`).values({...y,id:t}).execute(),(E=(v=this.logger)==null?void 0:v.debug)==null||E.call(v,"[rawInsert] Building mutation",{resourceName:e,resourceId:t,mutationId:i??"(auto-generated)",contextMessageId:(s==null?void 0:s.messageId)??"(none)",hasContext:!!s,contextKeys:s?Object.keys(s):[]});let m=this.buildMutation(e,t,"INSERT",l,i,s==null?void 0:s.messageId);if(m&&((U=(N=this.logger)==null?void 0:N.debug)==null||U.call(N,"[rawInsert] Mutation built, tracking",{mutationId:m.id,hasMeta:!!m.meta,originMutationId:(($=m.meta)==null?void 0:$.originMutationId)??"(none)",isTransaction:!!this.db.isTransaction}),this.trackMutation(m,l)),o!=null&&o.afterInsert){let j={...l,value:{...l.value,id:{value:t}}},M=z$2(j);M.id=t,await o.afterInsert({ctx:s,value:M,rawValue:j,db:this});}return {data:l,acceptedValues:u}}async rawUpdate(e,t,r,i,s){var f,g,T,b,R,S,v,E,N,$,U,j;let o=(g=(f=this.server)==null?void 0:f.router)==null?void 0:g.getHooks(e),a=(T=this.schema)==null?void 0:T[e],n=await this.rawFindById(e,t),[u,l]=((b=a==null?void 0:a.mergeMutation)==null?void 0:b.call(a,"set",r.value,n))??[r,r.value];if(!l)return {data:r,acceptedValues:null};let d=u,h={...d,value:{...d.value,id:{value:t}}};if(o!=null&&o.beforeUpdate){let M=z$2(h);M.id=t;let O;if(n){let A={...n,value:{...n.value,id:{value:t}}};O=z$2(A),O.id=t;}let C=await o.beforeUpdate({ctx:s,value:M,rawValue:h,previousValue:O,previousRawValue:n,db:this});C&&(d=C);}let y={},m={};for(let[M,O]of Object.entries(d.value)){let C=(R=O._meta)==null?void 0:R.timestamp;if(!C)continue;let A=(v=(S=a==null?void 0:a.fields[M])==null?void 0:S.getStorageFieldType)==null?void 0:v.call(S);(A==null?void 0:A.type)==="jsonb"||(A==null?void 0:A.type)==="json"?y[M]=JSON.stringify(O.value):y[M]=O.value,m[M]=C;}if(Object.keys(y).length===0)return {data:d,acceptedValues:l};await Promise.all([this.db.updateTable(e).set(y).where("id","=",t).execute(),this.db.insertInto(`${e}_meta`).values({...m,id:t}).onConflict(M=>M.column("id").doUpdateSet(m)).execute()]),(N=(E=this.logger)==null?void 0:E.debug)==null||N.call(E,"[rawUpdate] Building mutation",{resourceName:e,resourceId:t,mutationId:i??"(auto-generated)",contextMessageId:(s==null?void 0:s.messageId)??"(none)",hasContext:!!s,contextKeys:s?Object.keys(s):[]});let p=this.buildMutation(e,t,"UPDATE",d,i,s==null?void 0:s.messageId);if(p){(j=($=this.logger)==null?void 0:$.debug)==null||j.call($,"[rawUpdate] Mutation built, tracking",{mutationId:p.id,hasMeta:!!p.meta,originMutationId:((U=p.meta)==null?void 0:U.originMutationId)??"(none)",isTransaction:!!this.db.isTransaction});let M=await this.rawFindById(e,t);M&&this.trackMutation(p,M);}if(o!=null&&o.afterUpdate){let M=await this.rawFindById(e,t);if(M){let O={...M,value:{...M.value,id:{value:t}}},C=z$2(O);C.id=t;let A;if(n){let rt={...n,value:{...n.value,id:{value:t}}};A=z$2(rt),A.id=t;}await o.afterUpdate({ctx:s,value:C,rawValue:O,previousValue:A,previousRawValue:n,db:this});}}return {data:d,acceptedValues:l}}async transaction(e){if(!this.schema)throw new Error("Schema not initialized");if(this.db.isTransaction){let s=Math.random().toString(36).substring(2,15),o=this.mutationStack,a=[];this.mutationStack=a;let n=await this.db.savepoint(s).execute(),u=false,l=false;try{return await e({trx:this,commit:async()=>{await n.releaseSavepoint(s).execute(),u=!0,o.push(...a);},rollback:async()=>{await n.rollbackToSavepoint(s).execute(),l=!0,a.length=0;}}).then(d=>n.isCommitted||n.isRolledBack||u||l?d:n.releaseSavepoint(s).execute().then(()=>(o.push(...a),d)))}catch(d){throw l||await n.rollbackToSavepoint(s).execute().catch(()=>{}),a.length=0,d}finally{this.mutationStack=o;}}let t=[],r=this.mutationStack;this.mutationStack=t;let i=await this.db.startTransaction().execute();try{let s=new c(i,this.schema,this.logger,this.server);return s.mutationStack=t,await e({trx:s,commit:async()=>{var o,a;await i.commit().execute(),(a=(o=this.logger)==null?void 0:o.debug)==null||a.call(o,"[transaction] Explicit commit flushing mutations",{count:t.length,mutations:t.map(({mutation:n})=>{var u;return {id:n.id,resource:n.resource,resourceId:n.resourceId,procedure:n.procedure,hasMeta:!!n.meta,originMutationId:((u=n.meta)==null?void 0:u.originMutationId)??"(none)"}})}),this.notifyMutations(t);},rollback:async()=>{await i.rollback().execute(),t.length=0;}}).then(o=>i.isCommitted||i.isRolledBack?o:i.commit().execute().then(()=>{var a,n;return (n=(a=this.logger)==null?void 0:a.debug)==null||n.call(a,"[transaction] Auto-commit flushing mutations",{count:t.length,mutations:t.map(({mutation:u})=>{var l;return {id:u.id,resource:u.resource,resourceId:u.resourceId,procedure:u.procedure,hasMeta:!!u.meta,originMutationId:((l=u.meta)==null?void 0:l.originMutationId)??"(none)"}})}),this.notifyMutations(t),o}))}catch(s){throw await i.rollback().execute(),t.length=0,s}finally{this.mutationStack=r;}}get internalDB(){return this.db}isRelationalField(e,t){var i;if(!this.schema)return false;let r=this.schema[e];return !!((i=r==null?void 0:r.relations)!=null&&i[t])}parseRelationalJsonStrings(e,t){var s,o;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 i={};for(let[a,n]of Object.entries(e))if(a==="_meta"&&typeof n=="string")if(n.startsWith("{")&&n.endsWith("}")||n.startsWith("[")&&n.endsWith("]"))try{i[a]=JSON.parse(n);}catch{i[a]=n;}else i[a]=n;else if(this.isRelationalField(t,a))if(typeof n=="string")if(n.startsWith("{")&&n.endsWith("}")||n.startsWith("[")&&n.endsWith("]"))try{let u=JSON.parse(n);if(this.schema){let l=this.schema[t],d=(s=l==null?void 0:l.relations)==null?void 0:s[a];if(d){let h=d.entity.name;i[a]=this.parseRelationalJsonStrings(u,h);}else i[a]=u;}else i[a]=u;}catch{i[a]=n;}else i[a]=n;else if(typeof n=="object"&&n!==null&&!Array.isArray(n))if(this.schema){let u=this.schema[t],l=(o=u==null?void 0:u.relations)==null?void 0:o[a];if(l){let d=l.entity.name;i[a]=this.parseRelationalJsonStrings(n,d);}else i[a]=n;}else i[a]=n;else Array.isArray(n)?i[a]=n.map(u=>{var l,d;if(typeof u=="string")try{let h=JSON.parse(u);if(this.schema){let y=this.schema[t],m=(l=y==null?void 0:y.relations)==null?void 0:l[a];if(m){let p=m.entity.name;return this.parseRelationalJsonStrings(h,p)}}return h}catch{return u}if(typeof u=="object"&&u!==null&&this.schema){let h=this.schema[t],y=(d=h==null?void 0:h.relations)==null?void 0:d[a];if(y){let m=y.entity.name;return this.parseRelationalJsonStrings(u,m)}}return u}):i[a]=n;else i[a]=n;return i}convertToMaterializedLiveType(e,t){var i;let r=(i=this.schema)==null?void 0:i[t];return {value:Object.entries(e).reduce((s,[o,a])=>{var d,h,y,m,p,f,g,T,b;if(o==="_meta")return s;let n=(h=(d=r==null?void 0:r.fields[o])==null?void 0:d.getStorageFieldType)==null?void 0:h.call(d),u=(n==null?void 0:n.type)==="jsonb"||(n==null?void 0:n.type)==="json",l=(r==null?void 0:r.relations)&&o in r.relations;if(o==="id")s[o]={value:a};else if(u)s[o]={value:a,_meta:{timestamp:(y=e==null?void 0:e._meta)==null?void 0:y[o]}};else if(l){let R=r.relations[o].entity,S=(R==null?void 0:R.name)??t;Array.isArray(a)?s[o]={value:a.map(v=>this.convertToMaterializedLiveType(v,S)),_meta:{timestamp:(m=e==null?void 0:e._meta)==null?void 0:m[o],relation:true}}:a!==null&&typeof a=="object"?s[o]={...this.convertToMaterializedLiveType(a,S),_meta:{timestamp:(p=e==null?void 0:e._meta)==null?void 0:p[o],relation:true}}:s[o]={value:a,_meta:{timestamp:(f=e==null?void 0:e._meta)==null?void 0:f[o],relation:true}};}else Array.isArray(a)?s[o]={value:a,_meta:{timestamp:(g=e==null?void 0:e._meta)==null?void 0:g[o]}}:typeof a=="object"&&a!==null&&!(a instanceof Date)?s[o]={value:a,_meta:{timestamp:(T=e==null?void 0:e._meta)==null?void 0:T[o]}}:s[o]={value:a,_meta:{timestamp:(b=e==null?void 0:e._meta)==null?void 0:b[o]}};return s},{})}}isKyselyLike(e){if(e instanceof Kysely)return true;if(!e||typeof e!="object")return false;let t=e,r=typeof t.selectFrom=="function",i=typeof t.startTransaction=="function",s=typeof t.savepoint=="function",o=typeof t.isTransaction=="boolean"||typeof t.isTransaction=="function";return r&&i||s&&o}buildMutation(e,t,r,i,s,o){var n;let a={};for(let[u,l]of Object.entries(i.value)){if(u==="id")continue;let d=(n=l._meta)==null?void 0:n.timestamp;d&&(a[u]={value:l.value,_meta:{timestamp:d}});}return Object.keys(a).length===0?null:{id:s??ee(),type:"MUTATE",resource:e,resourceId:t,procedure:r,payload:a,meta:o?{originMutationId:o}:void 0}}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 r=e;for(let i of r)this.server.notifySubscribers(i,t);}else {let r=e;for(let{mutation:i,entityData:s}of r)this.server.notifySubscribers(i,s);}}};var Ce=class c{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=G$1({level:e.logLevel??F$1.INFO}),(t=e.middlewares)==null||t.forEach(r=>{this.middlewares.add(r);}),this.storage.init(this.schema,this.logger,this),this.contextProvider=e.contextProvider,this.queryEngine=new re({router:{get:async(r,i)=>{var d;let{headers:s,cookies:o,queryParams:a,context:n}=(i==null?void 0:i.context)??{};if(!(i!=null&&i.batcher))throw new Error("Batcher is required");let u={...r,type:"QUERY",headers:s,cookies:o,queryParams:a,context:n},l=await((d=this.router.routes[r.resource])==null?void 0:d.handleQuery({req:u,batcher:i.batcher}));return (l==null?void 0:l.data)??[]},incrementQueryStep:(r,i={})=>{var a;let s=(a=this.router.routes[r.query.resource])==null?void 0:a.getAuthorizationClause({...r.query,type:"QUERY",headers:i.headers,cookies:i.cookies,queryParams:i.queryParams,context:i.context});if(typeof s=="boolean"&&!s)throw new Error("Not authorized");let o=z(r.query.where,typeof s=="object"?s:void 0);return {...r,query:{...r.query,where:o}}}},storage:this.storage,schema:this.schema,logger:this.logger});}static create(e){return new c(e)}handleQuery(e){return this.wrapInMiddlewares(async t=>{let{headers:r,cookies:i,queryParams:s,context:o,...a}=t,n={headers:r,cookies:i,queryParams:s,context:o},u=e.subscription?this.queryEngine.subscribe(a,d=>{var h;(h=e.subscription)==null||h.call(e,d);},n):void 0;return {data:await this.queryEngine.get(a,{context:n}),unsubscribe:u}})(e.req)}async handleMutation(e){return await this.wrapInMiddlewares(async r=>{let i=this.router.routes[r.resource];if(!i)throw new Error("Invalid resource");return i.handleMutation({req:r,db:this.storage,schema:this.schema})})(e.req)}async handleCustomQuery(e){let t=await this.wrapInMiddlewares(async h=>{let y=this.router.routes[h.resource];if(!y)throw new Error("Invalid resource");return y.handleCustomQuery({req:h,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:i,cookies:s,queryParams:o,context:a}=e.req,n={headers:i,cookies:s,queryParams:o,context:a},u=t.buildQueryRequest(),l=e.subscription?this.queryEngine.subscribe(u,h=>{var y;(y=e.subscription)==null||y.call(e,h);},n):void 0,d=await this.queryEngine.get(u,{context:n});return e.subscription?{data:d,unsubscribe:l,query:u}:d.map(h=>z$2(h))}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((r,i)=>s=>i({req:s,next:r}),e)(t)}},Cn=Ce.create;export{Se as ProcedureRoute,Re as Route,we as RouteFactory,be as Router,Ie as SQLStorage,Ce as Server,K as Storage,Jr as createMiddleware,V as createServerDB,kr as expressAdapter,Gr as routeFactory,Kr as router,Cn as server};
|
|
12
|
+
`.execute(c);}catch(n){K(n)||i==null||i.warn("Could not add foreign key constraint",e,t,r,n);}}async function Zt(c,e,t,r){for(let{tableName:i,columnName:s,references:o}of e){let a=t.find(l=>l.name===i),n=a==null?void 0:a.columns.find(l=>l.name===s),[u]=o.split(".");a&&n&&J(t,u)&&await Xe(c,i,s,o,r);}}async function Yt(c,e,t,r){for(let[i,s]of Object.entries(e)){let o=`${i}_meta`,a=t.find(n=>n.name===o);if(a)for(let[n,u]of Object.entries(s.fields)){let l=u.getStorageFieldType(),d=a.columns.find(h=>h.name===n);l.primary&&d&&J(t,i)&&await Xe(c,o,n,`${i}.${n}`,r);}}}async function et(c,e,t){let r=k(c),i=await c.introspection.getTables(),s=[];await Ht(c,e,r,t);for(let[a,n]of Object.entries(e)){let u=i.find(h=>h.name===a),l=i.find(h=>h.name===`${a}_meta`),d=Wt(n,u,i,s,a);if(u)for(let[h,y]of Object.entries(n.fields)){let p=u.columns.find(T=>T.name===h),m=y.getStorageFieldType(),g=ve(m,r);p&&p.dataType!==g&&(t==null||t.warn("Column type mismatch:",h,"expected to have type:",g,"but has type:",p.dataType));}!u&&d.length>0?await Kt(c,a,d,i,r,t):u&&await Jt(c,a,d,i,s,r,t),await Gt(c,a,n,l,i,t);}let o=await c.introspection.getTables();await Zt(c,s,o,t),await Yt(c,e,o,t);}function ae(c,e,t,r){if(!c)throw new Error("Schema not initialized");let i=c[e];if(!i)throw new Error("Resource not found");let s=r.$or,o=r.$and;return (s?t.or:t.and)(s?r.$or.map(a=>ae(c,e,t,a)):o?r.$and.map(a=>ae(c,e,t,a)):Object.entries(r).map(([a,n])=>{var u,l;if(i.fields[a])return (n==null?void 0:n.$eq)!==void 0?t(`${e}.${a}`,n.$eq===null?"is":"=",n.$eq):(n==null?void 0:n.$in)!==void 0?t(`${e}.${a}`,"in",n.$in):(n==null?void 0:n.$not)!==void 0?((u=n==null?void 0:n.$not)==null?void 0:u.$in)!==void 0?t(`${e}.${a}`,"not in",n.$not.$in):((l=n==null?void 0:n.$not)==null?void 0:l.$eq)!==void 0?t(`${e}.${a}`,n.$not.$eq===null?"is not":"!=",n.$not.$eq):t(`${e}.${a}`,n.$not===null?"is not":"!=",n.$not):(n==null?void 0:n.$gt)!==void 0?t(`${e}.${a}`,">",n.$gt):(n==null?void 0:n.$gte)!==void 0?t(`${e}.${a}`,">=",n.$gte):(n==null?void 0:n.$lt)!==void 0?t(`${e}.${a}`,"<",n.$lt):(n==null?void 0:n.$lte)!==void 0?t(`${e}.${a}`,"<=",n.$lte):t(`${e}.${a}`,n===null?"is":"=",n);if(i.relations[a]){let d=i.relations[a],h=d.entity.name;return d.type==="many"?t.exists(ce(c,h,t.selectFrom(h).select("id").whereRef(d.foreignColumn,"=",`${e}.id`),n)):ae(c,h,t,n)}return null}).filter(Boolean))}function oe(c,e,t,r){let i=c[e];if(!i)throw new Error("Resource not found");if(!r)return t;if(r.$and){for(let s of r.$and)t=oe(c,e,t,s);return t}else if(r.$or){for(let s of r.$or)t=oe(c,e,t,s);return t}for(let[s,o]of Object.entries(r)){if(!i.relations[s])continue;let a=i.relations[s],n=a.entity.name,u=a.type==="one"?"id":a.foreignColumn,l=a.type==="one"?a.relationalColumn:"id";t=t.leftJoin(n,`${n}.${u}`,`${e}.${l}`),o instanceof Object&&!Array.isArray(o)&&o!==null&&(t=oe(c,n,t,o));}return t}function ce(c,e,t,r){return !r||Object.keys(r).length===0?t:(t=oe(c,e,t,r),t.where(i=>ae(c,e,i,r)))}function Xt(c,e,t,r,i){let s=k(i),o=e[t];if(s==="sqlite"&&(o!=null&&o.fields)){let a=Object.keys(o.fields),n=c.selectFrom(r);for(let u of a)n=n.select(`${r}.${u}`);return n}return c.selectFrom(r).selectAll(r)}function er(c,e,t,r,i){let s=k(i),o=e[t];if(s==="sqlite"&&(o!=null&&o.fields)){let a=Object.keys(o.fields),n=c.selectFrom(r);for(let u of a)n=n.select(`${r}.${u}`);return n}return c.selectFrom(r).selectAll(r)}function ue(c,e,t,r,i,s){if(!r)return t;if(!c)throw new Error("Schema not initialized");let o=c[e];if(!o)throw new Error(`Resource not found: ${e}`);let{jsonObjectFrom:a,jsonArrayFrom:n}=i;for(let u of Object.keys(r)){if(!o.relations[u])throw new Error(`Relation ${u} not found in resource ${e}`);let l=o.relations[u],d=l.entity.name,h=r[u],y=l.type==="one"?"id":l.foreignColumn,p=l.type==="one"?l.relationalColumn:"id",m=l.type==="one"?a:n,g=E(h)?h:null,T=g==null?void 0:g.include;t=t.select(f=>{let R=`${d}_meta`,b=er(f,c,d,d,s).whereRef(`${d}.${y}`,"=",`${e}.${p}`).select(S=>a(Xt(S,c,d,R,s).whereRef(`${R}.id`,"=",`${d}.id`)).as("_meta"));if(g!=null&&g.where&&(b=ce(c,d,b,g.where)),g!=null&&g.orderBy)for(let S of g.orderBy)b=b.orderBy(`${d}.${S.key}`,S.direction);return (g==null?void 0:g.limit)!==void 0&&(b=b.limit(g.limit)),T&&Object.keys(T).length>0&&(b=ue(c,d,b,T,i,s)),m(b).as(u)});}return t}var Me=class c extends W{db;dialectHelpers;schema;logger;server;mutationStack=[];constructor(e,t,r,i){super(),this.isKyselyLike(e)?this.db=e:this.db=new Kysely({dialect:new PostgresDialect({pool:e})}),this.dialectHelpers=Ze(this.db),this.schema=t,this.logger=r,this.server=i,this.rawInsert=this.rawInsert.bind(this),this.rawUpdate=this.rawUpdate.bind(this);}async init(e,t,r){this.schema=e,this.logger=t,this.server=r,await et(this.db,e,t);}selectMetaColumns(e,t,r){var o;let i=k(this.db),s=(o=this.schema)==null?void 0:o[t];if(i==="sqlite"&&(s!=null&&s.fields)){let a=Object.keys(s.fields),n=e.selectFrom(r);for(let u of a)n=n.select(`${r}.${u}`);return n}return e.selectFrom(r).selectAll(r)}async rawFindById(e,t,r){if(!this.schema)throw new Error("Schema not initialized");let i=`${e}_meta`,s=await this.db.selectFrom(e).where("id","=",t).selectAll(e).select(n=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(n,e,i).whereRef(`${i}.id`,"=",`${e}.id`)).as("_meta"));s=ue(this.schema,e,s,r,this.dialectHelpers,this.db);let o=await s.executeTakeFirst();if(!o)return;let a=this.parseRelationalJsonStrings(o,e);return this.convertToMaterializedLiveType(a,e)}async findOne(e,t,r){let i=await this.rawFindById(e.name,t,r==null?void 0:r.include);if(i)return z$2(i)}async get(e){if(!this.schema)throw new Error("Schema not initialized");let{resource:t,where:r,include:i,limit:s,sort:o}=e,a=`${t}_meta`,n=this.db.selectFrom(t).selectAll(t).select(l=>this.dialectHelpers.jsonObjectFrom(this.selectMetaColumns(l,t,a).whereRef(`${a}.id`,"=",`${t}.id`)).as("_meta"));n=ce(this.schema,t,n,r),n=ue(this.schema,t,n,i,this.dialectHelpers,this.db),s!==void 0&&(n=n.limit(s)),o!==void 0&&o.forEach(l=>{n=n.orderBy(l.key,l.direction);});let u=await n.execute();return u.length===0?[]:u.map(l=>{let d=this.parseRelationalJsonStrings(l,t);return this.convertToMaterializedLiveType(d,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(i=>z$2(i))}async rawInsert(e,t,r,i,s){var m,g,T,f,R,b,S,v,E,Q,F;let o=(m=this.server)==null?void 0:m.getHooks(e),a=(g=this.schema)==null?void 0:g[e],[n,u]=((T=a==null?void 0:a.mergeMutation)==null?void 0:T.call(a,"set",r.value,void 0))??[r,r.value];if(!u)return {data:r,acceptedValues:null};let l=n,d={...l,value:{...l.value,id:{value:t}}};if(o!=null&&o.beforeInsert){let j=z$2(d);j.id=t;let I=await o.beforeInsert({ctx:s,value:j,rawValue:d,db:this});I&&(l=I);}let h={},y={};for(let[j,I]of Object.entries(l.value)){let O=(f=I._meta)==null?void 0:f.timestamp;if(!O)continue;let C=(b=(R=a==null?void 0:a.fields[j])==null?void 0:R.getStorageFieldType)==null?void 0:b.call(R);(C==null?void 0:C.type)==="jsonb"||(C==null?void 0:C.type)==="json"?h[j]=JSON.stringify(I.value):h[j]=I.value,y[j]=O;}await this.db.insertInto(e).values({...h,id:t}).execute(),await this.db.insertInto(`${e}_meta`).values({...y,id:t}).execute(),(v=(S=this.logger)==null?void 0:S.debug)==null||v.call(S,"[rawInsert] Building mutation",{resourceName:e,resourceId:t,mutationId:i??"(auto-generated)",contextMessageId:(s==null?void 0:s.messageId)??"(none)",hasContext:!!s,contextKeys:s?Object.keys(s):[]});let p=this.buildMutation(e,t,"INSERT",l,i,s==null?void 0:s.messageId);if(p&&((F=(E=this.logger)==null?void 0:E.debug)==null||F.call(E,"[rawInsert] Mutation built, tracking",{mutationId:p.id,hasMeta:!!p.meta,originMutationId:((Q=p.meta)==null?void 0:Q.originMutationId)??"(none)",isTransaction:!!this.db.isTransaction}),this.trackMutation(p,l)),o!=null&&o.afterInsert){let j={...l,value:{...l.value,id:{value:t}}},I=z$2(j);I.id=t,await o.afterInsert({ctx:s,value:I,rawValue:j,db:this});}return {data:l,acceptedValues:u}}async rawUpdate(e,t,r,i,s){var g,T,f,R,b,S,v,E,Q,F,j;let o=(g=this.server)==null?void 0:g.getHooks(e),a=(T=this.schema)==null?void 0:T[e],n=await this.rawFindById(e,t),[u,l]=((f=a==null?void 0:a.mergeMutation)==null?void 0:f.call(a,"set",r.value,n))??[r,r.value];if(!l)return {data:r,acceptedValues:null};let d=u,h={...d,value:{...d.value,id:{value:t}}};if(o!=null&&o.beforeUpdate){let I=z$2(h);I.id=t;let O;if(n){let A={...n,value:{...n.value,id:{value:t}}};O=z$2(A),O.id=t;}let C=await o.beforeUpdate({ctx:s,value:I,rawValue:h,previousValue:O,previousRawValue:n,db:this});C&&(d=C);}let y={},p={};for(let[I,O]of Object.entries(d.value)){let C=(R=O._meta)==null?void 0:R.timestamp;if(!C)continue;let A=(S=(b=a==null?void 0:a.fields[I])==null?void 0:b.getStorageFieldType)==null?void 0:S.call(b);(A==null?void 0:A.type)==="jsonb"||(A==null?void 0:A.type)==="json"?y[I]=JSON.stringify(O.value):y[I]=O.value,p[I]=C;}if(Object.keys(y).length===0)return {data:d,acceptedValues:l};await Promise.all([this.db.updateTable(e).set(y).where("id","=",t).execute(),this.db.insertInto(`${e}_meta`).values({...p,id:t}).onConflict(I=>I.column("id").doUpdateSet(p)).execute()]),(E=(v=this.logger)==null?void 0:v.debug)==null||E.call(v,"[rawUpdate] Building mutation",{resourceName:e,resourceId:t,mutationId:i??"(auto-generated)",contextMessageId:(s==null?void 0:s.messageId)??"(none)",hasContext:!!s,contextKeys:s?Object.keys(s):[]});let m=this.buildMutation(e,t,"UPDATE",d,i,s==null?void 0:s.messageId);if(m){(j=(Q=this.logger)==null?void 0:Q.debug)==null||j.call(Q,"[rawUpdate] Mutation built, tracking",{mutationId:m.id,hasMeta:!!m.meta,originMutationId:((F=m.meta)==null?void 0:F.originMutationId)??"(none)",isTransaction:!!this.db.isTransaction});let I=await this.rawFindById(e,t);I&&this.trackMutation(m,I);}if(o!=null&&o.afterUpdate){let I=await this.rawFindById(e,t);if(I){let O={...I,value:{...I.value,id:{value:t}}},C=z$2(O);C.id=t;let A;if(n){let rt={...n,value:{...n.value,id:{value:t}}};A=z$2(rt),A.id=t;}await o.afterUpdate({ctx:s,value:C,rawValue:O,previousValue:A,previousRawValue:n,db:this});}}return {data:d,acceptedValues:l}}async transaction(e){if(!this.schema)throw new Error("Schema not initialized");if(this.db.isTransaction){let s=Math.random().toString(36).substring(2,15),o=this.mutationStack,a=[];this.mutationStack=a;let n=await this.db.savepoint(s).execute(),u=false,l=false;try{return await e({trx:this,commit:async()=>{await n.releaseSavepoint(s).execute(),u=!0,o.push(...a);},rollback:async()=>{await n.rollbackToSavepoint(s).execute(),l=!0,a.length=0;}}).then(d=>n.isCommitted||n.isRolledBack||u||l?d:n.releaseSavepoint(s).execute().then(()=>(o.push(...a),d)))}catch(d){throw l||await n.rollbackToSavepoint(s).execute().catch(()=>{}),a.length=0,d}finally{this.mutationStack=o;}}let t=[],r=this.mutationStack;this.mutationStack=t;let i=await this.db.startTransaction().execute();try{let s=new c(i,this.schema,this.logger,this.server);return s.mutationStack=t,await e({trx:s,commit:async()=>{var o,a;await i.commit().execute(),(a=(o=this.logger)==null?void 0:o.debug)==null||a.call(o,"[transaction] Explicit commit flushing mutations",{count:t.length,mutations:t.map(({mutation:n})=>{var u;return {id:n.id,resource:n.resource,resourceId:n.resourceId,procedure:n.procedure,hasMeta:!!n.meta,originMutationId:((u=n.meta)==null?void 0:u.originMutationId)??"(none)"}})}),this.notifyMutations(t);},rollback:async()=>{await i.rollback().execute(),t.length=0;}}).then(o=>i.isCommitted||i.isRolledBack?o:i.commit().execute().then(()=>{var a,n;return (n=(a=this.logger)==null?void 0:a.debug)==null||n.call(a,"[transaction] Auto-commit flushing mutations",{count:t.length,mutations:t.map(({mutation:u})=>{var l;return {id:u.id,resource:u.resource,resourceId:u.resourceId,procedure:u.procedure,hasMeta:!!u.meta,originMutationId:((l=u.meta)==null?void 0:l.originMutationId)??"(none)"}})}),this.notifyMutations(t),o}))}catch(s){throw await i.rollback().execute(),t.length=0,s}finally{this.mutationStack=r;}}get internalDB(){return this.db}isRelationalField(e,t){var i;if(!this.schema)return false;let r=this.schema[e];return !!((i=r==null?void 0:r.relations)!=null&&i[t])}parseRelationalJsonStrings(e,t){var s,o;if(k(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 i={};for(let[a,n]of Object.entries(e))if(a==="_meta"&&typeof n=="string")if(n.startsWith("{")&&n.endsWith("}")||n.startsWith("[")&&n.endsWith("]"))try{i[a]=JSON.parse(n);}catch{i[a]=n;}else i[a]=n;else if(this.isRelationalField(t,a))if(typeof n=="string")if(n.startsWith("{")&&n.endsWith("}")||n.startsWith("[")&&n.endsWith("]"))try{let u=JSON.parse(n);if(this.schema){let l=this.schema[t],d=(s=l==null?void 0:l.relations)==null?void 0:s[a];if(d){let h=d.entity.name;i[a]=this.parseRelationalJsonStrings(u,h);}else i[a]=u;}else i[a]=u;}catch{i[a]=n;}else i[a]=n;else if(typeof n=="object"&&n!==null&&!Array.isArray(n))if(this.schema){let u=this.schema[t],l=(o=u==null?void 0:u.relations)==null?void 0:o[a];if(l){let d=l.entity.name;i[a]=this.parseRelationalJsonStrings(n,d);}else i[a]=n;}else i[a]=n;else Array.isArray(n)?i[a]=n.map(u=>{var l,d;if(typeof u=="string")try{let h=JSON.parse(u);if(this.schema){let y=this.schema[t],p=(l=y==null?void 0:y.relations)==null?void 0:l[a];if(p){let m=p.entity.name;return this.parseRelationalJsonStrings(h,m)}}return h}catch{return u}if(typeof u=="object"&&u!==null&&this.schema){let h=this.schema[t],y=(d=h==null?void 0:h.relations)==null?void 0:d[a];if(y){let p=y.entity.name;return this.parseRelationalJsonStrings(u,p)}}return u}):i[a]=n;else i[a]=n;return i}convertToMaterializedLiveType(e,t){var i;let r=(i=this.schema)==null?void 0:i[t];return {value:Object.entries(e).reduce((s,[o,a])=>{var d,h,y,p,m,g,T,f,R;if(o==="_meta")return s;let n=(h=(d=r==null?void 0:r.fields[o])==null?void 0:d.getStorageFieldType)==null?void 0:h.call(d),u=(n==null?void 0:n.type)==="jsonb"||(n==null?void 0:n.type)==="json",l=(r==null?void 0:r.relations)&&o in r.relations;if(o==="id")s[o]={value:a};else if(u)s[o]={value:a,_meta:{timestamp:(y=e==null?void 0:e._meta)==null?void 0:y[o]}};else if(l){let b=r.relations[o].entity,S=(b==null?void 0:b.name)??t;Array.isArray(a)?s[o]={value:a.map(v=>this.convertToMaterializedLiveType(v,S)),_meta:{timestamp:(p=e==null?void 0:e._meta)==null?void 0:p[o],relation:true}}:a!==null&&typeof a=="object"?s[o]={...this.convertToMaterializedLiveType(a,S),_meta:{timestamp:(m=e==null?void 0:e._meta)==null?void 0:m[o],relation:true}}:s[o]={value:a,_meta:{timestamp:(g=e==null?void 0:e._meta)==null?void 0:g[o],relation:true}};}else Array.isArray(a)?s[o]={value:a,_meta:{timestamp:(T=e==null?void 0:e._meta)==null?void 0:T[o]}}:typeof a=="object"&&a!==null&&!(a instanceof Date)?s[o]={value:a,_meta:{timestamp:(f=e==null?void 0:e._meta)==null?void 0:f[o]}}:s[o]={value:a,_meta:{timestamp:(R=e==null?void 0:e._meta)==null?void 0:R[o]}};return s},{})}}isKyselyLike(e){if(e instanceof Kysely)return true;if(!e||typeof e!="object")return false;let t=e,r=typeof t.selectFrom=="function",i=typeof t.startTransaction=="function",s=typeof t.savepoint=="function",o=typeof t.isTransaction=="boolean"||typeof t.isTransaction=="function";return r&&i||s&&o}buildMutation(e,t,r,i,s,o){var n;let a={};for(let[u,l]of Object.entries(i.value)){if(u==="id")continue;let d=(n=l._meta)==null?void 0:n.timestamp;d&&(a[u]={value:l.value,_meta:{timestamp:d}});}return Object.keys(a).length===0?null:{id:s??X(),type:"MUTATE",resource:e,resourceId:t,procedure:r,payload:a,meta:o?{originMutationId:o}:void 0}}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 r=e;for(let i of r)this.server.notifySubscribers(i,t);}else {let r=e;for(let{mutation:i,entityData:s}of r)this.server.notifySubscribers(i,s);}}};var Ce=class c{router;storage;schema;middlewares=new Set;logger;hooksRegistry=new Map;initPromise;initError;contextProvider;queryEngine;constructor(e){var i;this.router=e.router,this.storage=e.storage,this.schema=e.schema,this.logger=G({level:e.logLevel??F.INFO}),(i=e.middlewares)==null||i.forEach(s=>{this.middlewares.add(s);});let t=this.router.hooksRegistry,r=new Set;if(t&&t.forEach((s,o)=>{r.add(o);}),e.hooks)for(let s of Object.keys(e.hooks))r.add(s);r.forEach(s=>{var u;let o=t==null?void 0:t.get(s),a=(u=e.hooks)==null?void 0:u[s],n=ye([o,a]);n&&this.hooksRegistry.set(s,n);}),this.initPromise=this.storage.init(this.schema,this.logger,this).catch(s=>{this.initError=s;}),this.contextProvider=e.contextProvider,this.queryEngine=new te({router:{get:async(s,o)=>{var y;let{headers:a,cookies:n,queryParams:u,context:l}=(o==null?void 0:o.context)??{};if(!(o!=null&&o.batcher))throw new Error("Batcher is required");let d={...s,type:"QUERY",headers:a,cookies:n,queryParams:u,context:l},h=await((y=this.router.routes[s.resource])==null?void 0:y.handleQuery({req:d,batcher:o.batcher}));return (h==null?void 0:h.data)??[]},incrementQueryStep:(s,o={})=>{var u;let a=(u=this.router.routes[s.query.resource])==null?void 0:u.getAuthorizationClause({...s.query,type:"QUERY",headers:o.headers,cookies:o.cookies,queryParams:o.queryParams,context:o.context});if(typeof a=="boolean"&&!a)throw new Error("Not authorized");let n=z(s.query.where,typeof a=="object"?a:void 0);return {...s,query:{...s.query,where:n}}}},storage:this.storage,schema:this.schema,logger:this.logger});}static create(e){return new c(e)}getHooks(e){return this.hooksRegistry.get(e)}async handleQuery(e){return await this.ensureInitialized(),this.wrapInMiddlewares(async t=>{let{headers:r,cookies:i,queryParams:s,context:o,...a}=t,n={headers:r,cookies:i,queryParams:s,context:o},u=e.subscription?this.queryEngine.subscribe(a,d=>{var h;(h=e.subscription)==null||h.call(e,d);},n):void 0;return {data:await this.queryEngine.get(a,{context:n}),unsubscribe:u}})(e.req)}async handleMutation(e){return await this.ensureInitialized(),await this.wrapInMiddlewares(async r=>{let i=this.router.routes[r.resource];if(!i)throw new Error("Invalid resource");return i.handleMutation({req:r,db:this.storage,schema:this.schema})})(e.req)}async handleCustomQuery(e){await this.ensureInitialized();let t=await this.wrapInMiddlewares(async h=>{let y=this.router.routes[h.resource];if(!y)throw new Error("Invalid resource");return y.handleCustomQuery({req:h,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:i,cookies:s,queryParams:o,context:a}=e.req,n={headers:i,cookies:s,queryParams:o,context:a},u=t.buildQueryRequest(),l=e.subscription?this.queryEngine.subscribe(u,h=>{var y;(y=e.subscription)==null||y.call(e,h);},n):void 0,d=await this.queryEngine.get(u,{context:n});return e.subscription?{data:d,unsubscribe:l,query:u}:d.map(h=>z$2(h))}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((r,i)=>s=>i({req:s,next:r}),e)(t)}async ensureInitialized(){if(await this.initPromise,this.initError)throw this.initError}},Qn=Ce.create;export{Se as ProcedureRoute,be as Route,we as RouteFactory,Re as Router,Me as SQLStorage,Ce as Server,W as Storage,rn as createMiddleware,D as createServerDB,gr as defineHooks,Hr as expressAdapter,ye as mergeEntityHooks,Tr as mergeHooks,nn as routeFactory,tn as router,Qn as server};
|