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